|
TRUST 1.9.8
HPC thermohydraulic platform
|
Terme source d'acceleration specialise pour la discretisation VDF. More...
#include <Terme_Source_Acceleration_VEF_Face.h>
Public Member Functions | |
| DoubleTab & | ajouter (DoubleTab &) const override |
| Ajoute le terme (la_source_ * rho * volume_entrelace) au champ resu. | |
| void | associer_champ_rho (const Champ_base &champ_rho) override |
| Associe le champ de masse volumique=> Le terme source calcule sera alors homogene a d/dt(integrale(rho*v)). | |
| Public Member Functions inherited from Terme_Source_Acceleration | |
| Terme_Source_Acceleration () | |
| void | associer_pb (const Probleme_base &) override |
| DoubleTab & | calculer (DoubleTab &) const override |
| resu=0; ajouter(resu); (appel a ajouter() de la classe derivee) | |
| int | a_pour_Champ_Fonc (const Motcle &mot, OBS_PTR(Champ_base) &ch_ref) const override |
| Methode surchargee de Source_base. | |
| const Champ_Don_base & | champ_vitesse () const |
| bool | has_champ_vitesse () const |
| const Champ_Don_base & | omega () const |
| bool | has_omega () const |
| Public Member Functions inherited from Source_base | |
| virtual void | resetTime (double t) |
| DOES NOTHING - to override in derived classes. | |
| virtual void | completer () |
| Met a jour les references internes a l'objet Source_base. | |
| virtual void | dimensionner (Matrice_Morse &) const |
| Dimensionnement de la matrice implicite des termes sources. | |
| virtual void | dimensionner_bloc_vitesse (Matrice_Morse &) const |
| virtual void | contribuer_a_avec (const DoubleTab &, Matrice_Morse &) const |
| contribution a la matrice implicite des termes sources par defaut pas de contribution | |
| virtual void | contribuer_au_second_membre (DoubleTab &) const |
| contribution au second membres des termes sources en implicite par defaut erreur | |
| virtual int | impr (Sortie &os) const |
| void | associer_domaines_public (const Domaine_dis_base &zdis, const Domaine_Cl_dis_base &zcldis) |
| virtual int | initialiser (double temps) |
| Contrairement aux methodes mettre_a_jour, les methodes initialiser des sources ne peuvent pas dependre de l'exterieur. | |
| virtual void | discretiser () |
| virtual void | contribuer_jacobienne (Matrice_Bloc &, int) const |
| virtual int | reprendre (Entree &) override |
| Reprise d'un Objet_U sur un flot d'entree Methode a surcharger. | |
| virtual int | sauvegarder (Sortie &) const override |
| Sauvegarde d'un Objet_U sur un flot de sortie Methode a surcharger. | |
| virtual int | has_interface_blocs () const |
| virtual void | dimensionner_blocs (matrices_t matrices, const tabs_t &semi_impl={ }) const |
| virtual void | ajouter_blocs (matrices_t matrices, DoubleTab &secmem, const tabs_t &semi_impl={ }) const |
| void | creer_champ (const Motcle &motlu) override |
| const Champ_base & | get_champ (const Motcle &nom) const override |
| bool | has_champ (const Motcle &nom, OBS_PTR(Champ_base) &ref_champ) const override |
| bool | has_champ (const Motcle &nom) const override |
| void | get_noms_champs_postraitables (Noms &nom, Option opt=NONE) const override |
| virtual void | ouvrir_fichier (SFichier &os, const Nom &, const int flag=1) const |
| Ouverture/creation d'un fichier d'impression d'un terme source A surcharger dans les classes derivees. | |
| void | set_fichier (const Nom &) |
| void | set_description (const Nom &nom) |
| void | set_col_names (const Noms &col_names) |
| const Nom | fichier () const |
| const Nom | description () const |
| DoubleVect & | bilan () |
| DoubleVect & | bilan () const |
| Champs_compris & | champs_compris () |
| const | LIST (OBS_PTR(Champ_Don_base)) &champs_don() const |
| Public Member Functions inherited from Champs_compris_interface | |
| virtual | ~Champs_compris_interface () |
| virtual bool | has_champ (const Motcle &nom, OBS_PTR(Champ_base)&ref_champ) const =0 |
| Public Member Functions inherited from MorEqn | |
| void | associer_eqn (const Equation_base &) |
| Associe une equation a l'objet. | |
| virtual void | calculer_pour_post (Champ_base &espace_stockage, const Nom &option, int comp) const |
| virtual Motcle | get_localisation_pour_post (const Nom &option) const |
| const Equation_base & | equation () const |
| Renvoie la reference sur l'equation pointe par MorEqn::mon_equation. | |
| Equation_base & | equation () |
| Renvoie la reference sur l'equation pointe par MorEqn::mon_equation. | |
| int | mon_equation_non_nul () const |
| virtual void | check_multiphase_compatibility () 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. | |
| 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 | |
| const DoubleTab & | calculer_vitesse_faces (DoubleTab &v_faces_stockage) const override |
| Calcul du champ de vitesse trois composantes aux faces a partir du champ de vitesse aux faces de eq_hydraulique_. | |
| void | associer_domaines (const Domaine_dis_base &, const Domaine_Cl_dis_base &) override |
| Methode appelee par Source_base::completer() apres associer_domaines Remplit les ref. | |
| Protected Member Functions inherited from Terme_Source_Acceleration | |
| virtual void | lire_data (Entree &s) |
| Methode appelee par readOn des classes derivees Terme_Source_Acceleration_VDF_Face, . | |
| virtual const Champ_Fonc_base & | get_terme_source_post () const |
| virtual Champ_Fonc_base & | get_set_terme_source_post () const |
| const DoubleTab & | calculer_la_source (DoubleTab &src_faces) const |
| Calcul de la valeur du champ la_source aux faces en fonction de - calculer_vitesse_faces(). | |
| virtual const Navier_Stokes_std & | get_eq_hydraulique () const |
| Renvoie eq_hydraulique_ ! | |
| void | mettre_a_jour (double temps) override |
| Evalue les champs d'acceleration et de rotation au temps t. | |
| Protected Member Functions inherited from Source_base | |
| LIST (OBS_PTR(Champ_Don_base)) champs_don_ | |
| Protected Member Functions inherited from MorEqn | |
| OBS_PTR (Equation_base) mon_equation | |
| virtual | ~MorEqn () |
| 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 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 Attributes inherited from Source_base | |
| int | col_width_ = 0 |
| Nom | out_ |
| Nom | description_ |
| Noms | col_names_ |
| DoubleVect | bilan_ |
| SFichier | Flux |
| Champs_compris | champs_compris_ |
Terme source d'acceleration specialise pour la discretisation VDF.
Definition at line 30 of file Terme_Source_Acceleration_VEF_Face.h.
|
overridevirtual |
Ajoute le terme (la_source_ * rho * volume_entrelace) au champ resu.
On suppose que resu est discretise comme la vitesse. L'espace virtuel de "resu" n'est PAS mis a jour !
Commentaire sur le schema: L'acceleration d/dt(v) est calculee aux elements, puis multipliee par "rho" aux elements, puis evaluee aux faces par une moyenne sur les elements voisins de la face. C'est un premier essai, pas forcement la meilleure idee. Comme l'acceleration depend de la vitesse qui est aux faces, on passe par deux interpolations successives. Effet de bord: On met (la_source_ * rho) dans terme_source_post_
Reimplemented from Source_base.
Definition at line 137 of file Terme_Source_Acceleration_VEF_Face.cpp.
|
overridevirtual |
Associe le champ de masse volumique=> Le terme source calcule sera alors homogene a d/dt(integrale(rho*v)).
| (champ_rho) | un champ de type Champ_Fonc_P0_VEF qui sera utilise lors des appels a "ajouter()" pour evaluer la masse volumique. |
Reimplemented from Source_base.
Definition at line 246 of file Terme_Source_Acceleration_VEF_Face.cpp.
|
overrideprotectedvirtual |
Methode appelee par Source_base::completer() apres associer_domaines Remplit les ref.
aux domaines et domaine_cl
Implements Source_base.
Definition at line 45 of file Terme_Source_Acceleration_VEF_Face.cpp.
|
overrideprotectedvirtual |
Calcul du champ de vitesse trois composantes aux faces a partir du champ de vitesse aux faces de eq_hydraulique_.
inconnue(). En VEF: rien a faire. On ne se sert pas du stockage fourni en parametre, on renvoie N.S.inconnue()
| (v_faces_stockage) | tableau ou stocker le resultat s'il y a des calculs a faire. En vef, on ne s'en sert pas |
Implements Terme_Source_Acceleration.
Definition at line 236 of file Terme_Source_Acceleration_VEF_Face.cpp.