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

#include <Pb_Couple_Optimisation_IBM.h>

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

Public Member Functions

void initialize () override
 This method is called once at the beginning, before any other one of the interface Problem.
const Interpolation_IBM_basele_modele_interpolation_IBM () const
const Source_PDF_basela_source_PDF_IBM () const
const Source_PDF_basela_source_PDF_IBM_adjt () const
const Champ_Don_basele_champ_aire_IBM () const
const Champ_Don_basele_champ_rotation_IBM () const
double alpha () const
bool solveTimeStep () override
 pour recodage eventuel et appel unifie en python
void calcul_derivee_forme_IBM ()
bool initTimeStep (double) override
 This method allocates and initializes the unknown and given fields for the future time step.
Public Member Functions inherited from Probleme_Couple
bool initTimeStep (double dt) override
 This method allocates and initializes the unknown and given fields for the future time step.
double computeTimeStep (bool &stop) const override
 Compute the value the Problem would like for the next time step.
bool solveTimeStep () override
 pour recodage eventuel et appel unifie en python
bool iterateTimeStep (bool &converged) override
 In the case solveTimeStep uses an iterative process, this method executes a single iteration.
bool updateGivenFields () override
 ATTENTION :
void ajouter (Probleme_base &)
 Ajoute un probleme a la liste des problemes couples.
int associer_ (Objet_U &) override
 Surcharge Objet_U::associer_(Objet_U&) Associe un objet au probleme couple, en verifiant le type.
virtual void associer_sch_tps_base (Schema_Temps_base &)
 Associe une copie du schema en temps a chaque probleme du Probleme couple.
virtual const Schema_Temps_baseschema_temps () const
 Renvoie le schema en temps associe aux problemes couples.
virtual Schema_Temps_baseschema_temps ()
 Renvoie le schema en temps associe aux problemes couples.
virtual void discretiser (Discretisation_base &)
 Associe une discretisation a tous les problemes du probleme couple.
virtual void mettre_a_jour_modele_rayo (double temps)
void initialize () override
 This method is called once at the beginning, before any other one of the interface Problem.
void sauver () const override
 Sauvegarder l'etat du probleme sur disque.
Public Member Functions inherited from Couplage_U
void terminate () override
 This method is called once at the end, after any other one.
double presentTime () const override
 Returns the present time.
void validateTimeStep () override
 Validates the calculated unknown by moving the present time at the end of the time step.
bool isStationary () const override
 Tells if the Problem unknowns have changed during the last time step.
std::string newCompute () override
void setStationary (bool) override
 Tells to the Problem that stationary is reached or not.
void abortTimeStep () override
 Aborts the resolution of the current time step.
void resetTime (double t) override
 Reset the current time of the Problem to a given value.
void getInputFieldsNames (Noms &noms) const override
 This method is used to find the names of input fields understood by the Problem.
void getOutputFieldsNames (Noms &noms) const override
int postraiter (int force=1) override
 Demande au probleme de postraiter ses champs, sondes,.
int limpr () const override
 Doit-on imprimer les statistiques d'execution maintenant ?
int lsauv () const override
 Doit-on sauvegarder l'etat du probleme sur disque maintenant ?
double futureTime () const override
 Returns the future time (end of current computing interval) This value is valid between initTimeStep and either.
 OBS_PTR (Field_base) findInputField(const Nom &name) const override
 OBS_PTR (Champ_Generique_base) findOutputField(const Nom &name) const override
void suppProblem (Probleme_U &)
void addProblem (Probleme_U &)
int nb_problemes () const
const Probleme_Uprobleme (int i) const
Probleme_Uprobleme (int i)
const Probleme_Uprobleme (const Nom &nom_pb) const
Probleme_Uprobleme (const Nom &nom_pb)
int indice_probleme (const Nom &nom_pb) const
Public Member Functions inherited from Probleme_U
virtual void getInputFieldTemplate (const Nom &name, ICoCo::TrioField &afield) const
virtual void setInputField (const Nom &name, const ICoCo::TrioField &afield)
virtual void getOutputField (const Nom &nameField, ICoCo::TrioField &afield) const
virtual void setInputIntValue (const Nom &name, const int &val)
virtual int getOutputIntValue (const Nom &name) const
virtual bool checkOutputIntEntry (const Nom &name) const
virtual void getOutputPointValues (const Nom &name, const std::vector< double > &x, const std::vector< double > &y, const std::vector< double > &z, std::vector< double > &vals, int compo)
double getOutputPointValues (const Nom &name, const double x, const double y, const double z, int compo)
virtual void setInputDoubleValue (const Nom &name, const double val)
virtual void setInputStringValue (const std::string &name, const std::string &val)
virtual std::string getOutputStringValue (const std::string &name)
virtual void post_initialize ()
virtual bool run ()
 Cette methode est une sorte de main() du Problem Elle peut etre utilisee si le probleme n'est couple a aucun autre.
