16#include <Paroi_loi_WW_scal_VDF.h>
17#include <Paroi_std_hyd_VDF.h>
18#include <Champ_Uniforme.h>
19#include <Domaine_Cl_VDF.h>
20#include <Dirichlet_paroi_fixe.h>
21#include <Dirichlet_paroi_defilante.h>
22#include <Probleme_base.h>
23#include <Fluide_base.h>
24#include <Modele_turbulence_hyd_base.h>
25#include <Convection_Diffusion_Concentration.h>
26#include <Modele_turbulence_scal_base.h>
27#include <Constituant.h>
58double Paroi_loi_WW_scal_VDF::Fthpar(
double y_plus,
double Pr,
double Beta)
60 static double C_inv = 2.12;
61 double Gamma = (0.01*pow(Pr*y_plus,4.))/(1.+5.*pow(Pr,3.)*y_plus);
62 double f = Pr*y_plus*exp(-Gamma);
64 f += (C_inv*log(1.+y_plus) + Beta)*exp(-1./(Gamma+1e-20));
71 tab_u_star.resize(le_dom_dis_->nb_faces_bord());
77 static double C = 1./2.12;
80 DoubleTab& alpha_t = diffusivite_turb.
valeurs();
85 const DoubleTab& tab_visco = ch_visco_cin.
valeurs();
91 visco = std::max(tab_visco(0,0),DMINFLOAT);
99 Cerr <<
"In Paroi_loi_WW_scal_VDF::calculer_scal : visco = " << tab_visco.
local_min_vect() <<
" <= 0 ? " << finl;
114 const RefObjU& modele_turbulence_hydr = eqn_hydr.
get_modele(TURBULENCE);
117 const DoubleVect& tab_ustar = loi.
tab_u_star();
124 for (
int n_bord=0; n_bord<domaine_VDF.
nb_front_Cl(); n_bord++)
134 const Cond_lim& la_cl = le_dom_Cl_dis_->les_conditions_limites(n_bord);
144 int boundary_index=-1;
146 boundary_index=n_bord;
147 assert(boundary_index >= 0);
149 for (
int num_face=ndeb; num_face<nfin; num_face++)
151 elem = face_voisins(num_face,0);
153 elem = face_voisins(num_face,1);
161 d_visco = tab_visco[elem];
170 double u_star = tab_ustar(num_face);
173 d_alpha = alpha.
valeurs()(0,0);
177 d_alpha = alpha.
valeurs()(elem);
179 d_alpha = alpha.
valeurs()(elem,0);
181 double Pr = d_visco/d_alpha;
182 double Beta = pow(3.85*pow(Pr,1./3.)-1.3,2.)+2.12*log(Pr);
183 alpha_t(elem) = u_star*dist*C;
191 int global_face=num_face;
193 equivalent_distance_[boundary_index][local_face] = d_alpha*Fthpar(dist*u_star/d_visco,Pr,Beta)/u_star;
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 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.
virtual int nb_comp() const
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.
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.
classe Paroi_loi_WW_scal_VDF
int init_lois_paroi() override
int calculer_scal(Champ_Fonc_base &) override
int init_lois_paroi() override
virtual const Equation_base & equation(int) const =0
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_