3110 lines
188 KiB
C++
3110 lines
188 KiB
C++
|
|
||
|
// This file is part of the Herezh++ application.
|
||
|
//
|
||
|
// The finite element software Herezh++ is dedicated to the field
|
||
|
// of mechanics for large transformations of solid structures.
|
||
|
// It is developed by Gérard Rio (APP: IDDN.FR.010.0106078.000.R.P.2006.035.20600)
|
||
|
// INSTITUT DE RECHERCHE DUPUY DE LÔME (IRDL) <https://www.irdl.fr/>.
|
||
|
//
|
||
|
// Herezh++ is distributed under GPL 3 license ou ultérieure.
|
||
|
//
|
||
|
// Copyright (C) 1997-2021 Université Bretagne Sud (France)
|
||
|
// AUTHOR : Gérard Rio
|
||
|
// E-MAIL : gerardrio56@free.fr
|
||
|
//
|
||
|
// This program is free software: you can redistribute it and/or modify
|
||
|
// it under the terms of the GNU General Public License as published by
|
||
|
// the Free Software Foundation, either version 3 of the License,
|
||
|
// or (at your option) any later version.
|
||
|
//
|
||
|
// This program is distributed in the hope that it will be useful,
|
||
|
// but WITHOUT ANY WARRANTY; without even the implied warranty
|
||
|
// of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
||
|
// See the GNU General Public License for more details.
|
||
|
//
|
||
|
// You should have received a copy of the GNU General Public License
|
||
|
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||
|
//
|
||
|
// For more information, please consult: <https://herezh.irdl.fr/>.
|
||
|
|
||
|
// implantation de la classe ParaAlgoControle
|
||
|
|
||
|
#include <stdlib.h>
|
||
|
using namespace std; //introduces namespace std
|
||
|
#include <math.h>
|
||
|
|
||
|
#include "ParaAlgoControle.h"
|
||
|
#include "MotCle.h"
|
||
|
#include "ParaGlob.h"
|
||
|
#include "ConstMath.h"
|
||
|
#include "MathUtil.h"
|
||
|
#include "CharUtil.h"
|
||
|
|
||
|
// ================ paramètres static ======================
|
||
|
// valeur par défaut de coef_pas_critique_deltat, compliqué pour qu'il n'y est pas de doute d'égalité
|
||
|
double ParaAlgoControle::coef_defaut_pa_critique = 0.853247689523;
|
||
|
// pour le temps
|
||
|
VariablesTemps ParaAlgoControle::tempo; // init aux valeurs par défaut
|
||
|
|
||
|
//================= fin paramètres static ====================
|
||
|
|
||
|
// CONSTRUCTEUR
|
||
|
// par défaut
|
||
|
ParaAlgoControle::ParaAlgoControle() :
|
||
|
tempo_specifique_algo(),
|
||
|
// on initialise les listes par défaut
|
||
|
type_matrice_secondaire(),type_resolution_secondaire(),type_preconditionnement_secondaire()
|
||
|
,nb_iter_nondirecte_secondaire(),tolerance_secondaire(),nb_vect_restart_secondaire()
|
||
|
,opti_pointeur_assemblage(0)
|
||
|
|
||
|
{// on met les parametres a leurs valeurs par defaut
|
||
|
// 1) parametres de controle généraux pour la résolution de l'équilibre
|
||
|
// générale
|
||
|
sauvegarde = 1; // frequence de sauvegarde
|
||
|
cas_de_sauvegarde = 1; // cas de gestion de la fréquence de sauvegarde, par défaut sauvegarde
|
||
|
// indique le nombre d'incréments entre deux sauvegardes
|
||
|
tempo_specifique_algo.deltatmaxi = tempo.deltatmaxi = 1.; // increment de temps maxi
|
||
|
tempo_specifique_algo.deltatmini = tempo.deltatmini = 0.; // increment de temps mini
|
||
|
coef_pas_critique_deltatmaxi = 0.; // // coeff du pas critique pour deltatmaxi s'il existe
|
||
|
coef_pas_critique_deltatmini = -3333256794.; // // coeff du pas critique pour deltatmini s'il existe
|
||
|
typeDFC_pas_critique_deltatmaxi = true; // par défaut pas critique DFC
|
||
|
typeDFC_pas_critique_deltatmini = true; // par défaut pas critique DFC
|
||
|
|
||
|
iterations = 100; // maxi d'iteration pour converger
|
||
|
precision = 1.e-3; // precision de la convergence
|
||
|
tempo_specifique_algo.prectemps = tempo.prectemps = 1.E-12; // precision sur le temps final
|
||
|
norme.nom1 = "Residu/Reaction"; // type de norme de convergence
|
||
|
norme.nom2 = " "; // ne sert que si norme.nom1 = fonction_nD:
|
||
|
cinematique = false; // cinematique sur l'increment ?
|
||
|
conv_forcee = false; // convergence forcee ?
|
||
|
multiplicateur = 1.; // multiplicateur de la charge
|
||
|
tempo_specifique_algo.deltat = tempo.deltat = 1.; // increment de temps
|
||
|
force_deltat = false; // a priori on reprend le deltat sauvegardé au pas précédent
|
||
|
coef_pas_critique_deltat=coef_defaut_pa_critique; // coeff du pas critique pour deltat s'il existe
|
||
|
typeDFC_pas_critique_deltat = true; // par défaut pas critique DFC
|
||
|
tempo_specifique_algo.tempsfin = tempo.tempsfin = 1.; // temps de fin de calcul
|
||
|
maxincre = 400 ; // maximum d'increment de temps
|
||
|
max_essai_incre = maxincre; // maximum de tentative d'increment de temps permis
|
||
|
restart = 0; // increment de redemarage de calcul
|
||
|
max_puissance = 1.e10; // maximum de la puissance tolérée dans le calcul
|
||
|
line_search = false; // line_seach désactivée par défaut
|
||
|
var_charge_externe = true; // charge externe participe à la raideur
|
||
|
var_jacobien = false; // variation du jacobien dans le calcul de la raideur
|
||
|
var_D = false; // variation de la vitesse de déformation dans le calcul de la raideur
|
||
|
// on renseigne la class ParaGlob sur les variables temps
|
||
|
ParaGlob::Init_temps(tempo);
|
||
|
|
||
|
|
||
|
// 2) paramètres liés au systèmes d'équations linéaire
|
||
|
|
||
|
type_matrice = BANDE_SYMETRIQUE; // type de stockage matriciel
|
||
|
symetrie_matrice = true; // assemblage symétrique par défaut
|
||
|
type_resolution = CHOLESKY; // type de résolution
|
||
|
type_preconditionnement = DIAGONAL; // type de préconditionnement
|
||
|
nb_iter_nondirecte = 30; // nombre d'itération dans le cas d'une méthode itérative
|
||
|
tolerance = 1.e-7; // tolerance de convergence dans le cas d'une méthode itérative
|
||
|
nb_vect_restart = 32; // nombre de vecteur sauvegardé dans le cas d'une méthode
|
||
|
// itérative avec redépart
|
||
|
// pour les matrices secondaires éventuelles, aucune déclaration, car
|
||
|
// par défaut il n'y en a pas
|
||
|
|
||
|
// 3) paramètres liés au pilotage de l'équilibre global
|
||
|
type_de_pilotage = PILOTAGE_BASIQUE; // type de pilotage basique par défaut
|
||
|
facteur_diminution = sqrt(3.); // facteurs d'augmentation, ou de diminution
|
||
|
facteur_augmentation = sqrt(2.); // du paramètre de chargement
|
||
|
fact_dim_en_mauvaiseConv = 1.23; // facteurs de diminution après une mauvaise convergence
|
||
|
nb_bonne_convergence = 3; // nb de bonne convergence -> augmentation du deltatt
|
||
|
nb_iter_pour_bonne_convergence = 0.25 * iterations; // nb d'iter pour statuer sur la bonne convergence
|
||
|
nb_iter_pour_mauvaise_convergence = 0.5 * iterations; // nb d'iter pour statuer sur la bonne convergence
|
||
|
init_comp_tangent_simple = -1; // nb d'itération avec un comportement tangent simple
|
||
|
sur_sous_relaxation = 1.; // facteur de sur ou sous relaxation
|
||
|
norme_incre_max = ConstMath::tresgrand; // limitation de l'incrément maxi des ddl
|
||
|
// pour les deux lignes qui suivent, ne pas bouger le maxi (==ConstMath::tresgrand) car
|
||
|
// il sert à savoir si les limitations sont actives c-a-d modifié par l'utilisateur
|
||
|
norme_incre_X_max = ConstMath::tresgrand; // limitation de l'incrément maxi des ddl de déplacement
|
||
|
norme_incre_V_max = ConstMath::tresgrand; // limitation de l'incrément maxi des ddl de vitesse
|
||
|
//
|
||
|
varMiniDdl = 0.; // limite mini en dessous de laquelle on considère qu'il n'y a pas convergence
|
||
|
varMaxiDdl = ConstMath::tresgrand; // idem en maxi
|
||
|
nbCycleControleResidu = 3; // entre combien d'iter on compare le max résidu
|
||
|
plageControleResidu = 3; // combien de fois il faut que le test soit négatif pour la non convergence
|
||
|
initIncreAvecDeltaDdlPrec = 1.; // initialisation de l'incrément avec l'incrément du pas précédent
|
||
|
jabobien_negatif = 1; // traitement du cas des jacobiens négatifs
|
||
|
var_maxi_jacobien = 0; // variation maxi autorisée du jacobien, si <= 1 pas pris en compte
|
||
|
cas_fctnD_charge = 0; // traitement d'un retour de fct nD problématique: dans le chargement
|
||
|
|
||
|
// 4) paramètres liès à la dynamique
|
||
|
type_calcul_masse = MASSE_DIAG_COEF_EGAUX; // type de calcul de la masse
|
||
|
// le type de stockage de la masse utilisée est celui de type_matrice
|
||
|
// qui est utilisé uniquement lorque la matrice masse n'est pas diagonale`
|
||
|
limitation_temps_maxi_stable = true; // booléen qui indique si la limitation supérieur
|
||
|
// du temps pour satisfaire la stabilité, est active ou pas
|
||
|
amort_visco_arti = 0; // indique si l'on inclut automatiquement un amortissement visqueux artificiel
|
||
|
visco_arti = 0.01; // valeur de la viscosité dynamique
|
||
|
maxi_C_en_fonction_M = 10000; // coef tel que: maxi C = maxi_C_en_fonction_M * M (cas de C critique)
|
||
|
coef_rayleigh_masse = 1.; // coeffs de rayleigh sur la masse pour la construction de [C]
|
||
|
coef_rayleigh_raideur = 0.; // coeffs de rayleigh sur la raideur pour la construction de [C]
|
||
|
// cas du bulk viscosity
|
||
|
bulk_viscosity = 0; // indique si oui ou non on utilise le bulk viscosity
|
||
|
c_Tracebulk = 1.5; // coefficient de la trace de D
|
||
|
c_Trace2bulk = 0.06; // coefficient du carré de la trace de D
|
||
|
|
||
|
// 5) paramètres liès à l'affichage des résultats
|
||
|
frequence_affichage_increment = 1; // fréquence sur les increments de l'affichage des résultats
|
||
|
frequence_affichage_iteration = 1; // fréquence sur les itération de l'affichage des résultats
|
||
|
sortie_fil_calcul = -1000000; // fréquence sur les incréments, pour la sortie au fil du calcul
|
||
|
cas_de_sortie_fil_calcul = 1; // par défaut le paramètre sortie_fil_calcul = un delta incrément
|
||
|
// nombre de chiffre significatifs utilisé pour l'affichage des double précision: le premier pour
|
||
|
// l'archivage du calcul le secon pour la visualisation graphique
|
||
|
nb_diggit_double_calcul = 17;
|
||
|
nb_diggit_double_graphique = 12;
|
||
|
nb_diggit_double_ecran= 8;
|
||
|
// 6) paramètres liès au contact
|
||
|
prec_pt_int_deb = 1.e-6; // précision du test: point intérieur ?, avant le début des calculs
|
||
|
factPourRayonAccostage = 1.; // facteur multiplicatif du déplacement maxi entre t et tdt, donnant
|
||
|
// distance maxi admissible entre le point et le point projeté
|
||
|
distanceMaxiAuPtProjete = ConstMath::grand; // a priori grand, est ensuite éventuellement géré par l'entrée des données
|
||
|
extra_boite_prelocalisation = 1.05; // donne la proportion de plus que l'on prend pour les boites
|
||
|
mini_extra_boite_prelocalisation = 0.001; // permet le calcul de la bande mini autour de la boite
|
||
|
ajout_extra_boite_prelocalisation = 0.; // ajout dans toutes les directions à la boite
|
||
|
contact_type = 0; // a priori il n'y a pas de contact de prélocalisation d'élément
|
||
|
fct_nD_bascul_contact_type_4="_"; // a priori pas de fonction nD
|
||
|
|
||
|
penalisationPenetration = 0.1; // facteur pour le calcul du facteur de pénalisation pour la pénétration
|
||
|
fct_nD_penalisationPenetration="_"; // pas de fonction par défaut
|
||
|
|
||
|
typePenalisationPenetration = 2; // par défaut le calcul est celui de ls-dyna avec la compressibilité du maître
|
||
|
penetration_contact_maxi = 0.1; // par défaut on met 1/10 de penetration,
|
||
|
fct_nD_penetration_contact_maxi="_"; // pas de fonction par défaut
|
||
|
|
||
|
penetration_borne_regularisation = ConstMath::tresgrand; // par défaut n'intervient pas
|
||
|
fct_nD_penetration_borne_regularisation="_"; // pas de fonction par défaut
|
||
|
|
||
|
force_contact_noeud_maxi = ConstMath::tresgrand; // borne maxi pour la force de réaction du noeud ,
|
||
|
fct_nD_force_contact_noeud_maxi="_"; // pas de fonction par défaut
|
||
|
|
||
|
penalisationTangentielle = 1.e6; // facteur de pénalisation pour le déplacement tangentiel
|
||
|
fct_nD_penalisationTangentielle="_"; // pas de fonction par défaut
|
||
|
|
||
|
typePenalisationTangentielle = 2; // indique le type de calcul pour la pénalisation pour le dep tangentiel
|
||
|
tangentielle_contact_maxi = 0.1; // indique une borne maxi de dep tangentiel (dont l'utilisation dépend de l'algo)
|
||
|
fct_nD_tangentielle_contact_maxi="_"; // pas de fonction par défaut
|
||
|
|
||
|
tangentielle_borne_regularisation = ConstMath::tresgrand;// par défaut n'intervient pas
|
||
|
fct_nD_tangentielle_borne_regularisation="_"; // pas de fonction par défaut
|
||
|
|
||
|
force_tangentielle_noeud_maxi = ConstMath::tresgrand;; // indique une borne maxi pour la force tangentielle
|
||
|
fct_nD_force_tangentielle_noeud_maxi="_"; // pas de fonction par défaut
|
||
|
|
||
|
prec_pt_sur_frontiere = 1.e-4; // précision de positionnement sur les X^ar d'un pt en contact sur une frontière
|
||
|
nb_boucle_newton_position_frontiere = 10; // nb de boucle maxi pour la recherche du positionnement du pt en contact
|
||
|
nbDecolAutorise = 1; // nb de fois un noeud décolle pour n'être plus considéré en contact
|
||
|
typeDeDecolement = 0; // type par défaut sur la réaction
|
||
|
nb_glissant = 1; // par défaut il n'y a pas de moyenne glissante
|
||
|
niveau_commentaire_contact = 0; // par défaut c'est le général qui commande
|
||
|
optimisation_numerotation = 0; // par défaut pas d'optimisation
|
||
|
|
||
|
// 7) paramètres liés aux calculs des énergies
|
||
|
nb_incr_cal_ener=1; // donne l'incrément mini, à partir duquel on calcul les énergie cumulée
|
||
|
affiche_incr_energie=false; // affichage oui ou non de l'énergie et du bilan sur l'incrément
|
||
|
// 8) paramètres liés aux calculs géométriques sur les éléments
|
||
|
point_interne_delta_thetai_maxi = 1.e-4; // coordonnée thetai ok si delta thetai < à la prec
|
||
|
point_interne_prec_thetai_interne = 1.e-6; // precision sur thetai sur le test du point interne
|
||
|
point_interne_nb_boucle_sur_delta_thetai = 10; // maxi boucle de Newton sur la recherche des thetai
|
||
|
point_interne_nb_externe = 3; //nb max de test positif "externe" pour statuer un point externe
|
||
|
cal_vol_total_entre_surface_et_plans_ref = false; // par défaut il n'y a pas de calcul de ces volumes
|
||
|
ratio_maxi_jacoMembrane_jacoPti = 200.; //rapport maxi autorisé entre le jacobien de la facette centrale
|
||
|
// et le jacobien au pti pour les éléments coques
|
||
|
type_calnum_inversion_metrique = CRAMER; // méthode historique
|
||
|
|
||
|
//------------ gestion de certaines interruptions systèmes ---------
|
||
|
// ces variables ne sont pas sauvegardées, elles sont accessibles de partout pour un projet donné
|
||
|
// on se sert de ParaAlgoControle pour le stockage, l'accès et la modification
|
||
|
sortieEquilibreGlobal=false; // par défaut
|
||
|
sortieEtatActuelDansBI=false; // par défaut
|
||
|
sortieEtatActuelDansCVisu = false; // par défaut
|
||
|
|
||
|
};
|
||
|
|
||
|
// de copie
|
||
|
ParaAlgoControle::ParaAlgoControle(const ParaAlgoControle& p) :
|
||
|
sauvegarde(p.sauvegarde),cas_de_sauvegarde(p.cas_de_sauvegarde),
|
||
|
tempo_specifique_algo(p.tempo_specifique_algo),
|
||
|
force_deltat(p.force_deltat),
|
||
|
coef_pas_critique_deltatmaxi(p.coef_pas_critique_deltatmaxi),
|
||
|
coef_pas_critique_deltatmini(p.coef_pas_critique_deltatmini),
|
||
|
typeDFC_pas_critique_deltatmaxi(p.typeDFC_pas_critique_deltatmaxi),
|
||
|
typeDFC_pas_critique_deltatmini(p.typeDFC_pas_critique_deltatmini),
|
||
|
iterations(p.iterations), precision(p.precision),
|
||
|
norme(p.norme),//prectemps(p.prectemps),
|
||
|
cinematique(p.cinematique),conv_forcee(p.conv_forcee),
|
||
|
multiplicateur(p.multiplicateur),//deltat(p.deltat),
|
||
|
coef_pas_critique_deltat(p.coef_pas_critique_deltat),
|
||
|
typeDFC_pas_critique_deltat(p.typeDFC_pas_critique_deltat),
|
||
|
maxincre(p.maxincre),//tempsfin(p.tempsfin),
|
||
|
max_essai_incre(p.max_essai_incre),
|
||
|
restart(p.restart),max_puissance(p.max_puissance),
|
||
|
line_search(p.line_search),var_charge_externe(p.var_charge_externe),
|
||
|
var_jacobien(p.var_jacobien),var_D(p.var_D),
|
||
|
type_matrice(p.type_matrice),symetrie_matrice(p.symetrie_matrice),
|
||
|
type_resolution(p.type_resolution),
|
||
|
type_preconditionnement(p.type_preconditionnement),
|
||
|
nb_iter_nondirecte(p.nb_iter_nondirecte),
|
||
|
tolerance(p.tolerance),nb_vect_restart(p.nb_vect_restart),
|
||
|
type_matrice_secondaire(p.type_matrice_secondaire),
|
||
|
type_resolution_secondaire(p.type_resolution_secondaire),
|
||
|
type_preconditionnement_secondaire(p.type_preconditionnement_secondaire),
|
||
|
nb_iter_nondirecte_secondaire(p.nb_iter_nondirecte_secondaire),
|
||
|
tolerance_secondaire(p.tolerance_secondaire),nb_vect_restart_secondaire(p.nb_vect_restart_secondaire),
|
||
|
opti_pointeur_assemblage(p.opti_pointeur_assemblage),
|
||
|
type_de_pilotage(p.type_de_pilotage),facteur_diminution(p.facteur_diminution),
|
||
|
facteur_augmentation(p.facteur_augmentation),fact_dim_en_mauvaiseConv(p.fact_dim_en_mauvaiseConv),
|
||
|
nb_bonne_convergence(p.nb_bonne_convergence),
|
||
|
nb_iter_pour_bonne_convergence(p.nb_iter_pour_bonne_convergence),
|
||
|
nb_iter_pour_mauvaise_convergence(p.nb_iter_pour_mauvaise_convergence),
|
||
|
init_comp_tangent_simple(p.init_comp_tangent_simple),
|
||
|
norme_incre_max(p.norme_incre_max),norme_incre_X_max(p.norme_incre_X_max),
|
||
|
norme_incre_V_max(p.norme_incre_V_max),
|
||
|
varMiniDdl(p.varMiniDdl),varMaxiDdl(p.varMaxiDdl),
|
||
|
nbCycleControleResidu(p.nbCycleControleResidu),plageControleResidu(p.plageControleResidu),
|
||
|
sur_sous_relaxation(p.sur_sous_relaxation),initIncreAvecDeltaDdlPrec(p.initIncreAvecDeltaDdlPrec),
|
||
|
jabobien_negatif(p.jabobien_negatif),var_maxi_jacobien(p.var_maxi_jacobien),
|
||
|
cas_fctnD_charge(p.cas_fctnD_charge),
|
||
|
type_calcul_masse(p.type_calcul_masse),
|
||
|
limitation_temps_maxi_stable(p.limitation_temps_maxi_stable),
|
||
|
amort_visco_arti(p.amort_visco_arti),visco_arti(p.visco_arti),
|
||
|
maxi_C_en_fonction_M(p.maxi_C_en_fonction_M),
|
||
|
coef_rayleigh_masse(p.coef_rayleigh_masse),coef_rayleigh_raideur(p.coef_rayleigh_raideur),
|
||
|
bulk_viscosity(p.bulk_viscosity),c_Tracebulk(p.c_Tracebulk),c_Trace2bulk(p.c_Trace2bulk),
|
||
|
frequence_affichage_increment(p.frequence_affichage_increment),
|
||
|
frequence_affichage_iteration(p.frequence_affichage_iteration),
|
||
|
sortie_fil_calcul(p.sortie_fil_calcul),
|
||
|
cas_de_sortie_fil_calcul(p.cas_de_sortie_fil_calcul),
|
||
|
nb_diggit_double_calcul(p.nb_diggit_double_calcul),
|
||
|
nb_diggit_double_graphique(p.nb_diggit_double_graphique),
|
||
|
nb_diggit_double_ecran(p.nb_diggit_double_ecran),
|
||
|
nb_incr_cal_ener(p.nb_incr_cal_ener),
|
||
|
affiche_incr_energie(p.affiche_incr_energie),
|
||
|
prec_pt_int_deb(p.prec_pt_int_deb),factPourRayonAccostage(p.factPourRayonAccostage),
|
||
|
distanceMaxiAuPtProjete(p.distanceMaxiAuPtProjete),
|
||
|
extra_boite_prelocalisation(p.extra_boite_prelocalisation),
|
||
|
mini_extra_boite_prelocalisation(p.mini_extra_boite_prelocalisation),
|
||
|
ajout_extra_boite_prelocalisation(p.ajout_extra_boite_prelocalisation),
|
||
|
contact_type(p.contact_type),prec_pt_sur_frontiere(p.prec_pt_sur_frontiere),
|
||
|
fct_nD_bascul_contact_type_4(p.fct_nD_bascul_contact_type_4),
|
||
|
penalisationPenetration(p.penalisationPenetration),
|
||
|
fct_nD_penalisationPenetration(p.fct_nD_penalisationPenetration),
|
||
|
penalisationTangentielle(p.penalisationTangentielle),
|
||
|
fct_nD_penalisationTangentielle(p.fct_nD_penalisationTangentielle),
|
||
|
typePenalisationPenetration(p.typePenalisationPenetration),
|
||
|
penetration_contact_maxi(p.penetration_contact_maxi),
|
||
|
fct_nD_penetration_contact_maxi(p.fct_nD_penetration_contact_maxi),
|
||
|
penetration_borne_regularisation(p.penetration_borne_regularisation),
|
||
|
fct_nD_penetration_borne_regularisation(p.fct_nD_penetration_borne_regularisation),
|
||
|
force_contact_noeud_maxi(p.force_contact_noeud_maxi),
|
||
|
fct_nD_force_contact_noeud_maxi(p.fct_nD_force_contact_noeud_maxi),
|
||
|
typePenalisationTangentielle(p.typePenalisationTangentielle),
|
||
|
tangentielle_contact_maxi(p.tangentielle_contact_maxi),
|
||
|
fct_nD_tangentielle_contact_maxi(p.fct_nD_tangentielle_contact_maxi),
|
||
|
tangentielle_borne_regularisation(p.tangentielle_borne_regularisation),
|
||
|
fct_nD_tangentielle_borne_regularisation(p.fct_nD_tangentielle_borne_regularisation),
|
||
|
force_tangentielle_noeud_maxi(p.force_tangentielle_noeud_maxi),
|
||
|
fct_nD_force_tangentielle_noeud_maxi(p.fct_nD_force_tangentielle_noeud_maxi),
|
||
|
nb_boucle_newton_position_frontiere(p.nb_boucle_newton_position_frontiere),
|
||
|
nbDecolAutorise(p.nbDecolAutorise),typeDeDecolement(p.typeDeDecolement),nb_glissant(p.nb_glissant),
|
||
|
niveau_commentaire_contact(p.niveau_commentaire_contact),
|
||
|
optimisation_numerotation(p.optimisation_numerotation),
|
||
|
point_interne_delta_thetai_maxi(p.point_interne_delta_thetai_maxi),
|
||
|
point_interne_prec_thetai_interne(p.point_interne_prec_thetai_interne),
|
||
|
point_interne_nb_boucle_sur_delta_thetai(p.point_interne_nb_boucle_sur_delta_thetai),
|
||
|
point_interne_nb_externe(p.point_interne_nb_externe),
|
||
|
cal_vol_total_entre_surface_et_plans_ref(p.cal_vol_total_entre_surface_et_plans_ref),
|
||
|
ratio_maxi_jacoMembrane_jacoPti(p.ratio_maxi_jacoMembrane_jacoPti),
|
||
|
type_calnum_inversion_metrique(p.type_calnum_inversion_metrique),
|
||
|
sortieEquilibreGlobal(p.sortieEquilibreGlobal),
|
||
|
sortieEtatActuelDansBI(p.sortieEtatActuelDansBI),
|
||
|
sortieEtatActuelDansCVisu(p.sortieEtatActuelDansCVisu)
|
||
|
{// pas de recopie des paramètre prec_pt_int_deb,extra_boite_prelocalisation car ils sont statics
|
||
|
// ParaGlob::Init_temps(tempo); // pas la peine car c'est une variable statique
|
||
|
};
|
||
|
|
||
|
// Surcharge de l'affectation
|
||
|
ParaAlgoControle& ParaAlgoControle::operator= (const ParaAlgoControle& p)
|
||
|
{ sauvegarde = p.sauvegarde; cas_de_sauvegarde = p.cas_de_sauvegarde;
|
||
|
tempo_specifique_algo = p.tempo_specifique_algo;
|
||
|
force_deltat = p.force_deltat;
|
||
|
coef_pas_critique_deltatmaxi = p.coef_pas_critique_deltatmaxi;
|
||
|
coef_pas_critique_deltatmini = p.coef_pas_critique_deltatmini;
|
||
|
typeDFC_pas_critique_deltatmaxi = p.typeDFC_pas_critique_deltatmaxi;
|
||
|
typeDFC_pas_critique_deltatmini = p.typeDFC_pas_critique_deltatmini;
|
||
|
iterations = p.iterations; precision = p.precision;
|
||
|
norme = p.norme; //prectemps = p.prectemps;
|
||
|
cinematique = p.cinematique; conv_forcee = p.conv_forcee;
|
||
|
multiplicateur = p.multiplicateur; //deltat = p.deltat;
|
||
|
coef_pas_critique_deltat = p.coef_pas_critique_deltat;
|
||
|
typeDFC_pas_critique_deltat = p.typeDFC_pas_critique_deltat;
|
||
|
maxincre = p.maxincre; //tempsfin = p.tempsfin;
|
||
|
max_essai_incre = p.max_essai_incre;
|
||
|
restart = p.restart; max_puissance = p.max_puissance;
|
||
|
line_search = p.line_search; var_charge_externe = p.var_charge_externe;
|
||
|
var_jacobien = p.var_jacobien; var_D = p.var_D;
|
||
|
type_matrice = p.type_matrice; symetrie_matrice = p.symetrie_matrice;
|
||
|
type_resolution = p.type_resolution;
|
||
|
type_preconditionnement = p.type_preconditionnement;
|
||
|
nb_iter_nondirecte = p.nb_iter_nondirecte;
|
||
|
tolerance = p.tolerance; nb_vect_restart = p.nb_vect_restart;
|
||
|
type_matrice_secondaire = p.type_matrice_secondaire;
|
||
|
type_resolution_secondaire = p.type_resolution_secondaire;
|
||
|
type_preconditionnement_secondaire = p.type_preconditionnement_secondaire;
|
||
|
nb_iter_nondirecte_secondaire = p.nb_iter_nondirecte_secondaire;
|
||
|
tolerance_secondaire = p.tolerance_secondaire; nb_vect_restart_secondaire = p.nb_vect_restart_secondaire;
|
||
|
opti_pointeur_assemblage = p.opti_pointeur_assemblage;
|
||
|
type_de_pilotage = p.type_de_pilotage; facteur_diminution = p.facteur_diminution;
|
||
|
facteur_augmentation = p.facteur_augmentation; fact_dim_en_mauvaiseConv = p.fact_dim_en_mauvaiseConv;
|
||
|
nb_bonne_convergence = p.nb_bonne_convergence;
|
||
|
nb_iter_pour_bonne_convergence = p.nb_iter_pour_bonne_convergence;
|
||
|
nb_iter_pour_mauvaise_convergence = p.nb_iter_pour_mauvaise_convergence;
|
||
|
init_comp_tangent_simple = p.init_comp_tangent_simple;
|
||
|
norme_incre_max = p.norme_incre_max; norme_incre_X_max = p.norme_incre_X_max;
|
||
|
norme_incre_V_max = p.norme_incre_V_max;
|
||
|
varMiniDdl = p.varMiniDdl; varMaxiDdl = p.varMaxiDdl;
|
||
|
nbCycleControleResidu = p.nbCycleControleResidu; plageControleResidu = p.plageControleResidu;
|
||
|
sur_sous_relaxation = p.sur_sous_relaxation; initIncreAvecDeltaDdlPrec = p.initIncreAvecDeltaDdlPrec;
|
||
|
jabobien_negatif = p.jabobien_negatif; var_maxi_jacobien = p.var_maxi_jacobien;
|
||
|
cas_fctnD_charge = p.cas_fctnD_charge;
|
||
|
type_calcul_masse = p.type_calcul_masse;
|
||
|
limitation_temps_maxi_stable = p.limitation_temps_maxi_stable;
|
||
|
amort_visco_arti = p.amort_visco_arti; visco_arti = p.visco_arti;
|
||
|
maxi_C_en_fonction_M = p.maxi_C_en_fonction_M;
|
||
|
coef_rayleigh_masse = p.coef_rayleigh_masse; coef_rayleigh_raideur = p.coef_rayleigh_raideur;
|
||
|
bulk_viscosity = p.bulk_viscosity; c_Tracebulk = p.c_Tracebulk; c_Trace2bulk = p.c_Trace2bulk;
|
||
|
frequence_affichage_increment = p.frequence_affichage_increment;
|
||
|
frequence_affichage_iteration = p.frequence_affichage_iteration;
|
||
|
sortie_fil_calcul = p.sortie_fil_calcul;
|
||
|
cas_de_sortie_fil_calcul = p.cas_de_sortie_fil_calcul;
|
||
|
nb_diggit_double_calcul = p.nb_diggit_double_calcul;
|
||
|
nb_diggit_double_graphique = p.nb_diggit_double_graphique;
|
||
|
nb_diggit_double_ecran = p.nb_diggit_double_ecran;
|
||
|
nb_incr_cal_ener = p.nb_incr_cal_ener;
|
||
|
affiche_incr_energie = p.affiche_incr_energie;
|
||
|
prec_pt_int_deb = p.prec_pt_int_deb; factPourRayonAccostage = p.factPourRayonAccostage;
|
||
|
distanceMaxiAuPtProjete = p.distanceMaxiAuPtProjete;
|
||
|
extra_boite_prelocalisation = p.extra_boite_prelocalisation;
|
||
|
mini_extra_boite_prelocalisation = p.mini_extra_boite_prelocalisation;
|
||
|
ajout_extra_boite_prelocalisation = p.ajout_extra_boite_prelocalisation;
|
||
|
contact_type = p.contact_type; prec_pt_sur_frontiere = p.prec_pt_sur_frontiere;
|
||
|
fct_nD_bascul_contact_type_4 = p.fct_nD_bascul_contact_type_4;
|
||
|
penalisationPenetration = p.penalisationPenetration;
|
||
|
fct_nD_penalisationPenetration = p.fct_nD_penalisationPenetration;
|
||
|
|
||
|
penalisationTangentielle = p.penalisationTangentielle;
|
||
|
fct_nD_penalisationPenetration = p.fct_nD_penalisationPenetration;
|
||
|
|
||
|
typePenalisationPenetration = p.typePenalisationPenetration;
|
||
|
penetration_contact_maxi = p.penetration_contact_maxi;
|
||
|
fct_nD_penetration_contact_maxi = p.fct_nD_penetration_contact_maxi;
|
||
|
|
||
|
penetration_borne_regularisation = p.penetration_borne_regularisation;
|
||
|
fct_nD_penetration_borne_regularisation = p.fct_nD_penetration_borne_regularisation;
|
||
|
|
||
|
force_contact_noeud_maxi = p.force_contact_noeud_maxi;
|
||
|
fct_nD_force_contact_noeud_maxi = p.fct_nD_force_contact_noeud_maxi;
|
||
|
|
||
|
typePenalisationTangentielle = p.typePenalisationTangentielle;
|
||
|
tangentielle_contact_maxi = p.tangentielle_contact_maxi;
|
||
|
fct_nD_tangentielle_contact_maxi = p.fct_nD_tangentielle_contact_maxi;
|
||
|
|
||
|
tangentielle_borne_regularisation = p.tangentielle_borne_regularisation;
|
||
|
fct_nD_tangentielle_borne_regularisation = p.fct_nD_tangentielle_borne_regularisation;
|
||
|
|
||
|
force_tangentielle_noeud_maxi = p.force_tangentielle_noeud_maxi;
|
||
|
fct_nD_force_tangentielle_noeud_maxi = p.fct_nD_force_tangentielle_noeud_maxi;
|
||
|
|
||
|
nb_boucle_newton_position_frontiere = p.nb_boucle_newton_position_frontiere;
|
||
|
nbDecolAutorise = p.nbDecolAutorise; typeDeDecolement = p.typeDeDecolement; nb_glissant = p.nb_glissant;
|
||
|
niveau_commentaire_contact = p.niveau_commentaire_contact;
|
||
|
optimisation_numerotation = p.optimisation_numerotation;
|
||
|
point_interne_delta_thetai_maxi = p.point_interne_delta_thetai_maxi;
|
||
|
point_interne_prec_thetai_interne = p.point_interne_prec_thetai_interne;
|
||
|
point_interne_nb_boucle_sur_delta_thetai = p.point_interne_nb_boucle_sur_delta_thetai;
|
||
|
point_interne_nb_externe = p.point_interne_nb_externe;
|
||
|
cal_vol_total_entre_surface_et_plans_ref = p.cal_vol_total_entre_surface_et_plans_ref;
|
||
|
ratio_maxi_jacoMembrane_jacoPti = p.ratio_maxi_jacoMembrane_jacoPti;
|
||
|
type_calnum_inversion_metrique = p.type_calnum_inversion_metrique;
|
||
|
sortieEquilibreGlobal = p.sortieEquilibreGlobal;
|
||
|
sortieEtatActuelDansBI = p.sortieEtatActuelDansBI;
|
||
|
sortieEtatActuelDansCVisu = p.sortieEtatActuelDansCVisu;
|
||
|
|
||
|
return *this;
|
||
|
};
|
||
|
|
||
|
|
||
|
// Méthodes publiques
|
||
|
void ParaAlgoControle::Lecture_paraAlgoControle(UtilLecture & entreePrinc)
|
||
|
{ if (ParaGlob::NiveauImpression() > 5)
|
||
|
cout << " debut de la lecture des parametres " << endl;
|
||
|
MotCle motCle; // ref aux mots cle
|
||
|
// on se positionne sur un mot cle
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
// def de variable logique disant si oui ou non il y a eu lecture d'un type de paramètre
|
||
|
bool controle_lec=false; bool para_systeme_lineaire_lec = false;
|
||
|
bool para_pilotage_equi_global_lec = false; bool para_dedies_dynamique_lec = false;
|
||
|
bool para_affichage_lec = false;bool para_contact_lec = false; bool para_energie_lec = false;
|
||
|
bool para_calculs_geometriques_lec = false; bool lecture_max_essai_incre = false;
|
||
|
// on lit tant qu'il s'agit d'un mot clé concernant les paramètres de contrôle
|
||
|
while ((strstr(entreePrinc.tablcar,"controle")!=NULL) ||
|
||
|
(strstr(entreePrinc.tablcar,"para_syteme_lineaire")!=NULL) ||
|
||
|
(strstr(entreePrinc.tablcar,"para_pilotage_equi_global")!=NULL) ||
|
||
|
(strstr(entreePrinc.tablcar,"para_dedies_dynamique")!=NULL) ||
|
||
|
(strstr(entreePrinc.tablcar,"para_affichage")!=NULL)||
|
||
|
(strstr(entreePrinc.tablcar,"para_contact")!=NULL)||
|
||
|
(strstr(entreePrinc.tablcar,"para_energie")!=NULL)||
|
||
|
(strstr(entreePrinc.tablcar,"para_calculs_geometriques")!=NULL)
|
||
|
)
|
||
|
{ if (strstr(entreePrinc.tablcar,"controle")!=NULL)
|
||
|
{controle_lec=true;
|
||
|
// on lit jusqu'au prochain mot cle
|
||
|
string nom;
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom == "SAUVEGARDE")
|
||
|
{ // on regarde s'il y a une référence à un intervalle
|
||
|
if((strstr(entreePrinc.tablcar,"INTER_TEMPS")!=NULL)
|
||
|
&& (strstr(entreePrinc.tablcar,"DERNIER_CALCUL")!=NULL))
|
||
|
{// cas où la sauvegarde est gérer en fonction d'un intervalle
|
||
|
cas_de_sauvegarde = 5; // enreg du type de gestion de sauvegarde
|
||
|
string nom1;
|
||
|
*(entreePrinc.entree) >> nom >> sauvegarde >> nom1;
|
||
|
if ((nom1 != "DERNIER_CALCUL") || (nom != "INTER_TEMPS"))
|
||
|
{ cout << "\n *** erreur on a lu : "<< nom << ", au lieu de DERNIER_CALCUL "
|
||
|
<< " ou alors on a lu : " << nom1 << ", au lieu de INTER_TEMPS !! ";
|
||
|
Sortie(1);
|
||
|
};
|
||
|
}
|
||
|
else if((strstr(entreePrinc.tablcar,"INTER_INCREMENT")!=NULL)
|
||
|
&& (strstr(entreePrinc.tablcar,"DERNIER_CALCUL")!=NULL))
|
||
|
{// cas où la sauvegarde est gérer en fonction d'un intervalle
|
||
|
cas_de_sauvegarde = 4; // enreg du type de gestion de sauvegarde
|
||
|
string nom1;
|
||
|
*(entreePrinc.entree) >> nom >> sauvegarde >> nom1;
|
||
|
if ((nom1 != "DERNIER_CALCUL") || (nom != "INTER_INCREMENT"))
|
||
|
{ cout << "\n *** erreur on a lu : "<< nom << ", au lieu de DERNIER_CALCUL "
|
||
|
<< " ou alors on a lu : " << nom1 << ", au lieu de INTER_INCREMENT !! ";
|
||
|
Sortie(1);
|
||
|
};
|
||
|
}
|
||
|
else if(strstr(entreePrinc.tablcar,"DERNIER_CALCUL")!=NULL)
|
||
|
{// cas où la sauvegarde est gérer en fonction du dernier calcul
|
||
|
cas_de_sauvegarde = 3; // enreg du type de gestion de sauvegarde
|
||
|
*(entreePrinc.entree) >> nom ; //>> sauvegarde;
|
||
|
}
|
||
|
else if(strstr(entreePrinc.tablcar,"INTER_TEMPS")!=NULL)
|
||
|
{// cas où la sauvegarde est gérer en fonction d'un intervale
|
||
|
cas_de_sauvegarde = 2; // enreg du type de gestion de sauvegarde
|
||
|
*(entreePrinc.entree) >> nom ;
|
||
|
sauvegarde = entreePrinc.lect_avec_const_double_utilisateur("SAUVEGARDE ");
|
||
|
}
|
||
|
else if(strstr(entreePrinc.tablcar,"INTER_INCREMENT")!=NULL)
|
||
|
{// cas où la sauvegarde est gérée par le nombre d'incréments
|
||
|
cas_de_sauvegarde = 1; // enreg du type de gestion de sauvegarde
|
||
|
*(entreePrinc.entree) >> nom ;
|
||
|
sauvegarde = entreePrinc.lect_avec_const_double_utilisateur("SAUVEGARDE ");
|
||
|
}
|
||
|
else
|
||
|
{// cas où la sauvegarde est gérée par le nombre d'incréments
|
||
|
cas_de_sauvegarde = 1; // enreg du type de gestion de sauvegarde
|
||
|
sauvegarde = entreePrinc.lect_avec_const_double_utilisateur("SAUVEGARDE ");
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "DELTAtMAXI")
|
||
|
{ // on regarde s'il y a une référence au pas critique
|
||
|
if(strstr(entreePrinc.tablcar,"COEF_PASCRITIQUE_DFC")!=NULL)
|
||
|
// cas où c'est un coef du pas critique DFC
|
||
|
{ //on passe la chaine de caractère et on lit le coeff
|
||
|
string toto;
|
||
|
typeDFC_pas_critique_deltatmaxi=true; // pas critique DFC
|
||
|
*(entreePrinc.entree) >> toto ;
|
||
|
coef_pas_critique_deltatmaxi = entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("DELTAtMAXI COEF_PASCRITIQUE_DFC ");
|
||
|
}
|
||
|
else if(strstr(entreePrinc.tablcar,"COEF_PASCRITIQUE")!=NULL)
|
||
|
// cas où c'est un coef du pas critique de la méthode
|
||
|
{ //on passe la chaine de caractère et on lit le coeff
|
||
|
string toto;
|
||
|
typeDFC_pas_critique_deltatmaxi=false; // pas critique spécifique
|
||
|
*(entreePrinc.entree) >> toto ;
|
||
|
coef_pas_critique_deltatmaxi = entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("DELTAtMAXI COEF_PASCRITIQUE ");
|
||
|
}
|
||
|
else
|
||
|
// sinon on lit directement le deltatmaxi
|
||
|
{ tempo_specifique_algo.deltatmaxi = tempo.deltatmaxi
|
||
|
= entreePrinc.lect_avec_const_double_utilisateur("DELTAtMAXI ");
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "DELTAtMINI")
|
||
|
{ // on regarde s'il y a une référence au pas critique
|
||
|
if(strstr(entreePrinc.tablcar,"COEF_PASCRITIQUE_DFC")!=NULL)
|
||
|
// cas où c'est un coef du pas critique DFC
|
||
|
{ //on passe la chaine de caractère et on lit le coeff
|
||
|
string toto;
|
||
|
typeDFC_pas_critique_deltatmini=true; // pas critique DFC
|
||
|
*(entreePrinc.entree) >> toto ;
|
||
|
coef_pas_critique_deltatmini = entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("DELTAtMINI COEF_PASCRITIQUE_DFC ");
|
||
|
}
|
||
|
else if(strstr(entreePrinc.tablcar,"COEF_PASCRITIQUE")!=NULL)
|
||
|
// cas où c'est un coef du pas critique
|
||
|
{ //on passe la chaine de caractère et on lit le coeff
|
||
|
string toto;
|
||
|
typeDFC_pas_critique_deltatmini=false; // pas critique DFC
|
||
|
*(entreePrinc.entree) >> toto ;
|
||
|
coef_pas_critique_deltatmini = entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("DELTAtMINI COEF_PASCRITIQUE ");
|
||
|
}
|
||
|
else
|
||
|
// sinon on lit directement le deltatmaxi
|
||
|
{ tempo_specifique_algo.deltatmini = tempo.deltatmini
|
||
|
= entreePrinc.lect_avec_const_double_utilisateur("DELTAtMINI ");};
|
||
|
}
|
||
|
else if (nom == "ITERATIONS")
|
||
|
{ // on regarde les termes par défaut qui sont dépendants de cette valeur
|
||
|
bool changer1 = (nb_iter_pour_bonne_convergence == 0.25 * iterations);
|
||
|
bool changer2 = (nb_iter_pour_mauvaise_convergence == 0.5 * iterations);
|
||
|
// lecture de la nouvelle valeur
|
||
|
iterations = (int) entreePrinc.lect_avec_const_double_utilisateur("ITERATIONS ");
|
||
|
if (changer1) nb_iter_pour_bonne_convergence = 0.25 * iterations;
|
||
|
if (changer2) nb_iter_pour_mauvaise_convergence = 0.5 * iterations;
|
||
|
}
|
||
|
else if (nom == "PRECISION")
|
||
|
{precision = entreePrinc.lect_avec_const_double_utilisateur("PRECISION ");}
|
||
|
else if (nom == "PRECTEMPS")
|
||
|
{tempo_specifique_algo.prectemps = tempo.prectemps
|
||
|
= entreePrinc.lect_avec_const_double_utilisateur("PRECTEMPS ");}
|
||
|
else if (nom == "MAX_PUISSANCE")
|
||
|
{max_puissance= entreePrinc.lect_avec_const_double_utilisateur("MAX_PUISSANCE ");}
|
||
|
else if (nom == "NORME")
|
||
|
{*(entreePrinc.entree) >> norme.nom1;
|
||
|
|
||
|
if ( !(strstr(norme.nom1.c_str(),"Residu") || strstr(norme.nom1.c_str(),"Residu/Reaction")
|
||
|
|| strstr(norme.nom1.c_str(),"Residu/PVExterne") || strstr(norme.nom1.c_str(),"Residu/PVInterne")
|
||
|
|| strstr(norme.nom1.c_str(),"Residu/maxPVI")|| strstr(norme.nom1.c_str(),"min(Res,Res/Reaction)")
|
||
|
|| strstr(norme.nom1.c_str(),"min(Res,Res/MaX(Reaction_et_PVExterne))")
|
||
|
|| strstr(norme.nom1.c_str(),"E_cinetique/E_statique_ET_ResSurReact")
|
||
|
|| strstr(norme.nom1.c_str(),"E_cinetique/E_statique_ET_Res/Reac_et_Fext")
|
||
|
|| strstr(norme.nom1.c_str(),"E_cin/E_stat_ET_min(Res,Res/Reac_et_Fext)")
|
||
|
|| strstr(norme.nom1.c_str(),"E_cinetique")
|
||
|
|| strstr(norme.nom1.c_str(),"Bilan_puissance/Max(puiss)")
|
||
|
|| strstr(norme.nom1.c_str(),"Residu/Reaction_et_Residu")
|
||
|
|| strstr(norme.nom1.c_str(),"fonction_nD:")
|
||
|
))
|
||
|
{ cout << "\n ** erreur en lecture du type de norme pour le controle"
|
||
|
<< " d\'algorithme, nom lu : "<< norme;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des parametres de controle **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
};
|
||
|
// s'il s'agit du nom d'une fonction nD on la récupère
|
||
|
if (norme.nom1 == "fonction_nD:")
|
||
|
*(entreePrinc.entree) >> norme.nom2;
|
||
|
}
|
||
|
else if (nom == "CINEMATIQUE")
|
||
|
{cinematique = (bool) entreePrinc.lect_avec_const_double_utilisateur("CINEMATIQUE ");
|
||
|
}
|
||
|
else if (nom == "CONV_FORCEE")
|
||
|
{conv_forcee = (bool) entreePrinc.lect_avec_const_double_utilisateur("CONV_FORCEE ");
|
||
|
}
|
||
|
else if (nom == "MULTIPLICATEUR")
|
||
|
{multiplicateur = entreePrinc.lect_avec_const_double_utilisateur("MULTIPLICATEUR ");
|
||
|
}
|
||
|
else if (nom == "DELTAt")
|
||
|
{ // on regarde s'il y a une référence au pas critique
|
||
|
if(strstr(entreePrinc.tablcar,"COEF_PASCRITIQUE_DFC")!=NULL)
|
||
|
// cas où c'est un coef du pas critique DFC
|
||
|
{ //on passe la chaine de caractère et on lit le coeff
|
||
|
string toto;
|
||
|
typeDFC_pas_critique_deltat=true; // pas critique DFC
|
||
|
*(entreePrinc.entree) >> toto ;
|
||
|
coef_pas_critique_deltat = entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("DELTAt COEF_PASCRITIQUE_DFC ");
|
||
|
}
|
||
|
else if(strstr(entreePrinc.tablcar,"COEF_PASCRITIQUE")!=NULL)
|
||
|
// cas où c'est un coef du pas critique
|
||
|
{ //on passe la chaine de caractère et on lit le coeff
|
||
|
string toto;
|
||
|
typeDFC_pas_critique_deltat=false; // pas critique DFC
|
||
|
*(entreePrinc.entree) >> toto ;
|
||
|
coef_pas_critique_deltat = entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("DELTAt COEF_PASCRITIQUE ");
|
||
|
}
|
||
|
else
|
||
|
// sinon on lit directement le deltat
|
||
|
{tempo_specifique_algo.deltat = tempo.deltat
|
||
|
= entreePrinc.lect_avec_const_double_utilisateur("DELTAt ");
|
||
|
};
|
||
|
// on regarde si l'on veut forcer la reprise du pas de temps donné dans le .info
|
||
|
// par rapport à celle du fichier de restart si il existe
|
||
|
if(strstr(entreePrinc.tablcar,"FORCE_DELTAT_DU_.INFO")!=NULL)
|
||
|
force_deltat=true; else force_deltat=false;
|
||
|
}
|
||
|
else if (nom == "TEMPSFIN")
|
||
|
{tempo_specifique_algo.tempsfin = tempo.tempsfin
|
||
|
= entreePrinc.lect_avec_const_double_utilisateur("TEMPSFIN ");
|
||
|
}
|
||
|
else if (nom == "MAXINCRE")
|
||
|
{maxincre = (int) entreePrinc.lect_avec_const_double_utilisateur("MAXINCRE ");
|
||
|
}
|
||
|
else if (nom == "MAX_ESSAI_INCRE")
|
||
|
{max_essai_incre= (int) entreePrinc.lect_avec_const_double_utilisateur("MAX_ESSAI_INCRE ");
|
||
|
lecture_max_essai_incre = true; // du coup le max_essai_incre ne prendra
|
||
|
} // pas la valeur par défaut qui est celle de maxincre
|
||
|
else if (nom == "RESTART")
|
||
|
{restart= (int) entreePrinc.lect_avec_const_double_utilisateur("RESTART ");
|
||
|
}
|
||
|
else if (nom == "LINE_SEARCH")
|
||
|
{line_search = true;}
|
||
|
else if (nom == "VARIATION_CHARGE_EXTERNE_SUR_RAIDEUR")
|
||
|
{var_charge_externe = (bool) entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("VARIATION_CHARGE_EXTERNE_SUR_RAIDEUR ");
|
||
|
}
|
||
|
else if (nom == "VARIATION_JACOBIEN_SUR_RAIDEUR")
|
||
|
{var_jacobien = (bool) entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("VARIATION_JACOBIEN_SUR_RAIDEUR ");
|
||
|
}
|
||
|
else if (nom == "VARIATION_VITESSE_DEFORMATION_SUR_RAIDEUR")
|
||
|
{var_D = (bool) entreePrinc.lect_avec_const_double_utilisateur
|
||
|
("VARIATION_VITESSE_DEFORMATION_SUR_RAIDEUR ");
|
||
|
}
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture de parametre de controle"
|
||
|
<< " d\'algorithme, nom lu : "<< nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des parametres de controle **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
};
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
};
|
||
|
};
|
||
|
// ensuite on s'occupe du sytème lineaire général
|
||
|
if (strstr(entreePrinc.tablcar,"para_syteme_lineaire")!=NULL)
|
||
|
{ para_systeme_lineaire_lec = true; // on signal qu'il y a lecture
|
||
|
// on lit jusqu'au prochain mot cle
|
||
|
string nom;
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom == "TYPE_MATRICE")
|
||
|
{*(entreePrinc.entree) >> type_matrice ;}
|
||
|
else if (nom == "SYMETRIE_MATRICE")
|
||
|
{symetrie_matrice= (bool) entreePrinc.lect_avec_const_double_utilisateur("SYMETRIE_MATRICE ");
|
||
|
}
|
||
|
else if (nom == "TYPE_RESOLUTION")
|
||
|
{*(entreePrinc.entree) >> type_resolution;}
|
||
|
else if (nom == "TYPE_PRECONDITIONNEMENT")
|
||
|
{*(entreePrinc.entree) >> type_preconditionnement;}
|
||
|
else if (nom == "NB_ITER_NONDIRECTE")
|
||
|
{nb_iter_nondirecte = (int) entreePrinc.lect_avec_const_double_utilisateur("NB_ITER_NONDIRECTE ");
|
||
|
}
|
||
|
else if (nom == "TOLERANCE")
|
||
|
{tolerance = entreePrinc.lect_avec_const_double_utilisateur("TOLERANCE ");
|
||
|
}
|
||
|
else if (nom == "NB_VECT_RESTART")
|
||
|
{nb_vect_restart = (int) entreePrinc.lect_avec_const_double_utilisateur("NB_VECT_RESTART ");}
|
||
|
else if (nom == "MATRICE_S_SECONDAIRE_S_")
|
||
|
{// dans le cas de matrices secondaires on lit tout d'abort les types de matrices
|
||
|
type_matrice_secondaire.clear(); // on vide d'abord la liste déjà existante
|
||
|
while (nom != "FIN_TYPE_MAT_SECONDAIRES_")
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom != "FIN_TYPE_MAT_SECONDAIRES_")
|
||
|
type_matrice_secondaire.push_back(Id_nom_matrice(nom));
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "TYPE_RESOLUTION_S_SECONDAIRE_S_")
|
||
|
{// dans le cas de matrices secondaires lecture du type de résolution
|
||
|
type_resolution_secondaire.clear(); // on vide d'abord la liste déjà existante
|
||
|
while (nom != "FIN_TYPE_RESOLUTION_SECONDAIRES_")
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom != "FIN_TYPE_RESOLUTION_SECONDAIRES_")
|
||
|
type_resolution_secondaire.push_back(Id_nom_resolution(nom));
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "TYPE_PRECONDITIONNEMENT_S_SECONDAIRE_S_")
|
||
|
{// dans le cas de matrices secondaires lecture du type de préconditionnement
|
||
|
type_preconditionnement_secondaire.clear(); // on vide d'abord la liste déjà existante
|
||
|
while (nom != "FIN_TYPE_PRECONDITIONNEMENT_SECONDAIRES_")
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom != "FIN_TYPE_PRECONDITIONNEMENT_SECONDAIRES_")
|
||
|
type_preconditionnement_secondaire.push_back(Id_nom_preconditionnement(nom));
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "NB_ITER_NONDIRECTE_S_SECONDAIRE_S_")
|
||
|
{// dans le cas de matrices secondaires lecture du nombre d'itération
|
||
|
nb_iter_nondirecte_secondaire.clear(); // on vide d'abord la liste déjà existante
|
||
|
while (nom != "FIN_NB_ITER_NONDIRECTE_SECONDAIRES_")
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom != "FIN_NB_ITER_NONDIRECTE_SECONDAIRES_")
|
||
|
nb_iter_nondirecte_secondaire.push_back(ChangeEntier(nom));
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "TOLERANCE_S_SECONDAIRE_S_")
|
||
|
{// dans le cas de matrices secondaires lecture du type de préconditionnement
|
||
|
tolerance_secondaire.clear(); // on vide d'abord la liste déjà existante
|
||
|
while (nom != "FIN_TOLERANCE_SECONDAIRES_")
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom != "FIN_TOLERANCE_SECONDAIRES_")
|
||
|
tolerance_secondaire.push_back(ChangeReel(nom));
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "NB_VECT_RESTART_S_SECONDAIRE_S_")
|
||
|
{// dans le cas de matrices secondaires lecture du type de préconditionnement
|
||
|
nb_vect_restart_secondaire.clear(); // on vide d'abord la liste déjà existante
|
||
|
while (nom != "FIN_NB_VECT_RESTART_SECONDAIRES_")
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom != "FIN_NB_VECT_RESTART_SECONDAIRES_")
|
||
|
nb_vect_restart_secondaire.push_back(ChangeEntier(nom));
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "OPTIMISATION_POINTEURS_ASSEMBLAGE")
|
||
|
{opti_pointeur_assemblage= (int) entreePrinc.lect_avec_const_double_utilisateur("OPTIMISATION_POINTEURS_ASSEMBLAGE ");}
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture de parametres"
|
||
|
<< " pour le système linéaire, nom lu : "<< nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des parametres du systeme lineaire **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
};
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
}
|
||
|
};
|
||
|
|
||
|
// 3) ensuite on s'occupe des paramètres de pilotage de l'équilibre global
|
||
|
if (strstr(entreePrinc.tablcar,"para_pilotage_equi_global")!=NULL)
|
||
|
{ para_pilotage_equi_global_lec = true; // on signal qu'il y a lecture
|
||
|
// on lit jusqu'au prochain mot cle
|
||
|
string nom;
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom == "FACTEUR_DIMINUTION")
|
||
|
facteur_diminution= entreePrinc.lect_avec_const_double_utilisateur("FACTEUR_DIMINUTION ");
|
||
|
else if (nom == "FACTEUR_AUGMENTATION")
|
||
|
facteur_augmentation= entreePrinc.lect_avec_const_double_utilisateur("FACTEUR_AUGMENTATION ");
|
||
|
else if (nom == "NB_BONNE_CONVERGENCE")
|
||
|
nb_bonne_convergence= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_BONNE_CONVERGENCE ");
|
||
|
else if (nom == "FACT_DIM_EN_MAUVAISE_CONVERGENCE")
|
||
|
fact_dim_en_mauvaiseConv= entreePrinc.lect_avec_const_double_utilisateur("FACT_DIM_EN_MAUVAISE_CONVERGENCE ");
|
||
|
else if (nom == "NB_ITER_POUR_BONNE_CONVERGENCE")
|
||
|
nb_iter_pour_bonne_convergence= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_ITER_POUR_BONNE_CONVERGENCE ");
|
||
|
else if (nom == "NB_ITER_POUR_MAUVAISE_CONVERGENCE")
|
||
|
nb_iter_pour_mauvaise_convergence= (int)entreePrinc.lect_avec_const_double_utilisateur("NB_ITER_POUR_MAUVAISE_CONVERGENCE ");
|
||
|
else if (nom == "INIT_COMP_TANGENT_SIMPLE")
|
||
|
init_comp_tangent_simple= entreePrinc.lect_avec_const_double_utilisateur("INIT_COMP_TANGENT_SIMPLE ");
|
||
|
else if (nom == "SUR_SOUS_RELAXATION")
|
||
|
sur_sous_relaxation= entreePrinc.lect_avec_const_double_utilisateur("SUR_SOUS_RELAXATION ");
|
||
|
else if (nom == "NORME_MAXI_INCREMENT")
|
||
|
norme_incre_max= entreePrinc.lect_avec_const_double_utilisateur("NORME_MAXI_INCREMENT ");
|
||
|
else if (nom == "NORME_MAXI_X_INCREMENT")
|
||
|
norme_incre_X_max= entreePrinc.lect_avec_const_double_utilisateur("NORME_MAXI_X_INCREMENT ");
|
||
|
else if (nom == "NORME_MAXI_V_INCREMENT")
|
||
|
norme_incre_V_max= entreePrinc.lect_avec_const_double_utilisateur("NORME_MAXI_V_INCREMENT ");
|
||
|
else if (nom == "MAXI_VARIATION_DDL_POUR_CONVERGENCE")
|
||
|
varMaxiDdl= entreePrinc.lect_avec_const_double_utilisateur("MAXI_VARIATION_DDL_POUR_CONVERGENCE ");
|
||
|
else if (nom == "MINI_VARIATION_DDL_POUR_CONVERGENCE")
|
||
|
varMiniDdl= entreePrinc.lect_avec_const_double_utilisateur("MINI_VARIATION_DDL_POUR_CONVERGENCE ");
|
||
|
else if (nom == "NB_CYCLE_CONTROLE_RESIDU")
|
||
|
nbCycleControleResidu= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_CYCLE_CONTROLE_RESIDU ");
|
||
|
else if (nom == "PLAGE_CONTROLE_RESIDU")
|
||
|
plageControleResidu= (int) entreePrinc.lect_avec_const_double_utilisateur("PLAGE_CONTROLE_RESIDU ");
|
||
|
else if (nom == "INIT_INCRE_AVEC_PAS_PREC")
|
||
|
initIncreAvecDeltaDdlPrec= entreePrinc.lect_avec_const_double_utilisateur("INIT_INCRE_AVEC_PAS_PREC ");
|
||
|
else if (nom == "CAS_JACOBIEN_NEGATIF")
|
||
|
jabobien_negatif= (int) entreePrinc.lect_avec_const_double_utilisateur("CAS_JACOBIEN_NEGATIF ");
|
||
|
else if (nom == "VAR_MAXI_JACOBIEN")
|
||
|
var_maxi_jacobien= entreePrinc.lect_avec_const_double_utilisateur("VAR_MAXI_JACOBIEN ");
|
||
|
else if (nom == "CAS_PB_FCTND_CHARGE")
|
||
|
cas_fctnD_charge= entreePrinc.lect_avec_const_double_utilisateur("CAS_PB_FCTND_CHARGE ");
|
||
|
else if (nom == "TYPE_DE_PILOTAGE")
|
||
|
*(entreePrinc.entree) >> type_de_pilotage;
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture de parametres"
|
||
|
<< " pour le pilotage de l'equilibre global, nom lu : "<< nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des parametres du pilotage de l'equilibre global **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
}
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
}
|
||
|
}
|
||
|
// 4) ensuite on s'occupe des paramètres liés à la dynamique
|
||
|
if (strstr(entreePrinc.tablcar,"para_dedies_dynamique")!=NULL)
|
||
|
{ para_dedies_dynamique_lec = true; // on signal qu'il y a lecture
|
||
|
// on lit jusqu'au prochain mot cle
|
||
|
string nom;
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom == "TYPE_CALCUL_MATRICE_MASSE")
|
||
|
{// lecture du type
|
||
|
*(entreePrinc.entree) >> nom;
|
||
|
if (nom == "MASSE_DIAG_COEF_EGAUX")
|
||
|
type_calcul_masse = MASSE_DIAG_COEF_EGAUX;
|
||
|
else if (nom == "MASSE_DIAG_COEF_VAR")
|
||
|
type_calcul_masse = MASSE_DIAG_COEF_VAR;
|
||
|
else if (nom == "MASSE_CONSISTANTE")
|
||
|
type_calcul_masse = MASSE_CONSISTANTE;
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture de parametres"
|
||
|
<< " pour le type de matrice de masse, type lu : "<< nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des donnees lie à la dynamique **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "LIMITATION_TEMPS_MAXI_STABLE")
|
||
|
{// lecture du booléen
|
||
|
limitation_temps_maxi_stable= (bool) entreePrinc.lect_avec_const_double_utilisateur("LIMITATION_TEMPS_MAXI_STABLE ");
|
||
|
}
|
||
|
else if (nom == "AMORTISSEMENT_VISCOSITE_ARTIFICIELLE")
|
||
|
{// lecture du cas d'amortissement
|
||
|
amort_visco_arti= (int) entreePrinc.lect_avec_const_double_utilisateur("AMORTISSEMENT_VISCOSITE_ARTIFICIELLE ");
|
||
|
}
|
||
|
else if (nom == "VISCOSITE_ARTIFICIELLE")
|
||
|
{// lecture de la viscosité ou de la proportion de viscosité critique
|
||
|
visco_arti= entreePrinc.lect_avec_const_double_utilisateur("VISCOSITE_ARTIFICIELLE ");
|
||
|
}
|
||
|
else if (nom == "MAXI_C_EN_FONCTION_M")
|
||
|
{// bornage de C critique
|
||
|
maxi_C_en_fonction_M= entreePrinc.lect_avec_const_double_utilisateur("MAXI_C_EN_FONCTION_M ");
|
||
|
}
|
||
|
else if (nom == "COEFFICIENT_DE_RAYLEIGH_POUR_LA_MASSE")
|
||
|
{// lecture du coefficient
|
||
|
coef_rayleigh_masse= entreePrinc.lect_avec_const_double_utilisateur("COEFFICIENT_DE_RAYLEIGH_POUR_LA_MASSE ");
|
||
|
}
|
||
|
else if (nom == "COEFFICIENT_DE_RAYLEIGH_POUR_LA_RAIDEUR")
|
||
|
{// lecture du coefficient
|
||
|
coef_rayleigh_raideur= entreePrinc.lect_avec_const_double_utilisateur("COEFFICIENT_DE_RAYLEIGH_POUR_LA_RAIDEUR ");
|
||
|
}
|
||
|
else if (nom == "BULK_VISCOSITY")
|
||
|
{// lecture du choix
|
||
|
bulk_viscosity= (int) entreePrinc.lect_avec_const_double_utilisateur("BULK_VISCOSITY ");
|
||
|
}
|
||
|
else if (nom == "COEFF_TRACE")
|
||
|
{// lecture du coefficient
|
||
|
c_Tracebulk= entreePrinc.lect_avec_const_double_utilisateur("COEFF_TRACE ");
|
||
|
}
|
||
|
else if (nom == "COEFF_CARRE_TRACE")
|
||
|
{// lecture du coefficient
|
||
|
c_Trace2bulk= entreePrinc.lect_avec_const_double_utilisateur("COEFF_CARRE_TRACE ");
|
||
|
}
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture de parametres"
|
||
|
<< " pour les donnees lie à la dynamique, nom lu : "<< nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des donnees lie à la dynamique **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
}
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// 5) paramètres liès à l'affichage des résultats
|
||
|
if (strstr(entreePrinc.tablcar,"para_affichage")!=NULL)
|
||
|
{ para_affichage_lec = true; // on signal qu'il y a lecture
|
||
|
// on lit jusqu'au prochain mot cle
|
||
|
string nom;
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom == "FREQUENCE_AFFICHAGE_INCREMENT")
|
||
|
frequence_affichage_increment= (int) entreePrinc.lect_avec_const_double_utilisateur("FREQUENCE_AFFICHAGE_INCREMENT ");
|
||
|
else if (nom == "FREQUENCE_AFFICHAGE_ITERATION")
|
||
|
frequence_affichage_iteration= (int) entreePrinc.lect_avec_const_double_utilisateur("FREQUENCE_AFFICHAGE_ITERATION ");
|
||
|
else if (nom == "FREQUENCE_SORTIE_FIL_DU_CALCUL")
|
||
|
{ // on regarde s'il y a une référence au pas critique
|
||
|
if(strstr(entreePrinc.tablcar,"INTER_TEMPS")!=NULL)
|
||
|
{// cas où la sauvegarde est gérer en fonction d'un pas de temps
|
||
|
cas_de_sortie_fil_calcul = 2; // enreg du type de gestion de sauvegarde
|
||
|
*(entreePrinc.entree) >> nom ;
|
||
|
sortie_fil_calcul= entreePrinc.lect_avec_const_double_utilisateur("FREQUENCE_SORTIE_FIL_DU_CALCUL ");
|
||
|
}
|
||
|
else if(strstr(entreePrinc.tablcar,"DERNIER_CALCUL")!=NULL)
|
||
|
{// cas où la sauvegarde est gérer en fonction du dernier calcul
|
||
|
cas_de_sortie_fil_calcul = 3; // enreg du type de gestion de sauvegarde
|
||
|
*(entreePrinc.entree) >> nom ; // passage du nom
|
||
|
sortie_fil_calcul =1000000; // grand
|
||
|
}
|
||
|
else
|
||
|
{// cas où la sauvegarde est gérée par le nombre d'incréments
|
||
|
cas_de_sortie_fil_calcul = 1; // enreg du type de gestion de sauvegarde
|
||
|
sortie_fil_calcul= entreePrinc.lect_avec_const_double_utilisateur("FREQUENCE_SORTIE_FIL_DU_CALCUL ");
|
||
|
// si la fréquence est nulle ou négative
|
||
|
if (sortie_fil_calcul <= 0)sortie_fil_calcul =-1000000;
|
||
|
};
|
||
|
}
|
||
|
else if (nom == "NB_CHIFFRE_POUR_DOUBLE_CALCUL")
|
||
|
nb_diggit_double_calcul= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_CHIFFRE_POUR_DOUBLE_CALCUL ");
|
||
|
else if (nom == "NB_CHIFFRE_POUR_DOUBLE_GRAPHIQUE")
|
||
|
nb_diggit_double_graphique= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_CHIFFRE_POUR_DOUBLE_GRAPHIQUE ");
|
||
|
else if (nom == "NB_CHIFFRE_POUR_DOUBLE_ECRAN")
|
||
|
nb_diggit_double_ecran= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_CHIFFRE_POUR_DOUBLE_ECRAN ");
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture des parametres d'affichage" << nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des parametres des parametres d'affichage **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
}
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
// 6) paramètres liès au contact
|
||
|
if (strstr(entreePrinc.tablcar,"para_contact")!=NULL)
|
||
|
{ para_contact_lec = true; // on signal qu'il y a lecture
|
||
|
// on lit jusqu'au prochain mot cle
|
||
|
string nom; string nom_inter;
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom == "PRECISION_POINT_INTERNE_DEBUT")
|
||
|
{prec_pt_int_deb= entreePrinc.lect_avec_const_double_utilisateur("PRECISION_POINT_INTERNE_DEBUT ");}
|
||
|
else if (nom == "FACT_POUR_RAYON_ACCOSTAGE")
|
||
|
{factPourRayonAccostage= entreePrinc.lect_avec_const_double_utilisateur("FACT_POUR_RAYON_ACCOSTAGE ");}
|
||
|
else if (nom == "DISTANCE_MAXI_AU_PT_PROJETE")
|
||
|
{distanceMaxiAuPtProjete= entreePrinc.lect_avec_const_double_utilisateur("DISTANCE_MAXI_AU_PT_PROJETE ");}
|
||
|
else if (nom == "PRECISION_BOITE_PRELOCALISATION")
|
||
|
{extra_boite_prelocalisation= entreePrinc.lect_avec_const_double_utilisateur("PRECISION_BOITE_PRELOCALISATION ");}
|
||
|
else if (nom == "MINI_EXTRA_BOITE_PRELOCALISATION")
|
||
|
{mini_extra_boite_prelocalisation= entreePrinc.lect_avec_const_double_utilisateur("MINI_EXTRA_BOITE_PRELOCALISATION ");}
|
||
|
else if (nom == "AJOUT_EXTRA_BOITE_PRELOCALISATION")
|
||
|
{ajout_extra_boite_prelocalisation= entreePrinc.lect_avec_const_double_utilisateur("AJOUT_EXTRA_BOITE_PRELOCALISATION ");}
|
||
|
else if (nom == "CONTACT_TYPE")
|
||
|
{contact_type= (int) entreePrinc.lect_avec_const_double_utilisateur("CONTACT_TYPE ");}
|
||
|
else if (nom == "FCT_ND_BASCUL_CONTACT_TYPE_4")
|
||
|
{*(entreePrinc.entree) >> fct_nD_bascul_contact_type_4;}
|
||
|
else if (nom == "PENALISATION_PENETRATION")
|
||
|
{if (strstr(entreePrinc.tablcar,"FCT_ND_PENALISATION_PENETRATION")!=NULL)
|
||
|
{*(entreePrinc.entree) >> nom_inter >> fct_nD_penalisationPenetration;
|
||
|
penalisationPenetration = -ConstMath::tresgrand; // valeur négative arbitraire
|
||
|
}
|
||
|
else
|
||
|
{penalisationPenetration= entreePrinc.lect_avec_const_double_utilisateur("PENALISATION_PENETRATION ");
|
||
|
fct_nD_penalisationPenetration = "_";
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "TYPE_PENALISATION_PENETRATION")
|
||
|
{typePenalisationPenetration= (int) entreePrinc.lect_avec_const_double_utilisateur("TYPE_PENALISATION_PENETRATION ");}
|
||
|
else if (nom == "PENETRATION_CONTACT_MAXI")
|
||
|
{if (strstr(entreePrinc.tablcar,"FCT_ND_PENETRATION_CONTACT_MAXI")!=NULL)
|
||
|
{*(entreePrinc.entree) >> nom_inter >> fct_nD_penetration_contact_maxi;
|
||
|
penetration_contact_maxi = -ConstMath::tresgrand; // valeur négative arbitraire
|
||
|
}
|
||
|
else
|
||
|
{penetration_contact_maxi= entreePrinc.lect_avec_const_double_utilisateur("PENETRATION_CONTACT_MAXI ");
|
||
|
penetration_contact_maxi=Dabs(penetration_contact_maxi);
|
||
|
fct_nD_penetration_contact_maxi = "_";
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "PENETRATION_BORNE_REGULARISATION")
|
||
|
{if (strstr(entreePrinc.tablcar,"FCT_ND_PENETRATION_BORNE_REGULARISATION")!=NULL)
|
||
|
{*(entreePrinc.entree) >> nom_inter >> fct_nD_penetration_borne_regularisation;
|
||
|
penetration_borne_regularisation = -ConstMath::tresgrand; // valeur négative arbitraire
|
||
|
}
|
||
|
else
|
||
|
{penetration_borne_regularisation= entreePrinc.lect_avec_const_double_utilisateur("PENETRATION_BORNE_REGULARISATION ");
|
||
|
penetration_borne_regularisation=Dabs(penetration_borne_regularisation);
|
||
|
fct_nD_penetration_borne_regularisation = "_";
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "FORCE_CONTACT_NOEUD_MAXI")
|
||
|
{if (strstr(entreePrinc.tablcar,"FCT_ND_FORCE_CONTACT_NOEUD_MAXI")!=NULL)
|
||
|
{*(entreePrinc.entree) >> nom_inter >> fct_nD_force_contact_noeud_maxi;
|
||
|
force_contact_noeud_maxi = -ConstMath::tresgrand; // valeur négative arbitraire
|
||
|
}
|
||
|
else
|
||
|
{force_contact_noeud_maxi= entreePrinc.lect_avec_const_double_utilisateur("FORCE_CONTACT_NOEUD_MAXI ");
|
||
|
force_contact_noeud_maxi=Dabs(force_contact_noeud_maxi);
|
||
|
fct_nD_force_contact_noeud_maxi = "_";
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "PENALISATION_TANGENTIELLE")
|
||
|
{if (strstr(entreePrinc.tablcar,"FCT_ND_PENALISATION_TANGENTIELLE")!=NULL)
|
||
|
{*(entreePrinc.entree) >> nom_inter >> fct_nD_penalisationTangentielle;
|
||
|
penalisationTangentielle = -ConstMath::tresgrand; // valeur négative arbitraire
|
||
|
}
|
||
|
else
|
||
|
{penalisationTangentielle= entreePrinc.lect_avec_const_double_utilisateur("PENALISATION_TANGENTIELLE ");
|
||
|
fct_nD_penalisationTangentielle = "_";
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "TYPE_PENALISATION_TANGENTIELLE")
|
||
|
{typePenalisationTangentielle= (int) entreePrinc.lect_avec_const_double_utilisateur("TYPE_PENALISATION_TANGENTIELLE ");}
|
||
|
else if (nom == "TANGENTIELLE_CONTACT_MAXI")
|
||
|
{if (strstr(entreePrinc.tablcar,"FCT_ND_TANGENTIELLE_CONTACT_MAXI")!=NULL)
|
||
|
{*(entreePrinc.entree) >> nom_inter >> fct_nD_tangentielle_contact_maxi;
|
||
|
tangentielle_contact_maxi = -ConstMath::tresgrand; // valeur négative arbitraire
|
||
|
}
|
||
|
else
|
||
|
{tangentielle_contact_maxi= entreePrinc.lect_avec_const_double_utilisateur("TANGENTIELLE_CONTACT_MAXI ");
|
||
|
tangentielle_contact_maxi=Dabs(tangentielle_contact_maxi);
|
||
|
fct_nD_tangentielle_contact_maxi = "_";
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "TANGENTIELLE_BORNE_REGULARISATION")
|
||
|
{if (strstr(entreePrinc.tablcar,"FCT_ND_TANGENTIELLE_BORNE_REGULARISATION")!=NULL)
|
||
|
{*(entreePrinc.entree) >> nom_inter >> fct_nD_tangentielle_borne_regularisation;
|
||
|
tangentielle_borne_regularisation = -ConstMath::tresgrand; // valeur négative arbitraire
|
||
|
}
|
||
|
else
|
||
|
{tangentielle_borne_regularisation= entreePrinc.lect_avec_const_double_utilisateur("TANGENTIELLE_BORNE_REGULARISATION ");
|
||
|
tangentielle_borne_regularisation=Dabs(tangentielle_borne_regularisation);
|
||
|
fct_nD_tangentielle_borne_regularisation = "_";
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "FORCE_TANGENTIELLE_NOEUD_MAXI")
|
||
|
{if (strstr(entreePrinc.tablcar,"FCT_ND_FORCE_TANGENTIELLE_NOEUD_MAXI")!=NULL)
|
||
|
{*(entreePrinc.entree) >> nom_inter >> fct_nD_force_tangentielle_noeud_maxi;
|
||
|
force_tangentielle_noeud_maxi = -ConstMath::tresgrand; // valeur négative arbitraire
|
||
|
}
|
||
|
else
|
||
|
{force_tangentielle_noeud_maxi= entreePrinc.lect_avec_const_double_utilisateur("FORCE_TANGENTIELLE_NOEUD_MAXI ");
|
||
|
force_tangentielle_noeud_maxi=Dabs(force_tangentielle_noeud_maxi);
|
||
|
fct_nD_force_tangentielle_noeud_maxi = "_";
|
||
|
}
|
||
|
}
|
||
|
else if (nom == "PRECISION_PT_SUR_FRONTIERE")
|
||
|
{prec_pt_sur_frontiere= entreePrinc.lect_avec_const_double_utilisateur("PRECISION_PT_SUR_FRONTIERE ");}
|
||
|
else if (nom == "NB_BOUCLE_NEWTON_SUR_POSITION_FRONTIERE")
|
||
|
{nb_boucle_newton_position_frontiere= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_BOUCLE_NEWTON_SUR_POSITION_FRONTIERE ");}
|
||
|
else if (nom == "NB_DECOLLEMENT_MAXI")
|
||
|
{nbDecolAutorise= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_DECOLLEMENT_MAXI ");}
|
||
|
else if (nom == "TYPE_DE_DECOLLEMENT")
|
||
|
{typeDeDecolement= (int) entreePrinc.lect_avec_const_double_utilisateur("TYPE_DE_DECOLLEMENT ");}
|
||
|
else if (nom == "NB_MOY_GLISSANT")
|
||
|
{nb_glissant= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_MOY_GLISSANT ");}
|
||
|
else if (nom == "NIVEAU_COMMENTAIRE_CONTACT")
|
||
|
{niveau_commentaire_contact= (int) entreePrinc.lect_avec_const_double_utilisateur("NIVEAU_COMMENTAIRE_CONTACT ");}
|
||
|
else if (nom == "OPTIMISATION_NUMEROTATION")
|
||
|
{optimisation_numerotation= (int) entreePrinc.lect_avec_const_double_utilisateur("OPTIMISATION_NUMEROTATION ");}
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture des parametres de contact" << nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des parametres des parametres de contact **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
}
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
};
|
||
|
}
|
||
|
|
||
|
// 7) paramètres liés aux calculs des énergies
|
||
|
if (strstr(entreePrinc.tablcar,"para_energie")!=NULL)
|
||
|
{ para_energie_lec = true; // on signal qu'il y a lecture
|
||
|
// on lit jusqu'au prochain mot cle
|
||
|
string nom;
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom == "CALCUL_ENERGIE")
|
||
|
{double calcul_energie;
|
||
|
*(entreePrinc.entree) >> calcul_energie;
|
||
|
cout << "\n warning CALCUL_ENERGIE est un parametre obsolete, le calcul est maintenant systematique "
|
||
|
<< endl;
|
||
|
}
|
||
|
else if (nom == "NB_INCR_CAL_ENERG")
|
||
|
nb_incr_cal_ener= (int) entreePrinc.lect_avec_const_double_utilisateur("NB_INCR_CAL_ENERG ");
|
||
|
else if (nom == "AFFICHE_INCR_ENERGIE")
|
||
|
affiche_incr_energie= (bool) entreePrinc.lect_avec_const_double_utilisateur("AFFICHE_INCR_ENERGIE ");
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture des parametres sur l'energie" << nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des parametres des parametres sur l'energie **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
}
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
}
|
||
|
};
|
||
|
|
||
|
// 8) paramètres liés aux calculs géométriques sur les éléments
|
||
|
if (strstr(entreePrinc.tablcar,"para_calculs_geometriques")!=NULL)
|
||
|
{ para_calculs_geometriques_lec = true; // on signal qu'il y a lecture
|
||
|
// on lit jusqu'au prochain mot cle
|
||
|
string nom;
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
while ( !motCle.SimotCle(entreePrinc.tablcar))
|
||
|
{ *(entreePrinc.entree) >> nom;
|
||
|
if (nom == "POINT_INTERNE_DELTA_THETAI_MAXI")
|
||
|
{point_interne_delta_thetai_maxi= entreePrinc.lect_avec_const_double_utilisateur("POINT_INTERNE_DELTA_THETAI_MAXI ");}
|
||
|
else if (nom == "POINT_INTERNE_PREC_THETAI_INTERNE")
|
||
|
{point_interne_prec_thetai_interne= entreePrinc.lect_avec_const_double_utilisateur("POINT_INTERNE_PREC_THETAI_INTERNE ");}
|
||
|
else if (nom == "POINT_INTERNE_NB_BOUCLE_SUR_DELTA_THETAI")
|
||
|
{point_interne_nb_boucle_sur_delta_thetai= (int) entreePrinc.lect_avec_const_double_utilisateur("POINT_INTERNE_NB_BOUCLE_SUR_DELTA_THETAI ");}
|
||
|
else if (nom == "POINT_INTERNE_NB_EXTERNE")
|
||
|
{point_interne_nb_externe= (int) entreePrinc.lect_avec_const_double_utilisateur("POINT_INTERNE_NB_EXTERNE ");}
|
||
|
else if (nom == "CAL_VOL_TOTAL_ENTRE_SURFACE_ET_PLANS_REF")
|
||
|
{cal_vol_total_entre_surface_et_plans_ref= (bool) entreePrinc.lect_avec_const_double_utilisateur("CAL_VOL_TOTAL_ENTRE_SURFACE_ET_PLANS_REF ");}
|
||
|
else if (nom == "RATIO_MAXI_JACOMEMBRANE_JACOPTI" )
|
||
|
{ratio_maxi_jacoMembrane_jacoPti= entreePrinc.lect_avec_const_double_utilisateur("RATIO_MAXI_JACOMEMBRANE_JACOPTI ");}
|
||
|
else if (nom == "TYPE_CALNUM_INVERSION_METRIQUE")
|
||
|
{ *(entreePrinc.entree) >> type_calnum_inversion_metrique;}
|
||
|
else
|
||
|
{ cout << "\n ** erreur en lecture des parametres de calculs geometrique: mot cle inconnu : " << nom;
|
||
|
entreePrinc.MessageBuffer
|
||
|
("** lecture des parametres des parametres sur l'energie **");
|
||
|
Affiche();
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
}
|
||
|
entreePrinc.NouvelleDonnee();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}; // fin de la lecture tant qu'il y a un mot clé relatif à la lecture de paramètres
|
||
|
// affichage d'information concernant les paramètres
|
||
|
if ((ParaGlob::NiveauImpression() >= 4 ) && (ParaGlob::param->EtatDeLaLecturePointInfo()==0))
|
||
|
{ if (!controle_lec)
|
||
|
{ cout << "\n lecture des parametres de controle ";
|
||
|
cout << "\n **** ATTENTION utilisation de TOUS les parametres par defaut !! " << flush;
|
||
|
};
|
||
|
if (!para_systeme_lineaire_lec)
|
||
|
{ cout << "\n lecture des parametres pour le syteme lineaire ";
|
||
|
cout << "\n **** ATTENTION utilisation de TOUS les parametres par defaut !! " << flush;
|
||
|
};
|
||
|
if (!para_pilotage_equi_global_lec)
|
||
|
{ cout << "\n ** lecture des parametres du pilotage de l'equilibre global **";
|
||
|
cout << "\n **** ATTENTION utilisation de TOUS les parametres par defaut !! " << flush;
|
||
|
};
|
||
|
if (!para_dedies_dynamique_lec)
|
||
|
{ cout << "\n ** lecture des parametres parametres lies a la dynamique **";
|
||
|
cout << "\n **** ATTENTION utilisation de TOUS les parametres par defaut !! " << flush;
|
||
|
};
|
||
|
if (!para_affichage_lec)
|
||
|
{ cout << "\n ** lecture des parametres parametres lies a l'affichage **";
|
||
|
cout << "\n **** ATTENTION utilisation de TOUS les parametres par defaut !! " << flush;
|
||
|
};
|
||
|
if (!para_contact_lec)
|
||
|
{ cout << "\n ** lecture des parametres parametres lies au contact **";
|
||
|
cout << "\n **** ATTENTION utilisation de TOUS les parametres par defaut !! " << flush;
|
||
|
}
|
||
|
if (!para_energie_lec)
|
||
|
{ cout << "\n ** lecture des parametres parametres lies aux energies **";
|
||
|
cout << "\n **** ATTENTION utilisation de TOUS les parametres par defaut !! " << flush;
|
||
|
}
|
||
|
if (!para_calculs_geometriques_lec)
|
||
|
{ cout << "\n ** lecture des parametres parametres lies aux calculs geometriques **";
|
||
|
cout << "\n **** ATTENTION utilisation de TOUS les parametres par defaut !! " << flush;
|
||
|
};
|
||
|
};
|
||
|
if ((ParaGlob::NiveauImpression() > 0 ) && (ParaGlob::param->EtatDeLaLecturePointInfo()> 0))
|
||
|
{ if (controle_lec)
|
||
|
cout << "\n relecture de certains(s) parametre(s) de controle " << flush;
|
||
|
if (para_systeme_lineaire_lec)
|
||
|
cout << "\n relecture de certains(s) parametre(s) pour le syteme lineaire " << flush;
|
||
|
if (para_pilotage_equi_global_lec)
|
||
|
cout << "\n ** relecture de certains(s) parametre(s) du pilotage de l'equilibre global **" << flush;
|
||
|
if (para_dedies_dynamique_lec)
|
||
|
cout << "\n ** relecture de certains(s) parametre(s) lies a la dynamique **" << flush;
|
||
|
if (para_affichage_lec)
|
||
|
cout << "\n ** relecture de certains(s) parametre(s) lies a l'affichage **" << flush;
|
||
|
if (para_contact_lec)
|
||
|
cout << "\n ** relecture de certains(s) parametre(s) lies au contact **" << flush;
|
||
|
if (para_energie_lec)
|
||
|
cout << "\n ** relecture de certains(s) parametre(s) lies aux energies **" << flush;
|
||
|
if (para_calculs_geometriques_lec)
|
||
|
cout << "\n ** relecture de certains(s) parametre(s) lies aux calculs geometriques **" << flush;
|
||
|
};
|
||
|
|
||
|
if (ParaGlob::NiveauImpression() >= 4 )
|
||
|
{ // vérification sur les paramètres temps
|
||
|
if (tempo.deltatmaxi < tempo.deltatmini)
|
||
|
{ cout << "\n ***erreur en lecture des parametres de controle du temps: deltat maxi "
|
||
|
<< tempo.deltatmaxi << " est inferieur eu deltat mini " << tempo.deltatmini;
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
};
|
||
|
if (tempo.deltatmini < 0.)
|
||
|
{ cout << "\n ***erreur en lecture des parametres de controle du temps: deltat mini est negatif: "
|
||
|
<< tempo.deltatmini;
|
||
|
throw (UtilLecture::ErrNouvelleDonnee(-1));
|
||
|
Sortie (1);
|
||
|
};
|
||
|
};
|
||
|
// particularité liée au paramètre max_essai_incre
|
||
|
if (!lecture_max_essai_incre) // s'il n'y a pas eu de lecture du paramètre max_essai_incre
|
||
|
max_essai_incre = maxincre; // on le met à la valeur par défaut = maxincre
|
||
|
|
||
|
if (ParaGlob::NiveauImpression() >= 4)
|
||
|
cout << " \n fin de la lecture des parametres " << endl;
|
||
|
};
|
||
|
|
||
|
// sauvegarde propre de l'élément sur base info
|
||
|
// cas donne le niveau de sauvegarde
|
||
|
// = 1 : on sauvegarde tout
|
||
|
// = 2 : on sauvegarde uniquement les données variables (supposées comme telles)
|
||
|
// incre : numero d'incrément auquel on sauvegarde
|
||
|
// éventuellement est définit de manière spécifique pour chaque algorithme
|
||
|
// dans les classes filles
|
||
|
void ParaAlgoControle::Ecriture_base_info_Para
|
||
|
(ofstream& sort,const int cas) const
|
||
|
{// dans le cas particulier de cette classe il n'y a que les paramètres
|
||
|
// du calcul qu'il faut sauvegarder
|
||
|
sort << "\n";
|
||
|
switch (cas)
|
||
|
{ case 1 : // ------- on sauvegarde tout -------------------------
|
||
|
{// 1) parametres de controle généraux pour la résolution de l'équilibre
|
||
|
// générale
|
||
|
sort << "PARAMETRES_DU_CALCUL_:\n";
|
||
|
sort << "frequence_de_sauvegarde " << sauvegarde << "\n";
|
||
|
sort << "casDeGestion_de_sauvegarde " << cas_de_sauvegarde << "\n";
|
||
|
sort << "force_deltat_du_point_info " << force_deltat << "\n";
|
||
|
sort << "coef_pas_critique_deltatmaxi " << coef_pas_critique_deltatmaxi << "\n";
|
||
|
sort << "coef_pas_critique_deltatmini " << coef_pas_critique_deltatmini << "\n";
|
||
|
sort << "typeDFC_pas_critique_deltatmaxi " << typeDFC_pas_critique_deltatmaxi << "\n";
|
||
|
sort << "typeDFC_pas_critique_deltatmini " << typeDFC_pas_critique_deltatmini << "\n";
|
||
|
sort << "maxi_d'iteration_pour_converger " << iterations << "\n";
|
||
|
sort << "precision_de_la_convergence " << precision << "\n";
|
||
|
// sort << "precision_sur_le_temps_final " << tempo.prectemps << "\n";
|
||
|
sort << "type_de_norme_de_convergence " << norme << "\n";
|
||
|
sort << "cinematique_sur_l'increment " << cinematique << "\n";
|
||
|
sort << "convergence_forcee " << conv_forcee << "\n";
|
||
|
sort << "multiplicateur_de_la_charge " << multiplicateur << "\n";
|
||
|
// sort << "increment_de_temps " << tempo.deltat << "\n";
|
||
|
sort << "coef_pas_critique_deltat " << coef_pas_critique_deltat << "\n";
|
||
|
sort << "typeDFC_pas_critique_deltat " << typeDFC_pas_critique_deltat << "\n";
|
||
|
// sort << "temps_de_fin_de_calcul " << tempo.tempsfin << "\n";
|
||
|
sort << "maximum_d'increment_de_temps " << maxincre << "\n";
|
||
|
sort << "maximum_d'essai_d'increment_de_temps " << max_essai_incre << "\n";
|
||
|
sort << "increment_de_redemarage_de_calcul " << restart << "\n";
|
||
|
sort << "maximum_de_puissance " << max_puissance << "\n";
|
||
|
sort << "utilisation_du_line_search " << line_search << '\n';
|
||
|
sort << "var_charge_externe " << var_charge_externe << '\n';
|
||
|
sort << "var_jacobien " << var_jacobien << '\n';
|
||
|
sort << "var_D " << var_D << '\n';
|
||
|
// sauvegarde du temps
|
||
|
tempo_specifique_algo.Ecriture_base_info_temps(sort,cas);
|
||
|
|
||
|
// 2) paramètres liés au systèmes d'équation linéairelinéaire
|
||
|
sort << "PARAMETRES_SYSTEM_LINEAIRE_:\n";
|
||
|
sort << "type_de_matrice " << type_matrice << "\n";
|
||
|
sort << "symetrie_matrice " << symetrie_matrice << "\n";
|
||
|
sort << "type_de_resolution " << type_resolution << "\n";
|
||
|
sort << "type_de_preconditionnement " << type_preconditionnement << "\n";
|
||
|
sort << "nombre_iteration_non_directe " << nb_iter_nondirecte << "\n";
|
||
|
sort << "tolerance_resol_non_directe " << tolerance << "\n";
|
||
|
sort << "nb_vecteur_restart " << nb_vect_restart << "\n";
|
||
|
// maintenant les listes pour les matrices secondaires si nécessaire
|
||
|
sort << " liste_pour_matrice_secondaire_ \n ";
|
||
|
if (!type_matrice_secondaire.empty())
|
||
|
{ sort << "type_matrice_secondaire(s)_taille: " << type_matrice_secondaire.size() << " \n";
|
||
|
list < Enum_matrice >::const_iterator ili,ili_end=type_matrice_secondaire.end();
|
||
|
for (ili = type_matrice_secondaire.begin();ili != ili_end;ili++)
|
||
|
sort << " " << (*ili) ;
|
||
|
sort << "\n";
|
||
|
};
|
||
|
|
||
|
if (!type_resolution_secondaire.empty())
|
||
|
{ sort << "type_resolution_secondaire(s)_taille: " << type_resolution_secondaire.size() << " \n";
|
||
|
list < Enum_type_resolution_matri >::const_iterator ili,ili_end=type_resolution_secondaire.end();
|
||
|
for (ili = type_resolution_secondaire.begin();ili != ili_end;ili++)
|
||
|
sort << " " << (*ili) ;
|
||
|
sort << "\n";
|
||
|
};
|
||
|
|
||
|
if (!type_preconditionnement_secondaire.empty())
|
||
|
{ sort << "type_preconditionnement_secondaire(s)_taille: " << type_preconditionnement_secondaire.size() << " \n";
|
||
|
list < Enum_preconditionnement >::const_iterator ili,ili_end=type_preconditionnement_secondaire.end();
|
||
|
for (ili = type_preconditionnement_secondaire.begin();ili != ili_end;ili++)
|
||
|
sort << " " << (*ili) ;
|
||
|
sort << "\n";
|
||
|
};
|
||
|
|
||
|
if (!nb_iter_nondirecte_secondaire.empty())
|
||
|
{ sort << "nb_iter_nondirecte_secondaire(s)_taille: " << nb_iter_nondirecte_secondaire.size() << " \n";
|
||
|
list < int >::const_iterator ili,ili_end=nb_iter_nondirecte_secondaire.end();
|
||
|
for (ili = nb_iter_nondirecte_secondaire.begin();ili != ili_end;ili++)
|
||
|
sort << " " << (*ili) ;
|
||
|
sort << "\n";
|
||
|
};
|
||
|
|
||
|
if (!tolerance_secondaire.empty())
|
||
|
{ sort << "tolerance_secondaire(s)_taille: " << tolerance_secondaire.size() << " \n";
|
||
|
list < double >::const_iterator ili,ili_end=tolerance_secondaire.end();
|
||
|
for (ili = tolerance_secondaire.begin();ili != ili_end;ili++)
|
||
|
sort << " " << (*ili) ;
|
||
|
sort << "\n";
|
||
|
};
|
||
|
|
||
|
if (!nb_vect_restart_secondaire.empty())
|
||
|
{ sort << "nb_vect_restart_secondaire(s)_taille: " << nb_vect_restart_secondaire.size() << " \n";
|
||
|
list < int >::const_iterator ili,ili_end=nb_vect_restart_secondaire.end();
|
||
|
for (ili = nb_vect_restart_secondaire.begin();ili != ili_end;ili++)
|
||
|
sort << " " << (*ili) ;
|
||
|
sort << "\n";
|
||
|
};
|
||
|
sort << " fin_liste_pour_matrice_secondaire_ \n ";
|
||
|
sort << "OPTIMISATION_POINTEURS_ASSEMBLAGE " << opti_pointeur_assemblage << "\n";
|
||
|
|
||
|
// 3) paramètres liés au pilotage de l'équilibre global
|
||
|
sort << "PARAMETRES_PILOTAGE_EQUILIBRE_GLOBAL:\n";
|
||
|
sort << "typ_de_pilotage " << Nom_TypePilotage(type_de_pilotage) << "\n";
|
||
|
sort << "facteur_diminution " << facteur_diminution << "\n";
|
||
|
sort << "facteur_augmentation " << facteur_augmentation << "\n";
|
||
|
sort << "nb_bonne_convergence " << nb_bonne_convergence << "\n";
|
||
|
sort << "fact_dim_en_mauvaiseConv " << fact_dim_en_mauvaiseConv << "\n";
|
||
|
sort << "nb_iter_pour_bonne_convergence " << nb_iter_pour_bonne_convergence << "\n";
|
||
|
sort << "nb_iter_pour_mauvaise_convergence " << nb_iter_pour_mauvaise_convergence << "\n";
|
||
|
sort << "init_comp_tangent_simple " << init_comp_tangent_simple << "\n";
|
||
|
sort << "sur_sous_relaxation " << sur_sous_relaxation << "\n";
|
||
|
sort << "norme_maxi_increment " << norme_incre_max << "\n";
|
||
|
sort << "norme_maxi_X_increment " << norme_incre_X_max << "\n";
|
||
|
sort << "norme_maxi_V_increment " << norme_incre_V_max << "\n";
|
||
|
sort << "maxi_variation_ddl_pour_convergence " << varMaxiDdl << "\n";
|
||
|
sort << "mini_variation_ddl_pour_convergence " << varMiniDdl << "\n";
|
||
|
sort << "nb_cycle_controle_residu " << nbCycleControleResidu << "\n";
|
||
|
sort << "plage_controle_residu " << plageControleResidu << "\n";
|
||
|
sort << "init_incre_avec_pas_prec " << initIncreAvecDeltaDdlPrec << "\n";
|
||
|
sort << "jabobien_negatif " << jabobien_negatif << "\n";
|
||
|
sort << "var_maxi_jacobien " << var_maxi_jacobien << "\n";
|
||
|
sort << "cas_fctnD_charge " << cas_fctnD_charge << "\n";
|
||
|
// 4) paramètres liès à la dynamique
|
||
|
sort << "PARAMETRES_DEDIES_DYNAMIQUE:\n";
|
||
|
sort << "type_calcul_masse " << type_calcul_masse << "\n";
|
||
|
sort << "limitation_temps_maxi_stable " << limitation_temps_maxi_stable << "\n";
|
||
|
sort << "amorti_visco_artificielle " << amort_visco_arti << "\n";
|
||
|
sort << "coeff_visco_artificielle " << visco_arti << "\n";
|
||
|
sort << "maxi_C_en_fonction_M " << maxi_C_en_fonction_M << "\n";
|
||
|
sort << "coeff_rayleigh_masse " << coef_rayleigh_masse << "\n";
|
||
|
sort << "coeff_rayleigh_raideur " << coef_rayleigh_raideur << "\n";
|
||
|
sort << "bulk_viscosity " << bulk_viscosity << "\n";
|
||
|
sort << "c_Tracebulk " << c_Tracebulk << "\n";
|
||
|
sort << "c_Trace2bulk " << c_Trace2bulk << "\n";
|
||
|
// 5) paramètres liès à l'affichage des résultats
|
||
|
sort << "PARAMETRES_AFFICHAGE:\n";
|
||
|
sort << "FREQUENCE_AFFICHAGE_INCREMENT " << frequence_affichage_increment << "\n";
|
||
|
sort << "FREQUENCE_AFFICHAGE_ITERATION " << frequence_affichage_iteration << "\n";
|
||
|
sort << "FREQUENCE_SORTIE_FIL_DU_CALCUL " << sortie_fil_calcul << "\n";
|
||
|
sort << "CAS_DE_FREQUENCE_SORTIE_FIL_CALCUL " << cas_de_sortie_fil_calcul << "\n";
|
||
|
sort << "NB_CHIFFRE_POUR_DOUBLE_CALCUL " << nb_diggit_double_calcul << "\n";
|
||
|
sort << "NB_CHIFFRE_POUR_DOUBLE_GRAPHIQUE " << nb_diggit_double_graphique << "\n";
|
||
|
sort << "NB_CHIFFRE_POUR_DOUBLE_ECRAN " << nb_diggit_double_ecran << "\n";
|
||
|
// 6) paramètres liès au contact
|
||
|
sort << "PARAMETRES_CONTACT:\n";
|
||
|
sort << "PRECISION_POINT_INTERNE_DEBUT " << prec_pt_int_deb << "\n";
|
||
|
sort << "FACT_POUR_RAYON_ACCOSTAGE " << factPourRayonAccostage << "\n";
|
||
|
sort << "DISTANCE_MAXI_AU_PT_PROJETE " << distanceMaxiAuPtProjete << "\n";
|
||
|
sort << "PRECISION_BOITE_PRELOCALISATION " << extra_boite_prelocalisation << "\n";
|
||
|
sort << "MINI_EXTRA_BOITE_PRELOCALISATION " << mini_extra_boite_prelocalisation << "\n";
|
||
|
sort << "AJOUT_EXTRA_BOITE_PRELOCALISATION " << ajout_extra_boite_prelocalisation << "\n";
|
||
|
sort << "CONTACT_TYPE " << contact_type << "\n";
|
||
|
sort << "FCT_ND_BASCUL_CONTACT_TYPE_4 " << fct_nD_bascul_contact_type_4 << "\n";
|
||
|
sort << "PENALISATION_PENETRATION " << penalisationPenetration
|
||
|
<< "FCT_ND_PENALISATION_PENETRATION"<< fct_nD_penalisationPenetration <<"\n";
|
||
|
sort << "TYPE_PENALISATION_PENETRATION " << typePenalisationPenetration << "\n";
|
||
|
sort << "PENETRATION_CONTACT_MAXI " << penetration_contact_maxi
|
||
|
<< "FCT_ND_PENETRATION_CONTACT_MAXI"<< fct_nD_penetration_contact_maxi <<"\n";
|
||
|
sort << "PENETRATION_BORNE_REGULARISATION " << penetration_borne_regularisation
|
||
|
<< "FCT_ND_PENETRATION_BORNE_REGULARISATION"<< fct_nD_penetration_borne_regularisation <<"\n";
|
||
|
sort << "FORCE_CONTACT_NOEUD_MAXI " << force_contact_noeud_maxi
|
||
|
<< "FCT_ND_FORCE_CONTACT_NOEUD_MAXI"<< fct_nD_force_contact_noeud_maxi <<"\n";
|
||
|
sort << "PENALISATION_TANGENTIELLE " << penalisationTangentielle
|
||
|
<< "FCT_ND_PENALISATION_TANGENTIELLE"<< fct_nD_penalisationTangentielle <<"\n";
|
||
|
sort << "TYPE_PENALISATION_TANGENTIELLE " << typePenalisationTangentielle << "\n";
|
||
|
sort << "TANGENTIELLE_CONTACT_MAXI " << tangentielle_contact_maxi
|
||
|
<< "FCT_ND_TANGENTIELLE_CONTACT_MAXI"<< fct_nD_tangentielle_contact_maxi <<"\n";
|
||
|
sort << "TANGENTIELLE_BORNE_REGULARISATION " << tangentielle_borne_regularisation
|
||
|
<< "FCT_ND_TANGENTIELLE_BORNE_REGULARISATION"<< fct_nD_tangentielle_borne_regularisation <<"\n";
|
||
|
sort << "FORCE_TANGENTIELLE_NOEUD_MAXI " << force_tangentielle_noeud_maxi
|
||
|
<< "FCT_ND_FORCE_TANGENTIELLE_NOEUD_MAXI"<< fct_nD_force_tangentielle_noeud_maxi <<"\n";
|
||
|
|
||
|
sort << "PRECISION_PT_SUR_FRONTIERE " << prec_pt_sur_frontiere << "\n";
|
||
|
sort << "NB_BOUCLE_NEWTON_SUR_POSITION_FRONTIERE " << nb_boucle_newton_position_frontiere << "\n";
|
||
|
sort << "NB_DECOLLEMENT_MAXI " << nbDecolAutorise << "\n";
|
||
|
sort << "TYPE_DE_DECOLLEMENT " << typeDeDecolement << "\n";
|
||
|
sort << "NB_MOY_GLISSANT " << nb_glissant << "\n";
|
||
|
sort << "NIVEAU_COMMENTAIRE_CONTACT "<< niveau_commentaire_contact << "\n";
|
||
|
sort << "OPTIMISATION_NUMEROTATION "<< optimisation_numerotation << "\n";
|
||
|
|
||
|
// 7) paramètres liès aux énergies
|
||
|
sort << "PARAMETRES_ENERGIES:\n";
|
||
|
sort << "NB_INCR_CAL_ENERG " << nb_incr_cal_ener << "\n";
|
||
|
sort << "AFFICHE_INCR_ENERGIE " << affiche_incr_energie << "\n";
|
||
|
// 8) paramètres liés aux calculs géométriques sur les éléments
|
||
|
sort << "PARAMETRES_CALCULS_GEOMETRIQUES:\n";
|
||
|
sort << "POINT_INTERNE_DELTA_THETAI_MAXI " << point_interne_delta_thetai_maxi << "\n";
|
||
|
sort << "POINT_INTERNE_PREC_THETAI_INTERNE " << point_interne_prec_thetai_interne << "\n";
|
||
|
sort << "POINT_INTERNE_NB_BOUCLE_SUR_DELTA_THETAI " << point_interne_nb_boucle_sur_delta_thetai << "\n";
|
||
|
sort << "POINT_INTERNE_NB_EXTERNE " << point_interne_nb_externe << "\n";
|
||
|
sort << "CAL_VOL_TOTAL_ENTRE_SURFACE_ET_PLANS_REF " << cal_vol_total_entre_surface_et_plans_ref << "\n";
|
||
|
sort << "RATIO_MAXI_JACOMEMBRANE_JACOPTI " << ratio_maxi_jacoMembrane_jacoPti << "\n";
|
||
|
sort << "TYPE_CALNUM_INVERSION_METRIQUE " << type_calnum_inversion_metrique << "\n";
|
||
|
sort << flush;
|
||
|
break;
|
||
|
}
|
||
|
case 2 : // ----------- sauvegarde uniquement de se qui varie --------------------
|
||
|
{// paramètres relatifs au temps
|
||
|
tempo_specifique_algo.Ecriture_base_info_temps(sort,cas);
|
||
|
break;
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
// cas de la lecture spécifique à l'algorithme dans base_info
|
||
|
void ParaAlgoControle::Lecture_base_info_Para(ifstream& ent,const int cas)
|
||
|
{ // dans le cas particulier de cette classe il n'y a que les paramètres
|
||
|
// du calcul qu'il faut lire
|
||
|
switch (cas)
|
||
|
{ case 1 : // lecture complète
|
||
|
{string toto;
|
||
|
ent >> toto;
|
||
|
ent >> toto >> sauvegarde ;
|
||
|
ent >> toto >> cas_de_sauvegarde ;
|
||
|
ent >> toto >> force_deltat ;
|
||
|
ent >> toto >> coef_pas_critique_deltatmaxi ;
|
||
|
ent >> toto >> coef_pas_critique_deltatmini ;
|
||
|
ent >> toto >> typeDFC_pas_critique_deltatmaxi ;
|
||
|
ent >> toto >> typeDFC_pas_critique_deltatmini ;
|
||
|
ent >> toto >> iterations ;
|
||
|
ent >> toto >> precision ;
|
||
|
ent >> toto >> norme ;
|
||
|
ent >> toto >> cinematique ;
|
||
|
ent >> toto >> conv_forcee ;
|
||
|
ent >> toto >> multiplicateur ;
|
||
|
ent >> toto >> coef_pas_critique_deltat ;
|
||
|
ent >> toto >> typeDFC_pas_critique_deltat ;
|
||
|
ent >> toto >> maxincre ;
|
||
|
ent >> toto >> max_essai_incre ;
|
||
|
ent >> toto >> restart ;
|
||
|
ent >> toto >> max_puissance ;
|
||
|
ent >> toto >> line_search ;
|
||
|
ent >> toto >> var_charge_externe ;
|
||
|
ent >> toto >> var_jacobien ;
|
||
|
ent >> toto >> var_D ;
|
||
|
// lecture du temps
|
||
|
tempo_specifique_algo.Lecture_base_info_temps(ent,cas);
|
||
|
|
||
|
// 2) paramètres liés au systèmes d'équation linéairelinéaire
|
||
|
ent >> toto ;
|
||
|
ent >> toto >> type_matrice ;
|
||
|
ent >> toto >> symetrie_matrice ;
|
||
|
ent >> toto >> type_resolution ;
|
||
|
ent >> toto >> type_preconditionnement ;
|
||
|
ent >> toto >> nb_iter_nondirecte ;
|
||
|
ent >> toto >> tolerance ;
|
||
|
ent >> toto >> nb_vect_restart ;
|
||
|
|
||
|
// maintenant les listes pour les matrices secondaires si nécessaire
|
||
|
ent >> toto ; // passage du mot clé
|
||
|
while (toto != "fin_liste_pour_matrice_secondaire_")
|
||
|
{ ent >> toto ; // on lit le mot clé
|
||
|
if (toto == "type_matrice_secondaire(s)_taille:")
|
||
|
{ type_matrice_secondaire.clear(); // on vide la liste
|
||
|
int taille = 0;
|
||
|
ent >> taille;
|
||
|
for (int i=1;i<=taille;i++)
|
||
|
{ ent >> toto;
|
||
|
type_matrice_secondaire.push_back(Id_nom_matrice(toto));
|
||
|
};
|
||
|
}
|
||
|
else if (toto == "type_resolution_secondaire(s)_taille:")
|
||
|
{ type_resolution_secondaire.clear(); // on vide la liste
|
||
|
int taille = 0;
|
||
|
ent >> taille;
|
||
|
for (int i=1;i<=taille;i++)
|
||
|
{ ent >> toto;
|
||
|
type_resolution_secondaire.push_back(Id_nom_resolution(toto));
|
||
|
};
|
||
|
}
|
||
|
else if (toto == "type_preconditionnement_secondaire(s)_taille:")
|
||
|
{ type_preconditionnement_secondaire.clear(); // on vide la liste
|
||
|
int taille = 0;
|
||
|
ent >> taille;
|
||
|
for (int i=1;i<=taille;i++)
|
||
|
{ ent >> toto;
|
||
|
type_preconditionnement_secondaire.push_back(Id_nom_preconditionnement(toto));
|
||
|
};
|
||
|
}
|
||
|
else if (toto == "nb_iter_nondirecte_secondaire(s)_taille:")
|
||
|
{ nb_iter_nondirecte_secondaire.clear(); // on vide la liste
|
||
|
int taille = 0;
|
||
|
ent >> taille;
|
||
|
for (int i=1;i<=taille;i++)
|
||
|
{ ent >> toto;
|
||
|
nb_iter_nondirecte_secondaire.push_back(ChangeEntier(toto));
|
||
|
};
|
||
|
}
|
||
|
else if (toto == "tolerance_secondaire(s)_taille:")
|
||
|
{ tolerance_secondaire.clear(); // on vide la liste
|
||
|
int taille = 0;
|
||
|
ent >> taille;
|
||
|
for (int i=1;i<=taille;i++)
|
||
|
{ ent >> toto;
|
||
|
tolerance_secondaire.push_back(ChangeReel(toto));
|
||
|
};
|
||
|
}
|
||
|
else if (toto == "nb_vect_restart_secondaire(s)_taille:")
|
||
|
{ nb_vect_restart_secondaire.clear(); // on vide la liste
|
||
|
int taille = 0;
|
||
|
ent >> taille;
|
||
|
for (int i=1;i<=taille;i++)
|
||
|
{ ent >> toto;
|
||
|
nb_vect_restart_secondaire.push_back(ChangeEntier(toto));
|
||
|
};
|
||
|
}
|
||
|
else if (toto == "fin_liste_pour_matrice_secondaire_")
|
||
|
{ } // on ne fait rien c'est ok
|
||
|
else
|
||
|
{cout << "\n erreur en lecture des listes pour matrices secondaires: "
|
||
|
<< " on a lu: "<< toto << " et on ne sait pas quoi en faire !! "
|
||
|
<< "\n ParaAlgoControle::Lecture_base_info_Para(.. "
|
||
|
<< endl;
|
||
|
Sortie(1);
|
||
|
};
|
||
|
};
|
||
|
ent >> toto >> opti_pointeur_assemblage;
|
||
|
|
||
|
|
||
|
// 3) paramètres liés au pilotage de l'équilibre global
|
||
|
ent >> toto ;
|
||
|
ent >> toto >> facteur_diminution;
|
||
|
ent >> toto >> type_de_pilotage;
|
||
|
ent >> toto >> facteur_augmentation;
|
||
|
ent >> toto >> nb_bonne_convergence;
|
||
|
ent >> toto >> fact_dim_en_mauvaiseConv;
|
||
|
ent >> toto >> nb_iter_pour_bonne_convergence;
|
||
|
ent >> toto >> nb_iter_pour_mauvaise_convergence;
|
||
|
ent >> toto >> init_comp_tangent_simple;
|
||
|
ent >> toto >> sur_sous_relaxation;
|
||
|
ent >> toto >> norme_incre_max;
|
||
|
ent >> toto >> norme_incre_X_max;
|
||
|
ent >> toto >> norme_incre_V_max;
|
||
|
ent >> toto >> varMaxiDdl;
|
||
|
ent >> toto >> varMiniDdl;
|
||
|
ent >> toto >> nbCycleControleResidu ;
|
||
|
ent >> toto >> plageControleResidu ;
|
||
|
ent >> toto >> initIncreAvecDeltaDdlPrec ;
|
||
|
ent >> toto >> jabobien_negatif ;
|
||
|
ent >> toto >> var_maxi_jacobien ;
|
||
|
ent >> toto >> cas_fctnD_charge ;
|
||
|
// 4) paramètres liès à la dynamique
|
||
|
ent >> toto ;
|
||
|
ent >> toto >> type_calcul_masse ;
|
||
|
ent >> toto >> limitation_temps_maxi_stable ;
|
||
|
ent >> toto >> amort_visco_arti ;
|
||
|
ent >> toto >> visco_arti ;
|
||
|
ent >> toto >> maxi_C_en_fonction_M ;
|
||
|
ent >> toto >> coef_rayleigh_masse ;
|
||
|
ent >> toto >> coef_rayleigh_raideur ;
|
||
|
ent >> toto >> bulk_viscosity ;
|
||
|
ent >> toto >> c_Tracebulk ;
|
||
|
ent >> toto >> c_Trace2bulk ;
|
||
|
// 5) paramètres liès à l'affichage des résultats
|
||
|
ent >> toto ;
|
||
|
ent >> toto >> frequence_affichage_increment ;
|
||
|
ent >> toto >> frequence_affichage_iteration ;
|
||
|
ent >> toto >> sortie_fil_calcul ;
|
||
|
ent >> toto >> cas_de_sortie_fil_calcul ;
|
||
|
ent >> toto >> nb_diggit_double_calcul ;
|
||
|
ent >> toto >> nb_diggit_double_graphique ;
|
||
|
ent >> toto >> nb_diggit_double_ecran ;
|
||
|
// 6) paramètres liès au contact
|
||
|
ent >> toto ;
|
||
|
ent >> toto >> prec_pt_int_deb ;
|
||
|
ent >> toto >> factPourRayonAccostage ;
|
||
|
ent >> toto >> distanceMaxiAuPtProjete;
|
||
|
ent >> toto >> extra_boite_prelocalisation ;
|
||
|
ent >> toto >> mini_extra_boite_prelocalisation ;
|
||
|
ent >> toto >> ajout_extra_boite_prelocalisation ;
|
||
|
ent >> toto >> contact_type ;
|
||
|
ent >> toto >> fct_nD_bascul_contact_type_4 ;
|
||
|
ent >> toto >> penalisationPenetration >> toto >> fct_nD_penalisationPenetration;
|
||
|
ent >> toto >> typePenalisationPenetration ;
|
||
|
ent >> toto >> penetration_contact_maxi >> toto >> fct_nD_penetration_contact_maxi ;
|
||
|
ent >> toto >> penetration_borne_regularisation >> toto >> fct_nD_penetration_borne_regularisation;
|
||
|
ent >> toto >> force_contact_noeud_maxi >> toto >> fct_nD_force_contact_noeud_maxi;
|
||
|
ent >> toto >> penalisationTangentielle >> toto >> fct_nD_penalisationTangentielle;
|
||
|
ent >> toto >> typePenalisationTangentielle ;
|
||
|
ent >> toto >> tangentielle_contact_maxi >> toto >> fct_nD_tangentielle_contact_maxi ;
|
||
|
ent >> toto >> tangentielle_borne_regularisation >> toto >> fct_nD_tangentielle_borne_regularisation;
|
||
|
ent >> toto >> force_tangentielle_noeud_maxi >> toto >> fct_nD_force_tangentielle_noeud_maxi ;
|
||
|
ent >> toto >> prec_pt_sur_frontiere ;
|
||
|
ent >> toto >> nb_boucle_newton_position_frontiere ;
|
||
|
ent >> toto >> nbDecolAutorise ;
|
||
|
ent >> toto >> typeDeDecolement ;
|
||
|
ent >> toto >> nb_glissant ;
|
||
|
// 7) paramètres liès aux énergies
|
||
|
ent >> toto ;
|
||
|
ent >> toto >> nb_incr_cal_ener ;
|
||
|
ent >> toto >> affiche_incr_energie ;
|
||
|
// 8) paramètres liés aux calculs géométriques sur les éléments
|
||
|
ent >> toto ;
|
||
|
ent >> toto >> point_interne_delta_thetai_maxi ;
|
||
|
ent >> toto >> point_interne_prec_thetai_interne ;
|
||
|
ent >> toto >> point_interne_nb_boucle_sur_delta_thetai ;
|
||
|
ent >> toto >> point_interne_nb_externe ;
|
||
|
ent >> toto >> cal_vol_total_entre_surface_et_plans_ref ;
|
||
|
ent >> toto >> ratio_maxi_jacoMembrane_jacoPti ;
|
||
|
ent >> toto >> type_calnum_inversion_metrique ;
|
||
|
break;
|
||
|
}
|
||
|
case 2 : // lecture uniquement de ce qui varie
|
||
|
{// lecture du temps
|
||
|
if (force_deltat && (restart!=0))
|
||
|
{ // cas du premier passage, et d'un restart
|
||
|
// cas ou on veut forcer l'état de deltat à la valeur du .info (ou autre valeur initiale)
|
||
|
double sauve_deltat = tempo_specifique_algo.deltat; // sauvegarde de la valeur initiale
|
||
|
tempo_specifique_algo.Lecture_base_info_temps(ent,cas);
|
||
|
tempo_specifique_algo.deltat = sauve_deltat; // récup de la valeur précédente
|
||
|
force_deltat = false;
|
||
|
tempo = tempo_specifique_algo;
|
||
|
}
|
||
|
else
|
||
|
{// cas courant
|
||
|
tempo_specifique_algo.Lecture_base_info_temps(ent,cas);
|
||
|
tempo = tempo_specifique_algo;
|
||
|
};
|
||
|
break;
|
||
|
};
|
||
|
} // -- fin du switch
|
||
|
};
|
||
|
|
||
|
// affichage des parametres de controle de l'algorithme
|
||
|
// et affichage des paramètres liés à la résolution du système linéaire
|
||
|
void ParaAlgoControle::Affiche() const
|
||
|
{
|
||
|
// 1) parametres de controle généraux pour la résolution de l'équilibre
|
||
|
// générale
|
||
|
cout << "\n parametres de controle de l'algorithmes \n";
|
||
|
cout << "frequence de sauvegarde = " << sauvegarde << '\n';
|
||
|
cout << "casDeGestion_de_sauvegarde = " << cas_de_sauvegarde << '\n';
|
||
|
cout << "force deltat du point info = " << force_deltat << '\n';
|
||
|
cout << "coef pas_critique pour deltatmaxi= " << coef_pas_critique_deltatmaxi << '\n';
|
||
|
cout << "coef pas_critique pour deltatmini= " << coef_pas_critique_deltatmini << '\n';
|
||
|
cout << "type pas_critique DFC pour deltatmaxi= " << typeDFC_pas_critique_deltatmaxi << '\n';
|
||
|
cout << "type pas_critique DFC pour deltatmini= " << typeDFC_pas_critique_deltatmini << '\n';
|
||
|
cout << "maxi d'iteration pour converger = " << iterations << '\n';
|
||
|
cout << "precision de la convergence = " << precision << '\n';
|
||
|
// cout << "precision sur le temps final = " << tempo.prectemps << '\n';
|
||
|
cout << "type de norme de convergence = " << norme << '\n';
|
||
|
cout << "cinematique sur l'increment = " << cinematique << '\n';
|
||
|
cout << "convergence forcee = " << conv_forcee << '\n';
|
||
|
cout << "multiplicateur de la charge = " << multiplicateur << '\n';
|
||
|
// cout << "increment de temps = " << tempo.deltat << '\n';
|
||
|
// cout << "temps de fin de calcul = " << tempo.tempsfin << '\n';
|
||
|
cout << "maximum d'increment de temps = " << maxincre << '\n';
|
||
|
cout << "maximum d'essai d'increment = " << max_essai_incre << '\n';
|
||
|
cout << "increment de redemarage de calcul = " << restart << '\n';
|
||
|
cout << "maximum de puissance = " << max_puissance << '\n';
|
||
|
cout << "utilisation du line_search = " << line_search << '\n';
|
||
|
cout << "var_charge_externe = " << var_charge_externe << '\n';
|
||
|
cout << "var_jacobien = " << var_jacobien << '\n';
|
||
|
cout << "var_D = " << var_D << '\n';
|
||
|
// affichage des paramètres liés au temps
|
||
|
tempo_specifique_algo.Affiche();
|
||
|
// 2) paramètres liés au systèmes d'équation linéaire
|
||
|
cout << "PARAMETRES_SYSTEM_LINEAIRE_:\n";
|
||
|
cout << "type de matrice " << type_matrice << "\n";
|
||
|
cout << "symetrie de l'assemblage " << symetrie_matrice << "\n";
|
||
|
cout << "type de resolution " << type_resolution << "\n";
|
||
|
cout << "type de preconditionnement " << type_preconditionnement << "\n";
|
||
|
cout << "nombre iteration non directe " << nb_iter_nondirecte << "\n";
|
||
|
cout << "tolerance resol non directe " << tolerance << "\n";
|
||
|
cout << "nb vecteur restart " << nb_vect_restart << "\n";
|
||
|
// maintenant les listes pour les matrices secondaires si nécessaire
|
||
|
if (!type_matrice_secondaire.empty())
|
||
|
{ cout << "type_matrice_secondaire(s)_taille: " << type_matrice_secondaire.size() << " \n";
|
||
|
list < Enum_matrice >::const_iterator ili,ili_end=type_matrice_secondaire.end();
|
||
|
for (ili = type_matrice_secondaire.begin();ili != ili_end;ili++)
|
||
|
cout << " " << (*ili) ;
|
||
|
cout << "\n";
|
||
|
};
|
||
|
|
||
|
if (!type_resolution_secondaire.empty())
|
||
|
{ cout << "type_resolution_secondaire(s)_taille: " << type_resolution_secondaire.size() << " \n";
|
||
|
list < Enum_type_resolution_matri >::const_iterator ili,ili_end=type_resolution_secondaire.end();
|
||
|
for (ili = type_resolution_secondaire.begin();ili != ili_end;ili++)
|
||
|
cout << " " << (*ili) ;
|
||
|
cout << "\n";
|
||
|
};
|
||
|
|
||
|
if (!type_preconditionnement_secondaire.empty())
|
||
|
{ cout << "type_preconditionnement_secondaire(s)_taille: " << type_preconditionnement_secondaire.size() << " \n";
|
||
|
list < Enum_preconditionnement >::const_iterator ili,ili_end=type_preconditionnement_secondaire.end();
|
||
|
for (ili = type_preconditionnement_secondaire.begin();ili != ili_end;ili++)
|
||
|
cout << " " << (*ili) ;
|
||
|
cout << "\n";
|
||
|
};
|
||
|
|
||
|
if (!nb_iter_nondirecte_secondaire.empty())
|
||
|
{ cout << "nb_iter_nondirecte_secondaire(s)_taille: " << nb_iter_nondirecte_secondaire.size() << " \n";
|
||
|
list < int >::const_iterator ili,ili_end=nb_iter_nondirecte_secondaire.end();
|
||
|
for (ili = nb_iter_nondirecte_secondaire.begin();ili != ili_end;ili++)
|
||
|
cout << " " << (*ili) ;
|
||
|
cout << "\n";
|
||
|
};
|
||
|
|
||
|
if (!tolerance_secondaire.empty())
|
||
|
{ cout << "tolerance_secondaire(s)_taille: " << tolerance_secondaire.size() << " \n";
|
||
|
list < double >::const_iterator ili,ili_end=tolerance_secondaire.end();
|
||
|
for (ili = tolerance_secondaire.begin();ili != ili_end;ili++)
|
||
|
cout << " " << (*ili) ;
|
||
|
cout << "\n";
|
||
|
};
|
||
|
|
||
|
if (!nb_vect_restart_secondaire.empty())
|
||
|
{ cout << "nb_vect_restart_secondaire(s)_taille: " << nb_vect_restart_secondaire.size() << " \n";
|
||
|
list < int >::const_iterator ili,ili_end=nb_vect_restart_secondaire.end();
|
||
|
for (ili = nb_vect_restart_secondaire.begin();ili != ili_end;ili++)
|
||
|
cout << " " << (*ili) ;
|
||
|
cout << "\n";
|
||
|
};
|
||
|
cout << "OPTIMISATION_POINTEURS_ASSEMBLAGE" << opti_pointeur_assemblage << "\n";
|
||
|
|
||
|
|
||
|
// 3) paramètres liés au pilotage de l'équilibre global
|
||
|
cout << "PARAMETRES_PILOTAGE_EQUILIBRE_GLOBAL:\n";
|
||
|
cout << "typ_de_pilotage " << Nom_TypePilotage(type_de_pilotage) << "\n";
|
||
|
cout << "facteur_diminution" << facteur_diminution << "\n";
|
||
|
cout << "facteur_augmentation" << facteur_augmentation << "\n";
|
||
|
cout << "nb_bonne_convergence" << nb_bonne_convergence << "\n";
|
||
|
cout << "fact_dim_en_mauvaiseConv" << fact_dim_en_mauvaiseConv << "\n";
|
||
|
cout << "nb_iter_pour_bonne_convergence" << nb_iter_pour_bonne_convergence << "\n";
|
||
|
cout << "nb_iter_pour_mauvaise_convergence " << nb_iter_pour_mauvaise_convergence << "\n";
|
||
|
cout << "init_comp_tangent_simple" << init_comp_tangent_simple << "\n";
|
||
|
cout << "sur_sous_relaxation" << sur_sous_relaxation << "\n";
|
||
|
cout << "norme_maxi_increment" << norme_incre_max << "\n";
|
||
|
cout << "norme_maxi_X_increment" << norme_incre_X_max << "\n";
|
||
|
cout << "norme_maxi_V_increment" << norme_incre_V_max << "\n";
|
||
|
cout << "maxi_variation_ddl_pour_convergence " << varMaxiDdl << "\n";
|
||
|
cout << "mini_variation_ddl_pour_convergence " << varMiniDdl << "\n";
|
||
|
cout << "nb_cycle_controle_residu " << nbCycleControleResidu << "\n";
|
||
|
cout << "plage_controle_residu " << plageControleResidu << "\n";
|
||
|
cout << "init_incre_avec_pas_prec " << initIncreAvecDeltaDdlPrec << "\n";
|
||
|
cout << "jabobien_negatif " << jabobien_negatif << "\n";
|
||
|
cout << "var_maxi_jacobien " << var_maxi_jacobien << "\n";
|
||
|
cout << "cas_fctnD_charge " << cas_fctnD_charge << "\n";
|
||
|
// 4) paramètres liès à la dynamique
|
||
|
cout << "PARAMETRES_DEDIES_DYNAMIQUE:\n";
|
||
|
cout << "type_calcul_masse" << type_calcul_masse << "\n";
|
||
|
cout << "limitation_temps_maxi_stable" << limitation_temps_maxi_stable << "\n";
|
||
|
cout << "amorti_visco_artificielle " << amort_visco_arti << "\n";
|
||
|
cout << "coeff_visco_artificielle " << visco_arti << "\n";
|
||
|
cout << "maxi_C_en_fonction_M " << maxi_C_en_fonction_M << "\n";
|
||
|
cout << "coeff_rayleigh_masse " << coef_rayleigh_masse << "\n";
|
||
|
cout << "coeff_rayleigh_raideur " << coef_rayleigh_raideur << "\n";
|
||
|
cout << "bulk_viscosity " << bulk_viscosity << "\n";
|
||
|
cout << "c_Tracebulk " << c_Tracebulk << "\n";
|
||
|
cout << "c_Trace2bulk " << c_Trace2bulk << "\n";
|
||
|
// 5) paramètres liès à l'affichage des résultats
|
||
|
cout << "PARAMETRES_AFFICHAGE:\n";
|
||
|
cout << "frequence_affichage_increment " << frequence_affichage_increment << "\n";
|
||
|
cout << "frequence_affichage_iteration " << frequence_affichage_iteration << "\n";
|
||
|
cout << "sortie_fil_calcul " << sortie_fil_calcul << "\n";
|
||
|
cout << "CAS_DE_SORTIE_FIL_CALCUL " << cas_de_sortie_fil_calcul << "\n";
|
||
|
cout << "nb_chiffre_pour_double_calcul " << nb_diggit_double_calcul << "\n";
|
||
|
cout << "nb_chiffre_pour_double_graphique " << nb_diggit_double_graphique << "\n";
|
||
|
cout << "nb_chiffre_pour_double_ecran " << nb_diggit_double_ecran << "\n";
|
||
|
// 6) paramètres liès au contact
|
||
|
cout << "PARAMETRES_CONTACT:\n";
|
||
|
cout << "PRECISION_POINT_INTERNE_DEBUT " << prec_pt_int_deb << "\n";
|
||
|
cout << "FACT_POUR_RAYON_ACCOSTAGE " << factPourRayonAccostage << "\n";
|
||
|
cout << "DISTANCE_MAXI_AU_PT_PROJETE" << distanceMaxiAuPtProjete << "\n";
|
||
|
cout << "PRECISION_BOITE_PRELOCALISATION " << extra_boite_prelocalisation << "\n";
|
||
|
cout << "MINI_EXTRA_BOITE_PRELOCALISATION " << mini_extra_boite_prelocalisation << "\n";
|
||
|
cout << "AJOUT_EXTRA_BOITE_PRELOCALISATION " << ajout_extra_boite_prelocalisation << "\n";
|
||
|
cout << "CONTACT_TYPE " << contact_type << "\n";
|
||
|
cout << "FCT_ND_BASCUL_CONTACT_TYPE_4 " << fct_nD_bascul_contact_type_4 << "\n";
|
||
|
cout << "PENALISATION_PENETRATION " << penalisationPenetration
|
||
|
<< "FCT_ND_PENALISATION_PENETRATION"<< fct_nD_penalisationPenetration <<"\n";
|
||
|
cout << "TYPE_PENALISATION_PENETRATION " << typePenalisationPenetration << "\n";
|
||
|
cout << "PENETRATION_CONTACT_MAXI " << penetration_contact_maxi
|
||
|
<< "FCT_ND_PENETRATION_CONTACT_MAXI"<< fct_nD_penetration_contact_maxi << "\n";
|
||
|
cout << "PENETRATION_BORNE_REGULARISATION " << penetration_borne_regularisation
|
||
|
<< "FCT_ND_PENETRATION_BORNE_REGULARISATION"<< fct_nD_penetration_borne_regularisation << "\n";
|
||
|
cout << "FORCE_CONTACT_NOEUD_MAXI " << force_contact_noeud_maxi
|
||
|
<< "FCT_ND_FORCE_CONTACT_NOEUD_MAXI"<< fct_nD_force_contact_noeud_maxi << "\n";
|
||
|
cout << "PENALISATION_TANGENTIELLE " << penalisationTangentielle
|
||
|
<< "FCT_ND_PENALISATION_TANGENTIELLE"<< fct_nD_penalisationTangentielle << "\n";
|
||
|
cout << "TYPE_PENALISATION_TANGENTIELLE " << typePenalisationTangentielle << "\n";
|
||
|
cout << "TANGENTIELLE_CONTACT_MAXI " << tangentielle_contact_maxi
|
||
|
<< "FCT_ND_TANGENTIELLE_CONTACT_MAXI"<< fct_nD_tangentielle_contact_maxi << "\n";
|
||
|
cout << "TANGENTIELLE_BORNE_REGULARISATION " << tangentielle_borne_regularisation
|
||
|
<< "FCT_ND_TANGENTIELLE_BORNE_REGULARISATION"<< fct_nD_tangentielle_borne_regularisation << "\n";
|
||
|
cout << "FORCE_TANGENTIELLE_NOEUD_MAXI " << force_tangentielle_noeud_maxi
|
||
|
<< "FCT_ND_FORCE_TANGENTIELLE_NOEUD_MAXI"<< fct_nD_force_tangentielle_noeud_maxi << "\n";
|
||
|
cout << "PRECISION_PT_SUR_FRONTIERE " << prec_pt_sur_frontiere << "\n";
|
||
|
cout << "NB_BOUCLE_NEWTON_SUR_POSITION_FRONTIERE " << nb_boucle_newton_position_frontiere << "\n";
|
||
|
cout << "NB_DECOLLEMENT_MAXI " << nbDecolAutorise << "\n";
|
||
|
cout << "TYPE_DE_DECOLLEMENT " << typeDeDecolement << "\n";
|
||
|
cout << "NB_MOY_GLISSANT " << nb_glissant << "\n";
|
||
|
cout << "NIVEAU_COMMENTAIRE_CONTACT " << niveau_commentaire_contact << "\n";
|
||
|
cout << "OPTIMISATION_NUMEROTATION " << optimisation_numerotation << "\n";
|
||
|
// 7) paramètres liès aux énergies
|
||
|
cout << "PARAMETRES_ENERGIES:\n";
|
||
|
cout << "NB_INCR_CAL_ENERG " << nb_incr_cal_ener << "\n";
|
||
|
cout << "AFFICHE_INCR_ENERGIE " << affiche_incr_energie << "\n";
|
||
|
// 8) paramètres liés aux calculs géométriques sur les éléments
|
||
|
cout << "PARAMETRES_CALCULS_GEOMETRIQUES:\n";
|
||
|
cout << "POINT_INTERNE_DELTA_THETAI_MAXI " << point_interne_delta_thetai_maxi << "\n";
|
||
|
cout << "POINT_INTERNE_PREC_THETAI_INTERNE " << point_interne_prec_thetai_interne << "\n";
|
||
|
cout << "POINT_INTERNE_NB_BOUCLE_SUR_DELTA_THETAI " << point_interne_nb_boucle_sur_delta_thetai << "\n";
|
||
|
cout << "POINT_INTERNE_NB_EXTERNE " << point_interne_nb_externe << "\n";
|
||
|
cout << "CAL_VOL_TOTAL_ENTRE_SURFACE_ET_PLANS_REF " << cal_vol_total_entre_surface_et_plans_ref << "\n";
|
||
|
cout << "RATIO_MAXI_JACOMEMBRANE_JACOPTI " << ratio_maxi_jacoMembrane_jacoPti << "\n";
|
||
|
cout << "TYPE_CALNUM_INVERSION_METRIQUE " << type_calnum_inversion_metrique << "\n";
|
||
|
};
|
||
|
|
||
|
// affichage et definition interactive des commandes
|
||
|
void ParaAlgoControle::Info_commande_ParaAlgoControle(UtilLecture& entreePrinc)
|
||
|
{
|
||
|
ofstream & sort = *(entreePrinc.Commande_pointInfo()); // pour simplifier
|
||
|
//On va proposer un menu
|
||
|
string rep=" ";
|
||
|
cout << "\n --- definition des parametres de controle ------ ";
|
||
|
while ((Minuscules(rep) != "f")&&(Minuscules(rep) != "0"))
|
||
|
{
|
||
|
try
|
||
|
{
|
||
|
cout << "\n choix du groupe de controle : "
|
||
|
<< "\n [c] -> para tres classique [-] para assez courants "
|
||
|
<< "\n (0 ou f) (fin) "
|
||
|
<< "\n (1) controles generaux pour la resolution de l'equilibre generale [c]"
|
||
|
<< "\n (2) parametres lies au systeme d'equation lineaire "
|
||
|
<< "\n (3) parametres lies à la dynamique "
|
||
|
<< "\n (4) parametres lies à l'affichage des resultats [c]"
|
||
|
<< "\n (5) parametres lies au contact "
|
||
|
<< "\n (6) parametres lies aux energies "
|
||
|
<< "\n (7) parametres lies aux calculs geometriques sur les elements "
|
||
|
<< "\n ";
|
||
|
rep = lect_return_defaut(false,"f");
|
||
|
if ((Minuscules(rep) == "f") || (Minuscules(rep) == "0"))// sortie directe
|
||
|
break;
|
||
|
int num = ChangeEntier(rep);
|
||
|
if (!((num >= 0)&&(num<=7)))
|
||
|
{ cout << "\n Erreur on attendait un entier entre 0 et 7 !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour arreter le programme";
|
||
|
};
|
||
|
switch (num)
|
||
|
{ case 0: // sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 1: // controles generaux pour la resolution de l'equilibre generale
|
||
|
{ sort << "\n\n controle #------------ "
|
||
|
<< "\n#--------------------------- "
|
||
|
<< "\n# PARAMETRE | VALEUR | "
|
||
|
<< "\n#--------------------------- ";
|
||
|
Tableau<bool> tab_modif(26,false); // indique qu'est-ce qui a été modifié
|
||
|
//On va proposer un menu
|
||
|
string repa=" ";
|
||
|
cout << "\n --- controle generaux ------ ";
|
||
|
while ((Minuscules(repa) != "f")&&(Minuscules(repa) != "0"))
|
||
|
{try
|
||
|
{ cout << "\n (0 ou f) (fin) "
|
||
|
<< "\n --- parametres de controle de l'algorithmes et para par defaut "
|
||
|
<< "\n [c] -> para tres classique [-] para assez courants "
|
||
|
<< "\n (1) frequence de sauvegarde = 1 [c] "
|
||
|
<< "\n (2) type de gestion de sauvegarde = 1 "
|
||
|
<< "\n (3) FORCE_DELTAT_DU_.INFO "
|
||
|
<< "\n (4) coef pas_critique pour deltatmaxi = 0."
|
||
|
<< "\n (5) coef pas_critique pour deltatmini = -3333256794."
|
||
|
<< "\n (6) type pas_critique DFC pour deltatmaxi = true "
|
||
|
<< "\n (7) type pas_critique DFC pour deltatmini = true "
|
||
|
<< "\n (8) maxi d'iteration pour converger = 100 [-] "
|
||
|
<< "\n (9) precision de la convergence = 1.e-3 [-] "
|
||
|
<< "\n (10) precision sur le temps final = 1.E-12"
|
||
|
<< "\n (11) type de norme de convergence = Residu/Reaction [-]"
|
||
|
<< "\n ou: fonction_nD: <le nom de la fonction nD> "
|
||
|
<< "\n (12) cinematique sur l'increment = false"
|
||
|
<< "\n (13) convergence forcee = false"
|
||
|
<< "\n (14) multiplicateur de la charge = 1."
|
||
|
<< "\n (15) increment de temps = 1. [c]"
|
||
|
<< "\n (16) temps de fin de calcul = 1. [c]"
|
||
|
<< "\n (17) maximum d'increment de temps = 400 [-]"
|
||
|
<< "\n (18) increment de redemarage de calcul = 0"
|
||
|
<< "\n (19) maximum de puissance = 1.e10"
|
||
|
<< "\n (20) utilisation du line_search = false"
|
||
|
<< "\n (21) var_charge_externe = true"
|
||
|
<< "\n (22) var_D= false"
|
||
|
<< "\n (23) ajout au choix sur la norme: "
|
||
|
<< "\n et_miniVarDdl et_VarRes et_maxiVarDdl"
|
||
|
<< "\n (24) delta t maxi 1. [c]"
|
||
|
<< "\n (25) delta t mini 0. [-]"
|
||
|
<< "\n (26) maximum d'essai d'increment de temps = maxincre [-]"
|
||
|
<< "\n ";
|
||
|
repa = lect_return_defaut(false,"f");;
|
||
|
if ((Minuscules(repa) == "f") || (Minuscules(repa) == "0"))// sortie directe
|
||
|
break;
|
||
|
int numa = ChangeEntier(repa);
|
||
|
if (!((numa >= 0)&&(numa<=26)))
|
||
|
{ cout << "\n Erreur on attendait un entier entre 0 et 26 !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour arreter le programme";
|
||
|
};
|
||
|
int val_int;
|
||
|
bool val_bool;
|
||
|
double val_double;
|
||
|
string val_string,string_inter;
|
||
|
bool bonne_lecture = false;
|
||
|
|
||
|
switch (numa)
|
||
|
{ case 0: // sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 2:
|
||
|
{ cout << "\n (1) type par intervalle d'increment "
|
||
|
<< "\n (2) type par intervalle de temps "
|
||
|
<< "\n (3) uniquement l'increment 0 et le dernier increment "
|
||
|
<< "\n (4) type par intervalle d'increment + le dernier increment "
|
||
|
<< "\n (5) type par intervalle de temps + le dernier increment \n"
|
||
|
;
|
||
|
string type_de_cas_de_sauvegarde;
|
||
|
type_de_cas_de_sauvegarde= lect_chaine();
|
||
|
cout << " valeur lue :" << type_de_cas_de_sauvegarde;
|
||
|
if (type_de_cas_de_sauvegarde == "1") {cas_de_sauvegarde=1;tab_modif(numa)=true;bonne_lecture=true;break;}
|
||
|
else if (type_de_cas_de_sauvegarde == "2") {cas_de_sauvegarde=2;tab_modif(numa)=true;bonne_lecture=true;break;}
|
||
|
else if (type_de_cas_de_sauvegarde == "3") {cas_de_sauvegarde=3;tab_modif(numa)=true;bonne_lecture=true;break;}
|
||
|
else if (type_de_cas_de_sauvegarde == "4") {cas_de_sauvegarde=4;tab_modif(numa)=true;bonne_lecture=true;break;}
|
||
|
else if (type_de_cas_de_sauvegarde == "5") {cas_de_sauvegarde=5;tab_modif(numa)=true;bonne_lecture=true;break;}
|
||
|
else {cout << "\n valeur lue erronee, on concerve la valeur "<< cas_de_sauvegarde;};
|
||
|
}
|
||
|
case 1:
|
||
|
{ cout << "\n nouvelle valeur (un entier ou un reel selon de type d'intervalle) (defaut 1) ? ";
|
||
|
string_inter= lect_return_defaut(false,"1");
|
||
|
cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_double = ChangeReel(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 8: case 17: case 18: case 26:
|
||
|
{ cout << "\n nouvelle valeur (un entier) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_int = ChangeEntier(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 4: case 5: case 9: case 10: case 14: case 15: case 16: case 19: case 24: case 25:
|
||
|
{ cout << "\n nouvelle valeur (un reel) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_double = ChangeReel(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 3: case 6: case 7: case 12: case 13: case 20: case 21: case 22:
|
||
|
{ cout << "\n nouvelle valeur (un entier 1(=true) ou 0(=false) ) ? ";
|
||
|
val_bool= (bool) lect_double();cout << " valeur lue ="<< val_bool;
|
||
|
bonne_lecture=true;
|
||
|
break;
|
||
|
}
|
||
|
case 11:
|
||
|
{ cout << "\n nouvelle valeur (un nom) ? ";
|
||
|
int nb_string = 14;
|
||
|
Tableau <string > tab_norme(nb_string);
|
||
|
tab_norme(1) = "Residu/Reaction_et_Residu";
|
||
|
tab_norme(2) = "Residu/Reaction";
|
||
|
tab_norme(3) = "Residu/PVExterne";
|
||
|
tab_norme(4) = "Residu/PVInterne";
|
||
|
tab_norme(5) = "Residu/maxPVI";
|
||
|
tab_norme(6) = "Residu";
|
||
|
tab_norme(7) = "min(Res,Res/Reaction)";
|
||
|
tab_norme(8) = "min(Res,Res/MaX(Reaction_et_PVExterne))";
|
||
|
tab_norme(9) = "E_cinetique/E_statique_ET_ResSurReact";
|
||
|
tab_norme(10) = "E_cinetique/E_statique_ET_Res/Reac_et_Fext";
|
||
|
tab_norme(11) = "E_cinetique";
|
||
|
tab_norme(12) = "Bilan_puissance/Max(puiss)";
|
||
|
tab_norme(13) = "Residu/Reaction_et_Residu";
|
||
|
tab_norme(14) = "fonction_nD: <un nom de fonction nD> ";
|
||
|
int nb_car_maxi=0; // init
|
||
|
// on recherche le nombre de caractères maxi
|
||
|
for (int i=1;i<nb_string+1;i++)
|
||
|
nb_car_maxi = MaX(nb_car_maxi, tab_norme(i).length());
|
||
|
// on affiche le menu
|
||
|
for (int i=1;i<nb_string+1;i++)
|
||
|
cout <<"\n "<< setw(nb_car_maxi) << left << tab_norme(i) <<" ("<<i<<")";
|
||
|
cout << "\n ? ";
|
||
|
val_string= lect_chaine();cout << " valeur lue ="<< val_string;
|
||
|
int num_choix = ChangeEntier(val_string);
|
||
|
if ((num_choix == 0) || (Minuscules(val_string) == "f"))
|
||
|
break;
|
||
|
if ((num_choix > 0)&&(num_choix < nb_string+1))
|
||
|
{ cout << " norme enregistree: " << tab_norme(num_choix);
|
||
|
norme.nom1 = tab_norme(num_choix);tab_modif(numa)=true;
|
||
|
bonne_lecture=true;break;
|
||
|
}
|
||
|
else { cout << "\n type incorrect on conserve: " << norme ;};
|
||
|
if (norme.nom1 == "fonction_nD:") // on doit demander le nom de la fonction nD
|
||
|
{cout << " nom de la fonction nD ? ";
|
||
|
norme.nom2= lect_chaine();cout << " valeur lue ="<< norme.nom2;
|
||
|
};
|
||
|
break;
|
||
|
}
|
||
|
case 23:
|
||
|
{ if (norme.nom1 == "fonction_nD:") // si on a déjà enregisté une fonction nD
|
||
|
// la suite n'est pas possible
|
||
|
{cout << "\n cas d'une norme controlee par une fonction nD, on ne peut pas rajouter d'indication! ";
|
||
|
}
|
||
|
else
|
||
|
{cout << "\n un nom au choix parmi: et_miniVarDdl et_VarRes et_maxiVarDdl ou un blanc ? ";
|
||
|
int nb_string = 3;
|
||
|
Tableau <string > tab_norme(nb_string);
|
||
|
tab_norme(1) = "et_miniVarDdl";
|
||
|
tab_norme(2) = "et_VarRes";
|
||
|
tab_norme(3) = "et_maxiVarDdl";
|
||
|
int nb_car_maxi=0; // init
|
||
|
// on recherche le nombre de caractères maxi
|
||
|
for (int i=1;i<nb_string+1;i++)
|
||
|
nb_car_maxi = MaX(nb_car_maxi, tab_norme(i).length());
|
||
|
// on affiche le menu
|
||
|
for (int i=1;i<nb_string+1;i++)
|
||
|
cout <<"\n "<< setw(nb_car_maxi) << left << tab_norme(i) <<" ("<<i<<")";
|
||
|
cout << "\n ? ";
|
||
|
val_string= lect_chaine();cout << " valeur lue ="<< val_string;
|
||
|
int num_choix = ChangeEntier(val_string);
|
||
|
if ((num_choix == 0) || (Minuscules(val_string) == "f"))
|
||
|
break;
|
||
|
if ((num_choix > 0)&&(num_choix < nb_string+1))
|
||
|
{ norme.nom1 += val_string;tab_modif(numa)=true;
|
||
|
cout << " norme enregistree: " << norme;
|
||
|
bonne_lecture=true;
|
||
|
break;
|
||
|
}
|
||
|
else { cout << "\n type incorrect on conserve: " << norme ;};
|
||
|
};
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
};
|
||
|
if (bonne_lecture)
|
||
|
switch (numa)
|
||
|
{ case 0: // préparation de sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 1: { sauvegarde = val_double;tab_modif(numa)=true;break;}
|
||
|
case 3: { force_deltat = val_bool;tab_modif(numa)=true;break;}
|
||
|
case 4: { coef_pas_critique_deltatmaxi = val_double;tab_modif(numa)=true;break;}
|
||
|
case 5: { coef_pas_critique_deltatmini = val_double;tab_modif(numa)=true;break;}
|
||
|
case 6: { typeDFC_pas_critique_deltatmaxi = val_bool;tab_modif(numa)=true;break;}
|
||
|
case 7: { typeDFC_pas_critique_deltatmini = val_bool;tab_modif(numa)=true;break;}
|
||
|
case 8: { iterations = val_int;tab_modif(numa)=true;break;}
|
||
|
case 9: { precision = val_double;tab_modif(numa)=true;break;}
|
||
|
case 10: { tempo_specifique_algo.prectemps = val_double;tab_modif(numa)=true;break;}
|
||
|
case 12: { cinematique = val_bool;tab_modif(numa)=true;break;}
|
||
|
case 13: { conv_forcee = val_bool;tab_modif(numa)=true;break;}
|
||
|
case 14: { multiplicateur = val_double;tab_modif(numa)=true;break;}
|
||
|
case 15: { tempo_specifique_algo.deltat = val_double;tab_modif(numa)=true;break;}
|
||
|
case 16: { tempo_specifique_algo.tempsfin = val_double;tab_modif(numa)=true;break;}
|
||
|
case 17: { maxincre = val_int;tab_modif(numa)=true;break;}
|
||
|
case 18: { restart = val_int;tab_modif(numa)=true;break;}
|
||
|
case 19: { max_puissance = val_double;tab_modif(numa)=true;break;}
|
||
|
case 20: { line_search = val_bool;tab_modif(numa)=true;break;}
|
||
|
case 21: { var_charge_externe = val_bool;tab_modif(numa)=true;break;}
|
||
|
case 22: { var_D = val_bool;tab_modif(numa)=true;break;}
|
||
|
case 24: { tempo_specifique_algo.deltatmaxi = val_double;tab_modif(numa)=true;break;}
|
||
|
case 25: { tempo_specifique_algo.deltatmini = val_double;tab_modif(numa)=true;break;}
|
||
|
case 26: { max_essai_incre = val_int;tab_modif(numa)=true;break;}
|
||
|
};
|
||
|
|
||
|
}
|
||
|
catch (ErrSortieFinale)
|
||
|
// cas d'une direction voulue vers la sortie
|
||
|
// on relance l'interuption pour le niveau supérieur
|
||
|
{ ErrSortieFinale toto;
|
||
|
throw (toto);
|
||
|
}
|
||
|
catch (...)//(UtilLecture::ErrNouvelleDonnee erreur)
|
||
|
{ cout << "\n Erreur on attendait un des mots cles proposes !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour sortir ";
|
||
|
};
|
||
|
}; //-- fin du while interne
|
||
|
// écriture des paramètres de contrôle
|
||
|
for (int i=1;i<=26;i++)
|
||
|
if (tab_modif(i))
|
||
|
{switch (i)
|
||
|
{ case 1: { sort << "\n SAUVEGARDE ";
|
||
|
switch (cas_de_sauvegarde)
|
||
|
{case 2: sort << " INTER_TEMPS " << sauvegarde ;break;
|
||
|
case 3: sort << " DERNIER_CALCUL ";break;
|
||
|
case 4: sort << " INTER_INCREMENT " << sauvegarde << " DERNIER_CALCUL ";break;
|
||
|
case 5: sort << " INTER_TEMPS " << sauvegarde << " DERNIER_CALCUL ";break;
|
||
|
default: sort << sauvegarde;
|
||
|
};
|
||
|
break;}
|
||
|
case 3: { sort << "\n FORCE_DELTAT_DU_.INFO "<< force_deltat;break;}
|
||
|
case 8: { sort << "\n ITERATIONS " << iterations ;break;}
|
||
|
case 9: { sort << "\n PRECISION "<< precision ;break;}
|
||
|
case 10: { sort << "\n PRECTEMPS " << tempo_specifique_algo.prectemps;break;}
|
||
|
case 11: { sort << "\n NORME " << norme;break;}
|
||
|
case 12: { sort << "\n CINEMATIQUE " << cinematique;break;}
|
||
|
case 13: { sort << "\n CONV_FORCEE " << conv_forcee;break;}
|
||
|
case 14: { sort << "\n MULTIPLICATEUR " << multiplicateur;break;}
|
||
|
case 15: { sort << "\n DELTAt " << tempo_specifique_algo.deltat;break;}
|
||
|
case 16: { sort << "\n TEMPSFIN " << tempo_specifique_algo.tempsfin;break;}
|
||
|
case 17: { sort << "\n MAXINCRE " << maxincre ;break;}
|
||
|
case 18: { sort << "\n RESTART " << restart;break;}
|
||
|
case 19: { sort << "\n MAX_PUISSANCE " << max_puissance;break;}
|
||
|
case 20: { sort << "\n LINE_SEARCH " << line_search;break;}
|
||
|
case 21: { sort << "\n VARIATION_CHARGE_EXTERNE_SUR_RAIDEUR " << var_charge_externe;break;}
|
||
|
case 22: { sort << "\n VARIATION_VITESSE_DEFORMATION_SUR_RAIDEUR " << var_D;break;}
|
||
|
case 24: { sort << "\n DELTAtMAXI " << tempo_specifique_algo.deltatmaxi;break;}
|
||
|
case 25: { sort << "\n DELTAtMINI " << tempo_specifique_algo.deltatmini;break;}
|
||
|
case 26: { sort << "\n MAX_ESSAI_INCRE " << max_essai_incre ;break;}
|
||
|
};
|
||
|
};
|
||
|
|
||
|
// cas du pas de temps maxi
|
||
|
if (tab_modif(4) || tab_modif(6)) // ou car si l'on change un des deux cela veut dire un facteur du coef critique
|
||
|
{if (typeDFC_pas_critique_deltatmaxi)
|
||
|
{sort << "\n DELTAtMAXI COEF_PASCRITIQUE_DFC "<< coef_pas_critique_deltatmaxi ;}
|
||
|
else
|
||
|
{sort << "\n DELTAtMAXI COEF_PASCRITIQUE "<< coef_pas_critique_deltatmaxi ;};
|
||
|
};
|
||
|
if (tab_modif(5) || tab_modif(7))
|
||
|
{if (typeDFC_pas_critique_deltatmini)
|
||
|
{sort << "\n DELTAtMINI COEF_PASCRITIQUE_DFC "<< coef_pas_critique_deltatmini ;}
|
||
|
else
|
||
|
{sort << "\n DELTAtMINI COEF_PASCRITIQUE "<< coef_pas_critique_deltatmini ;};
|
||
|
};
|
||
|
break;
|
||
|
}
|
||
|
case 2: // parametres lies au systeme d'equation lineaire
|
||
|
{ sort << "\n\n para_syteme_lineaire #------------ "
|
||
|
<< "\n#--------------------------- "
|
||
|
<< "\n# PARAMETRE | VALEUR | "
|
||
|
<< "\n#--------------------------- ";
|
||
|
int nb_item = 8; // nombre d'item du menu
|
||
|
Tableau<bool> tab_modif(nb_item,false); // indique qu'est-ce qui a été modifié
|
||
|
//On va proposer un menu
|
||
|
string repa=" ";
|
||
|
cout << "\n --- parametre de la resolution du systeme lineaire global ------ ";
|
||
|
while ((Minuscules(repa) != "f")&&(Minuscules(repa) != "0"))
|
||
|
{try
|
||
|
{ cout << "\n (0 ou f) (fin) "
|
||
|
<< "\n --- parametres de controle et para par defaut "
|
||
|
<< "\n [c] -> para tres classique [-] para assez courants "
|
||
|
<< "\n (1) TYPE_MATRICE = BANDE_SYMETRIQUE "
|
||
|
<< "\n (2) SYMETRIE_MATRICE = 1 "
|
||
|
<< "\n (3) TYPE_RESOLUTION = CHOLESKY "
|
||
|
<< "\n (4) TYPE_PRECONDITIONNEMENT = DIAGONAL "
|
||
|
<< "\n (5) NB_ITER_NONDIRECTE = 30"
|
||
|
<< "\n (6) TOLERANCE = 1.e-7 "
|
||
|
<< "\n (7) NB_VECT_RESTART = 32 "
|
||
|
<< "\n (8) OPTIMISATION_POINTEURS_ASSEMBLAGE = 0 [-] "
|
||
|
<< "\n NB: pour les matrices secondaires: voir doc. \n";
|
||
|
repa = lect_return_defaut(false,"f");
|
||
|
if ((Minuscules(repa) == "f") || (Minuscules(repa) == "0"))// sortie directe
|
||
|
break;
|
||
|
int numa = ChangeEntier(repa);
|
||
|
if (!((numa >= 0)&&(numa<=nb_item)))
|
||
|
{ cout << "\n Erreur on attendait un entier entre 0 et "<<nb_item<<" !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour arreter le programme";
|
||
|
};
|
||
|
int val_int;
|
||
|
bool val_bool;
|
||
|
double val_double;
|
||
|
string val_string,string_inter;
|
||
|
bool bonne_lecture = false;
|
||
|
|
||
|
switch (numa)
|
||
|
{ case 0: // sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 1:
|
||
|
{ cout << "\n nouveau type de matrice (un nom cf. doc ) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (Existe_Enum_matrice(string_inter))
|
||
|
{ val_string = string_inter;bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: ce type de matrice n'est pas correcte !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 2:
|
||
|
{ cout << "\n symetrie de la matrice (1 ou 0 ) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ int essai = ChangeEntier(string_inter);
|
||
|
if ((essai == 1) || (essai == 0))
|
||
|
{val_int = essai;bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " ** erreur il faut 1 ou 0 ! "; };
|
||
|
}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 3:
|
||
|
{ cout << "\n type de resolution (un nom cf. doc ) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (Existe_Enum_type_resolution_matri(string_inter))
|
||
|
{ val_string = string_inter;bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: ce type de resolution n'est pas correcte !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 4:
|
||
|
{ cout << "\n type de preconditionnement (un nom cf. doc ) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (Existe_Enum_preconditionnement(string_inter))
|
||
|
{ val_string = string_inter;bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: ce type de preconditionnement n'est pas correcte !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 5:
|
||
|
{ cout << "\n nb iteration pour un methode iterative (un entier) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_int = ChangeEntier(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 6:
|
||
|
{ cout << "\n precision de convergence pour un methode iterative (un reel) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_double = ChangeReel(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 7:
|
||
|
{ cout << "\n nb vecteurs sauvegarde pour un methode iterative (un entier) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_int = ChangeEntier(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 8:
|
||
|
{ cout << "\n optimisation des pointeurs d'assemblage (1 ou 0) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_int = ChangeEntier(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
};
|
||
|
if (bonne_lecture)
|
||
|
switch (numa)
|
||
|
{ case 0: // préparation de sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 1: { type_matrice = Id_nom_matrice(val_string);tab_modif(numa)=true;break;}
|
||
|
case 2: { symetrie_matrice = val_int;tab_modif(numa)=true;break;}
|
||
|
case 3: { type_resolution = Id_nom_resolution(val_string);tab_modif(numa)=true;break;}
|
||
|
case 4: { type_preconditionnement = Id_nom_preconditionnement(val_string);tab_modif(numa)=true;break;}
|
||
|
case 5: { nb_iter_nondirecte = val_int;tab_modif(numa)=true;break;}
|
||
|
case 6: { tolerance = val_double;tab_modif(numa)=true;break;}
|
||
|
case 7: { nb_vect_restart = val_int;tab_modif(numa)=true;break;}
|
||
|
case 8: { opti_pointeur_assemblage = val_int;tab_modif(numa)=true;break;}
|
||
|
};
|
||
|
}
|
||
|
catch (ErrSortieFinale)
|
||
|
// cas d'une direction voulue vers la sortie
|
||
|
// on relance l'interuption pour le niveau supérieur
|
||
|
{ ErrSortieFinale toto;
|
||
|
throw (toto);
|
||
|
}
|
||
|
catch (...)//(UtilLecture::ErrNouvelleDonnee erreur)
|
||
|
{ cout << "\n Erreur on attendait un des mots cles proposes !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour sortir ";
|
||
|
};
|
||
|
}; //-- fin du while interne
|
||
|
// écriture des paramètres de contrôle
|
||
|
for (int i=1;i<=nb_item;i++)
|
||
|
if (tab_modif(i))
|
||
|
{switch (i)
|
||
|
{ case 1: { sort << "\n TYPE_MATRICE " << Nom_matrice(type_matrice);break;}
|
||
|
case 2: { sort << "\n SYMETRIE_MATRICE " << symetrie_matrice;break;}
|
||
|
case 3: { sort << "\n TYPE_RESOLUTION "<< Nom_resolution(type_resolution);break;}
|
||
|
case 4: { sort << "\n TYPE_PRECONDITIONNEMENT " << Nom_preconditionnement(type_preconditionnement) ;break;}
|
||
|
case 5: { sort << "\n NB_ITER_NONDIRECTE "<< nb_iter_nondirecte ;break;}
|
||
|
case 6: { sort << "\n TOLERANCE " << tolerance;break;}
|
||
|
case 7: { sort << "\n NB_VECT_RESTART " << nb_vect_restart;break;}
|
||
|
case 8: { sort << "\n OPTIMISATION_POINTEURS_ASSEMBLAGE " << opti_pointeur_assemblage;break;}
|
||
|
};
|
||
|
};
|
||
|
|
||
|
break;
|
||
|
}
|
||
|
case 3: // parametres lies à la dynamique
|
||
|
{ break;
|
||
|
}
|
||
|
case 4: // parametres lies à l'affichage des resultats
|
||
|
{ sort << "\n\n para_affichage #------------ "
|
||
|
<< "\n#--------------------------- "
|
||
|
<< "\n# PARAMETRE | VALEUR | "
|
||
|
<< "\n#--------------------------- ";
|
||
|
int nb_choix = 7; // nombre de choix
|
||
|
Tableau<bool> tab_modif(nb_choix,false); // indique qu'est-ce qui a été modifié
|
||
|
//On va proposer un menu
|
||
|
string repa=" ";
|
||
|
cout << "\n --- affichage ------ ";
|
||
|
while ((Minuscules(repa) != "f")&&(Minuscules(repa) != "0"))
|
||
|
{try
|
||
|
{ cout << "\n (0 ou f) (fin) "
|
||
|
<< "\n --- parametres de controle de l'algorithmes et para par defaut "
|
||
|
<< "\n [c] -> para tres classique [-] para assez courants "
|
||
|
<< "\n (1) frequence d'affichage sur les increment = 1 [-]"
|
||
|
<< "\n (FREQUENCE_AFFICHAGE_INCREMENT) "
|
||
|
<< "\n (2) frequence d'affichage sur les iteration = 1 [-]"
|
||
|
<< "\n (FREQUENCE_AFFICHAGE_ITERATION) "
|
||
|
<< "\n (3) frequence de la sortie au fil du calcul = -1000000 [c]"
|
||
|
<< "\n (FREQUENCE_SORTIE_FIL_DU_CALCUL) "
|
||
|
<< "\n (4) cas de_sortie_fil_calcul"
|
||
|
<< "\n (FREQUENCE_AFFICHAGE_INCREMENT) "
|
||
|
<< "\n (5) NB chiffre significatifs pour archive et ecran = 17 "
|
||
|
<< "\n (NB_CHIFFRE_POUR_DOUBLE_CALCUL) "
|
||
|
<< "\n (6) NB chiffre significatifs pour graphique = 12 "
|
||
|
<< "\n (NB_CHIFFRE_POUR_DOUBLE_GRAPHIQUE) "
|
||
|
<< "\n (7) NB chiffre significatifs pour ecran = 8 "
|
||
|
<< "\n (NB_CHIFFRE_POUR_DOUBLE_ECRAN) "
|
||
|
<< "\n ";
|
||
|
repa = lect_return_defaut(false,"f");
|
||
|
if ((Minuscules(repa) == "f") || (Minuscules(repa) == "0"))// sortie directe
|
||
|
break;
|
||
|
int numa = ChangeEntier(repa);
|
||
|
if (!((numa >= 0)&&(numa<=nb_choix)))
|
||
|
{ cout << "\n Erreur on attendait un entier entre 0 et "<<nb_choix<<" !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour arreter le programme";
|
||
|
};
|
||
|
int val_int;
|
||
|
bool val_bool;
|
||
|
double val_double;
|
||
|
string val_string,string_inter;
|
||
|
|
||
|
switch (numa)
|
||
|
{ case 0: // sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 4:
|
||
|
{ cout << "\n (1) type par intervalle d'increment "
|
||
|
<< "\n (2) type par intervalle de temps "
|
||
|
<< "\n (3) uniquement le dernier increment \n";
|
||
|
string type_de_cas_de_sortie_fil_calcul;
|
||
|
type_de_cas_de_sortie_fil_calcul= lect_chaine();
|
||
|
cout << " valeur lue :" << type_de_cas_de_sortie_fil_calcul;
|
||
|
if (type_de_cas_de_sortie_fil_calcul == "1")
|
||
|
{cas_de_sortie_fil_calcul=1;tab_modif(numa)=true;break;}
|
||
|
else if (type_de_cas_de_sortie_fil_calcul == "2")
|
||
|
{cas_de_sortie_fil_calcul=2;tab_modif(numa)=true;break;}
|
||
|
else if (type_de_cas_de_sortie_fil_calcul == "3")
|
||
|
{cas_de_sortie_fil_calcul=3;tab_modif(numa)=true;break;}
|
||
|
else
|
||
|
{cout << "\n valeur lue erronee, on concerve la valeur "<< cas_de_sortie_fil_calcul;};
|
||
|
}
|
||
|
case 1: case 2: case 5: case 6: case 7:
|
||
|
{ cout << "\n nouvelle valeur (un entier) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_int = ChangeEntier(string_inter);}
|
||
|
else
|
||
|
{ cout << " erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 3:
|
||
|
{ cout << "\n nouvelle valeur (un reel) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_double = ChangeReel(string_inter);}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
};
|
||
|
switch (numa)
|
||
|
{ case 0: // préparation de sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 1: { frequence_affichage_increment = val_int;tab_modif(numa)=true;break;}
|
||
|
case 2: { frequence_affichage_iteration = val_int;tab_modif(numa)=true;break;}
|
||
|
case 3: { sortie_fil_calcul = val_double;tab_modif(numa)=true;break;}
|
||
|
case 5: { nb_diggit_double_calcul = val_int;tab_modif(numa)=true;break;}
|
||
|
case 6: { nb_diggit_double_graphique = val_int;tab_modif(numa)=true;break;}
|
||
|
case 7: { nb_diggit_double_ecran = val_int;tab_modif(numa)=true;break;}
|
||
|
};
|
||
|
// écriture
|
||
|
|
||
|
}
|
||
|
catch (ErrSortieFinale)
|
||
|
// cas d'une direction voulue vers la sortie
|
||
|
// on relance l'interuption pour le niveau supérieur
|
||
|
{ ErrSortieFinale toto;
|
||
|
throw (toto);
|
||
|
}
|
||
|
catch (...)//(UtilLecture::ErrNouvelleDonnee erreur)
|
||
|
{ cout << "\n Erreur on attendait un des mots cles proposes !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour sortir ";
|
||
|
};
|
||
|
}; //-- fin du while interne
|
||
|
// écriture des paramètres de contrôle
|
||
|
for (int i=1;i<=nb_choix;i++)
|
||
|
if (tab_modif(i))
|
||
|
{switch (i)
|
||
|
{ case 3: case 4 :
|
||
|
{ sort << "\n FREQUENCE_SORTIE_FIL_DU_CALCUL ";
|
||
|
switch (cas_de_sortie_fil_calcul)
|
||
|
{case 2: sort << " INTER_TEMPS " << sortie_fil_calcul ;break;
|
||
|
case 3: sort << " DERNIER_CALCUL ";break;
|
||
|
default: sort << sortie_fil_calcul;
|
||
|
};
|
||
|
break;
|
||
|
}
|
||
|
case 1: { sort << "\n FREQUENCE_AFFICHAGE_INCREMENT "<< frequence_affichage_increment;break;}
|
||
|
case 2: { sort << "\n FREQUENCE_AFFICHAGE_ITERATION " << frequence_affichage_iteration ;break;}
|
||
|
case 5: { sort << "\n NB_CHIFFRE_POUR_DOUBLE_CALCUL "<< nb_diggit_double_calcul ;break;}
|
||
|
case 6: { sort << "\n NB_CHIFFRE_POUR_DOUBLE_GRAPHIQUE " << nb_diggit_double_graphique;break;}
|
||
|
case 7: { sort << "\n NB_CHIFFRE_POUR_DOUBLE_ECRAN " << nb_diggit_double_ecran;break;}
|
||
|
};
|
||
|
};
|
||
|
break;
|
||
|
}
|
||
|
case 5: // parametres lies au contact
|
||
|
{ sort << "\n\n para_contact #------------ "
|
||
|
<< "\n#--------------------------- "
|
||
|
<< "\n# PARAMETRE | VALEUR | "
|
||
|
<< "\n#--------------------------- ";
|
||
|
Tableau<bool> tab_modif(33,false); // indique qu'est-ce qui a été modifié
|
||
|
//On va proposer un menu
|
||
|
string repa=" ";
|
||
|
cout << "\n --- controle generaux ------ ";
|
||
|
while ((Minuscules(repa) != "f")&&(Minuscules(repa) != "0"))
|
||
|
{try
|
||
|
{ cout << "\n (0 ou f) (fin) "
|
||
|
<< "\n --- parametres de controle du contact "
|
||
|
<< "\n [c] -> para tres classique [-] para assez courants "
|
||
|
<< "\n (1) PRECISION_POINT_INTERNE_DEBUT = 1.e-6 "
|
||
|
<< "\n (2) FACT_POUR_RAYON_ACCOSTAGE = 1. "
|
||
|
<< "\n (3) DISTANCE_MAXI_AU_PT_PROJETE = tres grand "
|
||
|
<< "\n (4) PRECISION_BOITE_PRELOCALISATION = 1.05 "
|
||
|
<< "\n (5) MINI_EXTRA_BOITE_PRELOCALISATION = -0.001 "
|
||
|
<< "\n (6) CONTACT_TYPE = 0 "
|
||
|
<< "\n (7) PENALISATION_PENETRATION = 0.1 "
|
||
|
<< "\n (8) TYPE_PENALISATION_PENETRATION = 2 "
|
||
|
<< "\n (9) PENETRATION_CONTACT_MAXI = 0.1 "
|
||
|
<< "\n (10) PENETRATION_BORNE_REGULARISATION = tres grand "
|
||
|
<< "\n (11) FORCE_CONTACT_NOEUD_MAXI = tres grand "
|
||
|
<< "\n (12) PENALISATION_TANGENTIELLE = 1.e6 "
|
||
|
<< "\n (13) PRECISION_PT_SUR_FRONTIERE = 1.e-4 "
|
||
|
<< "\n (14) NB_BOUCLE_NEWTON_SUR_POSITION_FRONTIERE = 10 "
|
||
|
<< "\n (15) NB_DECOLLEMENT_MAXI = 1 "
|
||
|
<< "\n (16) TYPE_DE_DECOLLEMENT = 0 "
|
||
|
<< "\n (17) NB_MOY_GLISSANT = 1 "
|
||
|
<< "\n (18) NIVEAU_COMMENTAIRE_CONTACT = 0 "
|
||
|
<< "\n (19) TYPE_PENALISATION_TANGENTIELLE = 2 "
|
||
|
<< "\n (20) TANGENTIELLE_CONTACT_MAXI = 0.1 "
|
||
|
<< "\n (21) TANGENTIELLE_BORNE_REGULARISATION = tres grand "
|
||
|
<< "\n (22) FORCE_TANGENTIELLE_NOEUD_MAXI = tres grand "
|
||
|
<< "\n (23) AJOUT_EXTRA_BOITE_PRELOCALISATION = 0. "
|
||
|
<< "\n (24) OPTIMISATION_NUMEROTATION = 0 "
|
||
|
<< "\n (25) FCT_ND_BASCUL_CONTACT_TYPE_4 = '_' "
|
||
|
<< "\n (26) FCT_ND_PENALISATION_PENETRATION "
|
||
|
<< "\n (27) FCT_ND_PENETRATION_CONTACT_MAXI "
|
||
|
<< "\n (28) FCT_ND_PENETRATION_BORNE_REGULARISATION "
|
||
|
<< "\n (29) FCT_ND_FORCE_CONTACT_NOEUD_MAXI "
|
||
|
<< "\n (30) FCT_ND_PENALISATION_TANGENTIELLE "
|
||
|
<< "\n (31) FCT_ND_TANGENTIELLE_CONTACT_MAXI "
|
||
|
<< "\n (32) FCT_ND_TANGENTIELLE_BORNE_REGULARISATION "
|
||
|
<< "\n (33) FCT_ND_FORCE_TANGENTIELLE_NOEUD_MAXI "
|
||
|
<< "\n (34 ou h ou ? ) informations "
|
||
|
<< "\n ";
|
||
|
repa = lect_return_defaut(false,"f");
|
||
|
if ((Minuscules(repa) == "f") || (Minuscules(repa) == "0"))// sortie directe
|
||
|
break;
|
||
|
int numa = ChangeEntier(repa);
|
||
|
if (repa == "?") numa = 34;
|
||
|
|
||
|
if (!((numa >= 0)&&(numa<=34)))
|
||
|
{ cout << "\n Erreur on attendait un entier entre 0 et 34 !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour arreter le programme";
|
||
|
};
|
||
|
int val_int;
|
||
|
bool val_bool;
|
||
|
double val_double;
|
||
|
string val_string,string_inter;
|
||
|
|
||
|
switch (numa)
|
||
|
{ case 0: // sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 6: case 8: case 14: case 15: case 16: case 17: case 18: case 19: case 24:
|
||
|
{ cout << "\n nouvelle valeur (un entier ) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_int = ChangeEntier(string_inter);}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 1: case 2: case 3: case 4: case 5: case 23: case 7: case 9: case 10: case 11:
|
||
|
case 12: case 13: case 20: case 21: case 22:
|
||
|
{ cout << "\n nouvelle valeur (un reel) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_double = ChangeReel(string_inter);}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 25:
|
||
|
{ cout << "\n donner le nom de la fonction nD (un string ) ? ";
|
||
|
val_string= lect_chaine();cout << " nom lue ="<<val_string;
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
case 34:
|
||
|
{ cout << "\n PRECISION_POINT_INTERNE_DEBUT: precision du test: point interieur ?, "
|
||
|
<< " avant le debut des calculs "
|
||
|
<< "\n FACT_POUR_RAYON_ACCOSTAGE: facteur multiplicatif du deplacement maxi entre t et tdt"
|
||
|
<< " donnant la distance maxi admissible entre le point et le point projete "
|
||
|
<< "\n DISTANCE_MAXI_AU_PT_PROJETE: a priori grand, est ensuite eventuellement "
|
||
|
<< " gere par l'entree des donnees"
|
||
|
<< "\n PRECISION_BOITE_PRELOCALISATION: donne la proportion de plus qui est "
|
||
|
<< " attribuee aux boites de prelocalisation "
|
||
|
<< "\n MINI_EXTRA_BOITE_PRELOCALISATION: permet le calcul de la bande mini autour de la boite de prelocalisation "
|
||
|
<< "\n AJOUT_EXTRA_BOITE_PRELOCALISATION: ajout dans toutes les directions autour de la boite de prelocalisation "
|
||
|
<< "\n CONTACT_TYPE: a priori il n'y a pas de contact d'element "
|
||
|
<< "\n PENALISATION_PENETRATION: facteur pour le calcul du coefficient de penalisation "
|
||
|
<< "\n TYPE_PENALISATION_PENETRATION: par defaut le calcul est identique a ls-dyna avec "
|
||
|
<< " la compressibilite du maitre "
|
||
|
<< "\n PENETRATION_CONTACT_MAXI: cf doc "
|
||
|
<< "\n PENETRATION_BORNE_REGULARISATION: cf doc "
|
||
|
<< "\n FORCE_CONTACT_NOEUD_MAXI: borne maxi pour la force de reaction du noeud "
|
||
|
<< "\n PENALISATION_TANGENTIELLE: facteur de penalisation pour le deplacement tangentiel "
|
||
|
<< "\n PRECISION_PT_SUR_FRONTIERE: precision de positionnement sur les X^ar d'un pt "
|
||
|
<< " en contact sur une frontiere "
|
||
|
<< "\n NB_BOUCLE_NEWTON_SUR_POSITION_FRONTIERE: nb de boucle maxi pour la recherche du "
|
||
|
<< " positionnement du pt en contact "
|
||
|
<< "\n NB_DECOLLEMENT_MAXI: nb de fois qu'un noeud decolle pour n'etre plus considere en contact "
|
||
|
<< "\n TYPE_DE_DECOLLEMENT: cf doc "
|
||
|
<< "\n NB_MOY_GLISSANT: nb de pt utilise pour la moyenne glissante cf doc "
|
||
|
<< "\n NIVEAU_COMMENTAIRE_CONTACT: si sup au niveau global, gere les sorties de commentaires "
|
||
|
<< "\n pour la penalisation sur le deplacement tangentiel, meme logique que la "
|
||
|
<< "\n penalisation en penetration "
|
||
|
<< "\n OPTIMISATION_NUMEROTATION : si diff de 0, indique une renumerotation en fct"
|
||
|
<< "\n du contact, en particulier apres l'apparition ou la disparition "
|
||
|
<< "\n d'element de contact"
|
||
|
<< "\n FCT_ND_BASCUL_CONTACT_TYPE_4: nom d'une fonction nD permettant de piloter "
|
||
|
<< "\n le basculement du type de contact 4 a 2 (cf. doc) "
|
||
|
<< endl;
|
||
|
break;
|
||
|
}
|
||
|
default:
|
||
|
cout << "\n cas non prevu, recommencer ! ";
|
||
|
};
|
||
|
switch (numa)
|
||
|
{ case 0: // préparation de sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 1: { prec_pt_int_deb = val_double;tab_modif(numa)=true;break;}
|
||
|
case 2: { factPourRayonAccostage = val_double;tab_modif(numa)=true;break;}
|
||
|
case 3: { distanceMaxiAuPtProjete = val_double;tab_modif(numa)=true;break;}
|
||
|
case 4: { extra_boite_prelocalisation = val_double;tab_modif(numa)=true;break;}
|
||
|
case 5: { mini_extra_boite_prelocalisation = val_double;tab_modif(numa)=true;break;}
|
||
|
case 6: { contact_type = val_int;tab_modif(numa)=true;break;}
|
||
|
case 7: { penalisationPenetration = val_double;tab_modif(numa)=true;break;}
|
||
|
case 8: { typePenalisationPenetration = val_int;tab_modif(numa)=true;break;}
|
||
|
case 9: { penetration_contact_maxi = val_double;tab_modif(numa)=true;break;}
|
||
|
case 10: { penetration_borne_regularisation = val_double;tab_modif(numa)=true;break;}
|
||
|
case 11: { force_contact_noeud_maxi = val_double;tab_modif(numa)=true;break;}
|
||
|
case 12: { penalisationTangentielle = val_double;tab_modif(numa)=true;break;}
|
||
|
case 13: { prec_pt_sur_frontiere = val_double;tab_modif(numa)=true;break;}
|
||
|
case 14: { nb_boucle_newton_position_frontiere = val_int;tab_modif(numa)=true;break;}
|
||
|
case 15: { nbDecolAutorise = val_int;tab_modif(numa)=true;break;}
|
||
|
case 16: { typeDeDecolement = val_int;tab_modif(numa)=true;break;}
|
||
|
case 17: { nb_glissant = val_int;tab_modif(numa)=true;break;}
|
||
|
case 18: { niveau_commentaire_contact = val_int;tab_modif(numa)=true;break;}
|
||
|
case 19: { typePenalisationTangentielle = val_int;tab_modif(numa)=true;break;}
|
||
|
case 20: { tangentielle_contact_maxi = val_double;tab_modif(numa)=true;break;}
|
||
|
case 21: { tangentielle_borne_regularisation = val_double;tab_modif(numa)=true;break;}
|
||
|
case 22: { force_tangentielle_noeud_maxi = val_double;tab_modif(numa)=true;break;}
|
||
|
case 23: { ajout_extra_boite_prelocalisation = val_double;tab_modif(numa)=true;break;}
|
||
|
case 24: { optimisation_numerotation = val_int;tab_modif(numa)=true;break;}
|
||
|
case 25: { fct_nD_bascul_contact_type_4 = val_string;tab_modif(numa)=true;break;}
|
||
|
case 26: { fct_nD_penalisationPenetration = val_string;tab_modif(numa)=true;break;}
|
||
|
case 27: { fct_nD_penetration_contact_maxi = val_string;tab_modif(numa)=true;break;}
|
||
|
case 28: { fct_nD_penetration_borne_regularisation = val_string;tab_modif(numa)=true;break;}
|
||
|
case 29: { fct_nD_force_contact_noeud_maxi = val_string;tab_modif(numa)=true;break;}
|
||
|
case 30: { fct_nD_penalisationTangentielle = val_string;tab_modif(numa)=true;break;}
|
||
|
case 31: { fct_nD_tangentielle_contact_maxi = val_string;tab_modif(numa)=true;break;}
|
||
|
case 32: { fct_nD_tangentielle_borne_regularisation = val_string;tab_modif(numa)=true;break;}
|
||
|
case 33: { fct_nD_force_tangentielle_noeud_maxi = val_string;tab_modif(numa)=true;break;}
|
||
|
default: break;
|
||
|
};
|
||
|
// écriture
|
||
|
|
||
|
}
|
||
|
catch (ErrSortieFinale)
|
||
|
// cas d'une direction voulue vers la sortie
|
||
|
// on relance l'interuption pour le niveau supérieur
|
||
|
{ ErrSortieFinale toto;
|
||
|
throw (toto);
|
||
|
}
|
||
|
catch (...)//(UtilLecture::ErrNouvelleDonnee erreur)
|
||
|
{ cout << "\n Erreur on attendait un des mots cles proposes !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour sortir ";
|
||
|
};
|
||
|
}; //-- fin du while interne
|
||
|
// écriture des paramètres de contrôle
|
||
|
for (int i=1;i<=17;i++)
|
||
|
if (tab_modif(i))
|
||
|
{switch (i)
|
||
|
{ case 1: { sort << "\n PRECISION_POINT_INTERNE_DEBUT "<< prec_pt_int_deb;break;}
|
||
|
case 2: { sort << "\n FACT_POUR_RAYON_ACCOSTAGE "<< factPourRayonAccostage;break;}
|
||
|
case 3: { sort << "\n DISTANCE_MAXI_AU_PT_PROJETE "<< distanceMaxiAuPtProjete;break;}
|
||
|
case 4: { sort << "\n PRECISION_BOITE_PRELOCALISATION " << extra_boite_prelocalisation ;break;}
|
||
|
case 5: { sort << "\n MINI_EXTRA_BOITE_PRELOCALISATION "<< mini_extra_boite_prelocalisation ;break;}
|
||
|
case 6: { sort << "\n CONTACT_TYPE " << contact_type;break;}
|
||
|
case 7: { sort << "\n PENALISATION_PENETRATION " << penalisationPenetration;break;}
|
||
|
case 8: { sort << "\n TYPE_PENALISATION_PENETRATION " << typePenalisationPenetration;break;}
|
||
|
case 9: { sort << "\n PENETRATION_CONTACT_MAXI " << penetration_contact_maxi;break;}
|
||
|
case 10: { sort << "\n PENETRATION_BORNE_REGULARISATION " << penetration_borne_regularisation;break;}
|
||
|
case 11: { sort << "\n FORCE_CONTACT_NOEUD_MAXI " << force_contact_noeud_maxi;break;}
|
||
|
case 12: { sort << "\n PENALISATION_TANGENTIELLE " << penalisationTangentielle ;break;}
|
||
|
case 13: { sort << "\n PRECISION_PT_SUR_FRONTIERE " << prec_pt_sur_frontiere;break;}
|
||
|
case 14: { sort << "\n NB_BOUCLE_NEWTON_SUR_POSITION_FRONTIERE " << nb_boucle_newton_position_frontiere;break;}
|
||
|
case 15: { sort << "\n NB_DECOLLEMENT_MAXI " << nbDecolAutorise;break;}
|
||
|
case 16: { sort << "\n TYPE_DE_DECOLLEMENT " << typeDeDecolement;break;}
|
||
|
case 17: { sort << "\n NB_MOY_GLISSANT " << nb_glissant;break;}
|
||
|
case 18: { sort << "\n NIVEAU_COMMENTAIRE_CONTACT " << niveau_commentaire_contact;break;}
|
||
|
case 19: { sort << "\n TYPE_PENALISATION_TANGENTIELLE " << typePenalisationTangentielle;break;}
|
||
|
case 20: { sort << "\n TANGENTIELLE_CONTACT_MAXI " << tangentielle_contact_maxi;break;}
|
||
|
case 21: { sort << "\n TANGENTIELLE_BORNE_REGULARISATION " << tangentielle_borne_regularisation;break;}
|
||
|
case 22: { sort << "\n FORCE_TANGENTIELLE_NOEUD_MAXI " << force_tangentielle_noeud_maxi;break;}
|
||
|
case 23: { sort << "\n AJOUT_EXTRA_BOITE_PRELOCALISATION "<< ajout_extra_boite_prelocalisation ;break;}
|
||
|
case 24: { sort << "\n OPTIMISATION_NUMEROTATION "<< optimisation_numerotation ;break;}
|
||
|
case 25: { sort << "\n FCT_ND_BASCUL_CONTACT_TYPE_4 "<< fct_nD_bascul_contact_type_4 ;break;}
|
||
|
case 26: { sort << "\n PENALISATION_PENETRATION FCT_ND_PENALISATION_PENETRATION "<< fct_nD_penalisationPenetration ;break;}
|
||
|
case 27: { sort << "\n PENETRATION_CONTACT_MAXI FCT_ND_PENETRATION_CONTACT_MAXI "<< fct_nD_penetration_contact_maxi ;break;}
|
||
|
case 28: { sort << "\n PENETRATION_BORNE_REGULARISATION FCT_ND_PENETRATION_BORNE_REGULARISATION "<< fct_nD_penetration_borne_regularisation ;break;}
|
||
|
case 29: { sort << "\n FORCE_CONTACT_NOEUD_MAXI FCT_ND_FORCE_CONTACT_NOEUD_MAXI "<< fct_nD_force_contact_noeud_maxi ;break;}
|
||
|
case 30: { sort << "\n PENALISATION_TANGENTIELLE FCT_ND_PENALISATION_TANGENTIELLE "<< fct_nD_penalisationTangentielle ;break;}
|
||
|
case 31: { sort << "\n TANGENTIELLE_CONTACT_MAXI FCT_ND_TANGENTIELLE_CONTACT_MAXI "<< fct_nD_tangentielle_contact_maxi ;break;}
|
||
|
case 32: { sort << "\n TANGENTIELLE_BORNE_REGULARISATION FCT_ND_TANGENTIELLE_BORNE_REGULARISATION "<< fct_nD_tangentielle_borne_regularisation ;break;}
|
||
|
case 33: { sort << "\n FORCE_TANGENTIELLE_NOEUD_MAXI FCT_ND_FORCE_TANGENTIELLE_NOEUD_MAXI "<< fct_nD_force_tangentielle_noeud_maxi ;break;}
|
||
|
default: break;
|
||
|
};
|
||
|
};
|
||
|
break;
|
||
|
}
|
||
|
case 6: // parametres lies aux energies
|
||
|
{ break;
|
||
|
}
|
||
|
case 7: // parametres lies aux calculs geometriques sur les elements
|
||
|
{ sort << "\n\n para_calculs_geometriques #------------ "
|
||
|
<< "\n#--------------------------- "
|
||
|
<< "\n# PARAMETRE | VALEUR | "
|
||
|
<< "\n#--------------------------- ";
|
||
|
int nb_choix = 7; // nombre de choix
|
||
|
Tableau<bool> tab_modif(nb_choix,false); // indique qu'est-ce qui a été modifié
|
||
|
//On va proposer un menu
|
||
|
string repa=" ";
|
||
|
cout << "\n --- affichage ------ ";
|
||
|
while ((Minuscules(repa) != "f")&&(Minuscules(repa) != "0"))
|
||
|
{try
|
||
|
{ cout << "\n (0 ou f) (fin) "
|
||
|
<< "\n --- parametres lies aux calculs geometriques sur les elements et para par defaut "
|
||
|
<< "\n [c] -> para tres classique [-] para assez courants "
|
||
|
<< "\n (1) precision sur theta_i pour test in/out element = 1.e-4 "
|
||
|
<< "\n (POINT_INTERNE_DELTA_THETAI_MAXI) "
|
||
|
<< "\n (2) precision sur theta_i pour test si in/sur frontiere/out element = 1.e-6 "
|
||
|
<< "\n (POINT_INTERNE_PREC_THETAI_INTERNE) "
|
||
|
<< "\n (3) nb de boucle de Newton pour recherche des theta_i pour surface non lineaire = 10 "
|
||
|
<< "\n (POINT_INTERNE_NB_BOUCLE_SUR_DELTA_THETAI) "
|
||
|
<< "\n (4) nb de fois le pt est externe dans boucle de Newton (3) avant que "
|
||
|
<< "\n declare definitivement externe -> arret boucle : = 3 "
|
||
|
<< "\n (POINT_INTERNE_NB_EXTERNE) "
|
||
|
<< "\n (5) indique si oui non -> calcul des volumes entre la membrane et les plans de ref (= 0) "
|
||
|
<< "\n (CAL_VOL_TOTAL_ENTRE_SURFACE_ET_PLANS_REF) "
|
||
|
<< "\n (6) rapport maxi entre jacobien de la facette centrale et du pti en epaisseur "
|
||
|
<< "\n pour les elements coques = 200. "
|
||
|
<< "\n (RATIO_MAXI_JACOMEMBRANE_JACOPTI) "
|
||
|
<< "\n (7) methode pour inversion du tenseur metrique (CRAMER ou LU_EQUILIBRE) = CRAMER "
|
||
|
<< "\n (TYPE_CALNUM_INVERSION_METRIQUE) "
|
||
|
<< "\n ";
|
||
|
repa = lect_return_defaut(false,"f");
|
||
|
if ((Minuscules(repa) == "f") || (Minuscules(repa) == "0"))// sortie directe
|
||
|
break;
|
||
|
int numa = ChangeEntier(repa);
|
||
|
if (!((numa >= 0)&&(numa<=nb_choix)))
|
||
|
{ cout << "\n Erreur on attendait un entier entre 0 et "<<nb_choix<<" !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour arreter le programme";
|
||
|
};
|
||
|
int val_int;
|
||
|
bool val_bool;
|
||
|
double val_double;
|
||
|
string val_string,string_inter;
|
||
|
bool bonne_lecture = false;
|
||
|
|
||
|
switch (numa)
|
||
|
{ case 0: // sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 3: case 4:
|
||
|
{ cout << "\n nouvelle valeur (un entier) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_int = ChangeEntier(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 1: case 2: case 6:
|
||
|
{ cout << "\n nouvelle valeur (un reel) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est numérique
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ val_double = ChangeReel(string_inter);bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 5:
|
||
|
{ cout << "\n calcul des volumes (1 ou 0 ) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (isNumeric( string_inter.c_str(), 10))
|
||
|
{ int essai = ChangeEntier(string_inter);
|
||
|
if ((essai == 1) || (essai == 0))
|
||
|
{val_int = essai;bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " ** erreur il faut 1 ou 0 ! "; };
|
||
|
}
|
||
|
else
|
||
|
{ cout << " *** erreur: valeur non numerique !! ";};
|
||
|
break;
|
||
|
}
|
||
|
case 7:
|
||
|
{ cout << "\n methode d'inversion (CRAMER ou LU_EQUILIBRE) ? ";
|
||
|
string_inter= lect_chaine();cout << " valeur lue ="<<string_inter;
|
||
|
// on test si c'est recevable
|
||
|
if (Existe_Enum_type_resolution_matri(val_string))
|
||
|
{ val_string = string_inter;bonne_lecture=true;}
|
||
|
else
|
||
|
{ cout << " *** erreur: ce type n'est pas correcte !! ";};
|
||
|
break;
|
||
|
}
|
||
|
};
|
||
|
switch (numa)
|
||
|
{ case 0: // préparation de sortie
|
||
|
{ break;} // normalement cela a déjà été filtré avant
|
||
|
case 1: { point_interne_delta_thetai_maxi = val_double;tab_modif(numa)=true;break;}
|
||
|
case 2: { point_interne_prec_thetai_interne = val_double;tab_modif(numa)=true;break;}
|
||
|
case 3: { point_interne_nb_boucle_sur_delta_thetai = val_int;tab_modif(numa)=true;break;}
|
||
|
case 4: { point_interne_nb_externe= val_int; tab_modif(numa) = true; break;}
|
||
|
case 5: { cal_vol_total_entre_surface_et_plans_ref = val_int;tab_modif(numa)=true;break;}
|
||
|
case 6: { ratio_maxi_jacoMembrane_jacoPti = val_double;tab_modif(numa)=true;break;}
|
||
|
case 7: { type_calnum_inversion_metrique = Id_nom_resolution(val_string);tab_modif(numa)=true;break;}
|
||
|
};
|
||
|
// écriture
|
||
|
|
||
|
}
|
||
|
catch (ErrSortieFinale)
|
||
|
// cas d'une direction voulue vers la sortie
|
||
|
// on relance l'interuption pour le niveau supérieur
|
||
|
{ ErrSortieFinale toto;
|
||
|
throw (toto);
|
||
|
}
|
||
|
catch (...)//(UtilLecture::ErrNouvelleDonnee erreur)
|
||
|
{ cout << "\n Erreur on attendait un des mots cles proposes !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour sortir ";
|
||
|
};
|
||
|
}; //-- fin du while interne
|
||
|
// écriture des paramètres de contrôle
|
||
|
for (int i=1;i<=nb_choix;i++)
|
||
|
if (tab_modif(i))
|
||
|
{switch (i)
|
||
|
{ case 1: { sort << "\n POINT_INTERNE_DELTA_THETAI_MAXI "<< point_interne_delta_thetai_maxi;break;}
|
||
|
case 2: { sort << "\n POINT_INTERNE_PREC_THETAI_INTERNE " << point_interne_prec_thetai_interne ;break;}
|
||
|
case 3: { sort << "\n POINT_INTERNE_NB_BOUCLE_SUR_DELTA_THETAI " << point_interne_nb_boucle_sur_delta_thetai; break;}
|
||
|
case 4: { sort << "\n POINT_INTERNE_NB_EXTERNE " << point_interne_nb_externe ;break;}
|
||
|
case 5: { sort << "\n CAL_VOL_TOTAL_ENTRE_SURFACE_ET_PLANS_REF "<< cal_vol_total_entre_surface_et_plans_ref ;break;}
|
||
|
case 6: { sort << "\n RATIO_MAXI_JACOMEMBRANE_JACOPTI " << ratio_maxi_jacoMembrane_jacoPti;break;}
|
||
|
case 7: { sort << "\n TYPE_CALNUM_INVERSION_METRIQUE " << type_calnum_inversion_metrique;break;}
|
||
|
};
|
||
|
};
|
||
|
break;
|
||
|
}
|
||
|
default:
|
||
|
cout << "\n le cas "<<rep<<" n'est pas traite !!, bizarre, il faut se plaindre !! ";
|
||
|
};
|
||
|
}
|
||
|
catch (ErrSortieFinale)
|
||
|
// cas d'une direction voulue vers la sortie
|
||
|
// on relance l'interuption pour le niveau supérieur
|
||
|
{ ErrSortieFinale toto;
|
||
|
throw (toto);
|
||
|
}
|
||
|
catch (...)//(UtilLecture::ErrNouvelleDonnee erreur)
|
||
|
{ cout << "\n Erreur on attendait un des mots cles proposes !!, "
|
||
|
<< "\n redonnez une bonne valeur"
|
||
|
<< "\n ou taper f ou 0 pour sortir ";
|
||
|
};
|
||
|
}; //-- fin du while
|
||
|
sort << "\n "<<flush;
|
||
|
|
||
|
};
|
||
|
|
||
|
|
||
|
// ramène vraie si le numéro d'increment est nulle modulo la frequence d'affichage d'incrément
|
||
|
// si ce dernier est > 0, sinon =0 modulo la fréquence de sauvegarde si celle-ci est < 0 sinon false
|
||
|
// dans le cas où les sorties s'effectue en fonction du temps, passage du dernier temps de sauvegarde
|
||
|
bool ParaAlgoControle::Vrai_commande_sortie(int icharge,const double& temps_derniere_sauvegarde) const
|
||
|
{ if (frequence_affichage_increment > 0)
|
||
|
{ if ((icharge % frequence_affichage_increment) == 0) return true;}
|
||
|
else if (frequence_affichage_increment < 0)
|
||
|
{ // cas où on se cale sur la sauvegarde
|
||
|
bool dernier_calcul = false; // par défaut on considère que ce n'est pas le dernier calcul
|
||
|
return SauvegardeAutorisee(icharge, temps_derniere_sauvegarde,dernier_calcul);
|
||
|
}
|
||
|
return false;
|
||
|
};
|
||
|
|
||
|
// indique si la sauvegarde est autorisée, en fonction des paramètres données par l'utilisateur et les variables
|
||
|
// passée en argument
|
||
|
// dernier_calcul : indique si c'est le dernier calcul ou pas
|
||
|
bool ParaAlgoControle::SauvegardeAutorisee(int incre,const double& temps_derniere_sauvegarde,bool dernier_calcul) const
|
||
|
{ bool ret=false;
|
||
|
switch (cas_de_sauvegarde)
|
||
|
{ case 1:
|
||
|
{ // cas d'une sauvegarde par numéro d'incrément
|
||
|
if (sauvegarde > 0.) { if ((incre % ((int)sauvegarde)) == 0) ret = true;}
|
||
|
else { return false;}; // cas où sauvegarde == 0
|
||
|
break;
|
||
|
}
|
||
|
case 2:
|
||
|
{ // cas d'une sauvegarde tous les intervals de temps = sauvegarde
|
||
|
if (sauvegarde >0)
|
||
|
{ if ((tempo_specifique_algo.TempsCourant()-temps_derniere_sauvegarde) > sauvegarde) return true;}
|
||
|
else { return false;}; // cas où sauvegarde == 0
|
||
|
break;
|
||
|
}
|
||
|
case 3:
|
||
|
{ // cas d'une sauvegarde uniquement au dernier calcul
|
||
|
if (dernier_calcul)
|
||
|
{ return true;}
|
||
|
else { return false;};
|
||
|
break;
|
||
|
}
|
||
|
case 4:
|
||
|
{ // cas d'une sauvegarde par numéro d'incrément + dernier incrément
|
||
|
if (sauvegarde > 0.) { if (((incre % ((int)sauvegarde)) == 0)|| dernier_calcul) return true;}
|
||
|
else if (dernier_calcul) {return true;}
|
||
|
else { return false;}; // cas où sauvegarde == 0
|
||
|
break;
|
||
|
}
|
||
|
case 5:
|
||
|
{ // cas d'une sauvegarde par numéro d'incrément
|
||
|
if (sauvegarde > 0.) { if (((tempo_specifique_algo.TempsCourant()-temps_derniere_sauvegarde) > sauvegarde)
|
||
|
|| dernier_calcul)
|
||
|
return true;
|
||
|
}
|
||
|
else if (dernier_calcul) {return true;}
|
||
|
else { return false;}; // cas où sauvegarde == 0
|
||
|
break;
|
||
|
}
|
||
|
|
||
|
default:
|
||
|
cout << "\n *** warning ce n'est pas normal, aucun type de sauvegarde n'est definit ! on continue quand meme ! "
|
||
|
<< endl;
|
||
|
if (ParaGlob::NiveauImpression() > 3 )
|
||
|
cout << "\n ParaAlgoControle::SauvegardeAutorisee(... " << endl;
|
||
|
break;
|
||
|
}
|
||
|
return ret; // au cas où
|
||
|
};
|
||
|
|
||
|
// indique si la sauvegarde au fil du calcul est autorisée, en fonction des paramètres données par l'utilisateur et les variables
|
||
|
// passée en argument
|
||
|
bool ParaAlgoControle::SauvegardeFilCalculAutorisee(int incre,const double& temps_derniere_sauvegarde,bool dernier_calcul) const
|
||
|
{ bool ret=false;
|
||
|
if (cas_de_sortie_fil_calcul==1)
|
||
|
{ // cas d'une sauvegarde par numéro d'incrément
|
||
|
if (dernier_calcul)
|
||
|
{ ret = true;} // par défaut le dernier calcul est valide
|
||
|
else if (sortie_fil_calcul > 0.)
|
||
|
{ if ((incre % ((int)sortie_fil_calcul)) == 0)
|
||
|
{ret = true;
|
||
|
//cout << "\n debug ParaAlgoControle::SauvegardeFilCalculAutorisee( "
|
||
|
// << "int sortie_fil_calcul) " << ((int)sortie_fil_calcul)
|
||
|
// << " (incre % ((int)sortie_fil_calcul)) "<< (incre % ((int)sortie_fil_calcul))
|
||
|
// << flush;
|
||
|
};
|
||
|
|
||
|
}
|
||
|
else { ret = false;}; // cas où sortie_fil_calcul == 0
|
||
|
}
|
||
|
else if (cas_de_sortie_fil_calcul == 2)
|
||
|
{ // cas d'une sauvegarde tous les intervals = sauvegarde
|
||
|
if (dernier_calcul) { ret = true;} // par défaut le dernier calcul est valide
|
||
|
else if (sortie_fil_calcul >0)
|
||
|
{ if ((tempo_specifique_algo.TempsCourant()-temps_derniere_sauvegarde) > sortie_fil_calcul) return true;}
|
||
|
else { ret = false;}; // cas où sortie_fil_calcul == 0
|
||
|
}
|
||
|
else if (cas_de_sortie_fil_calcul == 3)
|
||
|
{ // cas d'une sauvegarde uniquement au dernier calcul
|
||
|
if (dernier_calcul)
|
||
|
{ ret = true;}
|
||
|
else { ret = false;};
|
||
|
}
|
||
|
return ret;
|
||
|
};
|
||
|
|
||
|
// modification de l'increment de temps,
|
||
|
// si c'est >= au deltat mini et <= deltat maxi, => retour 0
|
||
|
// modif
|
||
|
// si c'est < au deltat mini ==> retour -1 : pas de modification du deltat
|
||
|
// si c'est > au deltat maxi ==> retour 1 : pas de modification du deltat
|
||
|
|
||
|
/* // si c'est < au deltat mini et que l'on est déjà au temps mini ==> retour -1 : pas de modification du deltat
|
||
|
// si c'est > au deltat maxi et que l'on est déjà au temps maxi ==> retour 1 : pas de modification du deltat
|
||
|
|
||
|
// si c'est > au deltat maxi et que l'on est < au temps maxi ==> retour 3 : pas de modification du deltat
|
||
|
// si c'est < au deltat mini et que l'on est > au temps mini ==> retour 4 : pas de modification du deltat */
|
||
|
|
||
|
|
||
|
int ParaAlgoControle::Modif_Deltat(double nouveau_temps)
|
||
|
{ int retour=0;
|
||
|
// le cas sans pb
|
||
|
if ((tempo_specifique_algo.deltatmini <= nouveau_temps) && (nouveau_temps <= tempo_specifique_algo.deltatmaxi))
|
||
|
{tempo_specifique_algo.deltat = tempo.deltat = nouveau_temps;};
|
||
|
|
||
|
// cas particuliers
|
||
|
if (nouveau_temps > tempo_specifique_algo.deltatmaxi)
|
||
|
{ retour = 1; }; // cas ou on veut un delta t plus grand que le maxi, on ne fait rien
|
||
|
if (nouveau_temps < tempo_specifique_algo.deltatmini)
|
||
|
{ retour = -1; }; // cas ou l'on veut un delta t plus petit que le mini, on ne fait rien
|
||
|
/*
|
||
|
if ((tempo.deltat==tempo.deltatmaxi)&&(nouveau_temps > tempo.deltatmaxi))
|
||
|
// cas ou l'on est déjà au delta t maxi et on veut un delta t encore plus grand, on ne fait rien
|
||
|
{ retour = 1; }
|
||
|
else if ((tempo.deltat==tempo.deltatmini)&&(nouveau_temps < tempo.deltatmini))
|
||
|
// cas ou l'on est déjà au delta t mini et on veut un delta t encore plus petit, on ne fait rien
|
||
|
{ retour = -1; }
|
||
|
else if ((tempo.deltat < tempo.deltatmaxi)&&(nouveau_temps > tempo.deltatmaxi))
|
||
|
// cas où le delta t actuel est plus petit que le maxi, et que l'on veut un delta t plus grand que le maxi
|
||
|
// on ne fait rien
|
||
|
{ retour = 3; //tempo.deltat=tempo.deltatmaxi;
|
||
|
}
|
||
|
else if ((tempo.deltat > tempo.deltatmini)&&(nouveau_temps < tempo.deltatmini))
|
||
|
// cas où le delta t actuel est plus grand que le mini, et que l'on veut un delta t plus petit que le mini
|
||
|
// on ne fait rien
|
||
|
{ retour = 4; //tempo.deltat=tempo.deltatmini;
|
||
|
};
|
||
|
|
||
|
else if ((tempo.deltat < tempo.deltatmaxi)&&(nouveau_temps > tempo.deltatmaxi))
|
||
|
// cas où le delta t actuel est plus petit que le maxi, et que l'on veut un delta t plus grand que le maxi
|
||
|
// on limite le deltat au deltat maxi, mais il y a modification
|
||
|
{ retour = 0; tempo.deltat=tempo.deltatmaxi;}
|
||
|
else if ((tempo.deltat > tempo.deltatmini)&&(nouveau_temps < tempo.deltatmini))
|
||
|
// cas où le delta t actuel est plus grand que le mini, et que l'on veut un delta t plus petit que le mini
|
||
|
// on limite le deltat au deltat mini, mais il y a modification
|
||
|
{ retour = 0; tempo.deltat=tempo.deltatmini;}
|
||
|
|
||
|
|
||
|
;
|
||
|
|
||
|
// if ((nouveau_temps == tempo.deltatmaxi) || (nouveau_temps == tempo.deltatmini))
|
||
|
// { retour = 0; } // on ne change rien
|
||
|
// else if ((nouveau_temps < tempo.deltatmini ) { retour = -1;}
|
||
|
// else if (tempo.deltatmaxi < nouveau_temps ) { retour = 1;}; */
|
||
|
|
||
|
return retour;
|
||
|
};
|
||
|
|
||
|
// modification de l'incrément dans les bornes
|
||
|
// si nouveau_temps < deltat mini ==> nouveau_temps = deltat mini
|
||
|
// si nouveau temps > deltat maxi ==> nouveau_temsp = deltat maxi
|
||
|
// sinon on laisse le delta_t à la valeur qu'il a actuellement
|
||
|
// ramène oui ou non si ça a été modifié
|
||
|
bool ParaAlgoControle::Modif_Detat_dans_borne(double& nouveau_temps)
|
||
|
{ bool modif=false;
|
||
|
if (nouveau_temps < tempo_specifique_algo.deltatmini)
|
||
|
{tempo_specifique_algo.deltat = tempo.deltat = tempo.deltatmini;
|
||
|
nouveau_temps = tempo.deltat;modif=true;
|
||
|
};
|
||
|
if (nouveau_temps > tempo_specifique_algo.deltatmaxi)
|
||
|
{tempo_specifique_algo.deltat = tempo.deltat = tempo.deltatmaxi;
|
||
|
nouveau_temps = tempo.deltat;modif=true;
|
||
|
};
|
||
|
return modif;
|
||
|
};
|
||
|
|
||
|
// mise à jour éventuel du pas de temps et du pas de temps maxi et mini dans le cas où ils sont définit avec des coeff
|
||
|
// d'un pas critique, ramène true s'il y a eu modification du pas de temps courant, false sinon
|
||
|
// temps_critique : temps critique de l'algorithme
|
||
|
// temps_critiqueDFC : temps critique de l'algo DFC = condition de courant
|
||
|
bool ParaAlgoControle::Modif_Deltat_DeltatMaxi(double temps_critique, double temps_critiqueDFC)
|
||
|
{ bool modif=false;
|
||
|
if (coef_pas_critique_deltat!= coef_defaut_pa_critique)
|
||
|
{// cas ou le coef multiplicateur du pas critique a été donné par l'utilisateur c'est-a-dire
|
||
|
// que le deltat voulu est une fraction du deltat critique
|
||
|
if (typeDFC_pas_critique_deltat)
|
||
|
{tempo_specifique_algo.deltat = tempo.deltat
|
||
|
= coef_pas_critique_deltat * temps_critiqueDFC - ConstMath::trespetit; modif = true;}
|
||
|
else {tempo_specifique_algo.deltat = tempo.deltat
|
||
|
= coef_pas_critique_deltat * temps_critique - ConstMath::trespetit; modif = true;}
|
||
|
};
|
||
|
if (coef_pas_critique_deltatmaxi != 0.)
|
||
|
{if (typeDFC_pas_critique_deltatmaxi)
|
||
|
{tempo_specifique_algo.deltatmaxi = tempo.deltatmaxi
|
||
|
= coef_pas_critique_deltatmaxi * temps_critiqueDFC; }
|
||
|
else {tempo_specifique_algo.deltatmaxi = tempo.deltatmaxi
|
||
|
= coef_pas_critique_deltatmaxi * temps_critique; };
|
||
|
}
|
||
|
if (coef_pas_critique_deltatmini != -3333256794.)
|
||
|
{if (typeDFC_pas_critique_deltatmini)
|
||
|
{tempo_specifique_algo.deltatmini = tempo.deltatmini
|
||
|
= coef_pas_critique_deltatmini * temps_critiqueDFC; }
|
||
|
else {tempo_specifique_algo.deltatmini = tempo.deltatmini
|
||
|
= coef_pas_critique_deltatmini * temps_critique; };
|
||
|
};
|
||
|
return modif;
|
||
|
};
|
||
|
|
||
|
// on met à jour les infos globales
|
||
|
std::vector <double>& ParaAlgoControle::Mise_a_jour_Grandeurs_globales()
|
||
|
{return ParaGlob::Mise_a_jour_Grandeurs_globales();};
|
||
|
|
||
|
|