TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Champ_Generique_Transformation.h
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
17#ifndef Champ_Generique_Transformation_included
18#define Champ_Generique_Transformation_included
19
20#include <Champ_Gen_de_Champs_Gen.h>
21#include <TRUST_Vector.h>
22#include <Parser_U.h>
23
24/*! @brief class Champ_Generique_Transformation
25 *
26 * Champ destine a post-traiter une "transformation" dependant de champs generiques et (ou) de x,y,z et t
27 * La classe porte un :
28 * -vecteur de Parseur (fxyz)
29 * -la (les) expression(s) pour exprimer la transformation (les_fct)
30 * -la methode de transformation choisie (methode_)
31 *
32 */
33
34//// Syntaxe a respecter pour jdd
35//
36// "nom_champ" Transformation {
37// "type_transfo" "type_info"
38// sources { ...{ ...source ref_Champ { Pb_champ "nom_pb" "nom_champ_discret1" } } ,
39// ...{ ...source ref_Champ { Pb_champ "nom_pb" "nom_champ_discret2" } } ,
40// ...
41// }
42// [localisation "loc"]
43// }
44//
45// "nom_champ" fixe par l'utilisateur sera le nom du champ generique.
46// "type_transfo" peut etre :
47// "fonction" permet d'appliquer une formule utilisant les valeurs des champs sources specifies et peut dependre de x,y,z et t.
48// -> type_info : f(nom_ch1,nom_ch2...,x,y,z,t) expression analytique
49//
50// "produit_scalaire" permet de calculer le produit scalaire de deux vecteurs.
51// -> type_info : vide car l'expression de transformation est construite automatiquement.
52// 2 sources de nature vectoriel doivent etre specifiees.
53//
54// "norme" permet de calculer la norme d'un vecteur.
55// -> type_info : idem a produit_scalaire
56// 1 source de nature vectoriel doit etre specifiee.
57//
58// "vecteur" permet de construire un champ de nature vectoriel a partir des composantes specifiees.
59// -> type_info : nom_pb nb_compo f1(nom_ch1,nom_ch2...,x,y,z,t) ...fn(nom_ch1,nom_ch2...,x,y,z,t)
60// nom_pb : nom du probleme.
61// nb_compo : nombre de composantes du champ vectoriel a creer.
62// f1,...,fn : expression des composantes du champ vectoriel a creeer.
63// Si des sources sont specifiees, elles doivent etre de nature scalaire.
64// Rq : si aucune source n'est specifiee par l''utilisateur, la version actuelle attribue une
65// source par defaut qui se base sur le champ inconnu de la premiere equation du probleme.
66// A terme (apres revision de la conception) ce contournement sera a eliminer.
67//
68// "composante" permet de construire un champ scalaire par extraction d'une composante d'un champ vectoriel.
69// -> type_info : num_compo : numero de la composante a extraire.
70// 1 source de nature vectoriel doit etre specifiee.
71//
72// "type_champ_gen" type d'un champ generique
73// "nom_champ_discret1" designe le nom du champ constituant la premiere source
74// "nom_champ_discret2" designe le nom du champ constituant la seconde source
75// ...
76// "loc" permet de specifier une localisation particuliere pour evaluer les valeurs de l espace de stockage
77// "unite" permet a l'utilisateur de donner une unite au champ obtenu
78// valeurs possibles : "elem", "som", "faces", "elem_dg" et "elem_som".
79// Dans le cas ou aucune localisation n'est specifiee, la localisation retenue est celle du support de la premiere source.
80//
81
83{
84
85 Declare_instanciable(Champ_Generique_Transformation);
86
87public:
88
89 void set_param(Param& param) const override;
90 int lire_motcle_non_standard(const Motcle&, Entree&) override;
93 const Noms get_property(const Motcle& query) const override;
94 const Champ_base& get_champ(OWN_PTR(Champ_base)& espace_stockage) const override;
95 const Champ_base& get_champ_without_evaluation(OWN_PTR(Champ_base)& espace_stockage) const override;
96
97 Entity get_localisation(const int index = -1) const override;
98 const Motcle get_directive_pour_discr() const override;
99 void completer(const Postraitement_base& post) override;
100 void nommer_source() override;
101 int preparer_macro();
103
104
105protected:
106
107 Nom methode_; //Methode indiquant le type de transformation retenue
108 Noms les_fct; //Contient l expression de la combinaison
109 mutable VECT(Parser_U) fxyz; //Parser utilise pour evaluer la valeur prise par la combinaison
110 int nb_comp_ = 1; //Nombre de composantes du champ evalue
111 Motcle localisation_; //Localisation du support d evaluation de l expression
112 Nom unite_; //unite du champ obtenu (a specifier par l'utilisateur)
113 Nature_du_champ nature_ch = scalaire; //Nature du champ evalue
114 bool fictive_source_ = false;
115
116private:
117 mutable OWN_PTR(Champ_Fonc_base) espace_stockage_;
118};
119
120#endif
classe Champ_Fonc_base Classe de base des champs qui sont fonction d'une grandeur calculee
Classe de base des champs generiques ayant comme source d'autres champs generiques L'utilisation des ...
class Champ_Generique_Transformation
const Motcle get_directive_pour_discr() const override
Renvoie la directive (champ_elem, champ_sommets, champ_face ou pression) pour lancer la discretisatio...
const Champ_base & get_champ_without_evaluation(OWN_PTR(Champ_base)&espace_stockage) const override
const Noms get_property(const Motcle &query) const override
Renvoie la propriete demandee.
Entity get_localisation(const int index=-1) const override
Renvoie le type des entites geometriques sur auxquelles les valeurs discretes sont attachees (NODE po...
const Champ_base & get_champ(OWN_PTR(Champ_base)&espace_stockage) const override
void completer(const Postraitement_base &post) override
void set_param(Param &param) const override
int lire_motcle_non_standard(const Motcle &, Entree &) override
Lecture des parametres de type non simple d'un objet_U a partir d'un flot d'entree.
classe Champ_base Cette classe est la base de la hierarchie des champs.
Definition Champ_base.h:43
Une chaine de caractere (Nom) en majuscules.
Definition Motcle.h:26
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
friend class Entree
Definition Objet_U.h:76
Helper class to factorize the readOn method of Objet_U classes.
Definition Param.h:112
classe Parser_U Version de la classe Parser, derivant de Objet_U.
Definition Parser_U.h:32
Classe de base pour l'ensemble des postraitements.