16#include <Paroi_std_scal_hyd_VDF.h>
17#include <Paroi_std_hyd_VDF.h>
18#include <Champ_Uniforme.h>
19#include <Champ_Uniforme_Morceaux.h>
20#include <Champ_Fonc_Tabule.h>
21#include <Champ_Fonc_Tabule_P0_VDF.h>
22#include <Domaine_Cl_VDF.h>
23#include <Dirichlet_paroi_fixe.h>
24#include <Dirichlet_paroi_defilante.h>
25#include <Probleme_base.h>
26#include <Fluide_base.h>
27#include <Modele_turbulence_hyd_base.h>
28#include <Convection_Diffusion_Concentration.h>
29#include <Modele_turbulence_scal_base.h>
30#include <Constituant.h>
68 param.lire_avec_accolades_depuis(s);
88 DoubleTab& alpha_t = diffusivite_turb.
valeurs();
93 const DoubleTab& tab_visco = ch_visco_cin.
valeurs();
99 visco = std::max(tab_visco(0,0),DMINFLOAT);
107 Cerr <<
"In Paroi_std_scal_hyd_VDF::calculer_scal : visco = " << tab_visco.
local_min_vect() <<
" <= 0 ? " << finl;
118 const RefObjU& modele_turbulence_hydr = eqn_hydr.
get_modele(TURBULENCE);
121 const DoubleVect& tab_u_star = loi.
tab_u_star();
123 const IntVect& orientation = domaine_VDF.
orientation();
135 double d_alpha = alpha.
valeurs()(0,0);
137 for (
int nc=0; nc<alpha.
valeurs().line_size(); nc++)
139 if (d_alpha!=alpha.
valeurs()(0,nc))
141 Cerr <<
"Error!" << finl;
142 Cerr <<
"Law of the wall are not implemented yet for constituants with different diffusion coefficients." << finl;
151 double d_alpha = alpha.
valeurs()(elem,0);
152 for (
int nc=0; nc<alpha.
valeurs().line_size(); nc++)
154 if (d_alpha!=alpha.
valeurs()(elem,nc))
156 Cerr <<
"Error!" << finl;
157 Cerr <<
"Law of the wall are not implemented yet for constituants with different diffusion coefficients." << finl;
166 for (
int n_bord=0; n_bord<domaine_VDF.
nb_front_Cl(); n_bord++)
176 const Cond_lim& la_cl = le_dom_Cl_dis_->les_conditions_limites(n_bord);
183 int nfin = ndeb + le_bord.
nb_faces();
186 int boundary_index=-1;
188 boundary_index=n_bord;
189 assert(boundary_index >= 0);
191 for (
int num_face=ndeb; num_face<nfin; num_face++)
193 int elem = face_voisins(num_face,0);
195 elem = face_voisins(num_face,1);
201 double u_star = tab_u_star(num_face);
202 double d_alpha = (alpha_uniforme ? alpha.
valeurs()(0,0) : alpha.
valeurs()(elem,0) );
204 int global_face=num_face;
207 if (u_star == 0 || d_alpha == 0)
215 double d_visco = (l_unif ? visco : tab_visco(elem,0));
216 double Pr = d_visco/d_alpha;
217 double y_plus = dist*u_star/d_visco;
228 int ori = orientation(num_face);
229 double y0=0.5*domaine_VDF.
dim_elem(elem,ori)*u_star/d_visco;
classe Champ_Don_base classe de base des Champs donnes (non calcules)
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 Cond_lim Classe generique servant a representer n'importe quelle classe
classe Convection_Diffusion_Concentration Cas particulier de Convection_Diffusion_std
classe Convection_Diffusion_std Cette classe est la base des equations modelisant le transport
classe Dirichlet_paroi_defilante Impose la vitesse de paroi dnas une equation de type Navier_Stokes.
classe Dirichlet_paroi_fixe Represente une paroi immobile dans une equation de type Navier_Stokes.
double dist_norm_bord_axi(int num_face) const
double dim_elem(int, int) const
int orientation(int) const override
inline DoubleVect& Domaine_VDF::porosite_face() {
double dist_norm_bord(int num_face) const override
int face_voisins(int num_face, int i) const
renvoie l'element voisin de numface dans la direction i.
const Front_VF & front_VF(int i) const
Class defining operators and methods for all reading operation in an input flow (file,...
classe Equation_base Le role d'une equation est le calcul d'un ou plusieurs champs....
virtual const Milieu_base & milieu() const =0
virtual const RefObjU & get_modele(Type_modele type) const
Probleme_base & probleme()
Renvoie le probleme associe a l'equation.
classe Fluide_base Cette classe represente un d'un fluide incompressible ainsi que
const Champ_Don_base & viscosite_cinematique() const
int num_local_face(const int) const
int num_premiere_face() const
const Nom & le_nom() const override
Renvoie le nom de la frontiere geometrique.
cette classe permet de specifier des options a la loi de paroi standard.
virtual const Champ_Don_base & diffusivite() const
Renvoie la diffusivite du milieu.
Classe Modele_turbulence_hyd_base Cette classe sert de base a la hierarchie des classes.
const Turbulence_paroi_base & loi_paroi() const
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.
int init_lois_paroi() override
classe Paroi_std_scal_hyd_VDF
int init_lois_paroi_scalaire()
int init_lois_paroi() override
int calculer_scal(Champ_Fonc_base &) override
virtual const Equation_base & equation(int) const =0
static void exit(int exit_code=-1)
Routine de sortie de TRUST dans une region Kokkos.
Classe de base des flux de sortie.
_TYPE_ local_min_vect(Mp_vect_options opt=VECT_REAL_ITEMS) const
const Objet_U & valeur() const
Classe Turbulence_paroi_base Classe de base pour la hierarchie des classes representant les modeles.
const DoubleVect & tab_u_star() const
DoubleVects equivalent_distance_
KOKKOS_INLINE_FUNCTION double T_plus(double y_plus, double Pr, double Prdt_sur_kappa)