TrioCFD 1.9.8
TrioCFD documentation
Loading...
Searching...
No Matches
Format_Post_CGNS Class Reference

classe Format_Post_CGNS More...

#include <Format_Post_CGNS.h>

Inheritance diagram for Format_Post_CGNS:
[legend]
Collaboration diagram for Format_Post_CGNS:
[legend]

Public Member Functions

 Format_Post_CGNS ()
void reset () override
void set_param (Param &param) 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 SortieprintOn (Sortie &) const
 Ecriture de l'objet sur un flot de sortie Methode a surcharger.
virtual EntreereadOn (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 Nomle_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_infoget_info () const
 Donne des informations sur le type de l'Objet_U.
const Nomque_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 Interpreteinterprete () const
Interpreteinterprete ()
Public Member Functions inherited from Process
virtual ~Process ()

Additional Inherited Members

Static Public Member Functions inherited from Objet_U
static const Nomnom_du_cas ()
 Renvoie une reference constante vers le nom du cas.
static Nomget_set_nom_du_cas ()
 Renvoie une reference non constante vers le nom du cas (pour pouvoir le modifier).
static const Type_infoinfo ()
 Donne des informations sur le type de l'Objet_U.
static const Objet_Uself_cast (const Objet_U &)
 methode ajoutee pour caster en python
static Objet_Uself_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 SortieJournal (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_Uoperator= (const Objet_U &)
 Operateur= : ne fait rien (on conserve le numero et l'identifiant).

Detailed Description

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:

  • an internally developed and supported method called Advanced Data Format (ADF), based on a common file format system previously in use at McDonnell Douglas,
- 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.

Constructor & Destructor Documentation

◆ Format_Post_CGNS()

Format_Post_CGNS::Format_Post_CGNS ( )

Definition at line 47 of file Format_Post_CGNS.cpp.

Member Function Documentation

◆ completer_post()

int Format_Post_CGNS::completer_post ( const Domaine & ,
const int ,
const Nature_du_champ & ,
const int ,
const Noms & ,
const Motcle & ,
const Nom &  )
inlineoverridevirtual

Reimplemented from Format_Post_base.

Definition at line 72 of file Format_Post_CGNS.h.

◆ ecrire_champ()

int Format_Post_CGNS::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 )
overridevirtual

Ecriture d'un champ dans le fichier de postraitement.

Parameters
(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.

◆ ecrire_domaine()

int Format_Post_CGNS::ecrire_domaine ( const Domaine & domaine,
const int est_le_premier_post )
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.

Parameters
(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.

◆ ecrire_domaine_dis()

int Format_Post_CGNS::ecrire_domaine_dis ( const Domaine & domaine,
const OBS_PTR(Domaine_dis_base)& domaine_dis_base,
const int est_le_premier_post )
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 200 of file Format_Post_CGNS.cpp.

◆ ecrire_domaine_dual()

void Format_Post_CGNS::ecrire_domaine_dual ( const Domaine & domaine,
const int est_le_premier_post )
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 185 of file Format_Post_CGNS.cpp.

◆ ecrire_domaine_low_level()

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.

◆ ecrire_entete()

int Format_Post_CGNS::ecrire_entete ( const double temps_courant,
const int reprise,
const int est_le_premier_post )
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 110 of file Format_Post_CGNS.cpp.

◆ ecrire_item_int()

int Format_Post_CGNS::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 )
inlineoverridevirtual

Ecriture d'un tableau d'entiers dans le fichier de postraitement.

See also
ecrire_champ
Parameters
(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.

◆ ecrire_temps()

int Format_Post_CGNS::ecrire_temps ( const double temps)
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.

◆ finir()

int Format_Post_CGNS::finir ( const int est_le_dernier_post)
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 174 of file Format_Post_CGNS.cpp.

◆ finir_ecriture()

int Format_Post_CGNS::finir_ecriture ( double temps_courant)
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 166 of file Format_Post_CGNS.cpp.

◆ initialize()

int Format_Post_CGNS::initialize ( const Nom & file_basename,
const int format,
const Nom & option_para )
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 99 of file Format_Post_CGNS.cpp.

◆ initialize_by_default()

int Format_Post_CGNS::initialize_by_default ( const Nom & file_basename)
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.

◆ preparer_post()

int Format_Post_CGNS::preparer_post ( const Nom & ,
const int ,
const int ,
const double  )
inlineoverridevirtual

Reimplemented from Format_Post_base.

Definition at line 73 of file Format_Post_CGNS.h.

◆ reset()

void Format_Post_CGNS::reset ( )
overridevirtual

Implements Format_Post_base.

Definition at line 52 of file Format_Post_CGNS.cpp.

◆ resetTime()

void Format_Post_CGNS::resetTime ( double t,
const std::string dirname )
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 78 of file Format_Post_CGNS.cpp.

◆ set_deformable_domain()

void Format_Post_CGNS::set_deformable_domain ( )
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 137 of file Format_Post_CGNS.cpp.

◆ set_discr_type()

void Format_Post_CGNS::set_discr_type ( const Nom & type)
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 123 of file Format_Post_CGNS.cpp.

◆ set_lagrangian_domain()

void Format_Post_CGNS::set_lagrangian_domain ( )
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 144 of file Format_Post_CGNS.cpp.

◆ set_loc_vector()

void Format_Post_CGNS::set_loc_vector ( const std::vector< std::string > & vec)
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 151 of file Format_Post_CGNS.cpp.

◆ set_param()

void Format_Post_CGNS::set_param ( Param & param) const
overridevirtual

Implements Format_Post_base.

Definition at line 71 of file Format_Post_CGNS.cpp.

◆ set_postraiter_domain()

void Format_Post_CGNS::set_postraiter_domain ( )
overridevirtual

Reimplemented from Format_Post_base.

Definition at line 130 of file Format_Post_CGNS.cpp.


The documentation for this class was generated from the following files: