16#include <Modele_turbulence_hyd_K_Eps_Bas_Reynolds.h>
17#include <Schema_Temps_base.h>
18#include <Fluide_base.h>
19#include <Champ_Uniforme.h>
21#include <Perf_counters.h>
44 if (mot ==
"Modele_Fonc_Bas_Reynolds")
47 mon_modele_fonc_->discretiser();
48 Cerr <<
"Low Reynolds number model type " << mon_modele_fonc_->que_suis_je() << finl;
62 const DoubleTab& tab_K_Eps = chK_Eps.
valeurs();
63 Debog::verifier(
"Modele_turbulence_hyd_K_Eps_Bas_Reynolds::calculer_viscosite_turbulente K_Eps", tab_K_Eps);
64 DoubleTab& visco_turb = la_viscosite_turbulente_->valeurs();
70 mon_modele_fonc_->Calcul_Fmu(Fmu, le_dom_dis, le_dom_Cl_dis, tab_K_Eps, ch_visco_cin);
72 Debog::verifier(
"Modele_turbulence_hyd_K_Eps_Bas_Reynolds::calculer_viscosite_turbulente Fmu", Fmu);
79 double non_prepare = 1;
80 if (visco_turb.
size() == n)
82 non_prepare =
mp_max(non_prepare);
87 visco_turb_au_format_K_eps_Bas_Re.typer(type);
90 if (visco_turb_K_eps_Bas_Re.
size() != n)
92 Cerr <<
"visco_turb_K_eps_Bas_Re size is " << visco_turb_K_eps_Bas_Re.
size() <<
" instead of " << n << finl;
96 fill_turbulent_viscosity_tab(n, tab_K_Eps, Fmu, visco_turb_K_eps_Bas_Re);
98 la_viscosite_turbulente_->affecter(visco_turb_au_format_K_eps_Bas_Re.valeur());
101 fill_turbulent_viscosity_tab(n, tab_K_Eps, Fmu, visco_turb);
103 la_viscosite_turbulente_->changer_temps(temps);
104 return la_viscosite_turbulente_;
107void Modele_turbulence_hyd_K_Eps_Bas_Reynolds::fill_turbulent_viscosity_tab(
const int n,
const DoubleTab& tab_K_Eps,
const DoubleTab& Fmu, DoubleTab& turbulent_viscosity)
109 for (
int i = 0; i < n; i++)
111 if (tab_K_Eps(i, 1) <= DMINFLOAT)
112 turbulent_viscosity[i] = 0.;
114 turbulent_viscosity[i] =
LeCmu_ * Fmu(i) * tab_K_Eps(i, 0) * tab_K_Eps(i, 0) / tab_K_Eps(i, 1);
131 statistics().begin_count(STD_COUNTERS::turbulent_viscosity, statistics().get_last_opened_counter_level()+1);
133 Debog::verifier(
"Modele_turbulence_hyd_K_Eps_Bas_Reynolds::mettre_a_jour apres calculer_viscosite_turbulente la_viscosite_turbulente", la_viscosite_turbulente_->valeurs());
134 statistics().end_count(STD_COUNTERS::turbulent_viscosity);
148 if (mon_modele_fonc_)
149 if (mon_modele_fonc_->has_champ(nom, ref_champ))
160 if (mon_modele_fonc_)
161 if (mon_modele_fonc_->has_champ(nom))
174 if (mon_modele_fonc_)
175 if (mon_modele_fonc_->has_champ(nom, ref_champ))
178 throw std::runtime_error(std::string(
"Field ") + nom.
getString() + std::string(
" not found !"));
185 if (mon_modele_fonc_)
186 mon_modele_fonc_->get_noms_champs_postraitables(nom, opt);
classe Champ_Don_base classe de base des Champs donnes (non calcules)
classe Champ_Fonc_base Classe de base des champs qui sont fonction d'une grandeur calculee
virtual DoubleTab & valeurs()=0
classe Champ_base Cette classe est la base de la hierarchie des champs.
static void verifier(const char *const msg, double)
classe Domaine_Cl_dis_base Les objets Domaine_Cl_dis_base representent les conditions aux limites
virtual void mettre_a_jour(double temps)
Effectue une mise a jour en temps de toutes les conditions aux limites.
classe Domaine_dis_base Cette classe est la base de la hierarchie des domaines discretisees.
Class defining operators and methods for all reading operation in an input flow (file,...
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.
virtual bool initTimeStep(double dt)
Allocation et initialisation de l'inconnue et des CLs jusqu'a present+dt.
Domaine_dis_base & domaine_dis()
Renvoie le domaine discretise associe a l'equation.
classe Fluide_base Cette classe represente un d'un fluide incompressible ainsi que
const Champ_Don_base & viscosite_cinematique() const
static void typer_lire_Modele_Fonc_Bas_Reynolds(OWN_PTR(Modele_Fonc_Bas_Reynolds_Base)&, const Equation_base &, Entree &is)
Champ_Inc_base & get_set_unknown()
const Champ_Inc_base & get_unknown() const
class Modele_turbulence_hyd_K_Eps_Bas_Reynolds
const Transport_K_Eps_Bas_Reynolds & get_eq_transport() const override
void mettre_a_jour(double) override
void controler() override
bool initTimeStep(double dt) override
int preparer_calcul() override
Prepare le calcul.
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override
virtual Champ_Fonc_base & calculer_viscosite_turbulente(double temps)
const Champ_base & get_champ(const Motcle &nom) const override
Transport_K_Eps_Bas_Reynolds & get_set_eq_transport() override
void get_noms_champs_postraitables(Noms &nom, Option opt=NONE) const override
void set_param(Param ¶m) const override
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.
void completer() override
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)
Classe Modele_turbulence_hyd_RANS_K_Eps_base Classe de base des modeles de type RANS_keps.
void set_param(Param ¶m) const override
OWN_PTR(Modele_Fonc_Bas_Reynolds_Base) &associe_modele_fonction()
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override
void get_noms_champs_postraitables(Noms &nom, Option opt=NONE) const override
OBS_PTR(Equation_base) mon_equation_
Une chaine de caractere (Nom) en majuscules.
class Nom Une chaine de caractere pour nommer les objets de TRUST
const std::string & getString() const
Un tableau de chaine de caracteres (VECT(Nom)).
virtual int lire_motcle_non_standard(const Motcle &motlu, Entree &is)
Lecture des parametres de type non simple d'un objet_U a partir d'un flot d'entree.
const Nom & que_suis_je() const
renvoie la chaine identifiant la classe.
virtual Entree & readOn(Entree &)
Lecture d'un Objet_U sur un flot d'entree Methode a surcharger.
virtual const Nom & le_nom() const
Donne le nom de l'Objet_U Methode a surcharger : renvoie "neant" dans cette implementation.
virtual Sortie & printOn(Sortie &) const
Ecriture de l'objet sur un flot de sortie Methode a surcharger.
Helper class to factorize the readOn method of Objet_U classes.
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.
static double mp_max(double)
static void exit(int exit_code=-1)
Routine de sortie de TRUST dans une region Kokkos.
virtual int faire_un_pas_de_temps_eqn_base(Equation_base &)=0
Classe de base des flux de sortie.
_SIZE_ dimension(int d) const
void completer() override
Complete la construction (initialisation) des objets associes a l'equation.
int controler_K_Eps()
Controle le champ inconnue K-epsilon en forcant a zero les valeurs du champ.