TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Domaine_Cl_VEF.h
1/****************************************************************************
2* Copyright (c) 2024, 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 Domaine_Cl_VEF_included
17#define Domaine_Cl_VEF_included
18
19/*! @brief class Domaine_Cl_VEF Cette classe porte les tableaux qui servent a mettre en oeuvre
20 *
21 * les condition aux limites dans la formulation VEF
22 * volumes_entrelaces_Cl_ : volumes des polyedres entrelaces autour des faces
23 * non standard
24 * normales_facettes_Cl_ : normales aux facettes situees dans des polyedres
25 * non standard
26 * type_elem_Cl_: type des polyedres non standard. Le type_elem_Cl d'un element
27 * non standard depend de son nombre de faces de Dirichlet et de
28 * la position de ces faces dans l'element (voir Tri_VEF et Tetra_VEF)
29 *
30 *
31 * @sa Domaine_Cl_dis_base
32 */
33
34#include <Domaine_Cl_dis_base.h>
35
36
37class Domaine_VEF;
38
40{
41 Declare_instanciable(Domaine_Cl_VEF);
42public:
43 void associer(const Domaine_dis_base&) override;
44 void completer(const Domaine_dis_base&) override;
45 int initialiser(double temps) override;
46 void imposer_cond_lim(Champ_Inc_base&, double) override;
47
48 virtual void remplir_volumes_entrelaces_Cl(const Domaine_VEF&);
51
52 inline DoubleVect& volumes_entrelaces_Cl() { return volumes_entrelaces_Cl_; }
53 inline const DoubleVect& volumes_entrelaces_Cl() const { return volumes_entrelaces_Cl_; }
54 inline const double& volumes_entrelaces_Cl(int i) const { return volumes_entrelaces_Cl_[i]; }
55 inline double& volumes_entrelaces_Cl(int i) { return volumes_entrelaces_Cl_[i]; }
56 inline DoubleTab& normales_facettes_Cl() { return normales_facettes_Cl_; }
57 inline const DoubleTab& normales_facettes_Cl() const { return normales_facettes_Cl_; }
58 inline const double& normales_facettes_Cl(int num_poly, int num_fa7, int ncomp) const { return normales_facettes_Cl_(num_poly, num_fa7, ncomp); }
59 inline double& normales_facettes_Cl(int num_poly, int num_fa7, int ncomp) { return normales_facettes_Cl_(num_poly, num_fa7, ncomp); }
60 inline DoubleTab& vecteur_face_facette_Cl() { return vecteur_face_facette_Cl_; }
61 inline const DoubleTab& vecteur_face_facette_Cl() const { return vecteur_face_facette_Cl_; }
62 inline int type_elem_Cl(int i) const { return type_elem_Cl_[i]; }
63 inline const IntVect& type_elem_Cl() const { return type_elem_Cl_; }
64
65 int nb_faces_sortie_libre() const;
67 const Domaine_VEF& domaine_vef() const;
68
69 int nb_bord_periodicite() const;
70
71protected:
76
78};
79
80#endif /* Domaine_Cl_VEF_included */
Classe Champ_Inc_base.
DoubleVect & volumes_entrelaces_Cl()
double & volumes_entrelaces_Cl(int i)
const double & volumes_entrelaces_Cl(int i) const
Domaine_VEF & domaine_vef()
int initialiser(double temps) override
Initialise les CLs Contrairement aux methodes mettre_a_jour, les methodes.
void imposer_cond_lim(Champ_Inc_base &, double) override
Impose les conditions aux limites a la valeur temporelle "temps" du Champ_Inc.
DoubleTab normales_facettes_Cl_
void associer(const Domaine_dis_base &) override
const DoubleTab & normales_facettes_Cl() const
int nb_bord_periodicite() const
const DoubleVect & volumes_entrelaces_Cl() const
const DoubleTab & vecteur_face_facette_Cl() const
int type_elem_Cl(int i) const
void remplir_type_elem_Cl(const Domaine_VEF &)
appele par remplir_volumes_entrelaces_Cl() : remplissage de type_elem_Cl_
virtual void remplir_volumes_entrelaces_Cl(const Domaine_VEF &)
appele par completer() : remplissage de type_elem_Cl_ et volumes_entrelaces_Cl_
DoubleTab & vecteur_face_facette_Cl()
void remplir_normales_facettes_Cl(const Domaine_VEF &)
appele par completer() : remplissage de normales_facettes_Cl_ et vecteur_face_caette_Cl_
IntVect type_elem_Cl_
const double & normales_facettes_Cl(int num_poly, int num_fa7, int ncomp) const
DoubleVect volumes_entrelaces_Cl_
int nb_faces_sortie_libre() const
void remplir_vecteur_face_facette_Cl(const Domaine_VEF &)
DoubleTab & normales_facettes_Cl()
DoubleTab vecteur_face_facette_Cl_
double & normales_facettes_Cl(int num_poly, int num_fa7, int ncomp)
const IntVect & type_elem_Cl() const
classe Domaine_Cl_dis_base Les objets Domaine_Cl_dis_base representent les conditions aux limites
void completer()
Appel Cond_lim_base::completer() sur chaque condition aux limites.
class Domaine_VEF
Definition Domaine_VEF.h:54
classe Domaine_dis_base Cette classe est la base de la hierarchie des domaines discretisees.