TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Champ_front_base.cpp
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#include <Champ_front_base.h>
17#include <Frontiere_dis_base.h>
18#include <Frontiere.h>
19
20Implemente_base_sans_constructeur(Champ_front_base,"Champ_front_base",Field_base);
21// XD front_field_base objet_u champ_front_base INHERITS_BRACE Basic class for fields at domain boundaries.
22
24/*! @brief Imprime le nom du champ sur un flot de sortie
25 *
26 * @param (Sortie& s) un flot de sortie
27 * @return (Sortie&) le flot de sortie modifie
28 */
29Sortie& Champ_front_base::printOn(Sortie& s ) const { return s << que_suis_je() << " " << le_nom(); }
30
31/*! @brief DOES NOTHING - to override in derived classes.
32 *
33 * @param (Entree& s) un flot d'entree
34 * @return (Entree&) le flot d'entree
35 */
36Entree& Champ_front_base::readOn(Entree& s ) { return s ; }
37
38
39/*! @brief Initialisation en debut de calcul.
40 *
41 * Imperativement cette methode ne doit pas utiliser de donnees
42 * externes a l'equation (couplage). Si mettre_a_jour le fait,
43 * alors initialiser ne doit pas appeler mettre_a_jour.
44 *
45 * @return (0 en cas d'erreur, 1 sinon.)
46 */
47int Champ_front_base::initialiser(double temps, const Champ_Inc_base& inco)
48{
49 return 1;
50}
51
52/*! @brief Associe une frontiere discretisee au champ.
53 *
54 * @param (Frontiere_dis_base& fr) la frontiere discretisee a associer au champ
55 */
57{
58 la_frontiere_dis = fr;
59}
60
61
62/*! @brief NE FAIT RIEN, a surcharger.
63 *
64 * Cette methode est appelee au debut de chaque pas de temps ou
65 * sous-pas-de-temps, elle peut eventuellement utiliser des donnees
66 * exterieures a l'equation. A charge a l'algorithme de s'assurer
67 * que ces donnees sont pertinentes...
68 * Calcule la valeur de la condition aux limites au temps demande.
69 *
70 * @param (double)
71 */
73{
74}
75
76/*! @brief Appele par Conds_lim::completer Par defaut ne fait rien.
77 *
78 * A surcharger dans les champs_front instationnaires.
79 *
80 */
84
85/*! @brief NE FAIT RIEN, a surcharger Cette methode peut calculer et stocker des donnees utiles a la
86 *
87 * CL, et dependant uniquement de l'inconnue sur laquelle porte
88 * cette CL (pas de l'exterieur). cf Champ_front_contact_VEF par exemple.
89 * Elle est appelee lorsque l'inconnue est modifiee.
90 *
91 * @param (double)
92 */
96
97/*! @brief Renvoie le vecteur des valeurs du champ pour la face donnee.
98 *
99 * Par defaut pour les champs fonc, on suppose que le tableau des
100 * valeurs porte nb_faces * nb_compo_ valeurs.
101 * Exemple de cas particulier: champ_front_uniforme::valeurs_face
102 *
103 * @param (num_face) l'indice d'une face sur la frontiere 0 <= num_face < frontiere_dis().frontiere().nb_faces()
104 * @param (val) On resize ce tableau et on le remplit.
105 */
106void Champ_front_base::valeurs_face(int num_face, DoubleVect& val) const
107{
108#ifndef NDEBUG
109 const int nb_faces = frontiere_dis().frontiere().nb_faces();
110 // Si plantage ici, c'est que le tableau des valeurs ne contient pas une
111 // valeur pour chaque face, il faut reimplementer la methode dans la
112 // classe derivee...
113 assert(num_face >= 0 && num_face < nb_faces);
114 assert(valeurs().dimension(0) == nb_faces);
115#endif
116 const int n = nb_compo_;
117 val.resize(n);
118 const DoubleTab& valeurs_a_copier=valeurs();
119 for (int i = 0; i < n; i++)
120 val[i] = valeurs_a_copier(num_face, i);
121}
122
127
128
129/*! @brief A implementer dans les classes derivees.
130 *
131 * Avance en temps : le nouveau temps present sera le temps passe
132 * en parametre.
133 *
134 * @return (int) 1 si OK, 0 sinon
135 */
137{
138 Cerr << "Champ_front_base::avancer(double temps) should be overloaded" << finl;
140 return 0;
141}
142
143/*! @brief A implementer dans les classes derivees.
144 *
145 * Recule en temps : le nouveau temps present sera le temps passe
146 * en parametre.
147 *
148 * @return (int) 1 si OK, 0 sinon
149 */
151{
152 Cerr << "Champ_front_base::reculer(double temps) should be overloaded " << "by " << que_suis_je() << finl;
154 return 0;
155}
156
157/*! @brief Change la valeur du temps pour la ieme valeur temporelle apres le present
158 *
159 */
161{
162 les_valeurs->futur(i).changer_temps(temps);
163}
164
165/*! @brief Calcule le taux d'accroissement du champ entre t1 et t2 et le stocke dans Gpoint_
166 *
167 */
169{
170 if (std::abs(t2-t1) < DMINFLOAT)
171 {
172 Gpoint_ = 0;
173 }
174 else
175 {
176 const DoubleTab& v1 = valeurs_au_temps(t1);
177 const DoubleTab& v2 = valeurs_au_temps(t2);
178 if (!Gpoint_.get_md_vector() && v1.dimension(0) == 1)
179 {
180 // Champ instationnaire uniforme
181 int dim = v1.dimension(1);
182 Gpoint_.resize(dim);
183 for (int i = 0; i < dim; i++)
184 Gpoint_(i) = (v2(0, i) - v1(0, i)) / (t2 - t1);
185 }
186 else
187 {
188 // Champs instationnaire variable
189 Gpoint_ = v1;
190 Gpoint_ *= -1;
191 Gpoint_ += v2;
192 Gpoint_ /= (t2 - t1);
193 }
194 }
195}
196
Classe Champ_Inc_base.
classe Champ_front_base Classe de base pour la hierarchie des champs aux frontieres.
virtual int initialiser(double temps, const Champ_Inc_base &inco)
Initialisation en debut de calcul.
virtual void associer_fr_dis_base(const Frontiere_dis_base &)
Associe une frontiere discretisee au champ.
virtual void changer_temps_futur(double temps, int i)
Change la valeur du temps pour la ieme valeur temporelle apres le present.
virtual const Frontiere_dis_base & frontiere_dis() const
Renvoie la frontiere discretisee associee au champ.
virtual const Domaine_dis_base & domaine_dis() const
virtual void calculer_coeffs_echange(double temps)
NE FAIT RIEN, a surcharger Cette methode peut calculer et stocker des donnees utiles a la.
virtual DoubleTab & valeurs() override
Renvoie le tableau des valeurs du champ.
virtual DoubleTab & valeurs_au_temps(double temps)=0
virtual void fixer_nb_valeurs_temporelles(int nb_cases)
Appele par Conds_lim::completer Par defaut ne fait rien.
virtual int reculer(double temps)
A implementer dans les classes derivees.
virtual int avancer(double temps)
A implementer dans les classes derivees.
virtual void mettre_a_jour(double temps)
NE FAIT RIEN, a surcharger.
virtual void valeurs_face(int, DoubleVect &) const
Renvoie le vecteur des valeurs du champ pour la face donnee.
virtual void calculer_derivee_en_temps(double t1, double t2)
Calcule le taux d'accroissement du champ entre t1 et t2 et le stocke dans Gpoint_.
classe Domaine_dis_base Cette classe est la base de la hierarchie des domaines discretisees.
Class defining operators and methods for all reading operation in an input flow (file,...
Definition Entree.h:42
const Nom & le_nom() const override
Renvoie le nom du champ.
int nb_compo_
Definition Field_base.h:95
int_t nb_faces() const
Renvoie le nombre de faces de la frontiere.
Definition Frontiere.h:59
classe Frontiere_dis_base Classe representant une frontiere discretisee.
const Frontiere & frontiere() const
Renvoie la frontiere geometrique associee.
const Domaine_dis_base & domaine_dis() const
static int dimension
Definition Objet_U.h:99
const Nom & que_suis_je() const
renvoie la chaine identifiant la classe.
Definition Objet_U.cpp:104
virtual Entree & readOn(Entree &)
Lecture d'un Objet_U sur un flot d'entree Methode a surcharger.
Definition Objet_U.cpp:293
virtual Sortie & printOn(Sortie &) const
Ecriture de l'objet sur un flot de sortie Methode a surcharger.
Definition Objet_U.cpp:282
static void exit(int exit_code=-1)
Routine de sortie de TRUST dans une region Kokkos.
Definition Process.cpp:455
Classe de base des flux de sortie.
Definition Sortie.h:52
_SIZE_ dimension(int d) const
Definition TRUSTTab.tpp:133
void resize(_SIZE_, RESIZE_OPTIONS opt=RESIZE_OPTIONS::COPY_INIT)
Definition TRUSTVect.tpp:91