TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Proprietes_part_vol.h
1/****************************************************************************
2* Copyright (c) 2015 - 2016, CEA
3* All rights reserved.
4*
5* Redistribution and use in source and binary forms, with or without modification, are permitted provided that the following conditions are met:
6* 1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
7* 2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
8* 3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote products derived from this software without specific prior written permission.
9*
10* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
11* IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
12* OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
13*
14*****************************************************************************/
15
16#ifndef Proprietes_part_vol_included
17#define Proprietes_part_vol_included
18
19#include <Objet_U_With_Params.h>
20#include <TRUSTTabFT.h>
21class Param;
22
23
24//! @brief Classe qui porte les proprietes de particules
25//!
26//! Actuellement seules les particules materielles sont dotees de proprietes
27//! Proprietes dynamiques : vitesse_p_, delat_v_
28//! Proprietes energetiques : temperature_p_
29//! Proprietes physiques : masse_volumique_p_
30//! Proprietes geometriques : diametre_p_, volume_p_,
31//!
32//! Toute operation modifiant le nombre de particules dans le domaine doit s accompagner
33//! d'une actualisation de l attribut nb_particules_ de cette classe
34//! Les operations susceptibles de modifier le nombre de particules sont actuellement :
35//! -lecture de la condition initiale
36//! -injection-transformation
37//! -nettoyage
38//! -passage d un sous domaine a un autre dans le cas d un calcul parallele
40{
41 Declare_instanciable_with_param(Proprietes_part_vol);
42public:
43
44 int lire_motcle_non_standard(const Motcle&, Entree&) override;
45 void completer();
46 void fixer_nb_particules(const int nb_part);
47 void lire_distribution(Entree& is);
48 void nettoyer(const ArrOfInt& som_utilises);
49 void ajouter_proprietes(const Proprietes_part_vol& proprietes_tmp);
50 void set_initialized();
51
52 inline DoubleTab& vitesse_particules();
53 inline const DoubleTab& vitesse_particules() const;
54 inline DoubleTab& delta_v();
55 inline const DoubleTab& delta_v() const;
56 inline DoubleTab& temperature_particules();
57 inline const DoubleTab& temperature_particules() const;
58 inline DoubleTab& masse_vol_particules();
59 inline const DoubleTab& masse_vol_particules() const;
60 inline DoubleTab& diametre_particules();
61 inline const DoubleTab& diametre_particules() const;
62 inline DoubleTab& volume_particules();
63 inline const DoubleTab& volume_particules() const;
64 inline int nb_particules() const;
65
66protected:
67
68 DoubleTabFT vitesse_p_; //vitesse des particule
69 DoubleTabFT deltat_v_; //difference entre vitesse vitesse du fluide
70 //(a la position de la particule) et vitesse de la particule
71 DoubleTabFT temperature_p_; //temperature
72 DoubleTabFT masse_volumique_p_; //densite
73 DoubleTabFT diametre_p_; //masse_volumique
74 DoubleTabFT volume_p_; //volume
75
76 int nb_particules_ = 0; //nombre de particules portees par l objet
77
78private:
79 bool flag_was_initialized = false;
80
81};
82
84{
85 return vitesse_p_;
86}
87
88inline const DoubleTab& Proprietes_part_vol::vitesse_particules() const
89{
90 return vitesse_p_;
91}
92
94{
95 return deltat_v_;
96}
97
98inline const DoubleTab& Proprietes_part_vol::delta_v() const
99{
100 return deltat_v_;
101}
102
104{
105 return temperature_p_;
106}
107
108inline const DoubleTab& Proprietes_part_vol::temperature_particules() const
109{
110 return temperature_p_;
111}
112
114{
115 return masse_volumique_p_;
116}
117
118inline const DoubleTab& Proprietes_part_vol::masse_vol_particules() const
119{
120 return masse_volumique_p_;
121}
122
124{
125 return diametre_p_;
126}
127
128inline const DoubleTab& Proprietes_part_vol::diametre_particules() const
129{
130 return diametre_p_;
131}
132
134{
135 return volume_p_;
136}
137
138inline const DoubleTab& Proprietes_part_vol::volume_particules() const
139{
140 return volume_p_;
141}
142
144{
145 return nb_particules_;
146}
147
148#endif
Une chaine de caractere (Nom) en majuscules.
Definition Motcle.h:26
Inherits from Objet_U, adds the very common method set_param for the Objet_U hierarchy.
friend class Entree
Definition Objet_U.h:76
Helper class to factorize the readOn method of Objet_U classes.
Definition Param.h:112
Classe qui porte les proprietes de particules.
DoubleTab & masse_vol_particules()
void fixer_nb_particules(const int nb_part)
DoubleTab & vitesse_particules()
void nettoyer(const ArrOfInt &som_utilises)
void lire_distribution(Entree &is)
DoubleTab & diametre_particules()
void ajouter_proprietes(const Proprietes_part_vol &proprietes_tmp)
DoubleTab & volume_particules()
int lire_motcle_non_standard(const Motcle &, Entree &) override
Lecture des parametres de type non simple d'un objet_U a partir d'un flot d'entree.
DoubleTab & temperature_particules()