TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Echange_contact_ODVM_VDF.cpp
1/****************************************************************************
2* Copyright (c) 2015 - 2016, 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 <Echange_contact_ODVM_VDF.h>
17#include <Pb_Conduction.h>
18#include <Equation_base.h>
19#include <Modele_turbulence_scal_base.h>
20#include <Paroi_ODVM_scal_VDF.h>
21
22
23Implemente_instanciable(Echange_contact_ODVM_VDF,"Paroi_echange_contact_ODVM_VDF",Echange_contact_VDF);
24
25
26
28{
29 return s << que_suis_je() << "\n";
30}
31
33{
35}
36
37void Echange_contact_ODVM_VDF::calculer_Teta_equiv(DoubleTab& La_T_ext,const DoubleTab& mon_h,const DoubleTab& lautre_h,int i,double temps)
38{
39 const Equation_base& mon_eqn = domaine_Cl_dis().equation();
40 const DoubleTab& mon_inco=mon_eqn.inconnue().valeurs();
41 const Domaine_VDF& ma_zvdf = ref_cast(Domaine_VDF,domaine_Cl_dis().domaine_dis());
42 const Front_VF& ma_front_vf = ref_cast(Front_VF,frontiere_dis());
43 DoubleTab& t_autre=T_autre_pb().valeurs_au_temps(temps);
44 int ndeb = ma_front_vf.num_premiere_face();
45 int nb_faces_bord = ma_front_vf.nb_faces();
46 int ind_fac,elem, isfluide=0;
47 //La_T_ext.resize(nb_faces_bord,1);
48
49 if (mon_eqn.probleme().equation(0).has_champ("vitesse"))
50 {
51 mon_eqn.probleme().equation(0).get_champ("vitesse");
52 isfluide=1;
53 }
54
55 const Champ_front_calc& chcal=ref_cast(Champ_front_calc,T_autre_pb());
56 const Equation_base& eq = (isfluide==1?mon_eqn:chcal.inconnue().equation());
57 const Modele_turbulence_scal_base& modele_turbulence = ref_cast(Modele_turbulence_scal_base,eq.get_modele(TURBULENCE).valeur());
58 const Turbulence_paroi_scal_base& loipar = modele_turbulence.loi_paroi();
59
60 const Paroi_ODVM_scal_VDF& paroi_vdf = ref_cast(Paroi_ODVM_scal_VDF,loipar);
61 // Initialise la loi de paroi si necessaire:
62// GF non pas ici // paroi_vdf.init_lois_paroi();
63 if (paroi_vdf.get_Tf0().size_array()==0)
64 {
65 Cerr<<"pb !!!!!!!!"<<finl;
67 }
68
69 for (int numfa=0; numfa<nb_faces_bord; numfa++)
70 {
71 ind_fac = numfa+ndeb;
72 if (ma_zvdf.face_voisins(ind_fac,0)!= -1)
73 elem = ma_zvdf.face_voisins(ind_fac,0);
74 else
75 elem = ma_zvdf.face_voisins(ind_fac,1);
76 // double Delta_T= (mon_h(numfa,0)*mon_inco(elem)+autre_h(numfa,0)*T_autre_pb(numfa) - paroi_vdf.get_Tf0(numfa)*(mon_h(numfa,0)+autre_h(numfa,0)) );
77
78 double Delta_T= (mon_h(numfa,0)*mon_inco(elem)+lautre_h(numfa,0)*t_autre(numfa,0) - paroi_vdf.get_Tf0(numfa)*(mon_h(numfa,0)+lautre_h(numfa,0)));
79
80 // SI PB FLUIDE :
81 if(isfluide) La_T_ext(numfa,0) = t_autre(numfa,0)+Delta_T/mon_h(numfa,0);
82 // SINON (Solide)
83 else La_T_ext(numfa,0) = t_autre(numfa,0)-Delta_T/lautre_h(numfa,0);
84 }
85}
86
DoubleTab & valeurs() override
Renvoie le tableau des valeurs du champ au temps courant.
virtual DoubleTab & valeurs_au_temps(double temps)=0
classe Champ_front_calc Classe derivee de Champ_front_var qui represente les
const Champ_Inc_base & inconnue() const
Renvoie le champ inconnue associe.
Domaine_Cl_dis_base & domaine_Cl_dis()
Renvoie le domaine des conditions aux limites discretisee dont l'objet fait partie.
virtual Frontiere_dis_base & frontiere_dis()
Renvoie la frontiere discretisee a laquelle les conditions aux limites s'appliquent.
class Domaine_VDF
Definition Domaine_VDF.h:64
int face_voisins(int num_face, int i) const
renvoie l'element voisin de numface dans la direction i.
Definition Domaine_VF.h:418
void calculer_Teta_equiv(DoubleTab &La_T_ext, const DoubleTab &mon_h, const DoubleTab &autre_h, int i, double temps) override
remplit Teta_eq utilise T_autre_pb au temps passe en parametre
virtual Champ_front_base & T_autre_pb()
Class defining operators and methods for all reading operation in an input flow (file,...
Definition Entree.h:42
classe Equation_base Le role d'une equation est le calcul d'un ou plusieurs champs....
virtual const RefObjU & get_modele(Type_modele type) const
virtual const Champ_Inc_base & inconnue() const =0
const Champ_base & get_champ(const Motcle &nom) const override
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override
Probleme_base & probleme()
Renvoie le probleme associe a l'equation.
class Front_VF
Definition Front_VF.h:36
int nb_faces() const
Definition Front_VF.h:53
int num_premiere_face() const
Definition Front_VF.h:63
Classe Modele_turbulence_scal_base Cette classe represente un modele de turbulence pour une equation ...
const Turbulence_paroi_scal_base & loi_paroi() const
Renvoie la loi de turbulence sur la paroi (version const).
const Equation_base & equation() const
Renvoie la reference sur l'equation pointe par MorEqn::mon_equation.
Definition MorEqn.h:62
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 Sortie & printOn(Sortie &) const
Ecriture de l'objet sur un flot de sortie Methode a surcharger.
Definition Objet_U.cpp:282
CLASS: Paroi_ODVM_scal_VDF.
double get_Tf0(int num_face) const
virtual const Equation_base & equation(int) const =0
static void exit(int exit_code=-1)
Routine de sortie de TRUST dans une region Kokkos.
Definition Process.cpp:455
Classe de base des flux de sortie.
Definition Sortie.h:52
const Objet_U & valeur() const
Definition TRUST_Ref.h:134
Classe Turbulence_paroi_scal_base Classe de base pour la hierarchie des classes representant les mode...