16#include <Multi_Sch_ThHyd.h>
17#include <Probleme_base.h>
18#include <Navier_Stokes_std.h>
40 return std::max(sch_ns_->nb_valeurs_temporelles(),sch_scalaires_->nb_valeurs_temporelles());
50 int n=sch_ns_->nb_valeurs_futures();
51 assert (n==sch_scalaires_->nb_valeurs_futures());
62 double t=sch_ns_->temps_futur(i);
63 assert(t==sch_scalaires_->temps_futur(i));
74 double t=sch_ns_->temps_defaut();
75 assert(t==sch_scalaires_->temps_defaut());
146 sch_ns_->mettre_a_jour();
147 sch_scalaires_->mettre_a_jour();
152 param.
ajouter(
"nb_ss_pas_dt",&nb_ss_pas_dt_);
153 param.
ajouter(
"Schema_Temps_NS",&sch_ns_);
154 param.
ajouter(
"Schema_Temps_scalaires",&sch_scalaires_);
170 sch_ns_->faire_un_pas_de_temps_eqn_base(eqn);
177 sch_scalaires_->faire_un_pas_de_temps_eqn_base(eqn);
188 for(
int i=nb_eqn-1; i>-1; i--)
193 Cout<<
"====================================================" << finl;
194 Cout<< eqn_i.
que_suis_je()<<
" equation is not solved."<<finl;
195 Cout<<
"====================================================" << finl;
220 bool ok=sch_ns_->corriger_dt_calcule(dt);
221 ok = ok && sch_scalaires_->corriger_dt_calcule(dt);
233 sch_ns_->changer_temps_courant(t);
234 sch_scalaires_->changer_temps_courant(t);
251 int ls2 = sch_ns_->stop();
252 int ls3 = sch_scalaires_->stop();
263 sch_ns_->imprimer(os);
264 sch_scalaires_->imprimer(os);
DoubleTab & valeurs() override
Renvoie le tableau des valeurs du champ au temps courant.
virtual void mettre_a_jour(double temps)
Effectue une mise a jour en temps de toutes les conditions aux limites.
Class defining operators and methods for all reading operation in an input flow (file,...
classe Equation_base Le role d'une equation est le calcul d'un ou plusieurs champs....
virtual int equation_non_resolue() const
virtual const Champ_Inc_base & inconnue() const =0
virtual DoubleTab & derivee_en_temps_inco(DoubleTab &)
Returns the time derivative of the unknown I of the equation: dI/dt = M-1*(sum(operators(I) + sources...
virtual Domaine_Cl_dis_base & domaine_Cl_dis()
Renvoie le domaine des conditions aux limite discretisee associee a l'equation.
Schema_Temps_base & schema_temps()
Renvoie le schema en temps associe a l'equation.
int faire_un_pas_de_temps_eqn_base(Equation_base &) override
Effectue un pas de temps d'Euler explicite sur l'equation passee en parametre.
void completer() override
void imprimer(Sortie &) const override
Appel a l'objet sous-jacent Imprime le schema en temp sur un flot de sortie (si il y a lieu).
int nb_valeurs_futures() const override
Renvoie le nombre de valeurs temporelles futures.
int mettre_a_jour() override
Mise a jour du temps courant (t+=dt) et du nombre de pas de temps effectue (nb_pas_dt_++).
int stop() const override
Appel a l'objet sous-jacent Renvoie 1 si il y lieu de stopper le calcul pour differente raisons:
int nb_valeurs_temporelles() const override
Renvoie le nombre de valeurs temporelles a conserver.
void set_param(Param &titi) const override
bool iterateTimeStep(bool &converged) override
Calculate the U(n+1) unknown for each equation (if solved) of the problem with the selected time sche...
double temps_defaut() const override
Renvoie le le temps le temps que doivent rendre les champs a l'appel de valeurs().
bool corriger_dt_calcule(double &) const override
Corrige le pas de temps dt_min <= dt <= dt_max.
double temps_futur(int i) const override
Renvoie le le temps a la i-eme valeur future.
void changer_temps_courant(const double) override
Appel a l'objet sous-jacent Change le temps courant.
classe Navier_Stokes_std Cette classe porte les termes de l'equation de la dynamique
const Nom & que_suis_je() const
renvoie la chaine identifiant la classe.
virtual Entree & readOn(Entree &)
Lecture d'un Objet_U sur un flot d'entree Methode a surcharger.
virtual Sortie & printOn(Sortie &) const
Ecriture de l'objet sur un flot de sortie Methode a surcharger.
Helper class to factorize the readOn method of Objet_U classes.
void ajouter(const char *keyword, const int *value, Param::Nature nat=Param::OPTIONAL)
Register an integer parameter.
classe Probleme_base C'est un Probleme_U qui n'est pas un couplage.
virtual int nombre_d_equations() const =0
virtual const Equation_base & equation(int) const =0
int diffusion_implicite() const
Renvoie 1 si le schema en temps a ete lu diffusion_implicite.
bool & set_indice_nb_pas_dt_max_atteint()
int & set_stationnaire_atteint()
virtual bool isStationary() const
Retourne 1 si lors du dernier pas de temps, le probleme n'a pas evolue.
double temps_courant() const
Renvoie le temps courant.
double & set_temps_courant()
virtual bool corriger_dt_calcule(double &dt) const
Corrige le pas de temps calcule que l'on passe en parametre et verifie qu'il n'est pas "trop" petit (...
double temps_sauv() const
Renvoie une reference sur le temps de sauvegarde.
double temps_impr() const
Renvoie une reference sur le temps d'impression.
virtual void set_param(Param &titi) const override
double dt_
Pas de temps de calcul.
double pas_temps_max() const
Renvoie le pas de temps maximum.
double temps_max() const
Renvoie une reference sur le temps maximum.
virtual void changer_temps_courant(const double)
Change le temps courant.
int indice_tps_final_atteint() const
virtual int stop() const
Renvoie 1 si il y lieu de stopper le calcul pour differente raisons: - le temps final est atteint.
int & set_niter_max_diffusion_implicite()
Probleme_base & pb_base()
double pas_temps_min() const
Renvoie le pas de temps minimum.
int & set_diffusion_implicite()
double & set_temps_init()
double pas_de_temps() const
Renvoie le pas de temps (delta_t) courant.
double seuil_diffusion_implicite() const
virtual void imprimer(Sortie &os) const
Imprime le pas de temps sur un flot de sortie s'il y a lieu.
double seuil_statio() const
Renvoie une reference sur le seuil stationnaire.
int & set_nb_pas_dt_max()
int niter_max_diffusion_implicite() const
int nb_pas_dt() const
Renvoie le nombre de pas de temps effectues.
double mode_dt_start() const
double temps_init() const
Renvoie le temps initial.
double & set_seuil_statio()
virtual int mettre_a_jour()
Mise a jour du temps courant (t+=dt) et du nombre de pas de temps effectue (nb_pas_dt_++).
double & set_seuil_diffusion_implicite()
int indice_nb_pas_dt_max_atteint() const
bool & set_indice_tps_final_atteint()
int nb_pas_dt_max() const
Renvoie une reference sur le nombre de pas maxi.
double facteur_securite_pas() const
Renvoie le facteur de securite ou multiplicateur de delta_t.
double & set_mode_dt_start()
Classe de base des flux de sortie.