|
TrioCFD 1.9.8
TrioCFD documentation
|
classe Format_Post_CGNS More...
#include <Format_Post_CGNS.h>
Public Member Functions | |
| Format_Post_CGNS () | |
| void | reset () override |
| void | set_param (Param ¶m) const override |
| void | set_postraiter_domain () override |
| void | set_deformable_domain () override |
| void | set_lagrangian_domain () override |
| void | set_discr_type (const Nom &) override |
| void | set_loc_vector (const std::vector< std::string > &) override |
| void | resetTime (double t, const std::string dirname) override |
| int | initialize_by_default (const Nom &) override |
| Initialise le fichier avec des parametres appropries pour son format (exemple: format ascii, efface le fichier existant, un. | |
| int | initialize (const Nom &, const int, const Nom &) override |
| int | completer_post (const Domaine &, const int, const Nature_du_champ &, const int, const Noms &, const Motcle &, const Nom &) override |
| int | preparer_post (const Nom &, const int, const int, const double) override |
| int | ecrire_entete (const double, const int, const int) override |
| int | ecrire_temps (const double) override |
| Commence l'ecriture d'un pas de temps. | |
| int | finir (const int) override |
| int | finir_ecriture (double) override |
| void | ecrire_domaine_dual (const Domaine &, const int) override |
| int | ecrire_domaine_dis (const Domaine &, const OBS_PTR(Domaine_dis_base)&, const int) override |
| int | ecrire_domaine (const Domaine &, const int) override |
| Ecriture d'un maillage. | |
| int | ecrire_domaine_low_level (const Domaine *, const Nom &, const DoubleTab &, const IntTab &, const Motcle &) |
| int | ecrire_item_int (const Nom &, const Nom &, const Nom &, const Nom &, const Nom &, const IntVect &, const int) override |
| Ecriture d'un tableau d'entiers dans le fichier de postraitement. | |
| int | ecrire_champ (const Domaine &, const Noms &, const Noms &, int, double, const Nom &, const Nom &, const Nom &, const Nom &, const DoubleTab &) override |
| Ecriture d'un champ dans le fichier de postraitement. | |
| Public Member Functions inherited from Format_Post_base | |
| 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 void | set_single_lata_option (const bool) |
| 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 () |
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 |
| 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 Format_Post_CGNS
The CFD General Notation System (CGNS) provides a general, portable, and extensible standard for the storage and retrieval of computational fluid dynamics (CFD) analysis data. It consists of a collection of conventions, and free and open software implementing those conventions. It is self-descriptive, machine-independent, well-documented, and administered by an international steering committee.
It is also an American Institute of Aeronautics and Astronautics (AIAA) Recommended Practice. The system consists of two parts: (1) a standard data model and mapping format for recording the data, and (2) software that reads, writes, and modifies data in that format. The format is a conceptual entity established by the documentation; the software is a physical product supplied to enable developers to access and produce data recorded in that format.
The CGNS system is designed to facilitate the exchange of data between sites and applications, and to help stabilize the archiving of aerodynamic data. The data are stored in a compact, binary format and are accessible through a complete and extensible library of functions. The API (Application Program Interface) is platform independent and can be easily implemented in C, C++, Fortran and Fortran90 applications.
CGNS is self-describing, allowing an application to interpret the structure and contents of a file without any outside information. CGNS can make use of either two different low-level data formats:
- HDF5, a widely used hierarchical data format
see : https://cgns.github.io/cgns-modern.github.io/index.html https://en.wikipedia.org/wiki/CGNS
Definition at line 55 of file Format_Post_CGNS.h.
| Format_Post_CGNS::Format_Post_CGNS | ( | ) |
Definition at line 47 of file Format_Post_CGNS.cpp.
|
inlineoverridevirtual |
Reimplemented from Format_Post_base.
Definition at line 72 of file Format_Post_CGNS.h.
|
overridevirtual |
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 from Format_Post_base.
Definition at line 223 of file Format_Post_CGNS.cpp.
|
overridevirtual |
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 from Format_Post_base.
Definition at line 212 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 200 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 185 of file Format_Post_CGNS.cpp.
| int Format_Post_CGNS::ecrire_domaine_low_level | ( | const Domaine * | dom, |
| const Nom & | nom_dom, | ||
| const DoubleTab & | som, | ||
| const IntTab & | elem, | ||
| const Motcle & | type_e ) |
Definition at line 192 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 110 of file Format_Post_CGNS.cpp.
|
inlineoverridevirtual |
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 84 of file Format_Post_CGNS.h.
|
overridevirtual |
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 from Format_Post_base.
Definition at line 158 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 174 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 166 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 99 of file Format_Post_CGNS.cpp.
|
overridevirtual |
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 from Format_Post_base.
Definition at line 88 of file Format_Post_CGNS.cpp.
|
inlineoverridevirtual |
Reimplemented from Format_Post_base.
Definition at line 73 of file Format_Post_CGNS.h.
|
overridevirtual |
Implements Format_Post_base.
Definition at line 52 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 78 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 137 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 123 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 144 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 151 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Implements Format_Post_base.
Definition at line 71 of file Format_Post_CGNS.cpp.
|
overridevirtual |
Reimplemented from Format_Post_base.
Definition at line 130 of file Format_Post_CGNS.cpp.