TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Entree_fluide_T_h_imposee.cpp
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#include <Entree_fluide_T_h_imposee.h>
17
18Implemente_instanciable(Entree_fluide_T_h_imposee, "Frontiere_ouverte_T_h_imposee", Dirichlet_entree_fluide);
19
20Sortie& Entree_fluide_T_h_imposee::printOn(Sortie& s) const { return s << que_suis_je() << finl; }
21
22/*! @brief Type le_champ_front en "Champ_front_uniforme".
23 *
24 * Lit les valeurs du champ exterieur si les conditions
25 * aux limites sont specifiees: "T_ext", "C_ext", "Y_ext" ou "K_Eps_ext"
26 * Produit une erreur sinon.
27 *
28 * @param (Entree& s) un flot d'entree
29 * @return (Entree& s) le flot d'entree modifie
30 * @throws type de champ exterieur non reconnu,
31 * les types reconnus sont: "T_ext", "C_ext", "Y_ext" ou "K_Eps_ext"
32 */
34{
35 if (app_domains.size() == 0) app_domains = { Motcle("Thermique"), Motcle("indetermine") };
36
37 le_champ_front.typer("Champ_front_uniforme");
38 le_champ_Text.typer("Champ_front_uniforme");
39 le_champ_hext.typer("Champ_front_uniforme");
40 Motcle motlu;
41 Motcles les_motcles(6);
42 {
43 les_motcles[0] = "T_ext";
44 les_motcles[1] = "C_ext";
45 les_motcles[2] = "K_Eps_ext";
46 les_motcles[3] = "H_ext";
47 les_motcles[4] = "Y_ext";
48 les_motcles[5] = "K_Omega_ext";
49 }
50
51 Motcle accfermee = "}";
52 Motcle accouverte = "{";
53 s >> motlu;
54 int rang;
55 if (motlu != accouverte)
56 {
57 Cerr << "On attendait une { dans la lecture de l'interface " << finl;
58 exit();
59 }
60 s >> motlu;
61 while (motlu != accfermee)
62 {
63 rang = les_motcles.search(motlu);
64 switch(rang)
65 {
66 case 0:
67 {
68 s >> le_champ_Text;
69 break;
70 }
71 case 1:
72 case 2:
73 case 3:
74 case 4:
75 {
76 s >> le_champ_hext;
77 break;
78 }
79 default:
80 {
81 Cerr << "Erreur a la lecture de la condition aux limites de type: " << finl;
82 Cerr << que_suis_je() << finl;
83 Cerr << "On attendait " << les_motcles << " a la place de " << motlu << finl;
84 exit();
85 }
86 }
87 s >> motlu;
88 }
89
90 return s;
91}
92
93/*! @brief Renvoie la valeur de la i-eme composante du champ impose a l'exterieur de la frontiere.
94 *
95 * @param (int i) indice suivant la premiere dimension du champ
96 * @return (double) la valeur imposee sur la composante du champ specifiee
97 * @throws deuxieme dimension du champ de frontiere superieur a 1
98 */
100{
101 if (type_cond_lim == 0)
102 {
103 // Cerr<<"Entree_fluide_T_h_imposee Condition limite en temperature"<<finl;
104 if (le_champ_Text->valeurs().size() == 1)
105 return le_champ_Text->valeurs()(0, 0);
106 else if (le_champ_Text->valeurs().dimension(1) == 1)
107 return le_champ_Text->valeurs()(i, 0);
108 else
109 Cerr << "Entree_fluide_T_h_imposee::val_ext" << finl;
110 exit();
111 return 0.;
112 }
113 else
114 {
115 // Cerr<<"Entree_fluide_T_h_imposee Condition limite en enthalpie"<<finl;
116 if (le_champ_hext->valeurs().size() == 1)
117 return le_champ_hext->valeurs()(0, 0);
118 else if (le_champ_hext->valeurs().dimension(1) == 1)
119 return le_champ_hext->valeurs()(i, 0);
120 else
121 Cerr << "Entree_fluide_T_h_imposee::val_ext" << finl;
122 exit();
123 return 0.;
124 }
125}
126
127/*! @brief Renvoie la valeur de la (i,j)-eme composante du champ impose a l'exterieur de la frontiere.
128 *
129 * @param (int i) indice suivant la premiere dimension du champ
130 * @param (int j) indice suivant la deuxieme dimension du champ
131 * @return (double) la valeur imposee sur la composante du champ specifiee
132 */
133double Entree_fluide_T_h_imposee::val_imp(int i, int j) const
134{
135 if (type_cond_lim == 0)
136 {
137 // Condition limite en temperature
138 if (le_champ_Text->valeurs().dimension(0) == 1)
139 return le_champ_Text->valeurs()(0, j);
140 else
141 return le_champ_Text->valeurs()(i, j);
142 }
143 else
144 {
145 // Condition limite en enthalpie
146 if (le_champ_hext->valeurs().dimension(0) == 1)
147 return le_champ_hext->valeurs()(0, j);
148 else
149 return le_champ_hext->valeurs()(i, j);
150 }
151}
std::vector< Motcle > app_domains
classe Dirichlet_entree_fluide Cette classe represente une condition aux limite imposant une grandeur
classe Entree_fluide_temperature_imposee Cas particulier de la classe Dirichlet_entree_fluide
double val_imp(int i) const override
Renvoie la valeur de la i-eme composante du champ impose a l'exterieur de la frontiere.
Class defining operators and methods for all reading operation in an input flow (file,...
Definition Entree.h:42
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