|
TRUST 1.9.8
HPC thermohydraulic platform
|
: Classe de postraitement des champs euleriens au format lata More...
#include <Format_Post_Lata.h>
Public Types | |
| enum | Format { ASCII , BINAIRE } |
| enum | Options_Para { SINGLE_FILE , SINGLE_FILE_MPIIO , MULTIPLE_FILES } |
| enum | Status { RESET , INITIALIZED , WRITING_TIME } |
Public Member Functions | |
| void | set_param (Param ¶m) 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. | |
| void | reset () override |
| Remet l'objet dans l'etat obtenu par le constructeur par defaut. | |
| void | resetTime (double t, const std::string dirname) override |
| 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) override |
| int | preparer_post (const Nom &id_du_domaine, const int est_le_premier_post, const int reprise, const double t_init) override |
| int | initialize_by_default (const Nom &file_basename) override |
| Initialisation de la classe avec des parametres par defaut (format ASCII, SINGLE_FILE). | |
| int | initialize (const Nom &file_basename, const int format, const Nom &option_para) override |
| int | modify_file_basename (const Nom file_basename, bool for_restart, const double tinit) override |
| Modifying name of the post file, plus some clever management of previously saved data in case of restart. | |
| int | ecrire_entete (const double temps_courant, const int reprise, const int est_le_premier_post) override |
| Ouvre le fichier maitre en mode ERASE et ecrit l'entete du fichier lata (sur le processeur maitre seulement). | |
| int | ecrire_domaine (const Domaine &domaine, const int est_le_premier_post) override |
| voir Format_Post_base::ecrire_domaine On accepte l'ecriture d'un domaine dans un pas de temps, mais | |
| int | ecrire_temps (const double temps) override |
| commence l'ecriture d'un nouveau pas de temps En l'occurence pour le format LATA: | |
| 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) override |
| voir Format_Post_base::ecrire_champ | |
| 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) override |
| Ecriture d'un tableau d'entiers dans le fichier de postraitement. | |
| int | finir (const int est_le_dernier_post) override |
| virtual int | reconstruct (const Nom file_basename, const Nom, const double tinit) |
| virtual int | finir_sans_reprise (const Nom file_basename) |
| void | ecrire_domaine_low_level (const Nom &id_dom, const DoubleTab &sommets, const IntTab &elements, const Motcle &type_elem) |
| Low level routine to write a mesh into a LATA file. | |
| int | ecrire_item_tid (const Nom &id_item, const Nom &id_du_domaine, const Nom &id_domaine, const Nom &localisation, const Nom &reference, const TIDVect &data, const int reference_size) |
| Format_Post_Lata () | |
| Constructeur par defaut: format_ ASCII et options_para_ = SINGLE_FILE. | |
| virtual int | initialize_lata (const Nom &file_basename, const Format format=ASCII, const Options_Para options_para=SINGLE_FILE) |
| Initialisation de la classe, ouverture du fichier et ecriture de l'entete. | |
| void | set_single_lata_option (const bool sing_lata) override |
| Public Member Functions inherited from Format_Post_base | |
| 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 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 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 () |
Static Public Member Functions | |
| static int | ecrire_entete_lata (const Nom &base_name, const Options_Para &option, const Format &format, const int est_le_premier_post) |
| static int | ecrire_temps_lata (const double temps, double &temps_format, const Nom &base_name, Status &stat, const Options_Para &option) |
| static const char * | extension_lata () |
| Renvoie l'extension conventionnelle des fichiers lata : ".lata". | |
| static const char * | remove_path (const char *filename) |
| Renvoie le nom d'un fichier sans le path : on enleve les caracteres avant le dernier /. | |
| 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 Protected Member Functions | |
| static trustIdType | write_doubletab (Fichier_Lata &fichier, const DoubleTab &tab, int &nb_colonnes, const Options_Para &option) |
| fichier est un fichier lata de donnees (pas le fichier maitre) on y ecrit le tableau tab tel quel (en binaire ou ascii et sur un ou | |
| static trustIdType | write_inttab (Fichier_Lata &fichier, bool decal_fort, trustIdType decalage_partiel, const IntTab &tab, int &nb_colonnes, const Options_Para &option) |
| Ecriture d'un tableau d'entiers dans le fichier fourni. | |
Protected Attributes | |
| Nom | lata_basename_ |
| Format | format_ |
| Options_Para | options_para_ |
| Status | status |
| bool | restart_already_moved_ |
| double | temps_courant_ |
| double | tinit_ |
| bool | un_seul_fichier_lata_ = false |
| long int | offset_elem_ = -1 |
| long int | offset_som_ = -1 |
Additional Inherited Members | |
| 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 |
| Protected Member Functions inherited from Format_Post_base | |
| 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). | |
: Classe de postraitement des champs euleriens au format lata
Definition at line 52 of file Format_Post_Lata.h.
| Enumerator | |
|---|---|
| ASCII | |
| BINAIRE | |
Definition at line 100 of file Format_Post_Lata.h.
| Enumerator | |
|---|---|
| SINGLE_FILE | |
| SINGLE_FILE_MPIIO | |
| MULTIPLE_FILES | |
Definition at line 101 of file Format_Post_Lata.h.
| Enumerator | |
|---|---|
| RESET | |
| INITIALIZED | |
| WRITING_TIME | |
Definition at line 102 of file Format_Post_Lata.h.
| Format_Post_Lata::Format_Post_Lata | ( | ) |
Constructeur par defaut: format_ ASCII et options_para_ = SINGLE_FILE.
Definition at line 33 of file Format_Post_Lata.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 124 of file Format_Post_Lata.cpp.
|
overridevirtual |
voir Format_Post_base::ecrire_champ
Reimplemented from Format_Post_base.
Definition at line 696 of file Format_Post_Lata.cpp.
|
overridevirtual |
voir Format_Post_base::ecrire_domaine On accepte l'ecriture d'un domaine dans un pas de temps, mais
les id_domaines doivent etre tous distincts. Ecrit le fichier "basename(_XXXXX).lata.nom_domaine", qui contient la liste des sommets et la liste des elements. Si le PE est maitre, ouvre le fichier maitre en mode APPEND et ajoute une reference a ce fichier.
Reimplemented from Format_Post_base.
Definition at line 662 of file Format_Post_Lata.cpp.
| void Format_Post_Lata::ecrire_domaine_low_level | ( | const Nom & | id_domaine, |
| const DoubleTab & | sommets, | ||
| const IntTab & | elements, | ||
| const Motcle & | type_element ) |
Low level routine to write a mesh into a LATA file.
Also called directly in TrioCFD, by Postraitement_ft_lata for interface writing.
Definition at line 497 of file Format_Post_Lata.cpp.
|
overridevirtual |
Ouvre le fichier maitre en mode ERASE et ecrit l'entete du fichier lata (sur le processeur maitre seulement).
void Format_Post_Lata::ecrire_entete_lata()
Reimplemented from Format_Post_base.
Definition at line 118 of file Format_Post_Lata.cpp.
|
static |
Definition at line 920 of file Format_Post_Lata.cpp.
|
overridevirtual |
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 from Format_Post_base.
Definition at line 908 of file Format_Post_Lata.cpp.
| int Format_Post_Lata::ecrire_item_tid | ( | const Nom & | id_item, |
| const Nom & | id_du_domaine, | ||
| const Nom & | id_domaine, | ||
| const Nom & | localisation, | ||
| const Nom & | reference, | ||
| const TIDVect & | data, | ||
| const int | reference_size ) |
Definition at line 914 of file Format_Post_Lata.cpp.
|
overridevirtual |
commence l'ecriture d'un nouveau pas de temps En l'occurence pour le format LATA:
Ouvre le fichier maitre en mode APPEND et ajoute une ligne "TEMPS xxxxx" si ce temps n'a pas encore ete ecrit
Reimplemented from Format_Post_base.
Definition at line 687 of file Format_Post_Lata.cpp.
|
static |
Definition at line 978 of file Format_Post_Lata.cpp.
|
static |
Renvoie l'extension conventionnelle des fichiers lata : ".lata".
Definition at line 96 of file Format_Post_Lata.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 995 of file Format_Post_Lata.cpp.
|
virtual |
Definition at line 430 of file Format_Post_Lata.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 286 of file Format_Post_Lata.cpp.
|
overridevirtual |
Initialisation de la classe avec des parametres par defaut (format ASCII, SINGLE_FILE).
Reimplemented from Format_Post_base.
Definition at line 279 of file Format_Post_Lata.cpp.
|
virtual |
Initialisation de la classe, ouverture du fichier et ecriture de l'entete.
Definition at line 314 of file Format_Post_Lata.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 Format_Post_base.
Definition at line 86 of file Format_Post_Lata.cpp.
|
overridevirtual |
Modifying name of the post file, plus some clever management of previously saved data in case of restart.
Reimplemented from Format_Post_base.
Definition at line 326 of file Format_Post_Lata.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 129 of file Format_Post_Lata.cpp.
|
virtual |
Definition at line 390 of file Format_Post_Lata.cpp.
|
static |
Renvoie le nom d'un fichier sans le path : on enleve les caracteres avant le dernier /.
Definition at line 105 of file Format_Post_Lata.cpp.
|
overridevirtual |
Remet l'objet dans l'etat obtenu par le constructeur par defaut.
Implements Format_Post_base.
Definition at line 41 of file Format_Post_Lata.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 52 of file Format_Post_Lata.cpp.
|
overridevirtual |
Implements Format_Post_base.
Definition at line 80 of file Format_Post_Lata.cpp.
|
inlineoverridevirtual |
Reimplemented from Format_Post_base.
Definition at line 110 of file Format_Post_Lata.h.
|
staticprotected |
fichier est un fichier lata de donnees (pas le fichier maitre) on y ecrit le tableau tab tel quel (en binaire ou ascii et sur un ou
plusieurs fichiers en parallel). nb_colonnes est rempli avec le produit des tab.dimension(i) pour i>0
Definition at line 257 of file Format_Post_Lata.cpp.
|
staticprotected |
Ecriture d'un tableau d'entiers dans le fichier fourni.
Les valeurs ecrites sont les valeurs du tableau auquelles ont ajoute "decalage". Cette valeur est utilisee pour passer en numerotation fortran (ajouter 1), ou pour passer en numerotation globale (ajouter le nombre d'elements sur les processeurs precedents).
On renvoie dans nb_colonnes la somme des dimension(i) pour i>0. Valeur de retour: somme des dimension(0) ecrits (selon que tous les processeurs ecrivent sur le meme fichier ou pas).
Definition at line 271 of file Format_Post_Lata.cpp.
|
protected |
Definition at line 120 of file Format_Post_Lata.h.
|
protected |
Definition at line 119 of file Format_Post_Lata.h.
|
protected |
Definition at line 129 of file Format_Post_Lata.h.
|
protected |
Definition at line 129 of file Format_Post_Lata.h.
|
protected |
Definition at line 121 of file Format_Post_Lata.h.
|
protected |
Definition at line 124 of file Format_Post_Lata.h.
|
protected |
Definition at line 122 of file Format_Post_Lata.h.
|
protected |
Definition at line 126 of file Format_Post_Lata.h.
|
protected |
Definition at line 127 of file Format_Post_Lata.h.
|
protected |
Definition at line 128 of file Format_Post_Lata.h.