TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Champ_Generique_Interpolation.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#ifndef Champ_Generique_Interpolation_included
17#define Champ_Generique_Interpolation_included
18
19#include <Champ_Gen_de_Champs_Gen.h>
20
21
22/*! @brief Un champ generique qui est construit comme une interpolation d'un autre champ generique (interpolation aux sommets ou aux elements).
23 *
24 * L interpolation sera effectuee sur un domaine qui peut etre
25 * le domaine de calcul ou un domaine different specifie par l utilisateur
26 *
27 */
28
29//// Syntaxe a respecter pour jdd
30//
31// "nom_champ" Interpolation { [ domaine ] "dom_interp"
32// localisation "loc"
33// source "type_champ_ge" { ...source ref_Champ { Pb_champ "nom_pb" "nom_champ_discret" } }
34// }
35// "nom_champ" fixe par utilisateur sera le nom du champ generique
36// "dom_interp" nom du domaine d interpolation dans le cas ou il differe du domaine de calcul (optionnel)
37// "loc" designe la localisation d interpolation "elem", "elem_dg", "faces" ou "som"
38// "type_champ_gen" type d'un champ generique
39
41{
42 Declare_instanciable(Champ_Generique_Interpolation);
43public:
44 void reset() override;
45 void set_param(Param& param) const override;
46 //int lire_motcle_non_standard(const Motcle&, Entree&);
47 virtual int set_localisation(const Motcle& localisation, int exit_on_error = 1);
48 virtual int set_methode(const Motcle& methode, int exit_on_error = 1);
49 virtual int set_domaine(const Nom& nom_domaine, int exit_on_error = 1);
50 const Champ_base& get_champ(OWN_PTR(Champ_base)& espace_stockage) const override;
51 const Champ_base& get_champ_without_evaluation(OWN_PTR(Champ_base)& espace_stockage) const override;
53
54 const DoubleTab& get_ref_values() const override;
55 void get_copy_values(DoubleTab&) const override;
56 //virtual void get_xyz_values(const DoubleTab & coords, DoubleTab & values, ArrOfBit & validity_flag) const;
57
58 Entity get_localisation(const int index = -1) const override;
59 const Domaine& get_ref_domain() const override;
60 void get_copy_domain(Domaine&) const override;
61
62 const DoubleTab& get_ref_coordinates() const override;
63 void get_copy_coordinates(DoubleTab&) const override;
64 //virtual const IntTab& get_ref_connectivity(Entity index1, Entity index2) const;
65 //virtual void get_copy_connectivity(Entity index1, Entity index2, IntTab &) const;
66
67 const Noms get_property(const Motcle& query) const override;
68 void nommer_source() override;
69 void completer(const Postraitement_base& post) override;
70 const Domaine_dis_base& get_ref_domaine_dis_base() const override;
71 const Motcle get_directive_pour_discr() const override;
73
74 const Noms& fixer_noms_compo(const Noms& noms) override;
75 const Noms& fixer_noms_synonyms(const Noms& noms) override;
76 //L attribut compo_ de Champ_Generique_Interpolation n est rempli que pour les Champ_Generique_Interpolation
77 //crees par macro et cela afin de reproduire les noms de composantes dans les lml
79
80private:
81 Motcle localisation_; // localisation d interpolation elem, som
82 Motcle methode_; // calculer_champ_post, etc...
83 Nom nom_domaine_lu_; // Nom du domaine lu
84 OBS_PTR(Domaine) domaine_; // domaine sur lequel on veut interpoler le champ (domaine natif si reference nulle)
85 OBS_PTR(Domaine_dis_base) le_dom_dis; // rempli si domaine d'interpolation different du domaine natif. Une REF car le Domaine_dis_cache est responsable de la memoire
86 // ex : Sonde utilise valeur_aux...() qui necessite de disposer d un domaine discretise
87 int optimisation_sous_maillage_,optimisation_demande_;
88 ArrOfInt renumerotation_maillage_;
89 mutable OWN_PTR(Champ_Fonc_base) espace_stockage_;
90 mutable OWN_PTR(Champ_base) espace_stockage_source_;
91};
92
93#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 ...
Un champ generique qui est construit comme une interpolation d'un autre champ generique (interpolatio...
void get_copy_domain(Domaine &) const override
Cree une copie du domaine sur lequel sera evalue l espace de stockage.
const Noms & fixer_noms_compo(const Noms &noms) override
const Motcle get_directive_pour_discr() const override
Renvoie la directive (champ_elem, champ_sommets, champ_face ou pression) pour lancer la discretisatio...
void completer(const Postraitement_base &post) override
void set_param(Param &param) const override
const DoubleTab & get_ref_values() const override
Renvoie une reference au tableau de valeurs discretes s'il existe en memoire.
const DoubleTab & get_ref_coordinates() const override
Renvoie une reference au tableau des coordonnees des sommets du maillage support du champ,...
void reset() override
restore la configuration initiale de l'objet localisation non specifiee, source non specifiee,...
virtual int set_domaine(const Nom &nom_domaine, int exit_on_error=1)
Initialisation de la classe: initialisation du domaine d'interpolation Parametres valides : "" => dom...
const Domaine_dis_base & get_ref_domaine_dis_base() const override
Renvoie une ref au domaine_discretisee du domaine sur lequel sera evalue l espace de stockage.
const Domaine & get_ref_domain() const override
Renvoie une ref au domaine sur lequel sera evalue l espace de stockage.
virtual const Champ_base & get_champ_with_calculer_champ_post() const
Interpolation du champ source a l'aide de Champ_base::calculer_champ_xxx_post.
Entity get_localisation(const int index=-1) const override
Renvoie le type des entites geometriques sur auxquelles les valeurs discretes sont attachees (NODE po...
void get_copy_values(DoubleTab &) const override
Remplit le tableau values avec les valeurs discretes du champ (cree une copie).
virtual int set_methode(const Motcle &methode, int exit_on_error=1)
Initialisation de la classe: initialisation de la methode d'interpolation Parametres valides : calcul...
const Noms get_property(const Motcle &query) const override
Renvoie la propriete demandee.
void get_copy_coordinates(DoubleTab &) const override
const Champ_base & get_champ(OWN_PTR(Champ_base)&espace_stockage) const override
Interpolation du champ source en fonction de la methode, localisation et domaine demandes.
const Champ_base & get_champ_without_evaluation(OWN_PTR(Champ_base)&espace_stockage) const override
virtual int set_localisation(const Motcle &localisation, int exit_on_error=1)
Initialisation de la classe: initialisation de la localisation demandee.
const Noms & fixer_noms_synonyms(const Noms &noms) override
classe Champ_base Cette classe est la base de la hierarchie des champs.
Definition Champ_base.h:43
classe Domaine_dis_base Cette classe est la base de la hierarchie des domaines discretisees.
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
Helper class to factorize the readOn method of Objet_U classes.
Definition Param.h:112
Classe de base pour l'ensemble des postraitements.