|
TRUST 1.9.8
HPC thermohydraulic platform
|
: Classe de postraitement des champs euleriens au format lml. More...
#include <Format_Post_Lml.h>
Public Member Functions | |
| void | reset () override |
| Remet l'objet dans l'etat obtenu par le constructeur par defaut. | |
| void | set_param (Param ¶m) const override |
| int | initialize_by_default (const Nom &file_basename) override |
| Initialisation de la classe avec des parametres par defaut. | |
| int | initialize (const Nom &file_basename, const int format, const Nom &option_para) override |
| int | ecrire_entete (const double temps_courant, const int reprise, const int est_le_premier_post) 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 | finir (const int est_le_dernier_post) override |
| int | ecrire_domaine (const Domaine &domaine, const int est_le_premie_post) override |
| voir Format_Post_base::ecrire_domaine | |
| int | ecrire_temps (const double temps) override |
| commence l'ecriture d'un nouveau pas de temps En l'occurence pour le format Lml: | |
| 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. | |
| Format_Post_Lml () | |
| Constructeur par defaut: Specifier dans commentaire ce qui est fixe par defaut. | |
| Public Member Functions inherited from Format_Post_base | |
| virtual void | resetTime (double t, const std::string dirname) |
| 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 | 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 | 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_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 () |
Static Public Member Functions | |
| static int | ecrire_domaine_lml (const Domaine &domaine, Nom &nom_fic) |
| static int | ecrire_temps_lml (const double temps, Nom &nom_fic) |
| static int | ecrire_champ_lml (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 DoubleTab &data, Nom &nom_fic) |
| static int | ecrire_item_int_lml (const Nom &id_item, const Nom &id_domaine, const IntVect &data, const Nom &nom_fic) |
| static int | ecrire_entete_lml (Nom &nom_fic, const int est_le_premier_post) |
| static int | finir_lml (Nom &nom_fic, const int est_le_dernier_post) |
| static int | completer_post_lml () |
| static int | preparer_post_lml () |
| 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) |
Protected Attributes | |
| Nom | lml_basename_ |
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 lml.
Only works for small enough domains (domain exceeding the 32b limit can not be written in LML).
Pour creer un fichier valide, il faut faire: (initialisation) initialize("base_nom_fichier",...); // base_nom_fichier indique le nom du fichier sans extension ".lml" // met eventuellement en jeux les informations d autres postraitements ecrire_entete(temps_courant,reprise,est_le_premier_post) ecrire_domaine(domaine,est_le_premier_post)
(pour chaque dt) ecrire_temps(temps_courant) ecrire_champ(const Domaine& domaine, const Noms& unite_, const Noms& noms_compo, int ncomp,double temps_,double temps_courant const Nom & id_du_champ, const Nom & id_du_domaine, const Nom & localisation, const DoubleTab & data) [ecrire_champ(..., data)]
(finir) finir(est_le_dernier_post)
Definition at line 44 of file Format_Post_Lml.h.
| Format_Post_Lml::Format_Post_Lml | ( | ) |
Constructeur par defaut: Specifier dans commentaire ce qui est fixe par defaut.
Definition at line 35 of file Format_Post_Lml.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 117 of file Format_Post_Lml.cpp.
|
static |
Definition at line 260 of file Format_Post_Lml.cpp.
|
overridevirtual |
voir Format_Post_base::ecrire_champ
Reimplemented from Format_Post_base.
Definition at line 173 of file Format_Post_Lml.cpp.
|
static |
Definition at line 476 of file Format_Post_Lml.cpp.
|
overridevirtual |
voir Format_Post_base::ecrire_domaine
Reimplemented from Format_Post_base.
Definition at line 140 of file Format_Post_Lml.cpp.
|
static |
Definition at line 270 of file Format_Post_Lml.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 91 of file Format_Post_Lml.cpp.
|
static |
Definition at line 218 of file Format_Post_Lml.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 197 of file Format_Post_Lml.cpp.
|
static |
Definition at line 611 of file Format_Post_Lml.cpp.
|
overridevirtual |
commence l'ecriture d'un nouveau pas de temps En l'occurence pour le format Lml:
Ouvre le fichier maitre en mode APPEND et ajoute une ligne "TEMPS xxxxx"
Reimplemented from Format_Post_base.
Definition at line 157 of file Format_Post_Lml.cpp.
|
static |
Definition at line 463 of file Format_Post_Lml.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 104 of file Format_Post_Lml.cpp.
|
static |
Definition at line 240 of file Format_Post_Lml.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 84 of file Format_Post_Lml.cpp.
|
overridevirtual |
Initialisation de la classe avec des parametres par defaut.
Reimplemented from Format_Post_base.
Definition at line 78 of file Format_Post_Lml.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 127 of file Format_Post_Lml.cpp.
|
static |
Definition at line 265 of file Format_Post_Lml.cpp.
|
overridevirtual |
Remet l'objet dans l'etat obtenu par le constructeur par defaut.
Implements Format_Post_base.
Definition at line 43 of file Format_Post_Lml.cpp.
|
overridevirtual |
Implements Format_Post_base.
Definition at line 70 of file Format_Post_Lml.cpp.
|
protected |
Definition at line 85 of file Format_Post_Lml.h.