TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Navier_Stokes_Fluide_Dilatable_base.h
1/****************************************************************************
2* Copyright (c) 2026, 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 Navier_Stokes_Fluide_Dilatable_base_included
17#define Navier_Stokes_Fluide_Dilatable_base_included
18
19#include <Navier_Stokes_Fluide_Dilatable_Proto.h>
20#include <Source_Masse_Fluide_Dilatable_base.h>
21#include <TRUSTTabs_forward.h>
22#include <Navier_Stokes_std.h>
23
24
25
26class Matrice_Morse;
27
28/*! @brief classe Navier_Stokes_Fluide_Dilatable_base Cette classe basse porte les termes de l'equation de la dynamique
29 *
30 * pour un fluide sans modelisation de la turbulence.
31 * On suppose l'hypothese de fluide dilatable.
32 * Sous ces hypotheses, on utilise la forme suivante des equations de
33 * Navier_Stokes:
34 * DU/dt = div(terme visqueux) - gradP/rho + sources/rho
35 * div U = W
36 * avec DU/dt : derivee particulaire de la vitesse
37 * rho : masse volumique
38 * Rq : l'implementation de la classe permet bien sur de negliger
39 * certains termes de l'equation (le terme visqueux, le terme
40 * convectif, tel ou tel terme source).
41 * L'inconnue est le champ de vitesse.
42 *
43 * @sa Navier_Stokes_std
44 */
45
47{
49
50public :
51 int lire_motcle_non_standard(const Motcle& mot, Entree& is) override;
52 int preparer_calcul() override;
53 void set_param(Param& param) const override;
54 void discretiser() override;
55 const Champ_Don_base& diffusivite_pour_transport() const override;
56 const Champ_base& diffusivite_pour_pas_de_temps() const override;
57 const Champ_base& vitesse_pour_transport() const override;
58
59 // Methodes virtuelles
60 DoubleTab& derivee_en_temps_inco(DoubleTab& ) override;
61 const Champ_base& get_champ(const Motcle& nom) const override;
62 bool has_champ(const Motcle& nom, OBS_PTR(Champ_base) &ref_champ) const override;
63 bool has_champ(const Motcle& nom) const override;
64 void completer() override;
65 void assembler( Matrice_Morse& mat_morse, const DoubleTab& present, DoubleTab& secmem) override ;
66 void assembler_avec_inertie( Matrice_Morse& mat_morse, const DoubleTab& present, DoubleTab& secmem) override ;
67 void assembler_blocs_avec_inertie(matrices_t matrices, DoubleTab& secmem, const tabs_t& semi_impl) override;
68 int impr(Sortie& os) const override;
69 bool initTimeStep(double dt) override;
70
71 // Methodes inlines
72 inline void mettre_a_jour(double temps) override
73 {
75 if (source_masse_)
76 source_masse_->mettre_a_jour(temps);
77 }
78
79 inline const Champ_Inc_base& rho_la_vitesse() const override { return rho_la_vitesse_; }
80
81 inline bool has_source_masse() const { return bool(source_masse_); }
83 {
84 assert(source_masse_);
85 return source_masse_.valeur();
86 }
87
88protected:
90};
91
92#endif /* Navier_Stokes_Fluide_Dilatable_base_included */
classe Champ_Don_base classe de base des Champs donnes (non calcules)
Classe Champ_Inc_base.
classe Champ_base Cette classe est la base de la hierarchie des champs.
Definition Champ_base.h:43
Classe Matrice_Morse Represente une matrice M (creuse), non necessairement carree.
Une chaine de caractere (Nom) en majuscules.
Definition Motcle.h:26
classe Navier_Stokes_Fluide_Dilatable_base Cette classe basse porte les termes de l'equation de la dy...
bool has_champ(const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override
void assembler_avec_inertie(Matrice_Morse &mat_morse, const DoubleTab &present, DoubleTab &secmem) override
const Champ_Inc_base & rho_la_vitesse() const override
DoubleTab & derivee_en_temps_inco(DoubleTab &) override
Returns the time derivative of the unknown I of the equation: dI/dt = M-1*(sum(operators(I) + sources...
int lire_motcle_non_standard(const Motcle &mot, Entree &is) override
Lecture des parametres de type non simple d'un objet_U a partir d'un flot d'entree.
const Champ_base & diffusivite_pour_pas_de_temps() const override
void completer() override
Complete l'equation base, associe la pression a l'equation,.
const Champ_Don_base & diffusivite_pour_transport() const override
const Source_Masse_Fluide_Dilatable_base & source_masse() const
const Champ_base & vitesse_pour_transport() const override
void assembler(Matrice_Morse &mat_morse, const DoubleTab &present, DoubleTab &secmem) override
void mettre_a_jour(double temps) override
La valeur de l'inconnue sur le pas de temps a ete calculee.
int preparer_calcul() override
Appel Equation_base::preparer_calcul() Assemblage du solveur pression et.
const Champ_base & get_champ(const Motcle &nom) const override
int impr(Sortie &os) const override
Imprime les operateurs de l'equation sur un flot de sortie, de facon inconditionnelle.
OWN_PTR(Source_Masse_Fluide_Dilatable_base) source_masse_
void assembler_blocs_avec_inertie(matrices_t matrices, DoubleTab &secmem, const tabs_t &semi_impl) override
bool initTimeStep(double dt) override
Allocation et initialisation de l'inconnue et des CLs jusqu'a present+dt.
void mettre_a_jour(double temps) override
Effectue une mise a jour en temps de l'equation.
OBS_PTR(Fluide_base) le_fluide
friend class Entree
Definition Objet_U.h:76
friend class Sortie
Definition Objet_U.h:75
Helper class to factorize the readOn method of Objet_U classes.
Definition Param.h:112
: classe Source_Masse_Fluide_Dilatable_base Une source speciale pour l'equation de masse (utilisee se...