TRUST 1.9.8
HPC thermohydraulic platform
Loading...
Searching...
No Matches
Op_Conv_EF_VEF_P1NC_Stab.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 Op_Conv_EF_VEF_P1NC_Stab_included
17#define Op_Conv_EF_VEF_P1NC_Stab_included
18
19#include <Op_Conv_VEF_Face.h>
20#include <Equation_base.h>
21#include <TRUSTTabs.h>
22#include <TRUSTList.h>
23#include <TRUST_Ref.h>
24
25class Sous_domaine_VF;
26class Matrice_Morse;
27/*! @brief class Op_Conv_EF_VEF_P1NC_Stab
28 *
29 * Cette classe represente l'operateur de convection associe a une equation de
30 * transport d'un scalaire.
31 * La discretisation est VEF
32 * Le champ convecte est scalaire ou vecteur de type Champ_P1NC
33 * Le schema de convection est isu du papier
34 * "High-resolution FEM-TVD schemes based on a fully multidimensional flux limiter"
35 * D.Kuzmin and S.Turek.
36 * On herite de Op pour recuperer l'implicitation amont
37 *
38 *
39 * @sa Operateur_Conv_base
40 */
41
42
44{
45
46 Declare_instanciable(Op_Conv_EF_VEF_P1NC_Stab);
47
48public:
49
50 //Methodes annexes
51 void remplir_fluent() const override;
52 int is_compressible() const;
53 void completer() override;
54
55 //Methodes pour l'explicite
56 DoubleTab& ajouter(const DoubleTab& , DoubleTab& ) const override;
57
58 //Methodes pour l'implicite
59 void contribuer_a_avec(const DoubleTab&, Matrice_Morse&) const override;
60 void ajouter_contribution(const DoubleTab&, Matrice_Morse&) const override;
61
62 //test
63 void modifier_pour_Cl(Matrice_Morse&, DoubleTab&) const override;
64
65 public_for_cuda
66 void calculer_flux_bords(const DoubleTab&, const DoubleTab&, const DoubleTab&) const;
67 void calculer_coefficients_operateur_centre(DoubleTab&,const int, const DoubleTab& vitesse) const;
68 DoubleTab& ajouter_partie_compressible(const DoubleTab&, DoubleTab&, const DoubleTab& vitesse) const;
69 DoubleTab& ajouter_operateur_centre(const DoubleTab&, const DoubleTab&, DoubleTab&) const;
70 DoubleTab& ajouter_diffusion(const DoubleTab&, const DoubleTab&, DoubleTab&) const;
71 DoubleTab& ajouter_antidiffusion(const DoubleTab&, const DoubleTab&, DoubleTab&) const;
72 void ajouter_contribution_operateur_centre(const DoubleTab&, const DoubleTab&, Matrice_Morse&) const;
73 void ajouter_contribution_diffusion(const DoubleTab&, const DoubleTab&, Matrice_Morse&) const;
74 void mettre_a_jour_pour_periodicite(DoubleTab&) const;
75
76private :
77
78 //Methodes annexes
79
80 //Methodes pour l'explicite
81 void reinit_conv_pour_Cl(const DoubleTab&,const IntList&, const DoubleTabs&, const DoubleTab&, DoubleTab&) const;
82
83 KOKKOS_INLINE_FUNCTION void calculer_senseur(CDoubleTabView3, CDoubleArrView, const int, const int, CIntTabView, CIntTabView, CIntTabView, double*, double*, double*, double*) const;
84 inline void calculer_senseur(const DoubleTab&, const DoubleVect&, const int, const int, const IntTab&, const IntTab&, const IntTab&, ArrOfDouble&, ArrOfDouble&, ArrOfDouble&, ArrOfDouble&) const;
85 void ajouter_old(const DoubleTab& , DoubleTab&, const DoubleTab& vitesse) const;
86 void calculer_data_pour_dirichlet();
87
88 //Methodes pour l'implicite
89 void ajouter_contribution_antidiffusion(const DoubleTab&,const DoubleTab&,Matrice_Morse&) const;
90 void ajouter_contribution_partie_compressible(const DoubleTab&,const DoubleTab&,Matrice_Morse&) const;
91
92 //Methodes de test
93 void test(const DoubleTab&,const DoubleTab&, const DoubleTab& vitesse) const;
94 void test_difference_Kij(const DoubleTab&,DoubleTab&,DoubleTab&, const DoubleTab& vitesse) const;
95 void test_difference_resu(const DoubleTab&,const DoubleTab&,const DoubleTab&,const DoubleTab&,const DoubleTab& vitesse) const;
96 void test_implicite() const;
97
98 //Attributs de la classe
99 ArrOfInt elem_nb_faces_dirichlet_;
100 IntTab elem_faces_dirichlet_;
101 ArrsOfInt elem_faces_frontiere;
102
103 ArrOfDouble alpha_tab_;
104 ArrOfDouble beta_; // vaut zero pour les faces ou l'on souhaite degenerer en Amont.
105 // mutable DoubleTab limiteurs_;//tableau stockant pour chaque face la moyenne algebrique du limiteur
106
107 double alpha_ = 1.;
108
109 int is_compressible_ = 0;
110 int test_ = 0;
111 int old_ = 0;
112 int volumes_etendus_ = 1;
113
114 bool sous_domaine = false; // Cas d'un sous-domaine a definir pour que l'EF_Stab degenere en Amont
115 int new_jacobienne_ = 0;
116 Nom nom_sous_domaine;
117 OBS_PTR(Sous_domaine_VF) le_sous_domaine_dis;
118
119 int nb_ssz_alpha = -1;
120 DoubleVect alpha_ssz;
121 Noms noms_ssz_alpha;
122 bool ssz_alpha = false;
123};
124
125inline void Op_Conv_EF_VEF_P1NC_Stab::contribuer_a_avec(const DoubleTab& inco,
126 Matrice_Morse& matrice) const
127{
128 ajouter_contribution(inco, matrice);
129}
130
132{
133 return is_compressible_;
134}
135
136#endif
Classe Matrice_Morse Represente une matrice M (creuse), non necessairement carree.
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
class Op_Conv_EF_VEF_P1NC_Stab
DoubleTab & ajouter(const DoubleTab &, DoubleTab &) const override
DoubleTab & ajouter_diffusion(const DoubleTab &, const DoubleTab &, DoubleTab &) const
void completer() override
Associe l'operateur au domaine_dis, le domaine_Cl_dis, et a l'inconnue de son equation.
void ajouter_contribution_diffusion(const DoubleTab &, const DoubleTab &, Matrice_Morse &) const
void calculer_coefficients_operateur_centre(DoubleTab &, const int, const DoubleTab &vitesse) const
public_for_cuda void calculer_flux_bords(const DoubleTab &, const DoubleTab &, const DoubleTab &) const
void ajouter_contribution_operateur_centre(const DoubleTab &, const DoubleTab &, Matrice_Morse &) const
DoubleTab & ajouter_operateur_centre(const DoubleTab &, const DoubleTab &, DoubleTab &) const
void contribuer_a_avec(const DoubleTab &, Matrice_Morse &) const override
DOES NOTHING - to override in derived classes.
DoubleTab & ajouter_partie_compressible(const DoubleTab &, DoubleTab &, const DoubleTab &vitesse) const
DoubleTab & ajouter_antidiffusion(const DoubleTab &, const DoubleTab &, DoubleTab &) const
void modifier_pour_Cl(Matrice_Morse &, DoubleTab &) const override
DOES NOTHING - to override in derived classes.
void mettre_a_jour_pour_periodicite(DoubleTab &) const
void ajouter_contribution(const DoubleTab &, Matrice_Morse &) const override
const Champ_Inc_base & vitesse() const
Cette classe abstraite contient les informations geometrique de sous-domaine communes aux methodes de...