|
TrioCFD 1.9.8
TrioCFD documentation
|
Dummy parallel descriptor used for sequential computations. More...
#include <MD_Vector_seq.h>
Public Member Functions | |
| MD_Vector_seq () | |
| MD_Vector_seq (const trustIdType &nb) | |
| trustIdType | get_nb_items () const |
| bool | validate (trustIdType sz_array, int line_size) const override |
| int | get_nb_items_reels () const override |
| int | get_nb_items_tot () const override |
| trustIdType | nb_items_seq_tot () const override |
| int | nb_items_seq_local () const override |
| void | initialize_comm (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, DoubleVect &) const override |
| void | prepare_send_data (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, DoubleVect &) const override |
| void | process_recv_data (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, DoubleVect &) const override |
| void | initialize_comm (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, FloatVect &) const override |
| void | prepare_send_data (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, FloatVect &) const override |
| void | process_recv_data (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, FloatVect &) const override |
| void | initialize_comm (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, IntVect &) const override |
| void | prepare_send_data (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, IntVect &) const override |
| void | process_recv_data (const Echange_EV_Options &opt, Schema_Comm_Vecteurs &, IntVect &) const override |
| void | append_from_other_seq (const MD_Vector_seq &src, int offset, int multiplier) override |
| void | fill_md_vect_renum (const IntVect &renum, MD_Vector &md_vect) const override |
| bool | use_blocks () const override |
| Public Member Functions inherited from MD_Vector_mono | |
| const ArrOfInt & | get_blocs_items_to_sum () const override |
| const ArrOfInt & | get_items_to_sum () const override |
| const ArrOfInt & | get_blocs_items_to_compute () const override |
| const ArrOfInt & | get_items_to_compute () const override |
| Public Member Functions inherited from MD_Vector_base | |
| int | get_sequential_items_flags (ArrOfBit &flags, int line_size=1) const |
| int | get_sequential_items_flags (ArrOfInt &flags, int line_size=1) const |
| 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 | lire_motcle_non_standard (const Motcle &motlu, Entree &is) |
| Lecture des parametres de type non simple d'un objet_U a partir d'un flot d'entree. | |
| 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 | |
| int | get_seq_flags_impl (ArrOfBit &flags, int line_size) const override |
| Protected Member Functions inherited from MD_Vector_mono | |
| virtual void | append_from_other_std (const MD_Vector_std &src, int offset, int multiplier) |
| 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). | |
| virtual void | set_param (Param &) const |
Additional Inherited Members | |
| Static Public Member Functions inherited from MD_Vector_base | |
| static void | append_item_to_blocs (ArrOfInt &blocs, int item) |
| methode outil pour ajouter un item a un tableau du genre "blocs" contenant des series de blocs. | |
| 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 |
| Static Protected Member Functions inherited from MD_Vector_base | |
| static void | append_blocs (ArrOfInt &dest, const ArrOfInt &src, int offset=0, int multiplier=1) |
| static void | append_items (ArrOfInt &dest, const ArrOfInt &src, int offset=0, int multiplier=1) |
| Protected Attributes inherited from MD_Vector_mono | |
| ArrOfInt | blocs_items_to_sum_ |
| ArrOfInt | items_to_sum_ |
| ArrOfInt | blocs_items_to_compute_ |
| ArrOfInt | items_to_compute_ |
| Protected Attributes inherited from MD_Vector_base | |
| int | nb_items_tot_ = -1 |
| int | nb_items_reels_ = -1 |
| trustIdType | nb_items_seq_tot_ = -1 |
| int | nb_items_seq_local_ = -1 |
Dummy parallel descriptor used for sequential computations.
Its only useful information is the total number of items hold by the array which can be big (hence the use of trustIdType).
In this class, all the inherited counters accessors (get_nb_items*() methods, etc.) return this number. We however carefully check that the number of items fit within 32b since thoses inherited accessors return 'int'. No piece of code is actually using those methods in the 64b part of the execution (i.e. before Scatter).
Historically we used a MD_Vector_std for sequential computations too, and this std MD_Vector had a single block covering the whole array. But having a template version of the MD_Vector_std class (supporting both 32b and 64b) seemed unreasonable, hence the creation of the current class.
See arch.h.in for more explanations on 64b.
In this class, members inherited from MD_Vector_mono are meaningless and their information is not updated. Algorithm like get_sequential_items_flags() are actually overriden not to use this.
Definition at line 39 of file MD_Vector_seq.h.
|
inline |
Definition at line 45 of file MD_Vector_seq.h.
|
inline |
Definition at line 46 of file MD_Vector_seq.h.
|
overridevirtual |
Reimplemented from MD_Vector_mono.
Definition at line 73 of file MD_Vector_seq.cpp.
|
overridevirtual |
Implements MD_Vector_base.
Definition at line 79 of file MD_Vector_seq.cpp.
|
inline |
Definition at line 52 of file MD_Vector_seq.h.
|
overridevirtual |
Reimplemented from MD_Vector_base.
Definition at line 44 of file MD_Vector_seq.cpp.
|
overridevirtual |
Reimplemented from MD_Vector_base.
Definition at line 50 of file MD_Vector_seq.cpp.
|
overrideprotectedvirtual |
Reimplemented from MD_Vector_base.
Definition at line 63 of file MD_Vector_seq.cpp.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 65 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 69 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 73 of file MD_Vector_seq.h.
|
overridevirtual |
Reimplemented from MD_Vector_base.
Definition at line 56 of file MD_Vector_seq.cpp.
|
inlineoverridevirtual |
Reimplemented from MD_Vector_base.
Definition at line 61 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 66 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 70 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 74 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 67 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 71 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Implements MD_Vector_base.
Definition at line 75 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Whether algorithms in TRUSTVect_tools should use the blocks stored in members MD_Vector_mono::blocs_items_to_*
Implements MD_Vector_base.
Definition at line 86 of file MD_Vector_seq.h.
|
inlineoverridevirtual |
Check the consistency of array size as defined by the MD_Vector and as found in the array.
Reimplemented from MD_Vector_base.
Definition at line 55 of file MD_Vector_seq.h.