virtual bool runUntil (double time)
 This method has the same role as the method run, but it stops when reaching the time given in parameter.
void nommer (const Nom &name) override
 Donne un nom a l'Objet_U Methode virtuelle a surcharger.
const Nomle_nom () const override
 Donne le nom de l'Objet_U Methode a surcharger : renvoie "neant" dans cette implementation.
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 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 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.
const Interpreteinterprete () const
Interpreteinterprete ()
Public Member Functions inherited from Process
virtual ~Process ()

Protected Member Functions

void Save_Med_File_fonction_cout (DoubleTab &)
 OBS_PTR (Interpolation_IBM_base) my_interpolation_opt_
 OBS_PTR (Interpolation_IBM_base) my_interpolation_opt_adjt_
 OBS_PTR (Prepro_IBM_base) my_prepro_opt_
 OBS_PTR (Source_PDF_base) my_source_PDF_opt_
 OBS_PTR (Source_PDF_base) my_source_PDF_opt_adjt_
 OBS_PTR (Probleme_base) pb_etat_opt_
 OBS_PTR (Probleme_base) pb_adjt_opt_
 OBS_PTR (Probleme_base) pb_projection_opt_
 OWN_PTR (Champ_Don_base) source_derivee_forme_
 OWN_PTR (Champ_Don_base) normal_derivee_forme_
 OWN_PTR (Champ_Don_base) fonction_cout_lu_
Protected Member Functions inherited from Probleme_Couple
 VECT (OWN_PTR(Schema_Temps_base)) sch_clones
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).
virtual void set_param (Param &) const

Protected Attributes

Ecrire_MED ecr_med_fonction_cout_
int visu_cout_ = 0
 fonction_cout_
double alpha_ = 1.
double pond_shap_deriv_for_proj_ = 1.
int regul_PDF_shape_deriv_ = 0
int Numero_eq_optimis_ = -123
int Numero_src_deriv_form_ = -1
double modif_aire_pc_low_ = -1.0e+6
double modif_aire_pc_high_ = 1.0e+6
double area_ref_ = 0.
int area_ref_set_ =0
int nb_save_call_ = 0
Protected Attributes inherited from Probleme_Couple
ArrOfInt groupes
Protected Attributes inherited from Probleme_U
Nom nom_
ScalarRegister reg_
std::map< std::string, std::string > str_params_

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

Detailed Description

Definition at line 31 of file Pb_Couple_Optimisation_IBM.h.

Member Function Documentation

◆ alpha()

double Pb_Couple_Optimisation_IBM::alpha ( ) const
inline

Definition at line 42 of file Pb_Couple_Optimisation_IBM.h.

◆ calcul_derivee_forme_IBM()

void Pb_Couple_Optimisation_IBM::calcul_derivee_forme_IBM ( )

Definition at line 633 of file Pb_Couple_Optimisation_IBM.cpp.

◆ initialize()

void Pb_Couple_Optimisation_IBM::initialize ( )
overridevirtual

This method is called once at the beginning, before any other one of the interface Problem.

Exceptions
WrongContext

Reimplemented from Couplage_U.

Definition at line 180 of file Pb_Couple_Optimisation_IBM.cpp.

◆ initTimeStep()

bool Pb_Couple_Optimisation_IBM::initTimeStep ( double dt)
overridevirtual

This method allocates and initializes the unknown and given fields for the future time step.

The value of the interval is imposed through the parameter dt. In case of error, returns false.

Parameters
(doubledt) the time interval to allocate
Returns
(bool) true=OK, false=error, not able to tackle this dt
Exceptions
WrongContext,WrongArgument

Reimplemented from Couplage_U.

Definition at line 367 of file Pb_Couple_Optimisation_IBM.cpp.

◆ la_source_PDF_IBM()

const Source_PDF_base & Pb_Couple_Optimisation_IBM::la_source_PDF_IBM ( ) const
inline

Definition at line 38 of file Pb_Couple_Optimisation_IBM.h.

◆ la_source_PDF_IBM_adjt()

const Source_PDF_base & Pb_Couple_Optimisation_IBM::la_source_PDF_IBM_adjt ( ) const
inline

Definition at line 39 of file Pb_Couple_Optimisation_IBM.h.

◆ le_champ_aire_IBM()

const Champ_Don_base & Pb_Couple_Optimisation_IBM::le_champ_aire_IBM ( ) const
inline

Definition at line 40 of file Pb_Couple_Optimisation_IBM.h.

◆ le_champ_rotation_IBM()

const Champ_Don_base & Pb_Couple_Optimisation_IBM::le_champ_rotation_IBM ( ) const
inline

Definition at line 41 of file Pb_Couple_Optimisation_IBM.h.

◆ le_modele_interpolation_IBM()

const Interpolation_IBM_base & Pb_Couple_Optimisation_IBM::le_modele_interpolation_IBM ( ) const
inline

