* PAS_DEFA PROCEDUR MB234859 24/09/11 21:15:03 12008 ************************************************************************ * * Objet de la procedure : * - verifications coherences donnees. * - initialisations des valeurs par defaut des options de calcul * - initialisation des variables locales * * verifications de quelques arguments obligatoires * existence modele verification et initialisation modeles particuliers * affectation des valeurs par defaut des options dans TWORK * En cas de reprise, la configuration peut etre erronnee * (reprise/poursuite d'un calcul suite a une erreur) * ************************************************************************ * Verifier si d'anciens mots-cles ne sont pas utilises ************************************************************************ 'SI' (('EXISTE' PRECED 'GRANDES_ROTATIONS' ) 'OU' ('EXISTE' PRECED 'GRANDES_DEFORMATIONS')); 'MESS' ' ATTENTION :' ; 'MESS' ' Utilisez l''indice HYPOTHESE_DEFORMATIONS'; 'ERREUR' 21 ; 'FINSI'; * 'SI' ('EXISTE' PRECED 'CONTACT') ; 'MESS' ' ATTENTION :' ; 'ERREUR' 21 ; 'FINSI'; * 'SI' (('EXISTE' PRECED 'PROCEDURE_REAC_MECA') 'OU' ('EXISTE' PRECED 'PROCEDURE_CHAR_MECA') 'OU' ('EXISTE' PRECED 'PROCEDURE_REAC_THER') 'OU' ('EXISTE' PRECED 'PROCEDURE_CHAR_THER') 'OU' ('EXISTE' PRECED 'PROCEDURE_PARA_THER')) ; 'MESS' ' ATTENTION :' ; 'MESS' ' Les donnees concernant les procedures utilisateur ont ete modifiees :' ; 'ERREUR' 21 ; 'FINSI'; * Modifs CB215821 Juillet 2020 'SI' ('EXISTE' PRECED 'TEMPERATURE_REFERENCE'); 'MESS' ' ATTENTION :' ; 'ERREUR' 21 ; 'FINSI'; 'SI' ('EXISTE' PRECED 'TALPHA_REFERENCE'); 'MESS' ' ATTENTION :' ; 'ERREUR' 21 ; 'FINSI'; ************************************************************************ * Verifier la presence de certains indices de PRECED, obligatoires ************************************************************************ 'SI' ('NON' ('EXISTE' PRECED 'MODELE')) ; 'ERREUR' 'Il manque la donnee du modele.'; 'SINON' ; MO = PRECED.'MODELE'; 'SI' (('NEG' TYPMO 'MMODEL ') 'ET' ('NEG' TYPMO 'CHARGEME')) ; 'ERREUR' 'Le type du MODELE est incorrect'; 'FINSI'; 'FINSI' ; * 'SI' ('NON' ('EXISTE' PRECED 'CARACTERISTIQUES')) ; 'ERREUR' 'Il manque la donnee du materiau.'; 'SINON' ; MA = PRECED.'CARACTERISTIQUES' ; 'SI' (('NEG' TYPMA 'MCHAML ') 'ET' ('NEG' TYPMA 'CHARGEME')) ; 'ERREUR' 'Le type du champ de materiau est incorrect'; 'FINSI'; 'FINSI' ; * 'SI' ('EXISTE' PRECED 'TEMPS_CALCULES'); 'SI' ('NEG' TYP1 'LISTREEL'); 'ERREUR' 'Le type de TEMPS_CALCULES est incorrect'; 'FINSI'; 'FINSI' ; * 'SI' ('EXISTE' PRECED 'CHARGEMENT'); 'SI' ('NEG' TYP1 'CHARGEME'); 'ERREUR' 'Le type du CHARGEMENT est incorrect'; 'FINSI'; 'FINSI'; * * Typage de la table en sortie de PASAPAS ************************************************************************ * Initialiser les indices de WTABLE a leur valeur par defaut ************************************************************************ TWORK = 'TABLE' ; * adap_mode : adaptation du modele au cours du calcul TWORK.'ADAP_MODE' = FAUX; * Adherence presence de la composante ADHE (modele contact ou cont/fro) TWORK.'ADHERENCE' = FAUX ; * Advection presence d'un modele thermique advection ou diffusion advection TWORK.'ADVECTION' = FAUX; * matrice d'amortissement en dynamique * arret: indicateur pour quitter la boucle temporelle de PASAPAS TWORK.'ARRET' = FAUX; * autocrit: valeur du critere a utiliser dans autopilo(option automatique) TWORK.'AUTOCRIT' = 0.001; * autocoef: coefficient de pilotage * autodeux=vrai si pilotage et pas premiere tentative : pasapas TWORK.'AUTODEUX' = FAUX; * automatique =vrai si demande de pilotage automatique TWORK.'AUTOMATIQUE' = FAUX; * autopas : nb maxi de tentative en pilotage automatique TWORK.'AUTOPAS' = 250; * autoreca : indique quand recalculer le coefficient de pilotage TWORK.'AUTORECA' = 1; * beton_ht ( ne marche pas!) TWORK.'BETON_HT' = FAUX; * blocages_diffusions; matrices * blocages_mecaniques; matrices * blocages_thermiques; matrices * bou_meth : valeur par defaut du nombre de bouclage mecanique-thermique TWORK.'BOU_METH' = 1; * cafrotte : veut dire il existe modele contact-frottement TWORK.'CAFROTTE' = FAUX ; * capaconst logique il existe une capacite constante TWORK.'CAPACONST' = FAUX; * caracteristiques : * ceramique presence de modele ceramique TWORK.'CERAMIQUE' = FAUX; * indice celsius TWORK.'CELSIUS' = FAUX; * chargement idem celui de preced ou creation d'un chargement farfelu * chargement_i idem chargement DFIS et FI si certain materiau pas_defa * char_BLOD presence d'un chargement de BLOcages Diffusion TWORK.'CHAR_BLOD' = FAUX; * char_blom presence d'un chargement de BLOcages Mecaniques TWORK.'CHAR_BLOM' = FAUX; * char_blot presence d'un chargement de BLOcages Thermiques TWORK.'CHAR_BLOT' = FAUX; * char_defi presence de chargement DEFI deformation initiale TWORK.'CHAR_DEFI' = FAUX; * char_mate presence d'un chargement 'MATE' TWORK.'CHAR_MATE' = FAUX; * char_mode : le modele est de type chargement TWORK.'CHAR_MODE' = FAUX; * char_pres presence de chargement 'P ' de pression suiveuse TWORK.'CHAR_PRES' = FAUX; * char_the presence de chargement thermique pour la mecanique TWORK.'CHAR_THE' = FAUX; * char_pilo presence de chargement de pilotage indirect TWORK.'CHAR_PILO' = FAUX; TWORK.'ZONE_DE_PILOTAGE' = FAUX ; * clim matrice des blocagesmecaniques y compris contact et frottement pasapas * condconst logique il existe une conductivite constante TWORK.'CONDCONST' = FAUX; * conduction presence d'un modele de conduction TWORK.'CONDUCTION' = FAUX; * consolidation presence de consolidation TWORK.'CONSOLIDATION' = FAUX; * contact presence de contact TWORK.'CONTACT' = FAUX ; * conv logique precisant si unpas a bien converge * convection presence d'un modele de convection TWORK.'CONVECTION' = FAUX; * convergence_forcee logique demandant la convergence forcee TWORK.'CONVERGENCE_FORCEE' = VRAI; * demande de convergence mecanique-thermique en cas de bouclage TWORK.'CONVERGENCE_MEC_THE' = FAUX; * logique pour imposer au residu de decroitre de facon monotone TWORK.'CONVERGENCE_MONOTONE' = FAUX; * conv_thmec on a convergee le bouclage mecanique-thermique pasapas TWORK.'CONV_THMEC' = VRAI; * couplage le calcul contient des modeles thermiques et des mecaniques TWORK.'COUPLAGE' = FAUX; * cte_stefan_boltzmann valeur de la constante TWORK.'CTE_STEFAN_BOLTZMANN' = 5.673E-8 ; * deja_calc_charther indique le dernier temps pour lequel on a calcule le * chargement thermique dans charther : charther TWORK.'DEJA_CALC_CHARTHER' = 0.d0; * deltaiter sert au test de non convergence : unpas TWORK.'DELTAITER' = 10; * dt: valeur du delta de temps entre le dernier pas et le pas en cours:pasapas * dtprec : dt du pas precedent: pasapas TWORK.'DTPREC' = 0 ; * dynamique calcul en dynamique TWORK.'DYNAMIQUE' = FAUX; * endommagement il esiste un tel modele de comportement TWORK.'ENDOMMAGEMENT' = FAUX; * Enregistrement de la date du depart de PASAPAS * etat0 etat au temps 0 : pasapas pas_etat * etat1 etat au temps courant : pasapas pas_etat * etat_ref etat de reference : pasapas pas_etat * etref deformation d'origine thermique de reference : pas_epth * ether1 stocke des deformations thermiques au temps precedent : pasapas * fnonl permet forces de reequilibrage du pas precedent : unpas * fopl : forces d'acceleration et d'amortissement * configuration finale : pasapas unpas * configuration en debut de pas : pasapas * FOR_DIFF le calcul inclus des modeles DIFFUSION TWORK.'FOR_DIFF' = FAUX; * FOR_METALLU le calcul inclus des modeles METALLURGIE TWORK.'FOR_METALLU' = FAUX; * utilisation de la frormulation fefp TWORK.'FEFP_FORMULATION' = FAUX; * frea1 partie constante du second membre dynamique,consolidation: pasapas * frequentiel calcul en frequentiel * ftol desequilibre tolere * Configuration courante * grands_deplacement TWORK.'GRANDS_DEPLACEMENTS' = FAUX; * hypothese de calcul pour les deformations * indice d'evolution de la boucle temporelle de pasapas TWORK.'ICHG' = 0; * increment de charge du pas precedent : unpas * logique pour autoriser l'Initialisation a partir du pas precedent : unpas TWORK.'INITIALISATION' = VRAI; * iplavi il existe un modele devant passer par COMP TWORK.'IPLAVI' = FAUX; * ipresu : listreel des temps a mettre dans les tables resultats * iptime liste des temps a calculer * isauvega liste des temps sauvegardes (appel SAUV dans pasapas) * logique la sauvegarde dans pasapas est activee TWORK.'ISAUVEGL' = FAUX; * nombre de sous-pas realise dans unpas TWORK.'ISOUSPAS' = 0 ; * itcar des elements ont des caracteristiques geometriques TWORK.'ITCAR' = FAUX; * ither : pour un calcul meca presence de thermique (via mode ou char) TWORK.'ITHER' = FAUX; * k_sigma il faut utiliser l'operateur KSIGMA TWORK.'K_SIGMA' = FAUX; * k_tangent il faut utiliser l'operateur KTANG TWORK.'K_TANGENT' = FAUX; * k_tangent_iter0 matrice tangente a utiliser pour iteration 0 : unpas * k_tangent_pert operateur KTAN matrice tangente par perturbation : unpas TWORK.'K_TANGENT_PERT' = FAUX; * k_tangent_syme matrice tangente symetrisee : unpas TWORK.'K_TANGENT_SYME' = FAUX; * k_tang_pert_c1 matrice tangente par perturbation coefficient C1 : unpas TWORK.'K_TANG_PERT_C1' = 1.D-3; * k_tang_pert_c2 matrice tangente par perturbation coefficient C2 : unpas * lastktan matrice donnant la derniere matrice tangente : pasapas unpas * langrangien schema numerique lagrangien reactualise par defaut TWORK.'LAG_TOT' = 3 ; * ldeva liste des variables dont dependent les materiaux * leconomi l'option economique est activee : pas_sauv TWORK.'LECONOMI' = FAUX; * liaison_persistante si il existe des liaisons persistantes TWORK.'LIAISON_PERSISTANTE' = FAUX; * linesearch en grand deplacement TWORK.'LINESEARCH' = FAUX; * lisea_m pour les contacts unilateraux en mecaniques :pasapas unpas * lisea_t pour les changements de phase en thermique : pasapas transnon * lpar0 liste des parametres externes a passer a COMP * man methode asymptotique numerique TWORK.'MAN' = FAUX; * massconst logique il existe des masses constantes TWORK.'MASSCONST' = FAUX; * mat0 materiau au temps 0 : pasapas pas_epth * mat1 materiaux pour le pas en cours : pasapas unpas * matvar le materiau est variable : pas_verm TWORK.'MATVAR' = FAUX; * mat_con materiau des modeles de convection * mat_dif materiau des modeles de diffusion * mat_mec materiau des modeles de mecanique * mat_pha materiau des modeles de changement de phase 'PARFAIT' * mat_por materiau des modeles poreux * mat_ray materiau des modeles de rayonnement * mat1 materiaux de reference * mat_sol materiau des modeles de changement de phase 'SOLUBILITE' * mat_T materiau thermique + thermohydrique * mat_the materiau des modeles thermiques * mat_thm materiau thermohydrique * materiau des modeles convection + thermiques * maxdefor valeur limitant la deformation en cas de non convergence * ou de RENORMALISATION souhaitee de ZDEP1 TWORK.'MAXDEFOR' = 1.e-3; * maxiteration nombre maximum d'iteration pour un pas de calcul TWORK.'MAXITERATION' = 49; * maxisouspas nombre maximum de sous pas d'integration du fluage TWORK.'MAXISOUSPAS' = 2000; * maxsousiterations nombre maximum de sous iterations pour un calcul non-local TWORK.'MAXSOUSITERATION' = 500; * maxsouspas nombre maximum de sous pas en cas de non convergence TWORK.'MAXSOUSPAS' = 100; * ma_tot materiau des modeles mecaniques + poreux +liaison * mec1 il existe au moins un modele mecanique TWORK.'MEC1' = FAUX; * affichage messages options calcul entete procedure resolution THERMIQUE TWORK.'MESSTHER' = VRAI ; * modal ou statique TWORK.'MODAL' = FAUX; * mod_adv modele de thermique, advection * mod_con modele de thermique convection * mod_dif modele de diffusion * mod_mec modele mecanique * mod_pha modele de changement de phase 'PARFAIT' * mod_por modele poreux * mod_ray modele rayonnement * mod_sol modele de changement de phase 'SOLUBILITE' * mod_soq : modele source de chaleur * mod_T modele thermique + thermohydrique (contient inconnue T) * mod_the modele thermique * mod_thm modele thermohydrique * mod_tot modele thermique * mo_tot modele mecanique + modele poreux * mo_tot_prec modele mecanique + modele poreux au pas precedent * MODELE ce qui est dans preced.modele * mova nom de la variables internes dont le max est imprime * msrther1 deformations thermiques pour les poreux * msrther2 deformations thermiques pour les poreux * mtol valeur autorisee du desequilibre (en terme de moment) * naures valeur de preced .autoresu TWORK.'NAURES' = 100000; * premier pas de sauvegarde encore present (option economique de pasapas) TWORK.'NFSOR' = 0; * nombre maxi d'iteration internes si k_tangent TWORK.'NITERINTER_MAX' = 15; * niter_ktangent recalcule de la matrice tangente toutes les .. iterations TWORK.'NITER_KTANGENT' = 1; * nloc s'il existe un modele de comportement non_local (preced.non_local) * nmaxsubsteps nb maximun de substepping si fefp TWORK.'NMAXSUBSTEPS' = 1; * nombre_iterations nb d'iterations du pas precedent : pasapas unpas TWORK.'NOMBRE_ITERATIONS' = 12 ; * non_lineaire il existe un materiau utilisateur non-lineaire TWORK.'NON_LINEAIRE' = FAUX; * non_local decrit le modele de comportement non_local (preced.non_local) * delta temps du pas en cours pour dupont2 : pasapas TWORK.'NOUV_PAS' = 0.D0; * nsor numero a ecrire dans les tables de resultats : pas_ init TWORK.'NSOR' = 0; * formulation NAVIER_STOKES materiau NLIN TWORK.'NVSTNL' = FAUX ; * operateur matrice contenant l'operateur d'iterations : pasapas * Ordre est l'ordre de developpement de la MAN TWORK.'ORDRE' = 12; * para_exte il existe des parametres externes : pas_verm TWORK.'PARA_EXTE' = FAUX; * pas numero du pas de temps utile a transnon : pasapas TWORK.'PAS' = 0; * pas_ajuste si ajustement automatique de longueur de pas TWORK.'PAS_AJUSTE' = FAUX; * pas_redu en automatiqu il a fallu reduire le pas : pasapas unpas TWORK.'PAS_REDU' = FAUX; * phase il existe du changement de phase 'PARFAIT' TWORK.'PHASE' = FAUX; * plastique il exite un comportement plastique TWORK.'PLASTIQUE' = FAUX; * por1 il existe un model poreux TWORK.'POR1' = FAUX; * precflex critere de desequilibre sur moment autorise TWORK.'PRECFLEX' = 1.E-4; * precisinter precision pour les iterations locales (fefp) TWORK.'PRECISINTER' = 1.D-8; * precision critere de convergence Thermique & Mecanique TWORK.'PRECISION' = 1.E-4 ; * precsousiteration precision pour les sous iterations en non local TWORK.'PRECSOUSITERATION' = 1.0E-6; * predicteur * procedure initialisation pour g_theta * procedure_charmeca il faut appele la procedure charmeca TWORK.'PROCEDURE_CHARMECA' = FAUX; * procedure_charther il faut appele la procedure charther TWORK.'PROCEDURE_CHARTHER' = FAUX; * procedure_parather il faut appeler la procedure parather TWORK.'PROCEDURE_PARATHER' = FAUX ; * procedure_perso1 il faut appeler la procedur perso1 TWORK.'PROCEDURE_PERSO1' = FAUX; * procedure_perso2 il faut appeler la procedur perso2 TWORK.'PROCEDURE_PERSO2' = FAUX; * procedure_reev_mec il faut appeler la procedur reev_mec TWORK.'PROCEDURE_REEV_MEC' = FAUX ; * procedure_reev_the il faut appeler la procedur reev_the TWORK.'PROCEDURE_REEV_THE' = FAUX ; * procedur_thermique non de la procedure thermique a appeler * processeurs pour imposer l'option de parallelisme * projection le champ de temperature clcule doit etere projete TWORK.'PROJECTION' = FAUX; * raidconst il existe des raideurs constantes TWORK.'RAIDCONST' = FAUX; * raidaugm diffaugm theraugm il existe des raideurs augmentees TWORK.'RAIDAUGM' = FAUX; TWORK.'DIFFAUGM' = FAUX; TWORK.'THERAUGM' = FAUX; * autaug augmentation automatique TWORK.'AUTOAUGM' = FAUX; * rayo il existe du rayonnement en thermique TWORK.'RAYO' = FAUX; * rayonnement on y met des pre-calculs pour le rayonnement : transnon charther * Reactualisation de la matrice en grands deplacements pour 0,1 de defor TWORK.'REAC_GRANDS' = 0.1 ; * logique disant pour charther si geometrie a change : pasapas TWORK.'REA_GEOM' = FAUX ; * reaprec utile pour les contacts unilateraux en dynamiques * recaop = recalcul operateur TWORK.'RECAOP' = VRAI; * recari : recalcul de la rigidite TWORK.'RECARI' = FAUX; * reequilibrage : recalcul du dernier pas de temps lors d'une reprise TWORK.'REEQUILIBRAGE' = FAUX ; * relaxation_dupont2 coeff de relaxation pour dupont2 TWORK.'RELAXATION_DUPONT' = 0.25; * parametre de relaxation du pas de temps en non convergence TWORK.'RELAXATION_NONCONV' = 1.; * relaxation_thet coeff de relaxation pour transnon TWORK.'RELAXATION_THETA' = 1. ; * renormalisation de l'itere pour le limiter TWORK.'RENORMALISATION' = FAUX; * residu chpoint donnant le dernier residu d'equilibre : pasapas unpas * riblo_m matrice de blocages des appuis unilateraux : unpas * riblo_t matrice de blocages des changement de phase : transnon * valeurr des rigidites constantes * solubilite il existe du changement de phase 'SOLUBILITE' TWORK.'SOLUBILITE' = FAUX; * sous_increment nombre de sous increment TWORK.'SOUS_INCREMENT' = 1 ; TWORK.'RECALCUL_SOUSINC' = VRAI ; * SOURCE_Q presence d'un modele thermique source de chaleur TWORK.'SOURCE_Q' = FAUX; * test stabilite de la solution TWORK.'STABILITE' = VRAI; * substepping pour integrer en petites deformation TWORK.'SUBSTEPPING' = FAUX; * tabsauv table indiquant les options de sauv des resultats TWORK.'TABSAUV'.'DEFIN' = FAUX; TWORK.'TABSAUV'.'DEFTO' = FAUX; TWORK.'TABSAUV'.'DEFAP' = FAUX; * temps_calcules liste des tempsd a calculer * tem_calc liste des temps a calculer pour les proc thermique : pasapas * teta facteur pour la theta methode en consolidation TWORK.'TETA' = 1.0D0; * tet0 champ de temperature 2 pas avant : pasapas dupont2 TWORK.'TET0' = 0; * tet1 champ de temperature 1 pas avant : pasapas TWORK.'TET1' = 0; * tet2 champ de temperature du pas courant : pasapas TWORK.'TET2' = 0; * the1 le calcul inclus des modeles thermique TWORK.'THE1' = FAUX; * ther_courant champ de temperature propose pour charther : dupont2 transnon * thm1 le calcul inclus des modeles thermohydriques TWORK.'THM1' = FAUX; * tref temperature de reference 0 ou 273 : transnon dupont2 TWORK.'TREF' = 0.D0; * ttol desequilibre absolu dans TRANSNON * update_lagrangian on veut faire du lagrangien reactualise fefp TWORK.'UPDATE_LAGRANGIAN' = FAUX; * presence d'un modele dit utilisateur TWORK.'UTILISATEUR' = FAUX ; * vieuxpas dt precedent pour dupont2 TWORK.'VIEUXPAS' = 0.D0; * viscodommage il existe un modele de comportement viscodommage TWORK.'VISCODOMMAGE' = FAUX; * viscoplastique il existe un modele de comportement viscoplastique TWORK.'VISCOPLASTIQUE' = FAUX; * visco_externe il existe un modele de comportementvisco_externe TWORK.'VISCO_EXTERNE' = FAUX; * xdeno valeur pour calculer le critere de convergence force : unpas TWORK.'XDENO' = 0.d0; * xdenom valeur pour calculer le critere de convergence moment : unpas TWORK.'XDENOM' = 0.d0; * zraidv : rigidite K+4M/H2 (VITEUNIL) ************************************************************************ * Reprise/poursuite d'un calcul ************************************************************************ * - Reprise d'un calcul : supprimer les infos des instants t > treprise 'SI' (PRECED.'REPRISE' > 0.); PAS_REPR PRECED; 'FINSI'; 'SI' ('EXISTE' PRECED 'REEQUILIBRAGE') ; TWORK.'REEQUILIBRAGE' = PRECED.'REEQUILIBRAGE' ; 'FINSI' ; 'FINSI'; * * - Poursuite d'un calcul : repartir du dernier instant calcule 'REPETER' boui nii; 'SINON'; aa = iii. &boui; 'FINSI'; sinon ; TWORK. aa = PRECED . aa; finsi ; 'FINSI'; 'FIN' BOUI; 'SI' ('EXISTE' PRECED 'REEQUILIBRAGE') ; TWORK.'REEQUILIBRAGE' = PRECED.'REEQUILIBRAGE' ; 'FINSI' ; * * En cas de poursuite de calcul, indices eventuellement utiles a : * UNPAS, TRANSNON, TRANSLIN, DUPONT2 et autres sous-procedures... * (a ameliorer...) * * Pour initialisation a partir du pas precedent TWORK.'ZDEP1' = PRECED.'WTABLE'.'ZDEP1' ; TWORK.'FNONL' = PRECED.'WTABLE'.'FNONL' ; TWORK.'INCREMENT' = PRECED.'WTABLE'.'INCREMENT' ; TWORK.'RESIDU' = PRECED.'WTABLE'.'RESIDU' ; TWORK.'ISOUSPAS' = PRECED.'WTABLE'.'ISOUSPAS' ; 'FINSI' ; * * Pour le pilotage automatique TWORK.'AUTOCOEF' = PRECED.'WTABLE'.'AUTOCOEF'; TWORK.'XDENO' = PRECED.'WTABLE'.'XDENO' ; TWORK.'XDENOM' = PRECED.'WTABLE'.'XDENOM' ; * * En dynamique TWORK.'FREA1' = PRECED.'WTABLE'.'FREA1' ; TWORK.'OPERATEUR' = PRECED.'WTABLE'.'OPERATEUR' ; TWORK.'DTPREC' = PRECED.'WTABLE'.'DTPREC' ; * * Rigidite tangente TWORK.'LASTKTAN' = PRECED.'WTABLE'.'LASTKTAN' ; * * Pour PAS_AJUSTE TWORK.'NOMBRE_ITERATIONS' = PRECED.'WTABLE'.'NOMBRE_ITERATIONS' ; * THERMIQUE ajout de matiere (prour reprise) : TWORK.'CAPA_COURANTE' = PRECED.'WTABLE'.'CAPA_COURANTE' ; 'FINSI' ; 'FINSI' ; * 'FINSI'; TWORK.'RECAOP' = 'EGA' TWORK.'OPERATEUR' 'INCONNU' ; ************************************************************************ * Stocker TWORK a l'indice WTABLE de PRECED ************************************************************************ PRECED.'WTABLE' = TWORK ; ************************************************************************ * Renseigner WTABLE a partir des informations de PRECED ************************************************************************ 'SI' ('EGA' TYPMO 'CHARGEME') ; TWORK.'CHAR_MODE' = VRAI ; 'SINON' ; TWORK.'MODELE' = MO ; 'FINSI' ; *----------------------------------------------------------------------- 'SI' ('EGA' TYPMA 'CHARGEME') ; TWORK.'CHAR_MATE' = VRAI ; 'SINON' ; TWORK.'CARACTERISTIQUES' = MA ; 'FINSI'; *----------------------------------------------------------------------- TWORK.'CHARGEMENT' = PRECED.'CHARGEMENT'; 'FINSI'; *----------------------------------------------------------------------- 'SI' ('EXISTE' PRECED 'PAS_AJUSTE'); TWORK.'PAS_AJUSTE' = PRECED.'PAS_AJUSTE'; 'SI' TWORK.'PAS_AJUSTE' ; TWORK.'CONVERGENCE_FORCEE' = FAUX ; 'FINSI'; 'FINSI'; 'SI' ('EXISTE' PRECED 'AUTOMATIQUE'); TWORK.'AUTOMATIQUE' = PRECED.'AUTOMATIQUE'; * par defaut pas de controle de stabilite en pilotage TWORK.'STABILITE' = FAUX; 'FINSI' ; 'SI' TWORK.'AUTOMATIQUE'; TWORK.'PAS_AJUSTE' = FAUX; 'FINSI'; * TWORK.'TEMPS_CALCULES'= PRECED.'TEMPS_CALCULES'; 'SINON' ; 'SI' TWORK.'FREQUENTIEL' ; 'SI' ('EXISTE' TWORK.'CARACTERISTIQUES' 'FREQ') ; 'REPE' vfr1 ncfr1 ; ** hypothese 1 modele = 1 mode !! log_f1 = ('LOG' f1) / ('LOG' 10.) ; e10_f1 = 'ENTI' log_f1 ; 'SI' (log_f1 < 0.) ; e10_f1 = e10_f1 - 1 ; 'FINSI' ; 'SI'((log_f1 - e10_f1) 'EGA' 0.) ; e10_f1 = e10_f1 - 1 ; 'FINSI' ; p10_f1 = 10. ** e10_f1 ; (f1 - (p10_f1/1000.)) (f1 + (p10_f1/1000.)) ; l_i10 = l_ii * p10_f1 ; e10_min = e10_f1 ; e10_max = e10_f1 + 1 ; 'SINON' ; l_zf0 = l_zf ; 'SI' ((e10_f1 '>EG' e10_min) 'ET' (e10_f1 < e10_max)) ; 'SINON' ; 'SI' (e10_f1 < e10_min) ; e10_u = e10_f1 ; 'REPE' b_lz ; l_zf0 = l_i10 'ET' l_zf0 ; e10_u = e10_u + 1 ; 'SI' (e10_u 'EGA' e10_min) ; 'QUIT' b_lz ; 'FINSI' ; l_i10 = l_i10 * 10 ; 'FIN' b_lz ; e10_min = e10_f1 ; 'FINSI' ; 'SI' (e10_f1 '>EG' e10_max) ; e10_u = e10_f1 ; 'REPE' b_lz ; l_zf0 = l_i10 'ET' l_zf0 ; e10_u = e10_u - 1 ; 'SI' (e10_u < e10_max) ; 'QUIT' b_lz ; 'FINSI' ; l_i10 = l_i10 / 10 ; 'FIN' b_lz ; e10_max = e10_f1 + 1; 'FINSI' ; 'FINSI' ; 'FINSI' ; 'FIN' vfr1 ; 'SINON' ; l_zf = l_ii ; 'FINSI' ; TWORK.'TEMPS_CALCULES' = l_zf ; 'SINON' ; TWORK.'TEMPS_CALCULES' = l_ii ; 'FINSI' ; 'SINON'; 'SI' ('NON' ('EXISTE' PRECED 'TEMPS_SAUVES')); 'FINSI'; TWORK.'PAS_AJUSTE' = VRAI; TWORK.'TEMPS_CALCULES' = PRECED.'TEMPS_SAUVES'; TWORK.'TEMPS_SAUVES' = PRECED.'TEMPS_SAUVES'; 'FINSI'; 'FINSI'; TWORK.'IPTIME' = TWORK.'TEMPS_CALCULES'; TWORK.'IPRESU' = TWORK.'TEMPS_CALCULES'; 'SI' ('EXISTE' PRECED 'TEMPS_SAUVES' ); TWORK.'IPRESU' = PRECED.'TEMPS_SAUVES'; 'FINSI'; 'SI' ('EXISTE' PRECED 'TEMPS_SAUVEGARDES'); TWORK.'ISAUVEGL' = VRAI; TWORK.'ISAUVEGA' = PRECED.'TEMPS_SAUVEGARDES'; 'FINSI'; 'SI' ('EXISTE' PRECED 'ECONOMIQUE'); TWORK.'LECONOMI' = PRECED.'ECONOMIQUE'; 'FINSI'; TABSAUV = PRECED .'MES_SAUVEGARDES'; TWORK.'TABSAUV' = TABSAUV ; TWORK.'TABSAUV'.'DEFIN' = FAUX; 'FINSI'; TWORK.'TABSAUV'.'DEFTO' = FAUX; 'FINSI'; TWORK.'TABSAUV'.'DEFAP' = FAUX; 'FINSI'; 'FINSI'; LOGERR2 = VRAI; 'SI' TWORK.'ISAUVEGL'; 'FINSI'; 'SI' ('NON' (LOGERR1 'ET' LOGERR2)); 'FINSI'; * *----- Indicateur ADAP_MODE d'adaptation du modele : TWORK.'ADAP_MODE' = VRAI ; TWORK.'LTPS_ADAP' = PRECED.'TEMPS_ADAPTATION_MODELE' ; * TPS1_ADAP : prochain temps d'adaptation TWORK.'INDI_ADAP' = 1 ; 'SINON' ; 'FINSI' ; *----------------------------------------------------------------------- 'SI' ('EXISTE' PRECED 'CONSOLIDATION') ; TWORK.'CONSOLIDATION' = PRECED.'CONSOLIDATION' ; 'FINSI'; * 'SI' ('EXISTE' PRECED 'CONVERGENCE_MONOTONE'); TWORK.'CONVERGENCE_MONOTONE' = PRECED.'CONVERGENCE_MONOTONE'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'DELTAITER'); TWORK.'DELTAITER' = PRECED.'DELTAITER'; 'FINSI' ; * 'SI' ('EXISTE' PRECED 'DYNAMIQUE') ; TWORK.'DYNAMIQUE' = PRECED.'DYNAMIQUE'; 'SI' ('EXISTE' PRECED 'AMORTISSEMENT' ); 'FINSI'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'FTOL' ); TWORK.'FTOL' = PRECED.'FTOL'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'INITIALISATION'); TWORK.'INITIALISATION' = PRECED.'INITIALISATION'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'LIAISON_PERSISTANTE' ) ; TWORK.'LIAISON_PERSISTANTE' = PRECED.'LIAISON_PERSISTANTE'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'MAXSOUSITERATION') ; TWORK.'MAXSOUSITERATION' = PRECED.'MAXSOUSITERATION'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'MAXSOUSPAS'); TWORK.'MAXSOUSPAS' = PRECED.'MAXSOUSPAS' ; 'FINSI'; * 'SI' ('EXISTE' PRECED 'LINESEARCH'); 'SI' ('EGA' PRECED.'LINESEARCH' VRAI); TWORK.'LINESEARCH' = VRAI; TWORK.'GRANDS_DEPLACEMENTS' = VRAI; 'FINSI'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'MTOL' ); TWORK.'MTOL' = PRECED.'MTOL'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PRECISION') ; TWORK.'PRECISION' = PRECED.'PRECISION' ; 'FINS' ; * 'SI' ('EXISTE' PRECED 'PRECSOUSITERATION') ; TWORK.'PRECSOUSITERATION' = PRECED.'PRECSOUSITERATION'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PREDICTEUR'); TWORK.'GRANDS_DEPLACEMENTS' = VRAI; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PROCEDURE_CHARMECA'); TWORK.'PROCEDURE_CHARMECA' = PRECED.'PROCEDURE_CHARMECA'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PROCEDURE_CHARTHER'); TWORK.'PROCEDURE_CHARTHER' = PRECED.'PROCEDURE_CHARTHER'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PROCEDURE_PARATHER') ; TWORK.'PROCEDURE_PARATHER' = PRECED.'PROCEDURE_PARATHER' ; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PROCEDURE_PERSO1'); TWORK.'PROCEDURE_PERSO1' = PRECED.'PROCEDURE_PERSO1'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PROCEDURE_PERSO2'); TWORK.'PROCEDURE_PERSO2' = PRECED.'PROCEDURE_PERSO2'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PROCEDURE_REEV_MEC'); TWORK.'PROCEDURE_REEV_MEC' = PRECED.'PROCEDURE_REEV_MEC' ; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PROCEDURE_REEV_THE'); TWORK.'PROCEDURE_REEV_THE' = PRECED.'PROCEDURE_REEV_THE' ; 'FINSI'; * 'SI' ('EXISTE' PRECED 'PROCEDURE_THERMIQUE'); TWORK.'PROCEDURE_THERMIQUE' = PRECED.'PROCEDURE_THERMIQUE'; 'FINSI'; * TWORK.'REAC_GRANDS' = PRECED.'REAC_GRANDS'; 'FINSI'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'RENORMALISATION'); TWORK.'RENORMALISATION' = PRECED.'RENORMALISATION'; 'FINSI'; * TWORK.'SOUS-INCREMENT'=PRECED.'SOUS-INCREMENT'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'STABILITE'); 'SI' ('EGA' PRECED.'STABILITE' FAUX); TWORK.'STABILITE'= FAUX; 'SINON'; TWORK.'STABILITE'= VRAI; 'FINSI'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'CONVERGENCE_FORCEE'); TWORK.'CONVERGENCE_FORCEE' = PRECED.'CONVERGENCE_FORCEE'; 'SINON'; 'SI' ('NON' TWORK.'AUTOMATIQUE'); TWORK.'CONVERGENCE_FORCEE' = VRAI; 'FINSI'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'CONVERGENCE_MEC_THE'); TWORK.'CONVERGENCE_MEC_THE' = PRECED.'CONVERGENCE_MEC_THE'; 'FINSI'; 'SI' TWORK.'CONVERGENCE_MEC_THE'; TWORK.'AUTOMATIQUE' = FAUX; TWORK.'CONVERGENCE_FORCEE' = FAUX; 'SI' TWORK.'PAS_AJUSTE' ; 'ERREUR' 'Options CONVERGENCE_MEC_THE et PAS_AJUSTE incompatibles'; 'FINSI'; TWORK.'CRITERE_COHERENCE' = TWORK.'PRECISION' ; 'SI' ('EXISTE' PRECED 'CRITERE_COHERENCE') ; TWORK.'CRITERE_COHERENCE' = PRECED.'CRITERE_COHERENCE' ; 'FINSI' ; TWORK.'BOU_METH' = 10; 'SI' ('EXISTE' PRECED 'NB_BOTH'); TWORK.'BOU_METH'=PRECED.'NB_BOTH'; 'FINSI'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'MAXITERATION') ; TWORK.'MAXITERATION' = PRECED.'MAXITERATION'; 'SINON'; 'SI' ((TWORK.'AUTOMATIQUE') 'OU' (TWORK.'PAS_AJUSTE')) ; TWORK.'MAXITERATION' = 250; 'FINSI'; 'FINSI'; * 'SI' (TWORK.'CONVERGENCE_FORCEE' 'OU' TWORK.'RENORMALISATION'); TWORK.'MAXITERATION' = 250; 'SI' ('EXISTE' PRECED 'MAXDEFOR'); TWORK.'MAXDEFOR' = PRECED.'MAXDEFOR' ; 'FINSI'; 'SI' TWORK.'CONVERGENCE_FORCEE'; 'SI' ('EXISTE' PRECED 'RELAXATION_NONCONV'); TWORK.'RELAXATION_NONCONV' = PRECED.'RELAXATION_NONCONV' ; 'FINSI'; 'FINSI'; 'FINSI'; *----------------------------------------------------------------------- * Note : Il faudrait separer la thermique de la mecanique pour la //. TWORK.'NBPART' = NBPART ; 'SI' ('EXISTE' PRECED 'PROCESSEURS'); 'FINSI'; 'SI' ('<EG' NBPART 1); 'SINON' ; 'SI' ('EGA' MPARA 'INCONNU') ; * anciennes valeurs: 2000 200 NBELMIN = 200 ; NBELMM = 400; MINELE = 1000000 ; MAXELE = 0 ; 'REPE' BOUCMO IMOD ; 'SI' (MINELE > BBB); MINELE = BBB; 'FINSI'; 'SI' (MAXELE < BBB); MAXELE = BBB; 'FINSI'; 'FIN' BOUCMO ; NBTMP = (MINELE / NBELMM) ; ** mess 'nbtmp' ' ' nbtmp; SI (NBTMP < NBPART); NBPART = NBTMP; 'FINSI'; TWORK.'NBPART' = NBPART ; 'SI' ('>' NBPART 1); MINELE=MINELE/NBPART ; MAXELE=MAXELE/NBPART; ** mess 'minele maxele' ' ' minele ' ' maxele; 'SI' (MINELE > NBELMIN) ; 'SINON'; 'SI'( (MINELE > NBELMM) 'OU' (MAXELE > NBELMM)) ; 'FINSI'; 'FINSI'; 'SINON'; 'FINSI'; 'FINSI'; 'FINSI'; 'SINON' ; 'FINSI' ; ************************************************************************ * Decortiquer ce que contient le MODELE dans PAS_MODL ************************************************************************ * Oublier l'indice MODEL_COURANT pour re-initialiser la table oubl TWORK 'MODELE_COURANT' ; fins ; * * Oublier l'indice 'MO_TOT_PREC' pour le reinitialiser dans UNPAS oubl TWORK 'MO_TOT_PREC' ; fins ; PAS_MODL PRECED ; * 'SI' ('NON' ('OU' TWORK.'FOR_MECA' TWORK.'FOR_THER' TWORK.'FOR_DIFF' TWORK.'NVSTNL')) ; 'ERREUR' 'Le modele ne correspond a aucune formulation valable'; 'FINSI'; * 'SI' TWORK.'ADAP_MODE' ; 'SI' ('OU' TWORK.'FOR_METALLU' TWORK.'PHASE' TWORK.'SOLUBILITE' TWORK.'FOR_DIFF' TWORK.'THM1' TWORK.'FOR_MECA') ; 'FINSI' ; 'FINSI' ; * 'SI' (TWORK .'NVSTNL' 'ET' TWORK .'FOR_MECA') ; TWORK .'DYNAMIQUE' = VRAI ; 'FINSI' ; * * Noms des inconnues passees a TRANSNON : 'SI' ('NEG' TWORK.'MOD_TOT' 'INCONNU') ; 'FINS' ; * * GRANDS_DEPLACEMENTS si CONTACT : 'SI' TWORK.'CONTACT' ; TWORK.'GRANDS_DEPLACEMENTS' = VRAI; 'FINSI'; * *---------- Calcul purement thermique / diffusion ? ou couplage? ------- 'SI' (TWORK.'FOR_THER' 'OU' TWORK.'FOR_DIFF'); 'SI' TWORK.'FOR_MECA' ; TWORK.'COUPLAGE' = VRAI; TWORK.'PROJECTION' = PRECED.'PROJECTION'; 'FINSI'; 'FINSI'; 'FINSI'; * 'SI' TWORK.'POR1'; * * poreux+consolidation -> il faut donner la matrice de permeabilite * et ne pas etre en dynamique 'SI' TWORK.'CONSOLIDATION' ; 'SI' TWORK.'DYNAMIQUE' ; 'ERREUR' ' On ne peut pas etre en dynamique.' ; 'FINSI'; 'SI' ('NON' ('EXISTE' PRECED 'PERMEABILITE')); 'ERREUR' 'Il faut donner la matrice de permeabilite'; 'SINON'; TWORK.'PERMEABILITE'=PRECED.'PERMEABILITE'; 'FINSI'; 'SI' ('EXISTE' PRECED 'TETA' ) ; TWORK.'TETA' = PRECED.'TETA'; 'FINSI'; 'FINSI'; 'FINSI'; * * Verif. CHARGEMENT si formulation CHARGEMENT : 'ERREUR' 'Il manque la donnee d un chargement de pression'; 'FINSI' ; 'FINSI' ; TWORK.'CHAR_THE' = 'EXISTE' TWORK.'CHARGEMENT' 'T' ; TWORK.'CHAR_DEFI' = 'EXISTE' TWORK.'CHARGEMENT' 'DEFI' ; TWORK.'CHAR_PRES' = 'EXISTE' TWORK 'MOD_PRE' ; TWORK.'ITHER' = 'OU' TWORK.'FOR_THER' TWORK.'CHAR_THE' ; *------------ existe-t-il un chargement en pilotage indirect ? -------- 'SI' ('EXISTE' PRECED 'PILOTAGE_INDIRECT') ; TWORK.'CHAR_PILO' = VRAI; *--------- et des deplacements pilotes 'SI' ('EXISTE' PRECED 'DEPLACEMENTS_PILOTES' ); TWORK.'DEPLACEMENTS_PILOTES' = PRECED.'DEPLACEMENTS_PILOTES' ; 'FINSI'; *--------- et des forces pilotees 'SI' ('EXISTE' PRECED 'FORCES_PILOTEES' ); TWORK.'FORCES_PILOTEES' = PRECED.'FORCES_PILOTEES'; 'FINSI'; *--------- et une region de recherche 'SI' ('EXISTE' PRECED 'ZONE_DE_PILOTAGE' ); TWORK.'ZONE_DE_PILOTAGE' = PRECED.'ZONE_DE_PILOTAGE'; 'FINSI'; *--------- et le parametre de pilotage 'SI' ('EXISTE' PRECED 'PARAMETRE_DE_PILOTAGE' ); TWORK.'PARAMETRE_DE_PILOTAGE' = PRECED.'PARAMETRE_DE_PILOTAGE'; 'FINSI'; * *---------- Parametre de pilotage indirect et table de sortie 'FINSI'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'CAPACITE_CONSTANTE'); TWORK.'CAPACONST' = VRAI; TWORK.'CAPACITE_CONSTANTE' = PRECED.'CAPACITE_CONSTANTE'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'CONDUCTIVITE_CONSTANTE'); TWORK.'CONDCONST' = VRAI; TWORK.'CONDUCTIVITE_CONSTANTE' = PRECED.'CONDUCTIVITE_CONSTANTE'; 'FINSI'; ************************************************************************ * Verifications/initialisations propres a la THERMIQUE ************************************************************************ 'SI' TWORK.'FOR_THER' ; * 'SI' ('OU' TWORK.'PHASE' TWORK.'SOLUBILITE' TWORK.'FOR_DIFF' TWORK.'THM1'); 'FINSI'; * MOD_T = TWORK.'MOD_T' ; TTOL=PRECED.'TTOL' ; 'SINO'; 'FINS'; TWORK.'TTOL' = TTOL ; 'FINS'; TWORK.'PRIM_T' = PRIM_T 'ET' 'LX' ; * TWORK.'CELSIUS' = PRECED.'CELSIUS'; TWORK.'TREF' = 273.15 ; 'FINSI'; * BLOTHE1 = PRECED.'BLOCAGES_THERMIQUES' ; TWORK.'BLOCAGES_THERMIQUES' = BLOTHE1 ; 'FINSI'; * 'SI' TWORK.'RAYO' ; 'SI' ('NON' ('EXISTE' (TWORK.'CARACTERISTIQUES') 'EMIS')); 'ERREUR' ' Il manque la donnee des facteurs d emissivite'; 'FINSI'; 'SI'('EXISTE' PRECED 'CTE_STEFAN_BOLTZMANN') ; TWORK.'CTE_STEFAN_BOLTZMANN'=PRECED.'CTE_STEFAN_BOLTZMANN'; 'FINSI' ; 'FINSI'; * TWORK.'RELAXATION_THETA'=PRECED.'RELAXATION_THETA' ; 'FINSI'; * TWORK.'RELAXATION_DUPONT'= PRECED . 'RELAXATION_DUPONT' ; 'FINSI'; * 'SI' ('EXISTE' PRECED 'THERMIQUE_AUGMENTEE'); TWORK.'THERAUGM' = VRAI; TWORK.'THERMIQUE_AUGMENTEE' = PRECED.'THERMIQUE_AUGMENTEE'; RR= PRECED.'THERMIQUE_AUGMENTEE'; 'SI' (MNOMU 'NEG' MAVMU) ; 'ERREUR' 'Il ne faut pas de multiplicateur dans THERMIQUE_AUGMENTEE'; 'FINSI'; 'FINSI'; 'FINSI'; ************************************************************************ * Verifications/initialisations propres a la DIFFUSION ************************************************************************ 'SI' TWORK.'FOR_DIFF' ; * MOD_DIF = TWORK.'MOD_DIF' ; TWORK.'PRIM_DIF' = PRIM_DIF ; CTOL=PRECED.'CTOL' ; 'SINO'; 'ERRE' 'CTOL ne contient pas toutes les composantes de la DIFFUSION'; 'FINS'; 'SINO'; 'FINS'; 'FINS'; TWORK.'TTOL' = TWORK.'TTOL' 'ET' CTOL ; 'SINO'; TWORK.'TTOL' = CTOL ; 'FINS'; 'FINS'; TWORK.'PRIM_DIF' = PRIM_DIF 'ET' 'LX' ; * BLODIF1 = PRECED.'BLOCAGES_DIFFUSIONS' ; TWORK.'BLOCAGES_DIFFUSIONS' = BLODIF1 ; 'FINSI' ; * TWORK.'RELAXATION_THETA'=PRECED.'RELAXATION_THETA' ; 'FINSI'; * TWORK.'RELAXATION_DUPONT'= PRECED . 'RELAXATION_DUPONT' ; 'FINSI'; * 'SI' ('EXISTE' PRECED 'DIFFUSION_AUGMENTEE'); TWORK.'DIFFAUGM' = VRAI; TWORK.'DIFFUSION_AUGMENTEE' = PRECED.'DIFFUSION_AUGMENTEE'; RR= PRECED.'DIFFUSION_AUGMENTEE'; 'SI' (MNOMU 'NEG' MAVMU) ; 'ERREUR' 'Il ne faut pas de multiplicateur dans DIFFUSION_AUGMENTEE'; 'FINSI'; 'FINSI'; 'FINSI'; ************************************************************************ * Verifications/initialisations propres a la MECANIQUE ************************************************************************ BLOMEC1 = PRECED.'BLOCAGES_MECANIQUES' ; TWORK.'BLOCAGES_MECANIQUES' = BLOMEC1 ; 'FINSI'; * 'SI' TWORK.'FOR_MECA' ; * 'SI' ('EXISTE' PRECED 'PRECISION') ; TWORK.'PRECFLEX' = PRECED.'PRECISION' ; 'FINSI'; 'SI' ('EXISTE' PRECED 'PRECFLEX') ; TWORK.'PRECFLEX' = PRECED.'PRECFLEX'; 'FINSI'; * 'SI' ('EXISTE' PRECED 'K_TANGENT'); TWORK.'K_TANGENT' = PRECED.'K_TANGENT'; 'FINSI'; 'SI' ('EXISTE' PRECED 'K_TANGENT_PERT') ; TWORK.'K_TANGENT_PERT' = PRECED.'K_TANGENT_PERT' ; 'SI' TWORK.'K_TANGENT_PERT' ; TWORK.'K_TANGENT' = VRAI ; 'FINSI' ; 'FINSI' ; 'SI' ('EXISTE' PRECED 'K_TANG_PERT_C1') ; TWORK.'K_TANG_PERT_C1' = PRECED.'K_TANG_PERT_C1' ; 'FINSI' ; 'SI' ('EXISTE' PRECED 'K_TANG_PERT_C2') ; TWORK.'K_TANG_PERT_C2' = PRECED.'K_TANG_PERT_C2' ; 'FINSI' ; * Par defaut, C2 = C1/100 (C1 donne ou par defaut 1.D-3) 'SI' ('EGA' TWORK.'K_TANG_PERT_C2' 'INCONNU') ; TWORK.'K_TANG_PERT_C2' = TWORK.'K_TANG_PERT_C1' / 1.D+02 ; 'FINSI' ; * Matrice tangente a utiliser pour iteration 0 dans UNPAS * Par defaut, matrice tangente precedemment calculee si existe 'SI' ('EXISTE' PRECED 'K_TANGENT_ITER0') ; TWORK.'K_TANGENT_ITER0' = PRECED.'K_TANGENT_ITER0' ; 'FINSI' ; * Utilisation matrice tangente symetrisee 'SI' ('EXISTE' PRECED 'K_TANGENT_SYME') ; TWORK.'K_TANGENT_SYME' = PRECED.'K_TANGENT_SYME' ; 'FINSI' ; 'SI' ( 'EXISTE' PRECED 'NITER_KTANGENT'); TWORK.'NITER_KTANGENT' =PRECED.'NITER_KTANGENT' ; 'FINSI'; *----------MAN? ordre de la MAN? 'SI' ('EXISTE' PRECED 'MAN' ); TWORK.'MAN'= PRECED.'MAN'; 'FINSI'; 'SI' ( 'EXISTE' PRECED 'ORDRE'); TWORK.'ORDRE'=PRECED.'ORDRE'; 'FINSI'; *-------------y-a-t-il du substepping?----------- 'SI' ('EXISTE' PRECED 'SUBSTEPPING'); TWORK.'SUBSTEPPING'=PRECED.'SUBSTEPPING' ; 'FINSI'; 'SI' ('EXISTE' PRECED 'PRECISINTER'); TWORK.'PRECISINTER' = PRECED.'PRECISINTER'; 'FINSI'; 'SI' ('EXISTE' PRECED 'NITERINTER_MAX'); TWORK.'NITERINTER_MAX' =PRECED.'NITERINTER_MAX'; 'FINSI'; 'SI' ('EXISTE' PRECED 'NMAXSUBSTEPS'); TWORK.'NMAXSUBSTEPS'=PRECED.'NMAXSUBSTEPS'; 'FINSI'; *------------- quelle est l'hypothese de calcul des deformations ? 'SI' ('EXISTE' PRECED 'HYPOTHESE_DEFORMATIONS' ); 'SINON'; 'MESS' 'Les valeurs permises pour HYPOTHESE_DEFORMATIONS sont :'; 'MESS' 'LINEAIRE, QUADRATIQUE, TRUESDELL, JAUMANN, UTILISATEUR'; 'FINSI'; 'FINSI'; *------------- y-a-t-il du grand deplacement ? 'SI' ('EXISTE' PRECED 'GRANDS_DEPLACEMENTS' ); 'SI' (TWORK.'CONTACT' 'ET' ('NON' PRECED.'GRANDS_DEPLACEMENTS')); 'MESS' 'Un calcul avec un modele de CONTACT doit necessairement' 'MESS' 'etre realise en GRANDS_DEPLACEMENTS !'; 'FINSI'; TWORK.'GRANDS_DEPLACEMENTS' = PRECED.'GRANDS_DEPLACEMENTS'; 'FINSI'; *------------- quelques reglages forces en grands deplacements 'SI' TWORK.'GRANDS_DEPLACEMENTS' ; TWORK.'RECARI' = VRAI ; * * PV Quel interet d'avoir les deformations? ** par defaut, on sauvegarde des def. totales en grands deplacements ** 'SI' ('NON' ('EXIS' PRECED 'MES_SAUVEGARDES')); ** TWORK.'TABSAUV'.'DEFTO'= VRAI; ** 'FINS'; * par defaut, on calcule avec une deformation quadratique en grands deplacements * mais on laisse faire l'utilisateur s'il souhaite autrement 'FINSI'; * par defaut, on active K_SIGMA en grands deplacements si pas de controle de stabilite 'SI' ('NON' TWORK.'STABILITE'); TWORK.'K_SIGMA'=VRAI; 'FINSI'; * par defaut, on active K_SIGMA en grands deplacements si deformations quadratiques 'SI' ('EGA' TWORK.'HYPOTHESE_DEFORMATIONS' 'QUADRATIQUE'); TWORK.'K_SIGMA'=VRAI; 'FINSI'; *------Y-a-t-il des elements dont il faudra reactualiser les caracteristiques? 'V1X ' 'V1Y ' 'V1Z ' 'V2X ' 'V2Y ' 'V2Z '; ITE2 = &BOU_CAR; TWORK.'ITCAR' = VRAI; 'QUITTER' BOU_CAR; 'FINSI'; 'FIN' BOU_CAR; 'FINSI'; * ---------- y-a-t-il une demande sur K_SIGMA ? 'SI' ('EXISTE' PRECED 'K_SIGMA'); TWORK.'K_SIGMA' = PRECED.'K_SIGMA'; 'FINSI'; * ---------- y-a-t-il une demande sur LAGRANGIEN ? 'SI' ('EXISTE' PRECED 'LAGRANGIEN'); 'SI' ('EGA' preced.'LAGRANGIEN' 'TOTAL'); TWORK.'LAG_TOT' = 1; 'SINON'; 'SI' ('EGA' preced.'LAGRANGIEN' 'FIN_PAS'); TWORK.'LAG_TOT' = 2; 'SINON'; 'SI' (('EGA' preced.'LAGRANGIEN' 'REACTUALISE') 'OU' ('EGA' preced.'LAGRANGIEN' 'MI_PAS')); TWORK.'LAG_TOT' = 3; 'SINON'; 'FINSI'; 'FINSI'; 'FINSI'; 'FINSI'; * * MOdele TOTal si FOR_MECA : MO_TOT = TWORK.'MO_TOT' ; *--------- initialisation des comportements d'apres le modele TWORK.'PLASTIQUE' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; TWORK.'PLASTIQUE' = VRAI; TWORK.'IPLAVI' = VRAI; TWORK.'ENDOMMAGEMENT' = VRAI; 'FINSI'; TWORK.'VISCOPLASTIQUE' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; TWORK.'VISCODOMMAGE' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; TWORK.'ENDOMMAGEMENT' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; TWORK.'NON_LINEAIRE' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; TWORK.'VISCO_EXTERNE' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; TWORK.'CERAMIQUE' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; TWORK.'MODAL' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; TWORK.'IMPEDANCE' = VRAI; TWORK.'IPLAVI' = VRAI; 'FINSI'; * 'SI' ('OU' TWORK.'CERAMIQUE' TWORK.'ENDOMMAGEMENT' TWORK.'VISCODOMMAGE'); TWORK.'RECARI' = VRAI; TWORK.'LAG_TOT' = 0 ; 'FINS'; * *- existe-t-il un chargement de flux neutronique pour le modele mistral *- existe-t-il un chargement de densite de fissions pour gatt_monerie & uo2 *---- si oui on sort si non on le cree a zero 'SI' ('NON' ('EXISTE' (TWORK.'CHARGEMENT') 'FI ')) ; 'FINSI'; 'FINSI'; 'SI' ('NON' ('EXISTE' (TWORK.'CHARGEMENT') 'DFIS')) ; 'FINSI'; 'FINSI'; * TWORK.'PARA_EXTE'=VRAI; 'FINSI'; *--------------y-a-t-il une formulation feFP 'SI' ('EXISTE' PRECED 'FEFP_FORMULATION'); TWORK.'FEFP_FORMULATION' = PRECED.'FEFP_FORMULATION'; 'FINSI'; 'SI' TWORK.'FEFP_FORMULATION'; TWORK.'GRANDS_DEPLACEMENTS' = FAUX ; TWORK.'K_SIGMA' = VRAI ; TWORK.'K_TANGENT' = VRAI ; TWORK.'SUBSTEPPING' = FAUX ; TWORK.'RECARI' = VRAI ; 'FINSI'; 'SI' ( 'EXISTE' PRECED 'UPDATE_LAGRANGIAN' ); TWORK.'UPDATE_LAGRANGIAN' = PRECED.'UPDATE_LAGRANGIAN' ; 'FINSI'; 'SI' ('NON' TWORK.'GRANDS_DEPLACEMENTS'); TWORK.'LAG_TOT' = 0 ; 'FINS'; *---------- en cas de pilotage automatique ? 'SI' TWORK.'AUTOMATIQUE' ; 'SI' ('EXISTE' PRECED 'AUTOCRIT'); TWORK.'AUTOCRIT'= PRECED.'AUTOCRIT'; 'FINSI'; 'SI' ('EXISTE' PRECED 'AUTOPAS'); TWORK.'AUTOPAS'= PRECED.'AUTOPAS'; 'FINSI'; 'SI' ('EXISTE' PRECED 'AUTORECA'); 'FINSI'; 'SI' ('EXISTE' PRECED 'AUTORESU'); TWORK.'NAURES' = PRECED.'AUTORESU'; 'FINSI'; TWORK.'DELTAITER' = TWORK.'MAXITERATION'; 'FINSI'; *------ y-a-t-il un nom de variable interne specifique ? 'SI' ('EXISTE' PRECED 'MOVA'); TWORK.'MOVA' =PRECED.'MOVA'; 'SINON'; 'SI'(TWORK.'VISCO_EXTERNE' 'OU' TWORK.'UTILISATEUR'); 'FINSI'; 'FINSI' ; 'FINSI'; *---------- y-a-t-il des elements de rigidite constante ? -------- 'SI' ( 'EXISTE' PRECED 'RIGIDITE_CONSTANTE'); TWORK.'RAIDCONST' =VRAI; TWORK.'RIGIDITE_CONSTANTE'=PRECED.'RIGIDITE_CONSTANTE'; RR= PRECED.'RIGIDITE_CONSTANTE'; 'SI' ( MNOMU 'NEG' MAVMU) ; 'ERREUR' 'Il ne faut pas de multiplicateur dans RIGIDITE_CONSTANTE'; 'FINSI'; 'FINSI'; *---------- y-a-t-il des elements de rigidite augmentee ? -------- 'SI' ('EXISTE' PRECED 'RIGIDITE_AUGMENTEE'); TWORK.'RAIDAUGM' =VRAI; TWORK.'RIGIDITE_AUGMENTEE'=PRECED.'RIGIDITE_AUGMENTEE'; RR= PRECED.'RIGIDITE_AUGMENTEE'; 'SI' ( MNOMU 'NEG' MAVMU) ; 'ERREUR' 'Il ne faut pas de multiplicateur dans RIGIDITE_AUGMENTEE'; 'FINSI'; 'SINON'; 'SI' ('EXISTE' PRECED 'AUGMENTATION_AUTOMATIQUE'); TWORK.'RIGIDITE_AUGMENTEE'='MASSE' TWORK.'MODELE' TWORK.'CARACTERISTIQUES'; 'FINSI'; 'FINSI'; 'SI' ('EXISTE' PRECED 'AUGMENTATION_AUTOMATIQUE'); 'SI' PRECED.'AUGMENTATION_AUTOMATIQUE'; TWORK.'AUTOAUGM' = VRAI; TWORK.'STABILITE' = VRAI ; *** 'SI' ('NON' TWORK.'RAIDAUGM'); *** 'ERREUR' 'il faut donner la matrice d augmentation dans RIGIDITE_AUGMENTEE'; *** 'FINSI'; 'FINSI'; 'FINSI'; *---------- y-a-t-il des elements de masse constante ? --------- 'SI' ('EXISTE' PRECED 'MASSE_CONSTANTE'); TWORK.'MASSE_CONSTANTE'=PRECED.'MASSE_CONSTANTE'; TWORK.'MASSCONST'=VRAI; 'FINSI'; *---------- y-a-t-il un sous_increment ? --------- 'SI' ('EXISTE' PRECED 'SOUS_INCREMENT'); TWORK.'SOUS_INCREMENT' = PRECED.'SOUS_INCREMENT'; TWORK.'RECALCUL_SOUSINC' = FAUX ; 'SI' ('<EG' TWORK.'SOUS_INCREMENT' 0) ; 'ERREUR' 21 ; 'FINSI'; 'FINSI'; *------------------- Cas du non local : 'SINON'; 'SI' ('EGA' (TWORK.'NON_LOCAL') 'HELM' ); 'MESS' 'Pas besoin de la connectivite pour Helmholtz'; 'SINON'; 'FINSI' ; 'FINSI' ; 'FINSI' ; 'FINSI'; TWORK.'CHARGEMENT_I' = TWORK.'CHARGEMENT'; ************************************************************************ * Recapitulatif des options choisies ************************************************************************ 'SAUTER' 1 'LIGNE'; 'SI' TWORK.'FOR_MECA' ; 'SI' TWORK.'FOR_THER'; 'SINON'; 'MESS' 'Calcul MECANIQUE'; 'FINSI'; 'SI' ('NEG' TWORK.'PREDICTEUR' 'INCONNU'); 'FINSI'; 'SI' TWORK.'K_SIGMA'; 'FINSI'; 'SI' TWORK.'GRANDS_DEPLACEMENTS'; 'SI' (TWORK.'LAG_TOT' 'EGA' 1) ; 'FINSI'; 'SI' (TWORK.'LAG_TOT' 'EGA' 2) ; 'FINSI'; 'SI' (TWORK.'LAG_TOT' 'EGA' 3) ; 'FINSI'; 'FINSI'; 'SI' TWORK.'STABILITE'; 'FINSI'; 'SI' TWORK.'LINESEARCH'; 'FINSI'; 'SI' (non TWORK.'INITIALISATION'); 'FINSI'; 'SI' TWORK.'CONVERGENCE_MONOTONE' ; 'FINSI'; 'SI' TWORK.'RENORMALISATION' ; 'FINSI'; 'SI' TWORK.'POR1'; 'FINSI'; 'SI' TWORK.'DYNAMIQUE' ; 'FINSI' ; 'SI' TWORK.'FREQUENTIEL' ; 'FINSI' ; 'SI' TWORK.'LIAISON_PERSISTANTE' ; 'FINSI' ; 'SI' TWORK.'CONSOLIDATION' ; 'FINSI' ; 'SI' TWORK.'PLASTIQUE' ; 'FINSI'; 'SI' TWORK.'VISCOPLASTIQUE' ; 'FINSI' ; 'SI' TWORK.'NON_LINEAIRE'; 'SI' TWORK.'UTILISATEUR' ; 'SINON'; 'FINSI'; 'FINSI' ; 'SI' TWORK.'VISCO_EXTERNE'; 'FINSI' ; 'SI' TWORK.'CHAR_THE'; 'FINSI'; 'SI' TWORK.'CHAR_DEFI'; 'FINSI'; 'SI' TWORK.'CHAR_PRES'; 'FINSI'; 'SI' TWORK.'CHAR_PILO'; 'FINSI'; 'SI' TWORK.'PARA_EXTE'; 'FINSI'; 'SI' TWORK.'GRANDS_DEPLACEMENTS' ; 'SI' ('NEG' TWORK.'HYPOTHESE_DEFORMATIONS' 'QUADRATIQUE'); 'MESS' ' ATTENTION : l''hypothese de deformations choisie est' ' ' PRECED.'HYPOTHESE_DEFORMATIONS'; 'MESS' ' on recommande plutot l''hypothese QUADRATIQUE'; 'FINSI'; 'FINSI'; 'SI' TWORK.'CONVERGENCE_FORCEE' ; 'FINSI'; 'SI' TWORK.'ENDOMMAGEMENT' ; 'FINSI'; 'SI' TWORK.'VISCODOMMAGE' ; 'FINSI'; 'SI' TWORK.'CERAMIQUE' ; 'FINSI'; * 'SI' IUO2; * 'MESS' ' *** VISCO-PLASTICITE + OTTOSEN ***'; * 'FINSI'; 'FINSI'; 'SI' TWORK.'CONTACT'; 'FINSI'; 'SI' (TWORK.'SOUS_INCREMENT' > 1); 'FINSI'; 'SI' TWORK.'CAFROTTE'; 'FINSI'; 'SI' TWORK.'K_TANGENT' ; 'SI' TWORK.'K_TANGENT_PERT' ; 'SINON' ; 'FINSI' ; 'MESS' ' MATRICE EVALUEE TOUTES LES' TWORK.'NITER_KTANGENT' 'ITERATIONS' ; 'SI' TWORK.'K_TANGENT_SYME' ; 'MESS' ' PARTIE SYMETRIQUE DE LA MATRICE TANGENTE UTILISEE'; 'FINSI' ; 'FINSI'; 'SI' TWORK.'SUBSTEPPING'; 'FINSI'; 'SI' TWORK.'UPDATE_LAGRANGIAN'; 'FINSI'; 'SI' TWORK.'FEFP_FORMULATION'; 'FINSI'; 'FINSI'; * 'SI' TWORK.'FOR_THER'; 'MESS' 'Calcul THERMIQUE '; 'FINSI'; * 'SI' TWORK.'NVSTNL' ; 'FINSI' ; 'SAUTER' 1 'LIGNE'; 'SI' ('EGA' TWORK.'PROCESSEURS' 'MONO_PROCESSEUR') ; 'SINON' ; 'SI' ('EGA' TWORK.'PROCESSEURS' 'COMPORTEMENT') ; 'SINON' ; 'SI' ('EGA' TWORK.'PROCESSEURS' 'AUTOMATIQUE') ; 'FINSI' ; 'FINSI' ; 'FINSI' ; 'SAUTER' 1 'LIGNE'; 'FINPROC' ;
© Cast3M 2003 - Tous droits réservés.
Mentions légales