TRUST 1.9.8
HPC thermohydraulic platform
Loading...
Searching...
No Matches
Loi_Etat_base.h
1/****************************************************************************
2* Copyright (c) 2025, 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#ifndef Loi_Etat_base_included
17#define Loi_Etat_base_included
18
19#include <Champs_compris_interface.h>
20#include <Champs_compris.h>
21#include <Champ_Don_base.h>
22#include <TRUST_Ref.h>
23
25class Probleme_base;
26
27/*! @brief classe Loi_Etat_base Cette classe est la base de la hierarchie des lois d'etat.
28 *
29 * Elle definit un fluide dilatable
30 *
31 * @sa Fluide_Dilatable_base, Classe abstraite dont toutes les lois d'etat doivent deriver., Methodes abstraites:, void calculer_coeff_T(), void calculer_masse_volumique()
32 */
33
35{
36 Declare_base_sans_constructeur(Loi_Etat_base);
37
38public :
41
43 void assoscier_probleme(const Probleme_base& pb);
44 void mettre_a_jour(double);
45 void calculer_nu();
47 const Champ_Don_base& ch_temperature() const;
48
49 // Methodes virtuelles
50 virtual void associer_fluide(const Fluide_Dilatable_base&);
51 virtual void preparer_calcul();
52 virtual void abortTimeStep();
53 virtual void initialiser_inco_ch();
54 virtual void calculer_mu();
55 virtual void calculer_lambda();
56 virtual void calculer_alpha();
57 virtual void calculer_mu_sur_Sc();
58 virtual void calculer_nu_sur_Sc();
59 virtual void calculer_masse_volumique();
60 virtual double calculer_H(double,double) const;
61 virtual double Drho_DP(double,double) const ;
62 virtual double Drho_DT(double,double) const ;
63 virtual double De_DP(double,double) const ;
64 virtual double De_DT(double,double) const ;
65
66 //Methodes de l interface des champs postraitables
67 const Champ_base& get_champ(const Motcle& nom) const override;
68 void creer_champ(const Motcle& motlu) override { }
69 void get_noms_champs_postraitables(Noms& nom,Option opt=NONE) const override;
70 bool has_champ(const Motcle& nom, OBS_PTR(Champ_base) &ref_champ) const override;
71 bool has_champ(const Motcle& nom) const override;
72
73 // Methodes virtuelles pure
74 const virtual Nom type_fluide() const =0;
75 virtual void initialiser() =0;
76 virtual void remplir_T() =0;
77 virtual void calculer_Cp() =0;
78 virtual double calculer_masse_volumique(double,double) const =0;
79 virtual double inverser_Pth(double,double) =0;
80
81 // Methodes inlines
82 inline Champs_compris& champs_compris() { return champs_compris_; }
83 inline const DoubleTab& temperature() const { return temperature_->valeurs(); }
84 inline const DoubleTab& rho_n() const { return tab_rho_n; }
85 inline const DoubleTab& rho_np1() const { return tab_rho_np1; }
86 inline double Prandt() const { return Pr_; }
87
88protected :
91 OWN_PTR(Champ_Don_base) temperature_;
92 DoubleTab tab_rho_n, tab_rho_np1; //rho a l'etape precedente et l'etape suivante
93 double Pr_;
94 int debug;
95 virtual void compute_tab_rho(DoubleTab&); // compute tab_rho
96
97private :
98 Champs_compris champs_compris_;
99};
100
101#endif /* Loi_Etat_base_included */
classe Champ_Don_base classe de base des Champs donnes (non calcules)
classe Champ_base Cette classe est la base de la hierarchie des champs.
Definition Champ_base.h:43
classe Champs_compris_interface Cette classe contient une interface de methodes destinees a gerer
classe Fluide_Dilatable_base Cette classe represente un d'un fluide dilatable,
void assoscier_probleme(const Probleme_base &pb)
Associe le probleme a la loi d'etat.
virtual void initialiser()=0
virtual void initialiser_inco_ch()
Initialise l'inconnue de l'equation de chaleur : ne fai rien.
virtual double De_DP(double, double) const
virtual double calculer_masse_volumique(double, double) const =0
const DoubleTab & rho_n() const
DoubleTab tab_rho_np1
virtual void calculer_Cp()=0
friend class Fluide_Weakly_Compressible
void mettre_a_jour(double)
Met a jour la loi d'etat et le champ rho.
const Champ_base & get_champ(const Motcle &nom) const override
virtual void abortTimeStep()
virtual double De_DT(double, double) const
void creer_champ(const Motcle &motlu) override
double Prandt() const
const DoubleTab & temperature() const
DoubleTab tab_rho_n
Champ_Don_base & ch_temperature()
virtual void remplir_T()=0
virtual const Nom type_fluide() const =0
virtual void compute_tab_rho(DoubleTab &)
virtual double inverser_Pth(double, double)=0
virtual void associer_fluide(const Fluide_Dilatable_base &)
Associe le fluide a la loi d'etat.
virtual void calculer_masse_volumique()
Recalcule la masse volumique.
virtual double Drho_DT(double, double) const
virtual void preparer_calcul()
Prepare le fluide au calcul.
Champs_compris & champs_compris()
virtual void calculer_alpha()
Calcule la diffusivite.
virtual double calculer_H(double, double) const
Cas gaz parfait : ne fait rien Cas gaz Reel : doit recalculer l'enthalpie a partir de la pression et ...
virtual double Drho_DP(double, double) const
OBS_PTR(Fluide_Dilatable_base) le_fluide
void get_noms_champs_postraitables(Noms &nom, Option opt=NONE) const override
OBS_PTR(Probleme_base) le_prob_
virtual void calculer_lambda()
Calcule la conductivite.
virtual void calculer_mu()
Calcule la viscosite.
void calculer_nu()
Calcule la viscosite cinematique.
virtual void calculer_nu_sur_Sc()
Ne fait rien Surcharge dans Loi_Etat_Melange_Binaire.
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override
OWN_PTR(Champ_Don_base) temperature_
const DoubleTab & rho_np1() const
friend class Fluide_Quasi_Compressible
virtual void calculer_mu_sur_Sc()
Ne fait rien Surcharge dans Loi_Etat_Melange_GP.
Une chaine de caractere (Nom) en majuscules.
Definition Motcle.h:26
class Nom Une chaine de caractere pour nommer les objets de TRUST
Definition Nom.h:31
Un tableau de chaine de caracteres (VECT(Nom)).
Definition Noms.h:26
Objet_U()
Constructeur par defaut : attribue un numero d'identifiant unique a l'objet (object_id_),...
Definition Objet_U.cpp:55
classe Probleme_base C'est un Probleme_U qui n'est pas un couplage.