Definition at line 37 of file Pb_Couple_Optimisation_IBM.h.

◆ OBS_PTR() [1/8]

Pb_Couple_Optimisation_IBM::OBS_PTR ( Interpolation_IBM_base )
protected

◆ OBS_PTR() [2/8]

Pb_Couple_Optimisation_IBM::OBS_PTR ( Interpolation_IBM_base )
protected

◆ OBS_PTR() [3/8]

Pb_Couple_Optimisation_IBM::OBS_PTR ( Prepro_IBM_base )
protected

◆ OBS_PTR() [4/8]

Pb_Couple_Optimisation_IBM::OBS_PTR ( Probleme_base )
protected

◆ OBS_PTR() [5/8]

Pb_Couple_Optimisation_IBM::OBS_PTR ( Probleme_base )
protected

◆ OBS_PTR() [6/8]

Pb_Couple_Optimisation_IBM::OBS_PTR ( Probleme_base )
protected

◆ OBS_PTR() [7/8]

Pb_Couple_Optimisation_IBM::OBS_PTR ( Source_PDF_base )
protected

◆ OBS_PTR() [8/8]

Pb_Couple_Optimisation_IBM::OBS_PTR ( Source_PDF_base )
protected

◆ OWN_PTR() [1/3]

Pb_Couple_Optimisation_IBM::OWN_PTR ( Champ_Don_base )
protected

◆ OWN_PTR() [2/3]

Pb_Couple_Optimisation_IBM::OWN_PTR ( Champ_Don_base )
protected

◆ OWN_PTR() [3/3]

Pb_Couple_Optimisation_IBM::OWN_PTR ( Champ_Don_base )
protected

◆ Save_Med_File_fonction_cout()

void Pb_Couple_Optimisation_IBM::Save_Med_File_fonction_cout ( DoubleTab & fcout)
protected

Definition at line 850 of file Pb_Couple_Optimisation_IBM.cpp.

◆ solveTimeStep()

bool Pb_Couple_Optimisation_IBM::solveTimeStep ( )
overridevirtual

pour recodage eventuel et appel unifie en python

Reimplemented from Probleme_U.

Definition at line 586 of file Pb_Couple_Optimisation_IBM.cpp.

Member Data Documentation

◆ alpha_

double Pb_Couple_Optimisation_IBM::alpha_ = 1.
protected

Definition at line 63 of file Pb_Couple_Optimisation_IBM.h.

◆ area_ref_

double Pb_Couple_Optimisation_IBM::area_ref_ = 0.
protected

Definition at line 70 of file Pb_Couple_Optimisation_IBM.h.

◆ area_ref_set_

int Pb_Couple_Optimisation_IBM::area_ref_set_ =0
protected

Definition at line 71 of file Pb_Couple_Optimisation_IBM.h.

◆ ecr_med_fonction_cout_

Ecrire_MED Pb_Couple_Optimisation_IBM::ecr_med_fonction_cout_
protected

Definition at line 49 of file Pb_Couple_Optimisation_IBM.h.

◆ fonction_cout_

Pb_Couple_Optimisation_IBM::fonction_cout_
protected

Definition at line 62 of file Pb_Couple_Optimisation_IBM.h.

◆ modif_aire_pc_high_

double Pb_Couple_Optimisation_IBM::modif_aire_pc_high_ = 1.0e+6
protected

Definition at line 69 of file Pb_Couple_Optimisation_IBM.h.

◆ modif_aire_pc_low_

double Pb_Couple_Optimisation_IBM::modif_aire_pc_low_ = -1.0e+6
protected

Definition at line 68 of file Pb_Couple_Optimisation_IBM.h.

◆ nb_save_call_

int Pb_Couple_Optimisation_IBM::nb_save_call_ = 0
protected

Definition at line 72 of file Pb_Couple_Optimisation_IBM.h.

◆ Numero_eq_optimis_

int Pb_Couple_Optimisation_IBM::Numero_eq_optimis_ = -123
protected

Definition at line 66 of file Pb_Couple_Optimisation_IBM.h.

◆ Numero_src_deriv_form_

int Pb_Couple_Optimisation_IBM::Numero_src_deriv_form_ = -1
protected

Definition at line 67 of file Pb_Couple_Optimisation_IBM.h.

◆ pond_shap_deriv_for_proj_

double Pb_Couple_Optimisation_IBM::pond_shap_deriv_for_proj_ = 1.
protected

Definition at line 64 of file Pb_Couple_Optimisation_IBM.h.

◆ regul_PDF_shape_deriv_

int Pb_Couple_Optimisation_IBM::regul_PDF_shape_deriv_ = 0
protected

Definition at line 65 of file Pb_Couple_Optimisation_IBM.h.

◆ visu_cout_

int Pb_Couple_Optimisation_IBM::visu_cout_ = 0
protected

Definition at line 50 of file Pb_Couple_Optimisation_IBM.h.


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