|
TRUST 1.9.8
HPC thermohydraulic platform
|
Classe de base des formats de postraitements pour les champs (lata, med, cgns, lml, single_lata). More...
#include <Format_Post_base.h>
Public Member Functions | |
| virtual void | reset ()=0 |
| virtual void | resetTime (double t, const std::string dirname) |
| virtual void | set_param (Param ¶m) const override=0 |
| 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. | |
| virtual int | initialize_by_default (const Nom &file_basename) |
| Initialise le fichier avec des parametres appropries pour son format (exemple: format ascii, efface le fichier existant, un. | |
| virtual int | initialize (const Nom &file_basename, const int format, const Nom &option_para) |
| virtual int | modify_file_basename (const Nom file_basename, bool for_restart, const double tinit) |
| Modification of the post processing file name. For save/restart this might also move and rename files around to avoid overriding existing files. | |
| virtual int | ecrire_entete (const double temps_courant, const int reprise, const int est_le_premier_post) |
| virtual int | completer_post (const Domaine &dom, const int axi, const Nature_du_champ &nature, const int nb_compo, const Noms &noms_compo, const Motcle &loc_post, const Nom &le_nom_champ_post) |
| virtual int | preparer_post (const Nom &id_du_domaine, const int est_le_premier_post, const int reprise, const double t_init) |
| virtual int | init_ecriture (double temps_courant, double temps_post, int est_le_premier_postraitement_pour_nom_fich_, const Domaine &domaine) |
| virtual int | finir_ecriture (double temps_courant) |
| virtual int | finir (const int est_le_dernier_post) |
| virtual int | ecrire_domaine (const Domaine &domaine, const int est_le_premier_post) |
| Ecriture d'un maillage. | |
| virtual void | ecrire_domaine_dual (const Domaine &domaine, const int est_le_premier_post) |
| virtual int | ecrire_domaine_dis (const Domaine &domaine, const OBS_PTR(Domaine_dis_base)&domaine_dis_base, const int est_le_premier_post) |
| virtual int | ecrire_temps (const double temps) |
| Commence l'ecriture d'un pas de temps. | |
| virtual int | ecrire_champ (const Domaine &domaine, const Noms &unite_, const Noms &noms_compo, int ncomp, double temps_, const Nom &id_du_champ, const Nom &id_du_domaine, const Nom &localisation, const Nom &nature, const DoubleTab &data) |
| Ecriture d'un champ dans le fichier de postraitement. | |
| virtual int | ecrire_item_int (const Nom &id_item, const Nom &id_du_domaine, const Nom &id_domaine, const Nom &localisation, const Nom &reference, const IntVect &data, const int reference_size) |
| Ecriture d'un tableau d'entiers dans le fichier de postraitement. | |
| virtual void | set_single_lata_option (const bool) |
| virtual void | set_postraiter_domain () |
| virtual void | set_deformable_domain () |
| virtual void | set_lagrangian_domain () |
| virtual void | set_discr_type (const Nom &) |
| virtual void | set_loc_vector (const std::vector< std::string > &) |
| Public Member Functions inherited from Objet_U | |
| ~Objet_U () override | |
| Destructeur, supprime l'objet de la liste d'objets enregistres dans "memoire". | |
| int | numero () const |
| Renvoie l'indice de l'objet dans Memoire::data. | |
| virtual int | duplique () const =0 |
| virtual Sortie & | printOn (Sortie &) const |
| Ecriture de l'objet sur un flot de sortie Methode a surcharger. | |
| virtual Entree & | readOn (Entree &) |
| Lecture d'un Objet_U sur un flot d'entree Methode a surcharger. | |
| virtual unsigned | taille_memoire () const =0 |
| virtual int | est_egal_a (const Objet_U &) const |
| Renvoie 1 si l'objet x et *this sont une seule et meme instance (meme adresse en memoire). | |
| virtual const Nom & | le_nom () const |
| Donne le nom de l'Objet_U Methode a surcharger : renvoie "neant" dans cette implementation. | |
| virtual void | nommer (const Nom &) |
| Donne un nom a l'Objet_U Methode virtuelle a surcharger. | |
| virtual int | reprendre (Entree &) |
| Reprise d'un Objet_U sur un flot d'entree Methode a surcharger. | |
| virtual int | sauvegarder (Sortie &) const |
| Sauvegarde d'un Objet_U sur un flot de sortie Methode a surcharger. | |
| int | get_object_id () const |
| Renvoie l'identifiant unique de l'objet object_id_. | |
| virtual const Type_info * | get_info () const |
| Donne des informations sur le type de l'Objet_U. | |
| const Nom & | que_suis_je () const |
| renvoie la chaine identifiant la classe. | |
| const char * | le_type () const |
| Donne le nom du type de l'Objet_U. | |
| virtual int | change_num (const int *const) |
| Change le numero interne de l'Objet_U. | |
| virtual int | associer_ (Objet_U &) |
| Associe l'Objet_U a un autre Objet_U Methode virtuelle a surcharger. | |
| const Interprete & | interprete () const |
| Interprete & | interprete () |
| Public Member Functions inherited from Process | |
| virtual | ~Process () |
Protected Member Functions | |
| OBS_PTR (Domaine_dis_base) domaine_dis_ | |
| Reference to the discretized domain - used for face fields. | |
| Protected Member Functions inherited from Objet_U | |
| Objet_U () | |
| Constructeur par defaut : attribue un numero d'identifiant unique a l'objet (object_id_), et enregistre l'objet en "memoire". | |
| Objet_U (const Objet_U &) | |
| Constructeur par copie. | |
| const Objet_U & | operator= (const Objet_U &) |
| Operateur= : ne fait rien (on conserve le numero et l'identifiant). | |
Additional Inherited Members | |
| Static Public Member Functions inherited from Objet_U | |
| static const Nom & | nom_du_cas () |
| Renvoie une reference constante vers le nom du cas. | |
| static Nom & | get_set_nom_du_cas () |
| Renvoie une reference non constante vers le nom du cas (pour pouvoir le modifier). | |
| static const Type_info * | info () |
| Donne des informations sur le type de l'Objet_U. | |
| static const Objet_U & | self_cast (const Objet_U &) |
| methode ajoutee pour caster en python | |
| static Objet_U & | self_cast (Objet_U &) |
| Static Public Member Functions inherited from Process | |
| static int | me () |
| renvoie mon rang dans le groupe de communication courant. | |
| static int | nproc () |
| renvoie le nombre de processeurs dans le groupe courant Voir Comm_Group::nproc() et PE_Groups::current_group() | |
| static bool | is_parallel () |
| static void | exit (int exit_code=-1) |
| Routine de sortie de TRUST dans une region Kokkos. | |
| static double | mp_sum (double) |
| Calcule la somme de x sur tous les processeurs du groupe courant. | |
| static float | mp_sum (float) |
| static trustIdType | mp_sum (trustIdType) |
| Calcule la somme de x sur tous les processeurs du groupe courant. | |
| static double | mp_max (double) |
| static double | mp_min (double) |
| static int | mp_max (int) |
| renvoie le plus grand int i sur l'ensemble des processeurs du groupe courant. | |
| static int | mp_min (int) |
| renvoie le plus petit int i sur l'ensemble des processeurs du groupe courant. | |
| static double | mp_sum_as_double (int v) |
| static trustIdType | mppartial_sum (trustIdType i) |
| Calul de la somme partielle de i sur les processeurs 0 a me()-1 (renvoie 0 sur le processeur 0). | |
| template<typename T> | |
| static void | mp_sum_for_each (T &arg1, T &arg2) |
| C++14 compatible mp_sum_for_each: combine multiple mp_sum calls into one collective operation Usage: mp_sum_for_each(a, b); mp_sum_for_each(a, b, c); mp_sum_for_each(a, b, c, d); mp_sum_for_each(a, b, c, d, e); All arguments must be of the same type (double or int) and are modified in place. Supports 2-5 parameters. | |
| template<typename T> | |
| static void | mp_sum_for_each (T &arg1, T &arg2, T &arg3) |
| template<typename T> | |
| static void | mp_sum_for_each (T &arg1, T &arg2, T &arg3, T &arg4) |
| template<typename T> | |
| static void | mp_sum_for_each (T &arg1, T &arg2, T &arg3, T &arg4, T &arg5) |
| template<typename T> | |
| static void | mp_max_for_each (T &arg1, T &arg2) |
| C++14 compatible mp_max_for_each: combine multiple mp_max calls into one collective operation. | |
| template<typename T> | |
| static void | mp_max_for_each (T &arg1, T &arg2, T &arg3) |
| template<typename T> | |
| static void | mp_max_for_each (T &arg1, T &arg2, T &arg3, T &arg4) |
| template<typename T> | |
| static void | mp_max_for_each (T &arg1, T &arg2, T &arg3, T &arg4, T &arg5) |
| template<typename T> | |
| static void | mp_min_for_each (T &arg1, T &arg2) |
| C++14 compatible mp_min_for_each: combine multiple mp_min calls into one collective operation. | |
| template<typename T> | |
| static void | mp_min_for_each (T &arg1, T &arg2, T &arg3) |
| template<typename T> | |
| static void | mp_min_for_each (T &arg1, T &arg2, T &arg3, T &arg4) |
| template<typename T> | |
| static void | mp_min_for_each (T &arg1, T &arg2, T &arg3, T &arg4, T &arg5) |
| template<typename _TYPE_> | |
| static void | mp_sum_for_each_item (TRUSTArray< _TYPE_ > &x, int n=-1) |
| template<typename _TYPE_> | |
| static void | mp_max_for_each_item (TRUSTArray< _TYPE_ > &x, int n=-1) |
| template<typename _TYPE_> | |
| static void | mp_min_for_each_item (TRUSTArray< _TYPE_ > &x, int n=-1) |
| static bool | mp_and (bool) |
| Calcule le 'et' logique de b sur tous les processeurs du groupe courant. | |
| static bool | mp_or (bool) |
| static int | check_int_overflow (trustIdType) |
| static int | je_suis_maitre () |
| renvoie 1 si on est sur le processeur maitre du groupe courant (c'est a dire me() == 0), 0 sinon. | |
| static KOKKOS_INLINE_FUNCTION void | Kokkos_exit (const char *) |
| Routine de sortie de TRUST dans une region Kokkos. | |
| static int | node_master () |
| renvoie 1 si on est sur le processeur maitre du noeud numa, 0 sinon. | |
| static void | exit (const Nom &message, int exit_code=-1) |
| static bool | is_sequential () |
| static void | barrier () |
| Synchronise tous les processeurs du groupe courant (attend que tous les processeurs soient arrives a la barriere). | |
| static void | abort () |
| Routine de sortie de Trio-U sur une erreur abort(). | |
| static Sortie & | Journal (int message_level=0) |
| Renvoie un objet statique de type Sortie qui sert de journal d'evenements. | |
| static double | ram_processeur () |
| static void | imprimer_ram_totale (int all_process=0) |
| static bool | force_single_file (const int ranks, const Nom &filename) |
| Static Public Attributes inherited from Objet_U | |
| static double | precision_geom = 1e-10 |
| static constexpr bool | HAS_POINTER = false |
| static int | dimension =0 |
| static int | format_precision_geom =11 |
| static int | axi =0 |
| static int | bidim_axi =0 |
| static int | DEACTIVATE_SIGINT_CATCH =0 |
| static Type_info | info_obj |
| static bool | disable_TU =false |
| Flag to disable or not the writing of the .TU files. | |
| static bool | stat_per_proc_perf_log =false |
| Flag to enable the writing of the statistics detailed per processor in _csv.TU file. | |
| Static Public Attributes inherited from Process | |
| static int | exception_sur_exit =0 |
| static int | multiple_files =5120 |
Classe de base des formats de postraitements pour les champs (lata, med, cgns, lml, single_lata).
Utilisation de la classe par l'interface generique: -typer un objet format de postraitement -initialiser l objet format de postraitement -proceder a des operations de complement et verification -ecrire un domaine -ecrire_temps -ecrire_champ (un type de champ supporte: aux elements ou aux sommets, ou encore aux faces si on a ecrit les faces du domaine et si les faces sont supportees par le postraitement)
Definition at line 100 of file Format_Post_base.h.
|
virtual |
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 109 of file Format_Post_base.cpp.
|
virtual |
Ecriture d'un champ dans le fichier de postraitement.
| (id_du_champ) | identifiant du champ (permet d'identifier un champ unique si on donne en plus un numero de pas de temps) |
| (id_du_domaine) | identifiant du domaine sur lequel le champ est defini Ce domaine doit avoir ete ecrit avant par "ecrire_domaine". |
| (localisation) | localisation des valeurs du champ (SOMMETS, ELEMENTS, ou tout autre id. de tableau deja ecrit) (tout n'est pas obligatoirement supporte par tous les postraitements) |
| (data) | tableau de valeurs a postraiter. Le nombre de lignes du tableau doit etre egal au nombre de lignes du tableau "localisation" (nombre de sommets, d'elements ou de faces ou autre). Valeur de retour: 1 si operation reussie, 0 sinon (par exemple, preconditions non remplies ou fonctionnalite non supportee par le format). |
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 185 of file Format_Post_base.cpp.
|
virtual |
Ecriture d'un maillage.
L'ecriture du domaine a lieu soit au debut, avant le premier appel a ecrire_temps, soit plus tard (maillage dynamique), mais ce n'est pas forcement supporte par le postraitement.
| (id_domaine) | le nom affecte au domaine dans le fichier lata. |
| (type_elem) | le type de l'element geometrique (un type supporte par la classe derivee, en general on comprend au moins "TETRAEDRE", "HEXAEDRE", "TRIANGLE" et "RECTANGLE") |
| (dimension) | la dimension du domaine (nombre de coordonnees des sommets) On peut avoir un domaine de dimension 3 et des elements de type triangle (postraitement d'une interface ou du bord d'un domaine volumique). |
| (sommets) | Coordonnees des sommets. S'il n'est pas vide, il faut que dimension(1)==dimension |
| (elements) | Indices des sommets de chaque element. dimension(1) doit correspondre au type de l'element (3 pour un triangle, 4 pour un rectangle ou un tetraedre, etc...) |
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 145 of file Format_Post_base.cpp.
|
virtual |
Reimplemented in Format_Post_CGNS, and Format_Post_Med.
Definition at line 158 of file Format_Post_base.cpp.
|
virtual |
Reimplemented in Format_Post_CGNS, and Format_Post_Med.
Definition at line 152 of file Format_Post_base.cpp.
|
virtual |
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 84 of file Format_Post_base.cpp.
|
virtual |
Ecriture d'un tableau d'entiers dans le fichier de postraitement.
| (reference) | Nom d'un autre tableau deja ecrit. data[i] est un indice dans ce tableau (exemple: on peut ecrire le tableau FACES_VOISINS, localisation=FACES, reference=ELEMENTS car le tableau est indexe par un numero de face et contient des indices d'elements) L'ecriture d'un domaine entraine automatiquement l'existence d'une tableau SOMMETS et d'un tableau ELEMENTS |
| (reference_size) | la taille (locale) du tableau cite en reference (dimension(0) du tableau). Cette dimension est utilisee pour renumeroter le contenu du tableau data afin de creer une numerotation globale lorsque tous les processeurs ecrivent dans un fichier unique. |
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 205 of file Format_Post_base.cpp.
|
virtual |
Commence l'ecriture d'un pas de temps.
La classe derivee doit accepter de recevoir plusieurs appels consecutifs a cette methode avec le meme temps.
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 170 of file Format_Post_base.cpp.
|
virtual |
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 90 of file Format_Post_base.cpp.
|
virtual |
Reimplemented in Format_Post_CGNS.
Definition at line 102 of file Format_Post_base.cpp.
|
virtual |
Definition at line 96 of file Format_Post_base.cpp.
|
virtual |
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 69 of file Format_Post_base.cpp.
|
virtual |
Initialise le fichier avec des parametres appropries pour son format (exemple: format ascii, efface le fichier existant, un.
fichier unique pour tous les processeurs etc...) Methode a surcharger dans les classes derivees. Valeur de retour: 1 si l'operation a reussi, 0 sinon.
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 62 of file Format_Post_base.cpp.
|
overridevirtual |
Lecture des parametres de type non simple d'un objet_U a partir d'un flot d'entree.
| (Motcle& | motlu) le nom du terme a lire |
| (Entree& | is) un flot d'entree |
Reimplemented from Objet_U.
Reimplemented in Format_Post_Lata.
Definition at line 50 of file Format_Post_base.cpp.
|
virtual |
Modification of the post processing file name. For save/restart this might also move and rename files around to avoid overriding existing files.
Reimplemented in Format_Post_Lata.
Definition at line 79 of file Format_Post_base.cpp.
|
protected |
Reference to the discretized domain - used for face fields.
|
virtual |
Reimplemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
Definition at line 120 of file Format_Post_base.cpp.
|
pure virtual |
Implemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
|
virtual |
Reimplemented in Format_Post_CGNS, and Format_Post_Lata.
Definition at line 40 of file Format_Post_base.cpp.
|
inlinevirtual |
Reimplemented in Format_Post_CGNS.
Definition at line 134 of file Format_Post_base.h.
|
inlinevirtual |
Reimplemented in Format_Post_CGNS.
Definition at line 136 of file Format_Post_base.h.
|
inlinevirtual |
Reimplemented in Format_Post_CGNS.
Definition at line 135 of file Format_Post_base.h.
|
inlinevirtual |
Reimplemented in Format_Post_CGNS.
Definition at line 137 of file Format_Post_base.h.
|
overridepure virtual |
Reimplemented from Objet_U.
Implemented in Format_Post_CGNS, Format_Post_Lata, Format_Post_Lml, and Format_Post_Med.
|
inlinevirtual |
Reimplemented in Format_Post_CGNS.
Definition at line 133 of file Format_Post_base.h.
|
inlinevirtual |
Reimplemented in Format_Post_Lata.
Definition at line 132 of file Format_Post_base.h.