TRUST 1.9.8
HPC thermohydraulic platform
Loading...
Searching...
No Matches
Op_Conv_Muscl_New_VEF_Face.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_Muscl_New_VEF_Face_included
17#define Op_Conv_Muscl_New_VEF_Face_included
18
19#include <Op_Conv_VEF_Face.h>
20#include <TRUSTTabs.h>
21#include <TRUSTList.h>
22#include <TRUST_Ref.h>
23class Matrice_Morse;
24class Sous_domaine_VF;
25
26/*! @brief class Op_Conv_Muscl_New_VEF_Face
27 *
28 * Cette classe represente l'operateur de convection associe a une equation de
29 * transport d'un scalaire.
30 * La discretisation est VEF
31 * Le champ convecte est scalaire ou vecteur de type Champ_P1NC
32 * Le schema de convection est issu du papier
33 * "High-resolution FEM-TVD schemes based on a fully multidimensional flux limiter"
34 * D.Kuzmin and S.Turek.
35 * On herite de Op pour recuperer l'implicitation amont
36 *
37 *
38 * @sa Operateur_Conv_base
39 */
40
41
43{
44
45 Declare_instanciable(Op_Conv_Muscl_New_VEF_Face);
46
47public:
48
49 //Methodes annexes
50 void remplir_fluent() const override;
51 //int is_compressible() const { return 1;/* is_compressible_; */ }
52
53 void completer() override;
54
55 //Methodes pour l'explicite
56 DoubleTab& ajouter(const DoubleTab& , DoubleTab& ) const override;
57 double calculer_dt_stab() const override;
58
59 //Methodes pour l'implicite
60 void contribuer_a_avec(const DoubleTab&, Matrice_Morse&) const override;
61 void ajouter_contribution(const DoubleTab&, Matrice_Morse&) const override;
62
63 //test
64 void modifier_pour_Cl(Matrice_Morse&, DoubleTab&) const override;
65
66 public_for_cuda
67 void calculer_flux_bords(const DoubleTab&, const DoubleTab&, const DoubleTab&) const;
68 void calculer_coefficients_operateur_centre(DoubleTab&,DoubleTab&,DoubleTab&,DoubleTab&,const int, const DoubleTab& vitesse) const;
69 void calculer_flux_operateur_centre(DoubleTab&,const DoubleTab&,const DoubleTab&,const DoubleTab&,const DoubleTab&,const int,const DoubleTab&,const DoubleTab&) const;
70 DoubleTab& ajouter_operateur_centre(const DoubleTab&,const DoubleTab&, const DoubleTab&, DoubleTab&) const;
71 DoubleTab& ajouter_diffusion(const DoubleTab&,const DoubleTab&, const DoubleTab&, DoubleTab&) const;
72 DoubleTab& ajouter_antidiffusion_v1(const DoubleTab&, const DoubleTab&, const DoubleTab&, DoubleTab&) const;
73 DoubleTab& ajouter_antidiffusion_v2(const DoubleTab&, const DoubleTab&, const DoubleTab&, DoubleTab&) const;
74 void mettre_a_jour_pour_periodicite(const DoubleTab&,const DoubleTab&,DoubleTab&) const;
75
76private :
77
78 //Methodes annexes
79
80 //Methodes pour l'explicite
81
82 void modifier_flux_operateur_centre(DoubleTab&,const DoubleTab&,const DoubleTab&,const DoubleTab&,const DoubleTab&,const int,const DoubleTab&,const DoubleTab&) const;
83
84 DoubleTab& ajouter_antidiffusion(const DoubleTab&, const DoubleTab&, const DoubleTab&, DoubleTab&) const;
85
86
87 KOKKOS_INLINE_FUNCTION void calculer_senseur(CDoubleTabView3, CDoubleTabView4, CDoubleArrView, const int, const int, const int, CIntTabView, CIntTabView, CIntTabView, double&, double&, double&, double&) const;
88 void calculer_data_pour_dirichlet();
89
90 //Attributs de la classe
91 IntTab is_element_for_upwinding_;
92 IntVect is_dirichlet_faces_;
93
94 //ArrOfDouble alpha_tab;
95 //ArrOfDouble beta_; // vaut zero pour les faces ou l'on souhaite degenerer en Amont.
96 // mutable DoubleTab limiteurs_;//tableau stockant pour chaque face la moyenne algebrique du limiteur
97
98 double max_limiteur_ = 1.;
99 int centered_ = 1;
100 int upwind_ = 1;
101 int stabilized_ = 1;
102 int old_centered_ = 0;
103 int version_ = 2;
104 int facsec_auto_ = 0;
105
106 // bool sous_domaine; // Cas d'un sous-domaine a definir pour que l'EF_Stab degenere en Amont
107 Nom nom_sous_domaine;
108 //OBS_PTR(Sous_domaine_VF) le_sous_domaine_dis;
109
110 //double (*limiteur_)(double)=nullptr;
111
112};
113
114inline void Op_Conv_Muscl_New_VEF_Face::contribuer_a_avec(const DoubleTab& inco,
115 Matrice_Morse& matrice) const
116{
117 ajouter_contribution(inco, matrice);
118}
119
120#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
class Op_Conv_Muscl_New_VEF_Face
void contribuer_a_avec(const DoubleTab &, Matrice_Morse &) const override
DOES NOTHING - to override in derived classes.
public_for_cuda void calculer_flux_bords(const DoubleTab &, const DoubleTab &, const DoubleTab &) const
DoubleTab & ajouter_antidiffusion_v1(const DoubleTab &, 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 modifier_pour_Cl(Matrice_Morse &, DoubleTab &) const override
DOES NOTHING - to override in derived classes.
DoubleTab & ajouter_antidiffusion_v2(const DoubleTab &, const DoubleTab &, const DoubleTab &, DoubleTab &) const
void calculer_flux_operateur_centre(DoubleTab &, const DoubleTab &, const DoubleTab &, const DoubleTab &, const DoubleTab &, const int, const DoubleTab &, const DoubleTab &) const
void calculer_coefficients_operateur_centre(DoubleTab &, DoubleTab &, DoubleTab &, DoubleTab &, const int, const DoubleTab &vitesse) const
void ajouter_contribution(const DoubleTab &, Matrice_Morse &) const override
double calculer_dt_stab() const override
Calcul dt_stab.
void mettre_a_jour_pour_periodicite(const DoubleTab &, const DoubleTab &, DoubleTab &) const
DoubleTab & ajouter(const DoubleTab &, DoubleTab &) const override
DoubleTab & ajouter_operateur_centre(const DoubleTab &, const DoubleTab &, const DoubleTab &, DoubleTab &) const
DoubleTab & ajouter_diffusion(const DoubleTab &, const DoubleTab &, const DoubleTab &, DoubleTab &) const
const Champ_Inc_base & vitesse() const
Cette classe abstraite contient les informations geometrique de sous-domaine communes aux methodes de...