16#include <Modele_turbulence_scal_Fluctuation_Temperature_W.h>
17#include <Modele_turbulence_hyd_K_Eps_Bas_Reynolds.h>
18#include <Probleme_base.h>
38 eqn.typer(
"Transport_Fluctuation_Temperature_W");
39 eqn_transport_Fluctu_Temp = ref_cast(Transport_Fluctuation_Temperature_W, eqn.valeur());
50 Cerr <<
"Lecture des parametres du modele de fluctuation thermique. Il doit y avoir deux types d'equation." << finl;
54 les_mots[0] =
"Transport_Fluctuation_Temperature_W";
56 int rang=les_mots.
search(mot);
61 Cerr <<
"Lecture de l'equation Transport_Fluctuation_Temperature_W" << finl;
62 eqn_transport_Fluctu_Temp->associer_modele_turbulence(*
this);
63 s >> eqn_transport_Fluctu_Temp.valeur();
68 Cerr <<
"Erreur a la lecture des donnees du modele de fluctuation thermique" << finl;
69 Cerr <<
"On attendait les motcles Transport_Fluctuation_Temperature_W au lieu de " << mot << finl;
79 la_viscosite_turbulente = visc_turb;
84 eqn_transport_Fluctu_Temp->preparer_calcul();
93 return eqn->initTimeStep(dt);
99 const DoubleTab& mu_t = la_viscosite_turbulente->valeurs();
100 double temps = la_viscosite_turbulente->temps();
101 const Champ_base& chFluctuTemp = eqn_transport_Fluctu_Temp->inconnue();
111 static const double C_Lambda = 0.11;
112 int n= alpha_t.
size();
113 if (mu_t.
size() != n)
115 Cerr <<
"Les DoubleTab des champs diffusivite_turbulente et viscosite_turbulente" << finl;
116 Cerr <<
"doivent avoir le meme nombre de valeurs nodales" << finl;
120 for (
int i=0; i<n; i++)
121 if ( (K_eps_Bas_Re(i,1) > 1.e-3 ) && (chFluctuTemp.
valeurs()(i,1) > 1.e-3) && (K_eps_Bas_Re(i,0) > 1.e-3 ) && (chFluctuTemp.
valeurs()(i,0) > 1.e-3))
122 alpha_t[i] =C_Lambda*K_eps_Bas_Re(i,0)*sqrt((K_eps_Bas_Re(i,0)/K_eps_Bas_Re(i,1))*(chFluctuTemp.
valeurs()(i,0)/(2*chFluctuTemp.
valeurs()(i,1))));
125 Cerr <<
" !!!! Eps ou EpsTeta est nul !!!! " << finl;
126 Cerr <<
" K = " << K_eps_Bas_Re(i,0) << finl;
127 alpha_t[i] = 0.0000001;
140 eqn_transport_Fluctu_Temp->domaine_Cl_dis().
mettre_a_jour(temps);
143 eqn_transport_Fluctu_Temp->mettre_a_jour(temps);
144 eqn_transport_Fluctu_Temp->controler_grandeur();
151 Cerr <<
"Dans Modele_turbulence_scal_Fluctuation_Temperature_W::completer()" << finl;
152 eqn_transport_Fluctu_Temp->completer();
158 Cerr <<
"Fin de Modele_turbulence_scal_Fluctuation_Temperature_W::completer()" << finl;
181 DoubleTrav tab_bidon;
182 is >> bidon >> bidon;
197 if (eqn->has_champ(nom, ref_champ))
208 if (eqn->has_champ(nom))
221 if (eqn->has_champ(nom, ref_champ))
224 throw std::runtime_error(std::string(
"Field ") + nom.
getString() + std::string(
" not found !"));
231 eqn->get_noms_champs_postraitables(nom,opt);
classe Champ_Fonc_base Classe de base des champs qui sont fonction d'une grandeur calculee
DoubleTab & valeurs() override
Renvoie le tableau des valeurs du champ au temps courant.
virtual DoubleTab & valeurs()=0
classe Champ_base Cette classe est la base de la hierarchie des champs.
Class defining operators and methods for all reading operation in an input flow (file,...
int reprendre(Entree &) override
On reprend l'inconnue a partir d'un flot d'entree.
virtual const RefObjU & get_modele(Type_modele type) const
int sauvegarder(Sortie &) const override
On sauvegarde l'inconnue, puis les sources sur un flot de sortie.
class Modele_turbulence_hyd_K_Eps_Bas_Reynolds
const Transport_K_Eps_Bas_Reynolds & get_eq_transport() const override
Classe Modele_turbulence_hyd_base Cette classe sert de base a la hierarchie des classes.
const Champ_Fonc_base & viscosite_turbulente() const
virtual Champ_Fonc_base & calculer_diffusivite_turbulente()
bool initTimeStep(double dt) override
A surcharger dans les classes derivees qui possedent une ou des equations Appeler preparer_pas_de_tem...
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) 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.
const Champ_base & get_champ(const Motcle &nom) const override
void associer_viscosite_turbulente(const Champ_Fonc_base &)
void get_noms_champs_postraitables(Noms &nom, Option opt=NONE) const override
virtual Transport_Fluctuation_Temperature_W & equation_Fluctu()
int reprendre(Entree &is) override
NE FAIT RIEN.
int sauvegarder(Sortie &os) const override
NE FAIT RIEN.
int preparer_calcul() override
NE FAIT RIEN.
void imprimer(Sortie &) const override
Effectue l'impression si cela est necessaire.
void set_param(Param &) const override
void completer() override
Complete le modele de turbulence: met a jour des references de l'objet.
void mettre_a_jour(double) override
Classe Modele_turbulence_scal_base Cette classe represente un modele de turbulence pour une equation ...
void get_noms_champs_postraitables(Noms &nom, Option opt=NONE) const override
int reprendre(Entree &) override
NE FAIT RIEN.
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override
virtual int preparer_calcul()
NE FAIT RIEN.
void a_faire(Sortie &) const
Effectue l'ecriture d'une identite si cela est necessaire.
Une chaine de caractere (Nom) en majuscules.
Un tableau d'objets de la classe Motcle.
int search(const Motcle &t) const
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)).
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.
classe Probleme_base C'est un Probleme_U qui n'est pas un couplage.
virtual const Equation_base & equation(int) const =0
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
virtual int mettre_a_jour()
Mise a jour du temps courant (t+=dt) et du nombre de pas de temps effectue (nb_pas_dt_++).
Classe de base des flux de sortie.
void jump(Entree &) override
const Objet_U & valeur() const
Classe Transport_K_Eps_base Classe de base pour les equations.
const Champ_Inc_base & inconnue() const override
Renvoie le champ inconnue de l'equation.