TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Modele_turbulence_hyd_K_Eps_Realisable_Bicephale.cpp
1/****************************************************************************
2* Copyright (c) 2019, 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 <Modele_turbulence_hyd_K_Eps_Realisable_Bicephale.h>
17#include <Modifier_pour_fluide_dilatable.h>
18#include <Modele_turbulence_scal_base.h>
19#include <Modele_Shih_Zhu_Lumley_VEF.h>
20#include <Fluide_Incompressible.h>
21#include <Schema_Temps_base.h>
22#include <Champ_Uniforme.h>
23#include <Perf_counters.h>
24#include <Probleme_base.h>
25#include <TRUSTTrav.h>
26#include <Param.h>
27#include <Debog.h>
28
29Implemente_instanciable(Modele_turbulence_hyd_K_Eps_Realisable_Bicephale, "Modele_turbulence_hyd_K_Epsilon_Realisable_Bicephale", Modele_turbulence_hyd_RANS_Bicephale_base);
30
31// XD K_Epsilon_Realisable_Bicephale mod_turb_hyd_rans K_Epsilon_Realisable_Bicephale INHERITS_BRACE Realizable
32// XD_CONT Two-headed K-Epsilon Turbulence Model
33
35{
36 return s << que_suis_je() << " " << le_nom();
37}
38
40{
42}
43
45{
47 param.ajouter_non_std("Modele_Fonc_Realisable", (this), Param::REQUIRED); // XD_ADD_P Modele_Fonc_Realisable_base
48 // XD_CONT This keyword is used to set the model used
49 param.ajouter("PRANDTL_K|Sigma_K", &Sigma_K_, Param::REQUIRED); // XD_ADD_P double
50 // XD_CONT Keyword to change the Prk|Sigma_K value (default 1.0). See https://turbmodels.larc.nasa.gov/ke-chien.html
51 param.ajouter("PRANDTL_EPS|Sigma_Eps", &Sigma_Eps_, Param::REQUIRED); // XD_ADD_P double
52 // XD_CONT Keyword to change the Pre|Sigma_Eps value (default 1.3)
53}
54
56{
57 if (mot == "Modele_Fonc_Realisable")
58 {
60 mon_modele_fonc_->associer_eqn_2(get_eq_transp_Eps());
61 get_modele_fonction()->discretiser();
62 Cerr << "Realizable Two-headed K_Epsilon model type " << get_modele_fonction().que_suis_je() << finl;
63 return 1;
64 }
65 else
67}
68
70{
71 const Champ_base& chK = get_eq_transp_K().inconnue();
72 Nom type = chK.que_suis_je();
73 const DoubleTab& tab_K = chK.valeurs();
74 const Champ_base& chEps = get_eq_transp_Eps().inconnue();
75 const DoubleTab& tab_Eps = chEps.valeurs();
76 Debog::verifier("Modele_turbulence_hyd_K_Eps_Realisable_Bicephale::calculer_viscosite_turbulente K", tab_K);
77 Debog::verifier("Modele_turbulence_hyd_K_Eps_Realisable_Bicephale::calculer_viscosite_turbulente Epsilon", tab_Eps);
78 DoubleTab& visco_turb = la_viscosite_turbulente_->valeurs();
79 int n = tab_K.dimension(0);
80
81 // dans le cas d'un domaine nul on doit effectuer le dimensionnement
82 double non_prepare = 1;
83 if (visco_turb.size() == n)
84 non_prepare = 0.;
85 non_prepare = mp_max(non_prepare);
86
87 if (non_prepare == 1)
88 {
89 OWN_PTR(Champ_Inc_base) visco_turb_au_format_K_eps_Rea;
90 visco_turb_au_format_K_eps_Rea.typer(type);
91 DoubleTab& visco_turb_K_eps_Rea = complete_viscosity_field(n, get_eq_transp_K().domaine_dis(), visco_turb_au_format_K_eps_Rea);
92
93 if (visco_turb_K_eps_Rea.size() != n)
94 {
95 Cerr << "visco_turb_K_eps_Rea size is " << visco_turb_K_eps_Rea.size() << " instead of " << n << finl;
97 }
98
99 fill_turbulent_viscosity_tab(n, tab_K, tab_Eps, visco_turb_K_eps_Rea);
100 la_viscosite_turbulente_->affecter(visco_turb_au_format_K_eps_Rea.valeur());
101 }
102 else
103 fill_turbulent_viscosity_tab(n, tab_K, tab_Eps, visco_turb);
104
105 la_viscosite_turbulente_->changer_temps(temps);
106 return la_viscosite_turbulente_;
107}
108
109void Modele_turbulence_hyd_K_Eps_Realisable_Bicephale::fill_turbulent_viscosity_tab(const int n, const DoubleTab& tab_K, const DoubleTab& tab_Eps, DoubleTab& turbulent_viscosity)
110{
111 const DoubleTab& Cmu = get_modele_fonction()->get_Cmu(); // attention : il faut qu'il soit deja calcule!
112 Debog::verifier("Modele_turbulence_hyd_K_Eps_Realisable_Bicephale::calculer_viscosite_turbulente Cmu", Cmu);
113
114 for (int i = 0; i < n; i++)
115 {
116 if (tab_Eps(i, 1) <= DMINFLOAT)
117 turbulent_viscosity[i] = 0.;
118 else
119 turbulent_viscosity[i] = Cmu(i) * tab_K(i) * tab_K(i) / tab_Eps(i);
120 }
121}
122
132
134{
137 if (!get_eq_transp_K().equation_non_resolue())
140 if (!get_eq_transp_Eps().equation_non_resolue())
143
144 statistics().begin_count(STD_COUNTERS::turbulent_viscosity, statistics().get_last_opened_counter_level()+1);
145 Debog::verifier("Modele_turbulence_hyd_K_Eps_Realisable_Bicephale::mettre_a_jour la_viscosite_turbulente before", la_viscosite_turbulente_->valeurs());
147 Debog::verifier("Modele_turbulence_hyd_K_Eps_Realisable_Bicephale::mettre_a_jour apres calculer_viscosite_turbulente la_viscosite_turbulente", la_viscosite_turbulente_->valeurs());
148 statistics().end_count(STD_COUNTERS::turbulent_viscosity);
149}
150
155
156
157bool Modele_turbulence_hyd_K_Eps_Realisable_Bicephale::has_champ(const Motcle& nom, OBS_PTR(Champ_base)& ref_champ) const
158{
160 return true;
161
162 if (mon_modele_fonc_)
163 if (mon_modele_fonc_->has_champ(nom, ref_champ))
164 return true;
165
166 return false; /* rien trouve */
167}
168
170{
172 return true;
173
174 if (mon_modele_fonc_)
175 if (mon_modele_fonc_->has_champ(nom))
176 return true;
177
178 return false; /* rien trouve */
179}
180
182{
183 OBS_PTR(Champ_base) ref_champ;
184
186 return ref_champ;
187
188 if (mon_modele_fonc_)
189 if (mon_modele_fonc_->has_champ(nom, ref_champ))
190 return ref_champ;
191
192 throw std::runtime_error(std::string("Field ") + nom.getString() + std::string(" not found !"));
193}
194
196{
198 if (mon_modele_fonc_)
199 mon_modele_fonc_->get_noms_champs_postraitables(nom, opt);
200}
201
203{
204 Nom lp = loipar_->que_suis_je();
205 if (lp == "negligeable_VEF" || lp == "negligeable_VDF")
206 if (!associe_modele_fonction())
207 {
208 Cerr << "The turbulence model of type " << que_suis_je() << finl;
209 Cerr << "must not be used with a wall law of type negligeable or with a modele_function." << finl;
210 Cerr << "Another wall law must be selected with this kind of turbulence model." << finl;
211 }
212}
classe Champ_Fonc_base Classe de base des champs qui sont fonction d'une grandeur calculee
Classe Champ_Inc_base.
virtual DoubleTab & valeurs()=0
classe Champ_base Cette classe est la base de la hierarchie des champs.
Definition Champ_base.h:43
static void verifier(const char *const msg, double)
Definition Debog.cpp:21
virtual void mettre_a_jour(double temps)
Effectue une mise a jour en temps de toutes les conditions aux limites.
Class defining operators and methods for all reading operation in an input flow (file,...
Definition Entree.h:42
virtual void mettre_a_jour(double temps)
La valeur de l'inconnue sur le pas de temps a ete calculee.
virtual int preparer_calcul()
Tout ce qui ne depend pas des autres problemes eventuels.
virtual Domaine_Cl_dis_base & domaine_Cl_dis()
Renvoie le domaine des conditions aux limite discretisee associee a l'equation.
Schema_Temps_base & schema_temps()
Renvoie le schema en temps associe a l'equation.
static void typer_lire_Modele_Fonc_Realisable(OWN_PTR(Modele_Fonc_Realisable_base)&, const Equation_base &, Entree &is)
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override
OWN_PTR(Modele_Fonc_Realisable_base) &associe_modele_fonction()
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.
Classe Modele_turbulence_hyd_RANS_Bicephale_base Classe de base des modeles de type RANS en formulati...
void get_noms_champs_postraitables(Noms &nom, Option opt=NONE) const override
Champ_Inc_base & get_set_K()
Renvoie le champ inconnue K du modele de turbulence Cette inconnue est portee.
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override
Transport_K_ou_Eps_base & get_set_eq_transp_K()
Renvoie l equation d evolution de K du modele de turbulence.
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.
const Transport_K_ou_Eps_base & get_eq_transp_K() const
Renvoie l equation d evolution de K du modele de turbulence (version const).
Transport_K_ou_Eps_base & get_set_eq_transp_Eps()
Renvoie l equation d evolution de epsilon du modele de turbulence.
Champ_Inc_base & get_set_Eps()
Renvoie le champ inconnue epsilon du modele de turbulence Cette inconnue est portee.
OBS_PTR(Equation_base) ma_seconde_equation_
const Transport_K_ou_Eps_base & get_eq_transp_Eps() const
Renvoie l equation d evolution de epsilon du modele de turbulence (version const).
DoubleTab & complete_viscosity_field(const int, const Domaine_dis_base &, Champ_Inc_base &)
std::enable_if_t<(M_TYPE==MODELE_TYPE::K_EPS||M_TYPE==MODELE_TYPE::K_EPS_REALISABLE||M_TYPE==MODELE_TYPE::K_OMEGA), void > calculate_limit_viscosity(Champ_Inc_base &, double)
virtual int preparer_calcul()
Prepare le calcul.
Une chaine de caractere (Nom) en majuscules.
Definition Motcle.h:26
class Nom Une chaine de caractere pour nommer les objets de TRUST
Definition Nom.h:31
const std::string & getString() const
Definition Nom.h:92
Un tableau de chaine de caracteres (VECT(Nom)).
Definition Noms.h:26
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 const Nom & le_nom() const
Donne le nom de l'Objet_U Methode a surcharger : renvoie "neant" dans cette implementation.
Definition Objet_U.cpp:319
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
@ REQUIRED
Definition Param.h:115
void ajouter_non_std(const char *keyword, const Objet_U *value, Param::Nature nat=Param::OPTIONAL)
Register a keyword handled by Objet_U::lire_motcle_non_standard.
Definition Param.cpp:489
static double mp_max(double)
Definition Process.cpp:376
static void exit(int exit_code=-1)
Routine de sortie de TRUST dans une region Kokkos.
Definition Process.cpp:455
class Schema_Temps_base
virtual int faire_un_pas_de_temps_eqn_base(Equation_base &)=0
Classe de base des flux de sortie.
Definition Sortie.h:52
_SIZE_ dimension(int d) const
Definition TRUSTTab.tpp:133
_SIZE_ size() const
Definition TRUSTVect.tpp:45
const Champ_Inc_base & inconnue() const override
Renvoie le champ inconnue de l'equation.