TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Discret_Thyd.cpp
1/****************************************************************************
2* Copyright (c) 2026, 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#include <Solveur_Implicite_base.h>
17#include <Schema_Implicite_base.h>
18#include <Schema_Temps_base.h>
19#include <Discret_Thyd.h>
20#include <Milieu_base.h>
21#include <Domaine_VF.h>
22
23Implemente_base(Discret_Thyd, "Discret_Thyd", Discret_Thermique);
24
25// XD discretisation_base objet_u discretisation_base INHERITS_BRACE Basic class for space discretization of
26// XD_CONT thermohydraulic turbulent problems.
27
28Sortie& Discret_Thyd::printOn(Sortie& s) const { return s; }
29
31{
32 Param p(que_suis_je());
33 set_param(p);
34 p.lire_avec_accolades(is);
36 return is;
37}
38
40{
41 p.ajouter("reorder", &reorder_); // XD_ADD_P reorder_mesh
42 // XD_CONT Reordering directive.
43}
44
45/**! Override to make sure reordering options are passed to Domaine_dis_base
46 */
48{
50 if(reorder_.algo() != Reorder_Algo::None)
52 return disb;
53}
54
55void Discret_Thyd::vitesse(const Schema_Temps_base& sch, Domaine_dis_base& z, OWN_PTR(Champ_Inc_base) &ch, int nb_comp) const
56{
57 Cerr << "Velocity discretization" << finl;
58 discretiser_champ("vitesse", z, "vitesse", "m/s", dimension * nb_comp, sch.nb_valeurs_temporelles(), sch.temps_courant(), ch);
59}
60
62{
63 Cerr << "Translation discretization" << finl;
64 discretiser_champ("vitesse", z, "translation", "m/s", dimension, sch.temps_courant(), ch);
65}
66
68{
69 Cerr << "Entcor discretization" << finl;
70 discretiser_champ("vitesse", z, "entcor", "m/s", dimension, sch.temps_courant(), ch);
71}
72
74{
75 Cerr << "Pressure discretization" << finl;
76 discretiser_champ("pression", z, "pression", "Pa.m3/kg", 1,
77 sub_type(Schema_Implicite_base, sch) ? ref_cast(Schema_Implicite_base, sch).solveur()->nb_valeurs_temporelles_pression() : 1, sch.temps_courant(), ch);
78}
79
81{
82 Cerr << "Pressure pa discretization" << finl;
83 discretiser_champ("pression", z, "pression_pa", "Pa", 1,
84 sub_type(Schema_Implicite_base, sch) ? ref_cast(Schema_Implicite_base, sch).solveur()->nb_valeurs_temporelles_pression() : 1, sch.temps_courant(), ch);
85}
86
88{
89 Cerr << "Velocity divergence discretization" << finl;
90 discretiser_champ("divergence_vitesse", z, "divergence_U", "m3/s", 1, 1, sch.temps_courant(), ch);
91}
92
93void Discret_Thyd::gradient_P(const Schema_Temps_base& sch, Domaine_dis_base& z, OWN_PTR(Champ_Inc_base) &ch, int nb_comp) const
94{
95 Cerr << "Pressure gradient discretization" << finl;
96 discretiser_champ("gradient_pression", z, "gradient_pression", "m/s2", dimension * nb_comp, 1, sch.temps_courant(), ch);
97}
98
100{
101 Cerr << "Discret_Thyd::creer_champ_vorticite() does nothing" << finl;
102 Cerr << que_suis_je() << "needs to overload it !" << finl;
104}
105
107{
108 // pour le VDF, on a besoin du OWN_PTR(Domaine_Cl_dis_base), mais pas pour le VEF
109 // -->> on passe quand meme l argument mais on n en fait rien!!!
110 Cerr << "Discret_Thyd::critere_Q() does nothing" << finl;
111 Cerr << que_suis_je() << " needs to overload it !" << finl;
113}
114
115void Discret_Thyd::diametre_hydraulique_face(const Domaine_dis_base& z, const DoubleVect& diam_face, const Schema_Temps_base& sch, OWN_PTR(Champ_Fonc_base) &ch) const
116{
117 Cerr << "Hydraulic diameter face field discretization" << finl;
118 const Domaine_VF& domaine_VF = ref_cast(Domaine_VF, z);
119 discretiser_champ("champ_face", domaine_VF, "diametre_hydraulique_face", "m", 1, sch.temps_courant(), ch);
120 Champ_Fonc_base& ch_fonc = ref_cast(Champ_Fonc_base, ch.valeur());
121 ch_fonc.valeurs().ref(diam_face);
122}
123
124void Discret_Thyd::section_passage(const Domaine_dis_base& z, const DoubleVect& section_passage_face, const Schema_Temps_base& sch, OWN_PTR(Champ_Fonc_base) &ch) const
125{
126 Cerr << "Section passage field discretization" << finl;
127 const Domaine_VF& domaine_VF = ref_cast(Domaine_VF, z);
128 discretiser_champ("champ_face", domaine_VF, "section_passage", "m2", dimension, sch.temps_courant(), ch);
129 Champ_Fonc_base& ch_fonc = ref_cast(Champ_Fonc_base, ch.valeur());
130 DoubleVect& tab = ch_fonc.valeurs();
131 tab.inject_array(section_passage_face);
132}
133
135{
136 // pour le VDF, on a besoin du OWN_PTR(Domaine_Cl_dis_base), mais pas pour le VEF
137 // -->> on passe quand meme l argument mais on n en fait rien!!!
138 Cerr << "Discret_Thyd::y_plus() does nothing" << finl;
139 Cerr << que_suis_je() << " needs to overload it !" << finl;
141}
142
144{
145 Cerr << "Discret_Thyd::distance_paroi_globale() does nothing" << finl;
146 Cerr << que_suis_je() << " needs to overload it !" << finl;
148}
149
150void Discret_Thyd::grad_T(const Domaine_dis_base& z, const Domaine_Cl_dis_base& zcl, const Champ_Inc_base& eqn, OWN_PTR(Champ_Fonc_base) &ch) const
151{
152 Cerr << "Discret_Thyd::grad_T() does nothing" << finl;
153 Cerr << que_suis_je() << " needs to overload it !" << finl;
155}
156
157void Discret_Thyd::h_conv(const Domaine_dis_base& z, const Domaine_Cl_dis_base& zcl, const Champ_Inc_base& eqn, OWN_PTR(Champ_Fonc_base) &ch, Motcle& nom, int temp_ref) const
158{
159 Cerr << "Discret_Thyd::h_conv() does nothing" << finl;
160 Cerr << que_suis_je() << " needs to overload it !" << finl;
162}
163
165{
166 Cerr << "Discret_Thyd::proprietes_physiques_fluide_Ostwald() does nothing" << finl;
167 Cerr << que_suis_je() << " needs to overload it !" << finl;
169}
170
172{
173 Cerr << "\nDiscret_Thyd::grad_u() does nothing" << finl;
174 Cerr << que_suis_je() << " needs to overload it !" << finl;
176}
177
178void Discret_Thyd::concentration(const Schema_Temps_base& sch, Domaine_dis_base& z, OWN_PTR(Champ_Inc_base) &ch, int nb_constituants, const Nom nom_champ) const
179{
180 Cerr << "Concentration discretization " << finl;
181 discretiser_champ("temperature", z, nom_champ, "%", nb_constituants, sch.nb_valeurs_temporelles(), sch.temps_courant(), ch);
182 ch->nommer(nom_champ);
183 if (nb_constituants > 1)
184 {
185 ch->fixer_nature_du_champ(multi_scalaire);
186 Noms noms(nb_constituants);
187 for (int i = 0; i < nb_constituants; i++)
188 {
189 noms[i] = nom_champ;
190 Nom param(i);
191 noms[i] += param;
192 ch->fixer_nom_compo(i, noms[i]);
193 }
194 }
195}
DoubleTab & valeurs() override
Surcharge Champ_base::valeurs() Renvoie le tableau des valeurs.
classe Champ_Fonc_base Classe de base des champs qui sont fonction d'une grandeur calculee
Classe Champ_Inc_base.
Class Discret_Thermique Cette classe est la classe de base representant une discretisation.
classe Discret_Thyd Cette classe est la classe de base representant une discretisation
void gradient_P(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Inc_base)&, int nb_comp=1) const
void pression_en_pa(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Inc_base)&) const
void set_param(Param &param) const override
void pression(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Inc_base)&) const
Domaine_dis_base & discretiser() const override
virtual void y_plus(const Domaine_dis_base &, const Domaine_Cl_dis_base &, const Champ_Inc_base &, OWN_PTR(Champ_Fonc_base)&) const
virtual void creer_champ_vorticite(const Schema_Temps_base &, const Champ_Inc_base &, OWN_PTR(Champ_Fonc_base)&) const
virtual void proprietes_physiques_fluide_Ostwald(const Domaine_dis_base &, Fluide_Ostwald &, const Navier_Stokes_std &, const Champ_Inc_base &) const
virtual void check_param()
void entcor(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Fonc_base)&) const
void concentration(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Inc_base)&, int=1, const Nom nom_champ="concentration") const
virtual void grad_u(const Domaine_dis_base &, const Domaine_Cl_dis_base &, const Champ_Inc_base &, OWN_PTR(Champ_Fonc_base)&) const
void divergence_U(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Inc_base)&) const
virtual void h_conv(const Domaine_dis_base &z, const Domaine_Cl_dis_base &zcl, const Champ_Inc_base &eqn, OWN_PTR(Champ_Fonc_base)&ch, Motcle &nom, int temp_ref) const
virtual void distance_paroi_globale(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Fonc_base)&) const
void translation(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Fonc_base)&) const
void vitesse(const Schema_Temps_base &, Domaine_dis_base &, OWN_PTR(Champ_Inc_base)&, int nb_comp=1) const
void section_passage(const Domaine_dis_base &, const DoubleVect &, const Schema_Temps_base &, OWN_PTR(Champ_Fonc_base)&) const
void diametre_hydraulique_face(const Domaine_dis_base &, const DoubleVect &, const Schema_Temps_base &, OWN_PTR(Champ_Fonc_base)&) const
virtual void grad_T(const Domaine_dis_base &z, const Domaine_Cl_dis_base &zcl, const Champ_Inc_base &eqn, OWN_PTR(Champ_Fonc_base)&ch) const
virtual void critere_Q(const Domaine_dis_base &, const Domaine_Cl_dis_base &, const Champ_Inc_base &, OWN_PTR(Champ_Fonc_base)&) const
virtual Domaine_dis_base & discretiser() const
Reorder_Mesh reorder_
Helper object to renumber entities (nodes, elems, faces) if requested.
void discretiser_champ(const Motcle &directive, const Domaine_dis_base &z, const Nom &nom, const Nom &unite, int nb_comp, int nb_pas_dt, double temps, OWN_PTR(Champ_Inc_base)&champ, const Nom &sous_type=NOM_VIDE) const
classe Domaine_Cl_dis_base Les objets Domaine_Cl_dis_base representent les conditions aux limites
class Domaine_VF
Definition Domaine_VF.h:44
classe Domaine_dis_base Cette classe est la base de la hierarchie des domaines discretisees.
void set_reorder(const Reorder_Mesh &r)
Class defining operators and methods for all reading operation in an input flow (file,...
Definition Entree.h:42
void nommer(const Nom &) override
Donne un nom au champ.
virtual Nature_du_champ fixer_nature_du_champ(Nature_du_champ nat)
Fixer la nature d'un champ: scalaire, multiscalaire, vectoriel.
virtual const Nom & fixer_nom_compo(int, const Nom &)
Fixe le nom de la i-eme composante du champ.
class Fluide_Ostwald
Une chaine de caractere (Nom) en majuscules.
Definition Motcle.h:26
classe Navier_Stokes_std Cette classe porte les termes de l'equation de la dynamique
class Nom Une chaine de caractere pour nommer les objets de TRUST
Definition Nom.h:31
Un tableau de chaine de caracteres (VECT(Nom)).
Definition Noms.h:26
static int dimension
Definition Objet_U.h:99
const Nom & que_suis_je() const
renvoie la chaine identifiant la classe.
Definition Objet_U.cpp:104
virtual Entree & readOn(Entree &)
Lecture d'un Objet_U sur un flot d'entree Methode a surcharger.
Definition Objet_U.cpp:293
virtual Sortie & printOn(Sortie &) const
Ecriture de l'objet sur un flot de sortie Methode a surcharger.
Definition Objet_U.cpp:282
Helper class to factorize the readOn method of Objet_U classes.
Definition Param.h:112
void ajouter(const char *keyword, const int *value, Param::Nature nat=Param::OPTIONAL)
Register an integer parameter.
Definition Param.cpp:364
static void exit(int exit_code=-1)
Routine de sortie de TRUST dans une region Kokkos.
Definition Process.cpp:455
class Schema_Implicite_base Classe de base pour tous les schemas en temps implicite
class Schema_Temps_base
double temps_courant() const
Renvoie le temps courant.
virtual int nb_valeurs_temporelles() const =0
Classe de base des flux de sortie.
Definition Sortie.h:52
TRUSTArray & inject_array(const TRUSTArray &source, _SIZE_ nb_elements=-1, _SIZE_ first_element_dest=0, _SIZE_ first_element_source=0)
virtual void ref(const TRUSTTab &)
Definition TRUSTTab.tpp:308