Télécharger pas_defa.procedur

Retour à la liste

Numérotation des lignes :

  1. * PAS_DEFA PROCEDUR MB234859 24/07/08 21:15:02 11958
  2. DEBPROC PAS_DEFA PRECED*'TABLE';
  3. ************************************************************************
  4. *
  5. * Objet de la procedure :
  6. * - verifications coherences donnees.
  7. * - initialisations des valeurs par defaut des options de calcul
  8. * - initialisation des variables locales
  9. *
  10. * verifications de quelques arguments obligatoires
  11. * existence modele verification et initialisation modeles particuliers
  12. * affectation des valeurs par defaut des options dans TWORK
  13. * En cas de reprise, la configuration peut etre erronnee
  14. * (reprise/poursuite d'un calcul suite a une erreur)
  15. *
  16. ************************************************************************
  17. * Verifier si d'anciens mots-cles ne sont pas utilises
  18. ************************************************************************
  19. 'SI' (('EXISTE' PRECED 'GRANDES_ROTATIONS' ) 'OU'
  20. ('EXISTE' PRECED 'GRANDES_DEFORMATIONS'));
  21. 'MESS' ' ATTENTION :' ;
  22. 'MESS' ' Les donnees concernant les GRANDES ROTATIONS et GRANDES DEFORMATIONS ont ete modifiees :';
  23. 'MESS' ' Utilisez l''indice HYPOTHESE_DEFORMATIONS';
  24. 'ERREUR' 21 ;
  25. 'FINSI';
  26. *
  27. 'SI' ('EXISTE' PRECED 'CONTACT') ;
  28. 'MESS' ' ATTENTION :' ;
  29. 'MESS' ' Les donnees concernant le CONTACT dans PASAPAS ont ete modifiees :' ;
  30. 'MESS' ' - L''indice CONTACT de la table de PASAPAS n''existe plus.';
  31. 'MESS' ' - Il faut definir un MODELE de CONTACT.' ;
  32. 'ERREUR' 21 ;
  33. 'FINSI';
  34. *
  35. 'SI' (('EXISTE' PRECED 'PROCEDURE_REAC_MECA') 'OU'
  36. ('EXISTE' PRECED 'PROCEDURE_CHAR_MECA') 'OU'
  37. ('EXISTE' PRECED 'PROCEDURE_REAC_THER') 'OU'
  38. ('EXISTE' PRECED 'PROCEDURE_CHAR_THER') 'OU'
  39. ('EXISTE' PRECED 'PROCEDURE_PARA_THER')) ;
  40. 'MESS' ' ATTENTION :' ;
  41. 'MESS' ' Les donnees concernant les procedures utilisateur ont ete modifiees :' ;
  42. 'MESS' ' - L''indice PROCEDURE_REAC_MECA est remplace par l''indice PROCEDURE_REEV_MEC' ;
  43. 'MESS' ' - L''indice PROCEDURE_CHAR_MECA est remplace par l''indice PROCEDURE_CHARMECA' ;
  44. 'MESS' ' - L''indice PROCEDURE_REAC_THER est remplace par l''indice PROCEDURE_REEV_THE' ;
  45. 'MESS' ' - L''indice PROCEDURE_CHAR_THER est remplace par l''indice PROCEDURE_CHARTHER' ;
  46. 'MESS' ' - L''indice PROCEDURE_PARA_THER est remplace par l''indice PROCEDURE_PARATHER' ;
  47. 'ERREUR' 21 ;
  48. 'FINSI';
  49.  
  50. * Modifs CB215821 Juillet 2020
  51. 'SI' ('EXISTE' PRECED 'TEMPERATURE_REFERENCE');
  52. 'MESS' ' ATTENTION :' ;
  53. 'MESS' ' L''indice ''TEMPERATURE_REFERENCE'' de PASAPAS a ete supprime';
  54. 'MESS' ' Il faut desormais fournir la composante ''TREF'' dans le materiau';
  55. 'ERREUR' 21 ;
  56. 'FINSI';
  57. 'SI' ('EXISTE' PRECED 'TALPHA_REFERENCE');
  58. 'MESS' ' ATTENTION :' ;
  59. 'MESS' ' L''indice ''TALPHA_REFERENCE'' de PASAPAS a ete supprime';
  60. 'MESS' ' Il faut desormais fournir la composante ''TALP'' dans le materiau';
  61. 'ERREUR' 21 ;
  62. 'FINSI';
  63. ************************************************************************
  64. * Verifier la presence de certains indices de PRECED, obligatoires
  65. ************************************************************************
  66. 'SI' ('NON' ('EXISTE' PRECED 'MODELE')) ;
  67. 'ERREUR' 'Il manque la donnee du modele.';
  68. 'SINON' ;
  69. MO = PRECED.'MODELE';
  70. TYPMO = 'TYPE' MO ;
  71. 'SI' (('NEG' TYPMO 'MMODEL ') 'ET' ('NEG' TYPMO 'CHARGEME')) ;
  72. 'ERREUR' 'Le type du MODELE est incorrect';
  73. 'FINSI';
  74. 'FINSI' ;
  75. *
  76. 'SI' ('NON' ('EXISTE' PRECED 'CARACTERISTIQUES')) ;
  77. 'ERREUR' 'Il manque la donnee du materiau.';
  78. 'SINON' ;
  79. MA = PRECED.'CARACTERISTIQUES' ;
  80. TYPMA = 'TYPE' MA ;
  81. 'SI' (('NEG' TYPMA 'MCHAML ') 'ET' ('NEG' TYPMA 'CHARGEME')) ;
  82. 'ERREUR' 'Le type du champ de materiau est incorrect';
  83. 'FINSI';
  84. 'FINSI' ;
  85. *
  86. 'SI' ('EXISTE' PRECED 'TEMPS_CALCULES');
  87. TYP1 = 'TYPE' PRECED.'TEMPS_CALCULES';
  88. 'SI' ('NEG' TYP1 'LISTREEL');
  89. 'ERREUR' 'Le type de TEMPS_CALCULES est incorrect';
  90. 'FINSI';
  91. 'FINSI' ;
  92. *
  93. 'SI' ('EXISTE' PRECED 'CHARGEMENT');
  94. TYP1 = 'TYPE' PRECED.'CHARGEMENT' ;
  95. 'SI' ('NEG' TYP1 'CHARGEME');
  96. 'ERREUR' 'Le type du CHARGEMENT est incorrect';
  97. 'FINSI';
  98. 'FINSI';
  99. *
  100. * Typage de la table en sortie de PASAPAS
  101. PRECED.'SOUSTYPE' = 'MOT' 'PASAPAS' ;
  102. ************************************************************************
  103. * Initialiser les indices de WTABLE a leur valeur par defaut
  104. ************************************************************************
  105. TWORK = 'TABLE' ;
  106. * adap_mode : adaptation du modele au cours du calcul
  107. TWORK.'ADAP_MODE' = FAUX;
  108. * Adherence presence de la composante ADHE (modele contact ou cont/fro)
  109. TWORK.'ADHERENCE' = FAUX ;
  110. * Advection presence d'un modele thermique advection ou diffusion advection
  111. TWORK.'ADVECTION' = FAUX;
  112. * matrice d'amortissement en dynamique
  113. TWORK.'AMORTISSEMENT' = 'MOT' 'INCONNU';
  114. * arret: indicateur pour quitter la boucle temporelle de PASAPAS
  115. TWORK.'ARRET' = FAUX;
  116. * autocrit: valeur du critere a utiliser dans autopilo(option automatique)
  117. TWORK.'AUTOCRIT' = 0.005;
  118. * autocoef: coefficient de pilotage
  119. TWORK.'AUTOCOEF' = 'MOT' 'INCONNU';
  120. * autodeux=vrai si pilotage et pas premiere tentative : pasapas
  121. TWORK.'AUTODEUX' = FAUX;
  122. * automatique =vrai si demande de pilotage automatique
  123. TWORK.'AUTOMATIQUE' = FAUX;
  124. * autopas : nb maxi de tentative en pilotage automatique
  125. TWORK.'AUTOPAS' = 250;
  126. * autoredu : reduit le critere de pilotage : pasapas unpas
  127. TWORK.'AUTOREDU' = 1.D0;
  128. * autored1 : joue sur la strategie d'evolution de autoredu :pasapas unpas
  129. TWORK.'AUTORED1' = 'MOT' 'INCONNU';
  130. * beton_ht ( ne marche pas!)
  131. TWORK.'BETON_HT' = FAUX;
  132. * blocages_diffusions; matrices
  133. TWORK.'BLOCAGES_DIFFUSIONS' = 'VIDE' 'RIGIDITE'/'RIGIDITE';
  134. * blocages_mecaniques; matrices
  135. TWORK.'BLOCAGES_MECANIQUES' = 'VIDE' 'RIGIDITE'/'RIGIDITE';
  136. * blocages_thermiques; matrices
  137. TWORK.'BLOCAGES_THERMIQUES' = 'VIDE' 'RIGIDITE'/'RIGIDITE';
  138. * bou_meth : valeur par defaut du nombre de bouclage mecanique-thermique
  139. TWORK.'BOU_METH' = 1;
  140. * cafrotte : veut dire il existe modele contact-frottement
  141. TWORK.'CAFROTTE' = FAUX ;
  142. * capaconst logique il existe une capacite constante
  143. TWORK.'CAPACONST' = FAUX;
  144. * caracteristiques :
  145. TWORK.'CARACTERISTIQUES' = 'MOT' 'INCONNU';
  146. * ceramique presence de modele ceramique
  147. TWORK.'CERAMIQUE' = FAUX;
  148. * indice celsius
  149. TWORK.'CELSIUS' = FAUX;
  150. * chargement idem celui de preced ou creation d'un chargement farfelu
  151. TWORK.'CHARGEMENT' = 'VIDE' 'CHARGEMENT' ;
  152. * chargement_i idem chargement DFIS et FI si certain materiau pas_defa
  153. TWORK.'CHARGEMENT_I' = 'MOT' 'INCONNU';
  154. * char_BLOD presence d'un chargement de BLOcages Diffusion
  155. TWORK.'CHAR_BLOD' = FAUX;
  156. * char_blom presence d'un chargement de BLOcages Mecaniques
  157. TWORK.'CHAR_BLOM' = FAUX;
  158. * char_blot presence d'un chargement de BLOcages Thermiques
  159. TWORK.'CHAR_BLOT' = FAUX;
  160. * char_defi presence de chargement DEFI deformation initiale
  161. TWORK.'CHAR_DEFI' = FAUX;
  162. * char_mate presence d'un chargement 'MATE'
  163. TWORK.'CHAR_MATE' = FAUX;
  164. * char_mode : le modele est de type chargement
  165. TWORK.'CHAR_MODE' = FAUX;
  166. * char_pres presence de chargement 'P ' de pression suiveuse
  167. TWORK.'CHAR_PRES' = FAUX;
  168. * char_the presence de chargement thermique pour la mecanique
  169. TWORK.'CHAR_THE' = FAUX;
  170. * char_pilo presence de chargement de pilotage indirect
  171. TWORK.'CHAR_PILO' = FAUX;
  172. TWORK.'DEPLACEMENTS_PILOTES' = 'VIDE' 'CHPOINT' / 'DISCRET' ;
  173. TWORK.'FORCES_PILOTEES' = 'VIDE' 'CHPOINT' / 'DISCRET' ;
  174. TWORK.'ZONE_DE_PILOTAGE' = FAUX ;
  175. TWORK.'PARAMETRE_DE_PILOTAGE' = 'MOT' 'INCONNU' ;
  176. * clim matrice des blocagesmecaniques y compris contact et frottement pasapas
  177. TWORK.'CLIM' = 'MOT' 'INCONNU';
  178. * condconst logique il existe une conductivite constante
  179. TWORK.'CONDCONST' = FAUX;
  180. * conduction presence d'un modele de conduction
  181. TWORK.'CONDUCTION' = FAUX;
  182. * consolidation presence de consolidation
  183. TWORK.'CONSOLIDATION' = FAUX;
  184. * contact presence de contact
  185. TWORK.'CONTACT' = FAUX ;
  186. * conv logique precisant si unpas a bien converge
  187. TWORK.'CONV' = VRAI;
  188. * convection presence d'un modele de convection
  189. TWORK.'CONVECTION' = FAUX;
  190. * convergence_forcee logique demandant la convergence forcee
  191. TWORK.'CONVERGENCE_FORCEE' = VRAI;
  192. * demande de convergence mecanique-thermique en cas de bouclage
  193. TWORK.'CONVERGENCE_MEC_THE' = FAUX;
  194. * logique pour imposer au residu de decroitre de facon monotone
  195. TWORK.'CONVERGENCE_MONOTONE' = FAUX;
  196. * conv_thmec on a convergee le bouclage mecanique-thermique pasapas
  197. TWORK.'CONV_THMEC' = VRAI;
  198. * couplage le calcul contient des modeles thermiques et des mecaniques
  199. TWORK.'COUPLAGE' = FAUX;
  200. * cte_stefan_boltzmann valeur de la constante
  201. TWORK.'CTE_STEFAN_BOLTZMANN' = 5.673E-8 ;
  202. * deja_calc_charther indique le dernier temps pour lequel on a calcule le
  203. * chargement thermique dans charther : charther
  204. TWORK.'DEJA_CALC_CHARTHER' = 0.d0;
  205. * deltaiter sert au test de non convergence : unpas
  206. TWORK.'DELTAITER' = 10;
  207. * dt: valeur du delta de temps entre le dernier pas et le pas en cours:pasapas
  208. TWORK.'DT' = 'MOT' 'INCONNU';
  209. * dtprec : dt du pas precedent: pasapas
  210. TWORK.'DTPREC' = 0 ;
  211. * dt_init : dt du pas de temps courant (sert au pilotage automatique) : pasapas
  212. TWORK.'DT_INIT' = 0.D0;
  213. * dynamique calcul en dynamique
  214. TWORK.'DYNAMIQUE' = FAUX;
  215. * endommagement il esiste un tel modele de comportement
  216. TWORK.'ENDOMMAGEMENT' = FAUX;
  217. * Enregistrement de la date du depart de PASAPAS
  218. TWORK.'EPOQUE' = DATE 'EPOCH';
  219. * etat0 etat au temps 0 : pasapas pas_etat
  220. TWORK.'ETAT0' = 'MOT' 'INCONNU';
  221. * etat1 etat au temps courant : pasapas pas_etat
  222. TWORK.'ETAT1' = 'MOT' 'INCONNU';
  223. * etat_ref etat de reference : pasapas pas_etat
  224. TWORK.'ETAT_REF' = 'MOT' 'INCONNU';
  225. * etref deformation d'origine thermique de reference : pas_epth
  226. TWORK.'ETREF' = 'MOT' 'INCONNU';
  227. * ether1 stocke des deformations thermiques au temps precedent : pasapas
  228. TWORK.'ETHER1' = 'MOT' 'INCONNU';
  229. * fnonl permet forces de reequilibrage du pas precedent : unpas
  230. TWORK.'FNONL' = 'MOT' 'INCONNU';
  231. * fopl : forces d'acceleration et d'amortissement
  232. TWORK.'FOPL' = 'MOT' 'INCONNU';
  233. * configuration finale : pasapas unpas
  234. TWORK.'FOR' = 'MOT' 'INCONNU';
  235. * configuration en debut de pas : pasapas
  236. TWORK.'FOR0' = 'MOT' 'INCONNU';
  237. * FOR_DIFF le calcul inclus des modeles DIFFUSION
  238. TWORK.'FOR_DIFF' = FAUX;
  239. * FOR_METALLU le calcul inclus des modeles METALLURGIE
  240. TWORK.'FOR_METALLU' = FAUX;
  241. * utilisation de la frormulation fefp
  242. TWORK.'FEFP_FORMULATION' = FAUX;
  243. * frea1 partie constante du second membre dynamique,consolidation: pasapas
  244. TWORK.'FREA1' = 'MOT' 'INCONNU';
  245. * frequentiel calcul en frequentiel
  246. TWORK.'FREQUENTIEL' = 'EGA' ('VALE' 'MODE') 'FREQ' ;
  247. * ftol desequilibre tolere
  248. TWORK.'FTOL' = 'MOT' 'INCONNU';
  249. * Configuration courante
  250. TWORK.'GE0_DEB' = 'MOT' 'INCONNU';
  251. * grands_deplacement
  252. TWORK.'GRANDS_DEPLACEMENTS' = FAUX;
  253. * hypothese de calcul pour les deformations
  254. TWORK.'HYPOTHESE_DEFORMATIONS' = 'MOT' 'LINEAIRE';
  255. * indice d'evolution de la boucle temporelle de pasapas
  256. TWORK.'ICHG' = 0;
  257. * increment de charge du pas precedent : unpas
  258. TWORK.'INCREMENT' ='MOT' 'INCONNU';
  259. * logique pour autoriser l'Initialisation a partir du pas precedent : unpas
  260. TWORK.'INITIALISATION' = VRAI;
  261. * iplavi il existe un modele devant passer par COMP
  262. TWORK.'IPLAVI' = FAUX;
  263. * ipresu : listreel des temps a mettre dans les tables resultats
  264. TWORK.'IPRESU' = 'MOT' 'INCONNU';
  265. * iptime liste des temps a calculer
  266. TWORK.'IPTIME' = 'MOT' 'INCONNU';
  267. * isauvega liste des temps sauvegardes (appel SAUV dans pasapas)
  268. TWORK.'ISAUVEGA' = 'MOT' 'INCONNU';
  269. * logique la sauvegarde dans pasapas est activee
  270. TWORK.'ISAUVEGL' = FAUX;
  271. * nombre de sous-pas realise dans unpas
  272. TWORK.'ISOUSPAS' = 0 ;
  273. * itcar des elements ont des caracteristiques geometriques
  274. TWORK.'ITCAR' = FAUX;
  275. * ither : pour un calcul meca presence de thermique (via mode ou char)
  276. TWORK.'ITHER' = FAUX;
  277. * k_sigma il faut utiliser l'operateur KSIGMA
  278. TWORK.'K_SIGMA' = FAUX;
  279. * k_tangent il faut utiliser l'operateur KTANG
  280. TWORK.'K_TANGENT' = FAUX;
  281. * k_tangent_iter0 matrice tangente a utiliser pour iteration 0 : unpas
  282. TWORK.'K_TANGENT_ITER0' = 'MOT' 'INCONNU';
  283. * k_tangent_pert operateur KTAN matrice tangente par perturbation : unpas
  284. TWORK.'K_TANGENT_PERT' = FAUX;
  285. * k_tangent_syme matrice tangente symetrisee : unpas
  286. TWORK.'K_TANGENT_SYME' = FAUX;
  287. * k_tang_pert_c1 matrice tangente par perturbation coefficient C1 : unpas
  288. TWORK.'K_TANG_PERT_C1' = 1.D-3;
  289. * k_tang_pert_c2 matrice tangente par perturbation coefficient C2 : unpas
  290. TWORK.'K_TANG_PERT_C2' = 'MOT' 'INCONNU';
  291. * lastktan matrice donnant la derniere matrice tangente : pasapas unpas
  292. TWORK.'LASTKTAN' = 'MOT' 'INCONNU';
  293. * langrangien schema numerique lagrangien reactualise par defaut
  294. TWORK.'LAG_TOT' = 3 ;
  295. * ldeva liste des variables dont dependent les materiaux
  296. TWORK.'LDEVA' = 'MOT' 'INCONNU';
  297. * leconomi l'option economique est activee : pas_sauv
  298. TWORK.'LECONOMI' = FAUX;
  299. * liaison_persistante si il existe des liaisons persistantes
  300. TWORK.'LIAISON_PERSISTANTE' = FAUX;
  301. * linesearch en grand deplacement
  302. TWORK.'LINESEARCH' = FAUX;
  303. * lisea_m pour les contacts unilateraux en mecaniques :pasapas unpas
  304. TWORK.'LISEA_M' = 'MOT' 'INCONNU';
  305. * lisea_t pour les changements de phase en thermique : pasapas transnon
  306. TWORK.'LISEA_T' = 'MOT' 'INCONNU';
  307. * lpar0 liste des parametres externes a passer a COMP
  308. TWORK.'LPAR0' = 'MOT' 'INCONNU';
  309. * man methode asymptotique numerique
  310. TWORK.'MAN' = FAUX;
  311. * massconst logique il existe des masses constantes
  312. TWORK.'MASSCONST' = FAUX;
  313. * mat0 materiau au temps 0 : pasapas pas_epth
  314. TWORK.'MAT0' = 'MOT' 'INCONNU';
  315. * mat1 materiaux pour le pas en cours : pasapas unpas
  316. TWORK.'MAT1' = 'MOT' 'INCONNU';
  317. * matvar le materiau est variable : pas_verm
  318. TWORK.'MATVAR' = FAUX;
  319. * mat_con materiau des modeles de convection
  320. TWORK.'MAT_CON' = 'MOT' 'INCONNU';
  321. * mat_dif materiau des modeles de diffusion
  322. TWORK.'MAT_DIF' = 'MOT' 'INCONNU';
  323. * mat_mec materiau des modeles de mecanique
  324. TWORK.'MAT_MEC' = 'MOT' 'INCONNU';
  325. * mat_pha materiau des modeles de changement de phase 'PARFAIT'
  326. TWORK.'MAT_PHA' = 'MOT' 'INCONNU';
  327. * mat_por materiau des modeles poreux
  328. TWORK.'MAT_POR' = 'MOT' 'INCONNU';
  329. * mat_ray materiau des modeles de rayonnement
  330. TWORK.'MAT_RAY' = 'MOT' 'INCONNU';
  331. * mat1 materiaux de reference
  332. TWORK.'MAT_REF' = 'MOT' 'INCONNU';
  333. * mat_sol materiau des modeles de changement de phase 'SOLUBILITE'
  334. TWORK.'MAT_SOL' = 'MOT' 'INCONNU';
  335. * mat_T materiau thermique + thermohydrique
  336. TWORK.'MAT_T' = 'MOT' 'INCONNU';
  337. * mat_the materiau des modeles thermiques
  338. TWORK.'MAT_THE' = 'MOT' 'INCONNU';
  339. * mat_thm materiau thermohydrique
  340. TWORK.'MAT_THM' = 'MOT' 'INCONNU';
  341. * materiau des modeles convection + thermiques
  342. TWORK.'MAT_TOT' = 'MOT' 'INCONNU';
  343. * maxdefor valeur limitant la deformation en cas de non convergence
  344. * ou de RENORMALISATION souhaitee de ZDEP1
  345. TWORK.'MAXDEFOR' = 1.e-3;
  346. * maxiteration nombre maximum d'iteration pour un pas de calcul
  347. TWORK.'MAXITERATION' = 49;
  348. * maxisouspas nombre maximum de sous pas d'integration du fluage
  349. TWORK.'MAXISOUSPAS' = 2000;
  350. * maxsousiterations nombre maximum de sous iterations pour un calcul non-local
  351. TWORK.'MAXSOUSITERATION' = 500;
  352. * maxsouspas nombre maximum de sous pas en cas de non convergence
  353. TWORK.'MAXSOUSPAS' = 100;
  354. * ma_tot materiau des modeles mecaniques + poreux +liaison
  355. TWORK.'MA_TOT' = 'MOT' 'INCONNU';
  356. * mec1 il existe au moins un modele mecanique
  357. TWORK.'MEC1' = FAUX;
  358. * affichage messages options calcul entete procedure resolution THERMIQUE
  359. TWORK.'MESSTHER' = VRAI ;
  360. * modal ou statique
  361. TWORK.'MODAL' = FAUX;
  362. * mod_adv modele de thermique, advection
  363. TWORK.'MOD_ADV' = 'MOT' 'INCONNU';
  364. * mod_con modele de thermique convection
  365. TWORK.'MOD_CON' = 'MOT' 'INCONNU';
  366. * mod_dif modele de diffusion
  367. TWORK.'MOD_DIF' = 'MOT' 'INCONNU';
  368. * mod_mec modele mecanique
  369. TWORK.'MOD_MEC' = 'MOT' 'INCONNU';
  370. * mod_pha modele de changement de phase 'PARFAIT'
  371. TWORK.'MOD_PHA' = 'MOT' 'INCONNU';
  372. * mod_por modele poreux
  373. TWORK.'MOD_POR' = 'MOT' 'INCONNU';
  374. * mod_ray modele rayonnement
  375. TWORK.'MOD_RAY' = 'MOT' 'INCONNU';
  376. * mod_sol modele de changement de phase 'SOLUBILITE'
  377. TWORK.'MOD_SOL' = 'MOT' 'INCONNU';
  378. * mod_soq : modele source de chaleur
  379. TWORK.'MOD_SOQ' = 'MOT' 'INCONNU';
  380. * mod_T modele thermique + thermohydrique (contient inconnue T)
  381. TWORK.'MOD_T' = 'MOT' 'INCONNU';
  382. * mod_the modele thermique
  383. TWORK.'MOD_THE' = 'MOT' 'INCONNU';
  384. * mod_thm modele thermohydrique
  385. TWORK.'MOD_THM' = 'MOT' 'INCONNU';
  386. * mod_tot modele thermique
  387. TWORK.'MOD_TOT' = 'MOT' 'INCONNU';
  388. * mo_tot modele mecanique + modele poreux
  389. TWORK.'MO_TOT' = 'MOT' 'INCONNU';
  390. * mo_tot_prec modele mecanique + modele poreux au pas precedent
  391. TWORK.'MO_TOT_PREC' = 'MOT' 'INCONNU';
  392. * MODELE ce qui est dans preced.modele
  393. TWORK.'MODELE' = 'MOT' 'INCONNU' ;
  394. * mova nom de la variables internes dont le max est imprime
  395. TWORK.'MOVA' = 'MOT' 'EPSE';
  396. * msrther1 deformations thermiques pour les poreux
  397. TWORK.'MSRTHER1' = 'MOT' 'INCONNU';
  398. * msrther2 deformations thermiques pour les poreux
  399. TWORK.'MSRTHER2' = 'MOT' 'INCONNU';
  400. * mtol valeur autorisee du desequilibre (en terme de moment)
  401. TWORK.'MTOL' = 'MOT' 'INCONNU';
  402. * naures valeur de preced .autoresu
  403. TWORK.'NAURES' = 100000;
  404. * nbplas nb de point ayant plastifie : pasapas unpas
  405. TWORK.'NBPLAS' = 'MOT' 'INCONNU';
  406. * premier pas de sauvegarde encore present (option economique de pasapas)
  407. TWORK.'NFSOR' = 0;
  408. * nombre maxi d'iteration internes si k_tangent
  409. TWORK.'NITERINTER_MAX' = 15;
  410. * niter_ktangent recalcule de la matrice tangente toutes les .. iterations
  411. TWORK.'NITER_KTANGENT' = 1;
  412. * nloc s'il existe un modele de comportement non_local (preced.non_local)
  413. TWORK.'NLOC' = FAUX ;
  414. * nmaxsubsteps nb maximun de substepping si fefp
  415. TWORK.'NMAXSUBSTEPS' = 1;
  416. * nombre_iterations nb d'iterations du pas precedent : pasapas unpas
  417. TWORK.'NOMBRE_ITERATIONS' = 12 ;
  418. * non_lineaire il existe un materiau utilisateur non-lineaire
  419. TWORK.'NON_LINEAIRE' = FAUX;
  420. * non_local decrit le modele de comportement non_local (preced.non_local)
  421. TWORK.'NON_LOCAL' = 'MOT' 'INCONNU' ;
  422. * delta temps du pas en cours pour dupont2 : pasapas
  423. TWORK.'NOUV_PAS' = 0.D0;
  424. * nsor numero a ecrire dans les tables de resultats : pas_ init
  425. TWORK.'NSOR' = 0;
  426. * formulation NAVIER_STOKES materiau NLIN
  427. TWORK.'NVSTNL' = FAUX ;
  428. * operateur matrice contenant l'operateur d'iterations : pasapas
  429. TWORK.'OPERATEUR' = 'MOT' 'INCONNU';
  430. * Ordre est l'ordre de developpement de la MAN
  431. TWORK.'ORDRE' = 12;
  432. * para_exte il existe des parametres externes : pas_verm
  433. TWORK.'PARA_EXTE' = FAUX;
  434. * pas numero du pas de temps utile a transnon : pasapas
  435. TWORK.'PAS' = 0;
  436. * pas_ajuste si ajustement automatique de longueur de pas
  437. TWORK.'PAS_AJUSTE' = FAUX;
  438. * pas_redu en automatiqu il a fallu reduire le pas : pasapas unpas
  439. TWORK.'PAS_REDU' = FAUX;
  440. * phase il existe du changement de phase 'PARFAIT'
  441. TWORK.'PHASE' = FAUX;
  442. * plastique il exite un comportement plastique
  443. TWORK.'PLASTIQUE' = FAUX;
  444. * por1 il existe un model poreux
  445. TWORK.'POR1' = FAUX;
  446. * precdecharge critere de decharge en opilotage automatique
  447. TWORK.'PRECDECHARGE' = 1.E-2;
  448. * precflex critere de desequilibre sur moment autorise
  449. TWORK.'PRECFLEX' = 1.E-4;
  450. * precisinter precision pour les iterations locales (fefp)
  451. TWORK.'PRECISINTER' = 1.D-8;
  452. * precision critere de convergence Thermique & Mecanique
  453. TWORK.'PRECISION' = 1.E-4 ;
  454. * precsousiteration precision pour les sous iterations en non local
  455. TWORK.'PRECSOUSITERATION' = 1.0E-6;
  456. * predicteur
  457. TWORK.'PREDICTEUR' = 'MOT' 'INCONNU';
  458. * procedure initialisation pour g_theta
  459. TWORK.'PROCEDURE' = 'MOT' 'PASAPAS';
  460. * procedure_charmeca il faut appele la procedure charmeca
  461. TWORK.'PROCEDURE_CHARMECA' = FAUX;
  462. * procedure_charther il faut appele la procedure charther
  463. TWORK.'PROCEDURE_CHARTHER' = FAUX;
  464. * procedure_parather il faut appeler la procedure parather
  465. TWORK.'PROCEDURE_PARATHER' = FAUX ;
  466. * procedure_perso1 il faut appeler la procedur perso1
  467. TWORK.'PROCEDURE_PERSO1' = FAUX;
  468. * procedure_perso2 il faut appeler la procedur perso2
  469. TWORK.'PROCEDURE_PERSO2' = FAUX;
  470. * procedure_reev_mec il faut appeler la procedur reev_mec
  471. TWORK.'PROCEDURE_REEV_MEC' = FAUX ;
  472. * procedure_reev_the il faut appeler la procedur reev_the
  473. TWORK.'PROCEDURE_REEV_THE' = FAUX ;
  474. * procedur_thermique non de la procedure thermique a appeler
  475. TWORK.'PROCEDURE_THERMIQUE' = 'MOT' 'NONLINEAIRE';
  476. * processeurs pour imposer l'option de parallelisme
  477. TWORK.'PROCESSEURS' = 'MOT' 'INCONNU';
  478. * projection le champ de temperature clcule doit etere projete
  479. TWORK.'PROJECTION' = FAUX;
  480. * raidconst il existe des raideurs constantes
  481. TWORK.'RAIDCONST' = FAUX;
  482. * raidaugm diffaugm theraugm il existe des raideurs augmentees
  483. TWORK.'RAIDAUGM' = FAUX;
  484. TWORK.'DIFFAUGM' = FAUX;
  485. TWORK.'THERAUGM' = FAUX;
  486. * autaug augmentation automatique
  487. TWORK.'AUTOAUGM' = FAUX;
  488. * rayo il existe du rayonnement en thermique
  489. TWORK.'RAYO' = FAUX;
  490. * rayonnement on y met des pre-calculs pour le rayonnement : transnon charther
  491. TWORK.'RAYONNEMENT' = 'MOT' 'INCONNU';
  492. * Reactualisation de la matrice en grands deplacements pour 0,1 de defor
  493. TWORK.'REAC_GRANDS' = 0.1 ;
  494. * logique disant pour charther si geometrie a change : pasapas
  495. TWORK.'REA_GEOM' = FAUX ;
  496. * reaprec utile pour les contacts unilateraux en dynamiques
  497. TWORK.'REAPREC' = 'MOT' 'INCONNU';
  498. * recaop = recalcul operateur
  499. TWORK.'RECAOP' = VRAI;
  500. * recari : recalcul de la rigidite
  501. TWORK.'RECARI' = FAUX;
  502. * reequilibrage : recalcul du dernier pas de temps lors d'une reprise
  503. TWORK.'REEQUILIBRAGE' = FAUX ;
  504. * relaxation_dupont2 coeff de relaxation pour dupont2
  505. TWORK.'RELAXATION_DUPONT' = 0.25;
  506. * parametre de relaxation du pas de temps en non convergence
  507. TWORK.'RELAXATION_NONCONV' = 1.;
  508. * relaxation_thet coeff de relaxation pour transnon
  509. TWORK.'RELAXATION_THETA' = 1. ;
  510. * renormalisation de l'itere pour le limiter
  511. TWORK.'RENORMALISATION' = FAUX;
  512. * residu chpoint donnant le dernier residu d'equilibre : pasapas unpas
  513. TWORK.'RESIDU' = 'MOT' 'INCONNU';
  514. * riblo_m matrice de blocages des appuis unilateraux : unpas
  515. TWORK.'RIBLO_M' = 'MOT' 'INCONNU';
  516. * riblo_t matrice de blocages des changement de phase : transnon
  517. TWORK.'RIBLO_T' = 'MOT' 'INCONNU';
  518. * valeurr des rigidites constantes
  519. TWORK.'RIGIDITE_CONSTANTE' = 'MOT' 'INCONNU';
  520. * solubilite il existe du changement de phase 'SOLUBILITE'
  521. TWORK.'SOLUBILITE' = FAUX;
  522. * sous_increment nombre de sous increment
  523. TWORK.'SOUS_INCREMENT' = 1 ;
  524. * SOURCE_Q presence d'un modele thermique source de chaleur
  525. TWORK.'SOURCE_Q' = FAUX;
  526. * test stabilite de la solution
  527. TWORK.'STABILITE' = VRAI;
  528. * substepping pour integrer en petites deformation
  529. TWORK.'SUBSTEPPING' = FAUX;
  530. * tabsauv table indiquant les options de sauv des resultats
  531. TWORK.'TABSAUV' = 'TABL' ;
  532. TWORK.'TABSAUV'.'DEFIN' = FAUX;
  533. TWORK.'TABSAUV'.'DEFTO' = FAUX;
  534. TWORK.'TABSAUV'.'DEFAP' = FAUX;
  535. * temps0 temps de calcul precedent : pasapas
  536. TWORK.'TEMPS0' = 0.D0;
  537. * temps_calcules liste des tempsd a calculer
  538. TWORK.'TEMPS_CALCULES' = 'MOT' 'INCONNU';
  539. * tem_calc liste des temps a calculer pour les proc thermique : pasapas
  540. TWORK.'TEM_CALC' = 'MOT' 'INCONNU';
  541. * teta facteur pour la theta methode en consolidation
  542. TWORK.'TETA' = 1.0D0;
  543. * tet0 champ de temperature 2 pas avant : pasapas dupont2
  544. TWORK.'TET0' = 0;
  545. * tet1 champ de temperature 1 pas avant : pasapas
  546. TWORK.'TET1' = 0;
  547. * tet2 champ de temperature du pas courant : pasapas
  548. TWORK.'TET2' = 0;
  549. * the1 le calcul inclus des modeles thermique
  550. TWORK.'THE1' = FAUX;
  551. * ther_courant champ de temperature propose pour charther : dupont2 transnon
  552. TWORK.'THER_COURANT' = 'MOT' 'INCONNU';
  553. * thm1 le calcul inclus des modeles thermohydriques
  554. TWORK.'THM1' = FAUX;
  555. * tref temperature de reference 0 ou 273 : transnon dupont2
  556. TWORK.'TREF' = 0.D0;
  557. * ttol desequilibre absolu dans TRANSNON
  558. TWORK.'TTOL' = 'MOT' 'INCONNU';
  559. * t_final objectif du temps a calcule si pas_ajuste pasapas
  560. TWORK.'T_FINAL' = 0.D0;
  561. * update_lagrangian on veut faire du lagrangien reactualise fefp
  562. TWORK.'UPDATE_LAGRANGIAN' = FAUX;
  563. * presence d'un modele dit utilisateur
  564. TWORK.'UTILISATEUR' = FAUX ;
  565. * vieuxpas dt precedent pour dupont2
  566. TWORK.'VIEUXPAS' = 0.D0;
  567. * viscodommage il existe un modele de comportement viscodommage
  568. TWORK.'VISCODOMMAGE' = FAUX;
  569. * viscoplastique il existe un modele de comportement viscoplastique
  570. TWORK.'VISCOPLASTIQUE' = FAUX;
  571. * visco_externe il existe un modele de comportementvisco_externe
  572. TWORK.'VISCO_EXTERNE' = FAUX;
  573. * xdeno valeur pour calculer le critere de convergence force : unpas
  574. TWORK.'XDENO' = 0.d0;
  575. * xdenom valeur pour calculer le critere de convergence moment : unpas
  576. TWORK.'XDENOM' = 0.d0;
  577. * zraidv : rigidite K+4M/H2 (VITEUNIL)
  578. TWORK.'ZRAIDV' = 'MOT' 'INCONNU' ;
  579. ************************************************************************
  580. * Reprise/poursuite d'un calcul
  581. ************************************************************************
  582. * - Reprise d'un calcul : supprimer les infos des instants t > treprise
  583. 'SI' ('EXIS' PRECED 'REPRISE');
  584. 'SI' (PRECED.'REPRISE' > 0.);
  585. PAS_REPR PRECED;
  586. 'FINSI';
  587. 'SI' ('EXISTE' PRECED 'REEQUILIBRAGE') ;
  588. TWORK.'REEQUILIBRAGE' = PRECED.'REEQUILIBRAGE' ;
  589. 'FINSI' ;
  590. 'FINSI';
  591. *
  592. * - Poursuite d'un calcul : repartir du dernier instant calcule
  593. 'SI' ('EXIS' PRECED 'CONTINUATION' );
  594. iii = 'INDEX' PRECED;nii= 'DIME' iii;
  595. 'REPETER' boui nii;
  596. 'SI' ('EGA' ('TYPE' iii. &boui ) 'MOT ');
  597. aa = 'MOT' iii. &boui;
  598. 'SINON';
  599. aa = iii. &boui;
  600. 'FINSI';
  601. 'SI'('NON' ('EXIS' TWORK aa));
  602. si (ega (type preced.aa) 'MOT') ;
  603. TWORK. aa = mot PRECED . aa ;
  604. sinon ;
  605. TWORK. aa = PRECED . aa;
  606. finsi ;
  607. 'FINSI';
  608. 'FIN' BOUI;
  609. 'SI' ('EXISTE' PRECED 'REEQUILIBRAGE') ;
  610. TWORK.'REEQUILIBRAGE' = PRECED.'REEQUILIBRAGE' ;
  611. 'FINSI' ;
  612. *
  613. * En cas de poursuite de calcul, indices eventuellement utiles a :
  614. * UNPAS, TRANSNON, TRANSLIN, DUPONT2 et autres sous-procedures...
  615. * (a ameliorer...)
  616. 'SI' ('EXIS' PRECED 'WTABLE') ;
  617. *
  618. * Pour initialisation a partir du pas precedent
  619. 'SI' ('EXIS' PRECED.'WTABLE' 'ZDEP1') ;
  620. TWORK.'ZDEP1' = PRECED.'WTABLE'.'ZDEP1' ;
  621. TWORK.'FNONL' = PRECED.'WTABLE'.'FNONL' ;
  622. TWORK.'INCREMENT' = PRECED.'WTABLE'.'INCREMENT' ;
  623. TWORK.'RESIDU' = PRECED.'WTABLE'.'RESIDU' ;
  624. TWORK.'ISOUSPAS' = PRECED.'WTABLE'.'ISOUSPAS' ;
  625. 'FINSI' ;
  626. *
  627. * Pour le pilotage automatique
  628. TWORK.'AUTOCOEF' = PRECED.'WTABLE'.'AUTOCOEF';
  629. TWORK.'AUTOREDU' = PRECED.'WTABLE'.'AUTOREDU';
  630. TWORK.'NBPLAS' = PRECED.'WTABLE'.'NBPLAS' ;
  631. TWORK.'XDENO' = PRECED.'WTABLE'.'XDENO' ;
  632. TWORK.'XDENOM' = PRECED.'WTABLE'.'XDENOM' ;
  633. *
  634. * En dynamique
  635. TWORK.'FREA1' = PRECED.'WTABLE'.'FREA1' ;
  636. TWORK.'OPERATEUR' = PRECED.'WTABLE'.'OPERATEUR' ;
  637. TWORK.'DTPREC' = PRECED.'WTABLE'.'DTPREC' ;
  638. *
  639. * Rigidite tangente
  640. TWORK.'LASTKTAN' = PRECED.'WTABLE'.'LASTKTAN' ;
  641. *
  642. * Pour PAS_AJUSTE
  643. TWORK.'NOMBRE_ITERATIONS' = PRECED.'WTABLE'.'NOMBRE_ITERATIONS' ;
  644.  
  645. * THERMIQUE ajout de matiere (prour reprise) :
  646. 'SI' ('EXIS' PRECED.'WTABLE' 'CAPA_COURANTE') ;
  647. TWORK.'CAPA_COURANTE' = PRECED.'WTABLE'.'CAPA_COURANTE' ;
  648. 'FINSI' ;
  649.  
  650. 'FINSI' ;
  651. *
  652. 'FINSI';
  653. TWORK.'RECAOP' = 'EGA' TWORK.'OPERATEUR' 'INCONNU' ;
  654. ************************************************************************
  655. * Stocker TWORK a l'indice WTABLE de PRECED
  656. ************************************************************************
  657. PRECED.'WTABLE' = TWORK ;
  658. ************************************************************************
  659. * Renseigner WTABLE a partir des informations de PRECED
  660. ************************************************************************
  661. 'SI' ('EGA' TYPMO 'CHARGEME') ;
  662. TWORK.'CHAR_MODE' = VRAI ;
  663. TWORK.'MODELE' = 'TIRE' MO 'MODE' TWORK.'TEMPS0' ;
  664. 'SINON' ;
  665. TWORK.'MODELE' = MO ;
  666. 'FINSI' ;
  667. *-----------------------------------------------------------------------
  668. 'SI' ('EGA' TYPMA 'CHARGEME') ;
  669. TWORK.'CHAR_MATE' = VRAI ;
  670. TWORK.'CARACTERISTIQUES' = 'TIRE' MA 'MATE' TWORK.'TEMPS0' ;
  671. 'SINON' ;
  672. TWORK.'CARACTERISTIQUES' = MA ;
  673. 'FINSI';
  674. *-----------------------------------------------------------------------
  675. 'SI' ('EXIS' PRECED 'CHARGEMENT') ;
  676. TWORK.'CHARGEMENT' = PRECED.'CHARGEMENT';
  677. 'FINSI';
  678. *-----------------------------------------------------------------------
  679. 'SI' ('EXISTE' PRECED 'PAS_AJUSTE');
  680. TWORK.'PAS_AJUSTE' = PRECED.'PAS_AJUSTE';
  681. 'SI' TWORK.'PAS_AJUSTE' ;
  682. TWORK.'CONVERGENCE_FORCEE' = FAUX ;
  683. 'FINSI';
  684. 'FINSI';
  685. 'SI' ('EXISTE' PRECED 'AUTOMATIQUE');
  686. TWORK.'AUTOMATIQUE' = PRECED.'AUTOMATIQUE';
  687. * par defaut pas de controle de stabilite en pilotage
  688. TWORK.'STABILITE' = FAUX;
  689. 'FINSI' ;
  690. 'SI' TWORK.'AUTOMATIQUE';
  691. TWORK.'PAS_AJUSTE' = FAUX;
  692. 'FINSI';
  693. *
  694. 'SI' (('EXIS' PRECED 'TEMPS_CALCULES') 'ET' ('NON' TWORK.'PAS_AJUSTE'));
  695. TWORK.'TEMPS_CALCULES'= PRECED.'TEMPS_CALCULES';
  696. 'SINON' ;
  697. 'SI' TWORK.'FREQUENTIEL' ;
  698. l_zf = 'PROG' ; l_ii = 'PROG' 1. 'PAS' 0.3 4. 'PAS' 1. 10. ;
  699. 'SI' ('EXISTE' TWORK.'CARACTERISTIQUES' 'FREQ') ;
  700. ccfr1 = 'EXCO' TWORK.'CARACTERISTIQUES' 'FREQ' 'NOID' ;
  701. 'SI' ('EGA' ('TYPE' ccfr1) 'MCHAML ') ;
  702. ncfr1 = 'EXTR' ccfr1 'NBZO' ;
  703. 'REPE' vfr1 ncfr1 ;
  704. ** hypothese 1 modele = 1 mode !!
  705. f1 = 'EXTR' ccfr1 'FREQ' &vfr1 1 1 ;
  706. log_f1 = ('LOG' f1) / ('LOG' 10.) ;
  707. e10_f1 = 'ENTI' log_f1 ;
  708. 'SI' (log_f1 < 0.) ; e10_f1 = e10_f1 - 1 ; 'FINSI' ;
  709. 'SI'((log_f1 - e10_f1) 'EGA' 0.) ; e10_f1 = e10_f1 - 1 ; 'FINSI' ;
  710. p10_f1 = 10. ** e10_f1 ;
  711. l_zf1 = 'PROG' (f1 - (p10_f1/10.)) (f1 - (p10_f1/100.))
  712. (f1 - (p10_f1/1000.)) (f1 + (p10_f1/1000.)) ;
  713. l_i10 = l_ii * p10_f1 ;
  714. 'SI' (('DIME' l_zf) 'EGA' 0) ;
  715. e10_min = e10_f1 ; e10_max = e10_f1 + 1 ;
  716. l_zf = 'ORDO' (l_i10 'ET' l_zf1) 'UNIQ' ;
  717. 'SINON' ;
  718. l_zf0 = l_zf ;
  719. 'SI' ((e10_f1 '>EG' e10_min) 'ET' (e10_f1 < e10_max)) ;
  720. l_zf = 'ORDO' (l_zf 'ET' l_zf1) 'UNIQ' ;
  721. 'SINON' ;
  722. 'SI' (e10_f1 < e10_min) ;
  723. e10_u = e10_f1 ;
  724. 'REPE' b_lz ;
  725. l_zf0 = l_i10 'ET' l_zf0 ; e10_u = e10_u + 1 ;
  726. 'SI' (e10_u 'EGA' e10_min) ; 'QUIT' b_lz ; 'FINSI' ;
  727. l_i10 = l_i10 * 10 ;
  728. 'FIN' b_lz ;
  729. e10_min = e10_f1 ;
  730. l_zf = 'ORDO' (l_zf0 'ET' l_zf1) 'UNIQ' ;
  731. 'FINSI' ;
  732. 'SI' (e10_f1 '>EG' e10_max) ;
  733. e10_u = e10_f1 ;
  734. 'REPE' b_lz ;
  735. l_zf0 = l_i10 'ET' l_zf0 ; e10_u = e10_u - 1 ;
  736. 'SI' (e10_u < e10_max) ; 'QUIT' b_lz ; 'FINSI' ;
  737. l_i10 = l_i10 / 10 ;
  738. 'FIN' b_lz ;
  739. e10_max = e10_f1 + 1;
  740. l_zf = 'ORDO' (l_zf0 'ET' l_zf1) 'UNIQ' ;
  741. 'FINSI' ;
  742. 'FINSI' ;
  743. 'FINSI' ;
  744. 'FIN' vfr1 ;
  745. 'SINON' ;
  746. l_zf = l_ii ;
  747. 'FINSI' ;
  748. TWORK.'TEMPS_CALCULES' = l_zf ;
  749. 'SINON' ;
  750. TWORK.'TEMPS_CALCULES' = l_ii ;
  751. 'FINSI' ;
  752. 'SINON';
  753. 'SI' ('NON' ('EXISTE' PRECED 'TEMPS_SAUVES'));
  754. 'ERREUR' 'Il manque la donnee des temps a sauver ou a calculer';
  755. 'FINSI';
  756. TWORK.'PAS_AJUSTE' = VRAI;
  757. TWORK.'TEMPS_CALCULES' = PRECED.'TEMPS_SAUVES';
  758. TWORK.'TEMPS_SAUVES' = PRECED.'TEMPS_SAUVES';
  759. 'FINSI';
  760. 'FINSI';
  761. *
  762. 'SI' TWORK.'FREQUENTIEL' ;
  763. 'REPETER' BTFRE ;
  764. TI = 'EXTRAIRE' TWORK.'TEMPS_CALCULES' &BTFRE ;
  765. 'SI' (TI '>' 0.D0) ;
  766. TWORK.'TEMPS0' = TI ;
  767. 'QUITTER' BTFRE ;
  768. 'FINSI' ;
  769. 'FIN' BTFRE ;
  770. 'FINSI' ;
  771. *
  772. TWORK.'IPTIME' = TWORK.'TEMPS_CALCULES';
  773. TWORK.'IPRESU' = TWORK.'TEMPS_CALCULES';
  774. 'SI' ('EXISTE' PRECED 'TEMPS_SAUVES' );
  775. TWORK.'IPRESU' = PRECED.'TEMPS_SAUVES';
  776. 'FINSI';
  777. 'SI' ('EXISTE' PRECED 'TEMPS_SAUVEGARDES');
  778. TWORK.'ISAUVEGL' = VRAI;
  779. TWORK.'ISAUVEGA' = PRECED.'TEMPS_SAUVEGARDES';
  780. 'FINSI';
  781. 'SI' ('EXISTE' PRECED 'ECONOMIQUE');
  782. TWORK.'LECONOMI' = PRECED.'ECONOMIQUE';
  783. 'FINSI';
  784. 'SI' ('EXIS' PRECED 'MES_SAUVEGARDES');
  785. TABSAUV = PRECED .'MES_SAUVEGARDES';
  786. TWORK.'TABSAUV' = TABSAUV ;
  787. 'SI' ('NON' ( 'EXIS' TABSAUV 'DEFIN'));
  788. TWORK.'TABSAUV'.'DEFIN' = FAUX;
  789. 'FINSI';
  790. 'SI' ('NON' ( 'EXIS' TABSAUV 'DEFTO'));
  791. TWORK.'TABSAUV'.'DEFTO' = FAUX;
  792. 'FINSI';
  793. 'SI' ('NON' ( 'EXIS' TABSAUV 'DEFAP'));
  794. TWORK.'TABSAUV'.'DEFAP' = FAUX;
  795. 'FINSI';
  796. 'FINSI';
  797. LOGERR1 = 'DANS' 'QUEL' TWORK.'IPRESU' TWORK.'IPTIME';
  798. LOGERR2 = VRAI;
  799. 'SI' TWORK.'ISAUVEGL';
  800. LOGERR2= 'DANS' 'QUEL' TWORK.'ISAUVEGA' TWORK.'IPTIME';
  801. 'FINSI';
  802. 'SI' ('NON' (LOGERR1 'ET' LOGERR2));
  803. 'ERRE' 1013;
  804. 'FINSI';
  805. *
  806. *----- Indicateur ADAP_MODE d'adaptation du modele :
  807. 'SI' ('EXIS' PRECED 'TEMPS_ADAPTATION_MODELE') ;
  808. TWORK.'ADAP_MODE' = VRAI ;
  809. TWORK.'LTPS_ADAP' = PRECED.'TEMPS_ADAPTATION_MODELE' ;
  810. * TPS1_ADAP : prochain temps d'adaptation
  811. TWORK.'TPS1_ADAP' = TWORK.'LTPS_ADAP' 'EXTR' 1 ;
  812. TWORK.'INDI_ADAP' = 1 ;
  813. 'SINON' ;
  814. TWORK.'TPS1_ADAP' = ('MAXI' TWORK.'TEMPS_CALCULES') + 1. ;
  815. 'FINSI' ;
  816. *-----------------------------------------------------------------------
  817. 'SI' ('EXISTE' PRECED 'CONSOLIDATION') ;
  818. TWORK.'CONSOLIDATION' = PRECED.'CONSOLIDATION' ;
  819. 'FINSI';
  820. *
  821. 'SI' ('EXISTE' PRECED 'CONVERGENCE_MONOTONE');
  822. TWORK.'CONVERGENCE_MONOTONE' = PRECED.'CONVERGENCE_MONOTONE';
  823. 'FINSI';
  824. *
  825. 'SI' ('EXISTE' PRECED 'DELTAITER');
  826. TWORK.'DELTAITER' = PRECED.'DELTAITER';
  827. 'FINSI' ;
  828. *
  829. 'SI' ('EXISTE' PRECED 'DYNAMIQUE') ;
  830. TWORK.'DYNAMIQUE' = PRECED.'DYNAMIQUE';
  831. 'SI' ('EXISTE' PRECED 'AMORTISSEMENT' );
  832. TWORK.'AMORTISSEMENT' = 'EXTR' PRECED.'AMORTISSEMENT' 'RIGI' 'NOMU';
  833. 'FINSI';
  834. 'FINSI';
  835. *
  836. 'SI' ('EXISTE' PRECED 'FTOL' );
  837. TWORK.'FTOL' = PRECED.'FTOL';
  838. 'FINSI';
  839. *
  840. 'SI' ('EXISTE' PRECED 'INITIALISATION');
  841. TWORK.'INITIALISATION' = PRECED.'INITIALISATION';
  842. 'FINSI';
  843. *
  844. 'SI' ('EXISTE' PRECED 'LIAISON_PERSISTANTE' ) ;
  845. TWORK.'LIAISON_PERSISTANTE' = PRECED.'LIAISON_PERSISTANTE';
  846. 'FINSI';
  847. *
  848. 'SI' ('EXISTE' PRECED 'MAXSOUSITERATION') ;
  849. TWORK.'MAXSOUSITERATION' = PRECED.'MAXSOUSITERATION';
  850. 'FINSI';
  851. *
  852. 'SI' ('EXISTE' PRECED 'MAXSOUSPAS');
  853. TWORK.'MAXSOUSPAS' = PRECED.'MAXSOUSPAS' ;
  854. 'FINSI';
  855. *
  856. 'SI' ('EXISTE' PRECED 'LINESEARCH');
  857. 'SI' ('EGA' PRECED.'LINESEARCH' VRAI);
  858. TWORK.'LINESEARCH' = VRAI;
  859. TWORK.'GRANDS_DEPLACEMENTS' = VRAI;
  860. 'FINSI';
  861. 'FINSI';
  862. *
  863. 'SI' ('EXISTE' PRECED 'MTOL' );
  864. TWORK.'MTOL' = PRECED.'MTOL';
  865. 'FINSI';
  866. *
  867. 'SI' ('EXISTE' PRECED 'PRECISION') ;
  868. TWORK.'PRECISION' = PRECED.'PRECISION' ;
  869. 'FINS' ;
  870. *
  871. 'SI' ('EXISTE' PRECED 'PRECSOUSITERATION') ;
  872. TWORK.'PRECSOUSITERATION' = PRECED.'PRECSOUSITERATION';
  873. 'FINSI';
  874. *
  875. 'SI' ('EXISTE' PRECED 'PREDICTEUR');
  876. TWORK.'PREDICTEUR' = 'MOT' PRECED.'PREDICTEUR';
  877. TWORK.'GRANDS_DEPLACEMENTS' = VRAI;
  878. 'FINSI';
  879. *
  880. 'SI' ('EXISTE' PRECED 'PROCEDURE_CHARMECA');
  881. TWORK.'PROCEDURE_CHARMECA' = PRECED.'PROCEDURE_CHARMECA';
  882. 'FINSI';
  883. *
  884. 'SI' ('EXISTE' PRECED 'PROCEDURE_CHARTHER');
  885. TWORK.'PROCEDURE_CHARTHER' = PRECED.'PROCEDURE_CHARTHER';
  886. 'FINSI';
  887. *
  888. 'SI' ('EXISTE' PRECED 'PROCEDURE_PARATHER') ;
  889. TWORK.'PROCEDURE_PARATHER' = PRECED.'PROCEDURE_PARATHER' ;
  890. 'FINSI';
  891. *
  892. 'SI' ('EXISTE' PRECED 'PROCEDURE_PERSO1');
  893. TWORK.'PROCEDURE_PERSO1' = PRECED.'PROCEDURE_PERSO1';
  894. 'FINSI';
  895. *
  896. 'SI' ('EXISTE' PRECED 'PROCEDURE_PERSO2');
  897. TWORK.'PROCEDURE_PERSO2' = PRECED.'PROCEDURE_PERSO2';
  898. 'FINSI';
  899. *
  900. 'SI' ('EXISTE' PRECED 'PROCEDURE_REEV_MEC');
  901. TWORK.'PROCEDURE_REEV_MEC' = PRECED.'PROCEDURE_REEV_MEC' ;
  902. 'FINSI';
  903. *
  904. 'SI' ('EXISTE' PRECED 'PROCEDURE_REEV_THE');
  905. TWORK.'PROCEDURE_REEV_THE' = PRECED.'PROCEDURE_REEV_THE' ;
  906. 'FINSI';
  907. *
  908. 'SI' ('EXISTE' PRECED 'PROCEDURE_THERMIQUE');
  909. TWORK.'PROCEDURE_THERMIQUE' = PRECED.'PROCEDURE_THERMIQUE';
  910. 'FINSI';
  911. *
  912. 'SI' ('EXIS' PRECED 'REAC_GRANDS');
  913. 'SI' ('EGA' ('TYPE' PRECED . 'REAC_GRANDS') 'FLOTTANT') ;
  914. TWORK.'REAC_GRANDS' = PRECED.'REAC_GRANDS';
  915. 'FINSI';
  916. 'FINSI';
  917. *
  918. 'SI' ('EXISTE' PRECED 'RENORMALISATION');
  919. TWORK.'RENORMALISATION' = PRECED.'RENORMALISATION';
  920. 'FINSI';
  921. *
  922. 'SI' ('EXIS' PRECED 'SOUS-INCREMENT' );
  923. TWORK.'SOUS-INCREMENT'=PRECED.'SOUS-INCREMENT';
  924. 'FINSI';
  925. *
  926. 'SI' ('EXISTE' PRECED 'STABILITE');
  927. 'SI' ('EGA' PRECED.'STABILITE' FAUX);
  928. TWORK.'STABILITE'= FAUX;
  929. 'SINON';
  930. TWORK.'STABILITE'= VRAI;
  931. 'FINSI';
  932. 'FINSI';
  933. *
  934. 'SI' ('EXISTE' PRECED 'CONVERGENCE_FORCEE');
  935. TWORK.'CONVERGENCE_FORCEE' = PRECED.'CONVERGENCE_FORCEE';
  936. 'SINON';
  937. 'SI' ('NON' TWORK.'AUTOMATIQUE');
  938. TWORK.'CONVERGENCE_FORCEE' = VRAI;
  939. 'FINSI';
  940. 'FINSI';
  941. *
  942. 'SI' ('EXISTE' PRECED 'CONVERGENCE_MEC_THE');
  943. TWORK.'CONVERGENCE_MEC_THE' = PRECED.'CONVERGENCE_MEC_THE';
  944. 'FINSI';
  945. 'SI' TWORK.'CONVERGENCE_MEC_THE';
  946. TWORK.'AUTOMATIQUE' = FAUX;
  947. TWORK.'CONVERGENCE_FORCEE' = FAUX;
  948. 'SI' TWORK.'PAS_AJUSTE' ;
  949. 'ERREUR' 'Options CONVERGENCE_MEC_THE et PAS_AJUSTE incompatibles';
  950. 'FINSI';
  951. TWORK.'CRITERE_COHERENCE' = TWORK.'PRECISION' ;
  952. 'SI' ('EXISTE' PRECED 'CRITERE_COHERENCE') ;
  953. TWORK.'CRITERE_COHERENCE' = PRECED.'CRITERE_COHERENCE' ;
  954. 'FINSI' ;
  955. TWORK.'BOU_METH' = 10;
  956. 'SI' ('EXISTE' PRECED 'NB_BOTH');
  957. TWORK.'BOU_METH'=PRECED.'NB_BOTH';
  958. 'FINSI';
  959. 'FINSI';
  960. *
  961. 'SI' ('EXISTE' PRECED 'MAXITERATION') ;
  962. TWORK.'MAXITERATION' = PRECED.'MAXITERATION';
  963. 'SINON';
  964. 'SI' ((TWORK.'AUTOMATIQUE') 'OU' (TWORK.'PAS_AJUSTE')) ;
  965. TWORK.'MAXITERATION' = 250;
  966. 'FINSI';
  967. 'FINSI';
  968. *
  969. 'SI' (TWORK.'CONVERGENCE_FORCEE' 'OU' TWORK.'RENORMALISATION');
  970. TWORK.'MAXITERATION' = 250;
  971. 'SI' ('EXISTE' PRECED 'MAXDEFOR');
  972. TWORK.'MAXDEFOR' = PRECED.'MAXDEFOR' ;
  973. 'FINSI';
  974. 'SI' TWORK.'CONVERGENCE_FORCEE';
  975. 'SI' ('EXISTE' PRECED 'RELAXATION_NONCONV');
  976. TWORK.'RELAXATION_NONCONV' = PRECED.'RELAXATION_NONCONV' ;
  977. 'FINSI';
  978. 'FINSI';
  979. 'FINSI';
  980. *-----------------------------------------------------------------------
  981. * Note : Il faudrait separer la thermique de la mecanique pour la //.
  982. NBPART = 'VALEUR' 'ASSI' ;
  983. TWORK.'NBPART' = NBPART ;
  984. MPARA = 'MOT' TWORK.'PROCESSEURS' ;
  985. 'SI' ('EXISTE' PRECED 'PROCESSEURS');
  986. MPARA = 'MOT' PRECED.'PROCESSEURS';
  987. 'FINSI';
  988. 'SI' ('&lt;EG' NBPART 1);
  989. MPARA = 'MOT' 'MONO_PROCESSEUR' ;
  990. 'SINON' ;
  991. 'SI' ('EGA' MPARA 'INCONNU') ;
  992. * anciennes valeurs: 2000 200
  993. NBELMIN = 200 ; NBELMM = 400;
  994. toutmo = 'EXTR' TWORK.'MODELE' 'ZONE' ;
  995. IMOD = ('DIME' toutmo) / 2 ;
  996. MINELE = 1000000 ; MAXELE = 0 ;
  997. 'REPE' BOUCMO IMOD ;
  998. BBB = 'NBEL' TOUTMO . (&BOUCMO * 2);
  999. 'SI' (MINELE > BBB); MINELE = BBB; 'FINSI';
  1000. 'SI' (MAXELE < BBB); MAXELE = BBB; 'FINSI';
  1001. 'FIN' BOUCMO ;
  1002. NBTMP = (MINELE / NBELMM) ;
  1003. ** mess 'nbtmp' ' ' nbtmp;
  1004. SI (NBTMP < NBPART); NBPART = NBTMP; 'FINSI';
  1005. TWORK.'NBPART' = NBPART ;
  1006. 'SI' ('>' NBPART 1);
  1007. MINELE=MINELE/NBPART ; MAXELE=MAXELE/NBPART;
  1008. ** mess 'minele maxele' ' ' minele ' ' maxele;
  1009. 'SI' (MINELE > NBELMIN) ;
  1010. MPARA = 'MOT' 'AUTOMATIQUE' ;
  1011. 'SINON';
  1012. 'SI'( (MINELE > NBELMM) 'OU' (MAXELE > NBELMM)) ;
  1013. MPARA = 'MOT' 'COMPORTEMENT' ;
  1014. 'FINSI';
  1015. 'FINSI';
  1016. 'SINON';
  1017. MPARA = 'MOT' 'MONO_PROCESSEUR' ;
  1018. 'FINSI';
  1019. 'FINSI';
  1020. 'FINSI';
  1021. LMPARA = 'MOTS' 'MONO_PROCESSEUR' 'AUTOMATIQUE' 'COMPORTEMENT' ;
  1022. 'SI' ('EXIS' LMPARA MPARA) ;
  1023. TWORK.'PROCESSEURS' = 'MOT' MPARA ;
  1024. 'SINON' ;
  1025. 'MESS' ' *** Cas // non prevu' ; 'ERREUR' 5 ;
  1026. 'FINSI' ;
  1027. ************************************************************************
  1028. * Decortiquer ce que contient le MODELE dans PAS_MODL
  1029. ************************************************************************
  1030. * Oublier l'indice MODEL_COURANT pour re-initialiser la table
  1031. si (exis TWORK 'MODELE_COURANT') ;
  1032. oubl TWORK 'MODELE_COURANT' ;
  1033. fins ;
  1034. *
  1035. * Oublier l'indice 'MO_TOT_PREC' pour le reinitialiser dans UNPAS
  1036. si (exis TWORK 'MO_TOT_PREC') ;
  1037. oubl TWORK 'MO_TOT_PREC' ;
  1038. fins ;
  1039.  
  1040. PAS_MODL PRECED ;
  1041. *
  1042. 'SI' ('NON' ('OU' TWORK.'FOR_MECA' TWORK.'FOR_THER' TWORK.'FOR_DIFF'
  1043. TWORK.'NVSTNL')) ;
  1044. 'ERREUR' 'Le modele ne correspond a aucune formulation valable';
  1045. 'FINSI';
  1046. *
  1047. 'SI' TWORK.'ADAP_MODE' ;
  1048. 'SI' ('OU' TWORK.'FOR_METALLU' TWORK.'PHASE' TWORK.'SOLUBILITE'
  1049. TWORK.'FOR_DIFF' TWORK.'THM1' TWORK.'FOR_MECA') ;
  1050. 'MESS' ' > Adaptation du modele pas disponible pour cette formulation.' ;
  1051. 'ERRE' 251 ;
  1052. 'FINSI' ;
  1053. 'FINSI' ;
  1054. *
  1055. 'SI' (TWORK .'NVSTNL' 'ET' TWORK .'FOR_MECA') ;
  1056. TWORK .'DYNAMIQUE' = VRAI ;
  1057. 'FINSI' ;
  1058. *
  1059. * Noms des inconnues passees a TRANSNON :
  1060. 'SI' ('NEG' TWORK.'MOD_TOT' 'INCONNU') ;
  1061. TWORK.'PRIM_TOT' ='EXTR' TWORK.'MOD_TOT' 'DEPL' ;
  1062. TWORK.'DUAL_TOT' ='EXTR' TWORK.'MOD_TOT' 'FORC' ;
  1063. 'FINS' ;
  1064. *
  1065. * GRANDS_DEPLACEMENTS si CONTACT :
  1066. 'SI' TWORK.'CONTACT' ;
  1067. TWORK.'GRANDS_DEPLACEMENTS' = VRAI;
  1068. 'FINSI';
  1069. *
  1070. *---------- Calcul purement thermique / diffusion ? ou couplage? -------
  1071. 'SI' (TWORK.'FOR_THER' 'OU' TWORK.'FOR_DIFF');
  1072. 'SI' TWORK.'FOR_MECA' ;
  1073. TWORK.'COUPLAGE' = VRAI;
  1074. 'SI' ('EXIS' PRECED 'PROJECTION');
  1075. TWORK.'PROJECTION' = PRECED.'PROJECTION';
  1076. 'FINSI';
  1077. 'FINSI';
  1078. 'FINSI';
  1079. *
  1080. 'SI' TWORK.'POR1';
  1081. TWORK.'MAI_POR' = 'EXTR' TWORK.'MOD_POR' 'MAIL';
  1082. TWORK.'MOT_POR' = 'MOTS' 'FP' 'FPQ' 'FTP' ;
  1083. *
  1084. * poreux+consolidation -> il faut donner la matrice de permeabilite
  1085. * et ne pas etre en dynamique
  1086. 'SI' TWORK.'CONSOLIDATION' ;
  1087. 'SI' TWORK.'DYNAMIQUE' ;
  1088. 'ERREUR' ' On ne peut pas etre en dynamique.' ;
  1089. 'FINSI';
  1090. 'SI' ('NON' ('EXISTE' PRECED 'PERMEABILITE'));
  1091. 'ERREUR' 'Il faut donner la matrice de permeabilite';
  1092. 'SINON';
  1093. TWORK.'PERMEABILITE'=PRECED.'PERMEABILITE';
  1094. 'FINSI';
  1095. 'SI' ('EXISTE' PRECED 'TETA' ) ;
  1096. TWORK.'TETA' = PRECED.'TETA';
  1097. 'FINSI';
  1098. 'FINSI';
  1099. 'FINSI';
  1100. *
  1101. * Verif. CHARGEMENT si formulation CHARGEMENT :
  1102. 'SI' ('EXIS' TWORK 'MOD_CHA') ;
  1103. 'SI' ('NON' ('EXIS' (TWORK.'CHARGEMENT') 'PRES')) ;
  1104. 'ERREUR' 'Il manque la donnee d un chargement de pression';
  1105. 'ERREUR' '-> voir la notice de l operateur CHAR';
  1106. 'FINSI' ;
  1107. 'FINSI' ;
  1108.  
  1109. TWORK.'CHAR_THE' = 'EXISTE' TWORK.'CHARGEMENT' 'T' ;
  1110. TWORK.'CHAR_DEFI' = 'EXISTE' TWORK.'CHARGEMENT' 'DEFI' ;
  1111. TWORK.'CHAR_MATE' = TWORK.'CHAR_MATE' 'OU' ('EXIS' TWORK.'CHARGEMENT' 'MATE') ;
  1112. TWORK.'CHAR_PRES' = 'EXISTE' TWORK 'MOD_PRE' ;
  1113. TWORK.'ITHER' = 'OU' TWORK.'FOR_THER' TWORK.'CHAR_THE' ;
  1114.  
  1115. *------------ existe-t-il un chargement en pilotage indirect ? --------
  1116. 'SI' ('EXISTE' PRECED 'PILOTAGE_INDIRECT') ;
  1117. TWORK.'CHAR_PILO' = VRAI;
  1118.  
  1119. *--------- et des deplacements pilotes
  1120. 'SI' ('EXISTE' PRECED 'DEPLACEMENTS_PILOTES' );
  1121. TWORK.'DEPLACEMENTS_PILOTES' = PRECED.'DEPLACEMENTS_PILOTES' ;
  1122. 'FINSI';
  1123.  
  1124. *--------- et des forces pilotees
  1125. 'SI' ('EXISTE' PRECED 'FORCES_PILOTEES' );
  1126. TWORK.'FORCES_PILOTEES' = PRECED.'FORCES_PILOTEES';
  1127. 'FINSI';
  1128.  
  1129. *--------- et une region de recherche
  1130. 'SI' ('EXISTE' PRECED 'ZONE_DE_PILOTAGE' );
  1131. TWORK.'ZONE_DE_PILOTAGE' = PRECED.'ZONE_DE_PILOTAGE';
  1132. 'FINSI';
  1133.  
  1134. *--------- et le parametre de pilotage
  1135. 'SI' ('EXISTE' PRECED 'PARAMETRE_DE_PILOTAGE' );
  1136. TWORK.'PARAMETRE_DE_PILOTAGE' = PRECED.'PARAMETRE_DE_PILOTAGE';
  1137. 'FINSI';
  1138. *
  1139. *---------- Parametre de pilotage indirect et table de sortie
  1140. 'SI' ('NON' ('EXIS' PRECED 'COEFFICIENT_DE_PILOTAGE'));
  1141. PRECED.'COEFFICIENT_DE_PILOTAGE' = PROG 0. ;
  1142. 'FINSI';
  1143. 'FINSI';
  1144. *
  1145. 'SI' ('EXISTE' PRECED 'CAPACITE_CONSTANTE');
  1146. TWORK.'CAPACONST' = VRAI;
  1147. TWORK.'CAPACITE_CONSTANTE' = PRECED.'CAPACITE_CONSTANTE';
  1148. 'FINSI';
  1149. *
  1150. 'SI' ('EXISTE' PRECED 'CONDUCTIVITE_CONSTANTE');
  1151. TWORK.'CONDCONST' = VRAI;
  1152. TWORK.'CONDUCTIVITE_CONSTANTE' = PRECED.'CONDUCTIVITE_CONSTANTE';
  1153. 'FINSI';
  1154. ************************************************************************
  1155. * Verifications/initialisations propres a la THERMIQUE
  1156. ************************************************************************
  1157. 'SI' TWORK.'FOR_THER' ;
  1158. *
  1159. 'SI' ('OU' TWORK.'PHASE' TWORK.'SOLUBILITE' TWORK.'FOR_DIFF' TWORK.'THM1');
  1160. TWORK.'PROCEDURE_THERMIQUE' = 'MOT' 'NONLINEAIRE';
  1161. 'FINSI';
  1162. *
  1163. MOD_T = TWORK.'MOD_T' ;
  1164. PRIM_T ='EXTR' MOD_T 'DEPL' ;
  1165.  
  1166. 'SI' ('EXIS' PRECED 'TTOL');
  1167. TTOL=PRECED.'TTOL' ;
  1168. 'SI' ('EGA' ('TYPE' TTOL) ('MOT' 'FLOTTANT'));
  1169. TTOL ='MANU' 'CHPO' ('EXTR' MOD_T 'MAIL') PRIM_T ('PROG' ('DIME' PRIM_T) '*' TTOL) 'NATURE' 'DIFFUS';
  1170. 'SINO';
  1171. 'ERRE' 'PAS_DEFA : l''indice ''TTOL'' ne peut etre qu''un ''FLOTTANT''' ;
  1172. 'FINS';
  1173. TWORK.'TTOL' = TTOL ;
  1174. 'FINS';
  1175. TWORK.'PRIM_T' = PRIM_T 'ET' 'LX' ;
  1176. TWORK.'DUAL_T' =('EXTR' MOD_T 'FORC') 'ET' 'FLX' ;
  1177. *
  1178. 'SI'('EXIS' PRECED 'CELSIUS');
  1179. TWORK.'CELSIUS' = PRECED.'CELSIUS';
  1180. TWORK.'TREF' = 273.15 ;
  1181. 'FINSI';
  1182. *
  1183. 'SI' ('EXIS' PRECED 'BLOCAGES_THERMIQUES');
  1184. BLOTHE1 = PRECED.'BLOCAGES_THERMIQUES' ;
  1185. TWORK.'BLOCAGES_THERMIQUES' = BLOTHE1 ;
  1186. TWORK.'CHAR_BLOT' = 'EGA' ('TYPE' BLOTHE1) 'CHARGEME' ;
  1187. 'FINSI';
  1188. *
  1189. 'SI' TWORK.'RAYO' ;
  1190. TWORK.'RAYONNEMENT' = 'PRRA' TWORK.'MOD_RAY';
  1191. 'SI' ('NON' ('EXISTE' (TWORK.'CARACTERISTIQUES') 'EMIS'));
  1192. 'ERREUR' ' Il manque la donnee des facteurs d emissivite';
  1193. 'FINSI';
  1194. 'SI'('EXISTE' PRECED 'CTE_STEFAN_BOLTZMANN') ;
  1195. TWORK.'CTE_STEFAN_BOLTZMANN'=PRECED.'CTE_STEFAN_BOLTZMANN';
  1196. 'SAUT' 1 'LIGN' ;
  1197. 'MESS' 'ATTENTION ! Constante de Stefan-Boltzmann en unites SI';
  1198. 'MESS' ' soit ' (TWORK . 'CTE_STEFAN_BOLTZMANN') ;
  1199. 'FINSI' ;
  1200. 'FINSI';
  1201. *
  1202. 'SI' ('EXIS' PRECED 'RELAXATION_THETA');
  1203. TWORK.'RELAXATION_THETA'=PRECED.'RELAXATION_THETA' ;
  1204. 'FINSI';
  1205. *
  1206. 'SI' ('EXIS' PRECED 'RELAXATION_DUPONT');
  1207. TWORK.'RELAXATION_DUPONT'= PRECED . 'RELAXATION_DUPONT' ;
  1208. 'FINSI';
  1209. *
  1210. 'SI' ('EXISTE' PRECED 'THERMIQUE_AUGMENTEE');
  1211. TWORK.'THERAUGM' = VRAI;
  1212. TWORK.'THERMIQUE_AUGMENTEE' = PRECED.'THERMIQUE_AUGMENTEE';
  1213. RR= PRECED.'THERMIQUE_AUGMENTEE';
  1214. MNOMU = ('EXTR' RR 'MAILLAGE' 'NOMU') 'NBNO';
  1215. MAVMU = ('EXTR' RR 'MAILLAGE' ) 'NBNO';
  1216. 'SI' (MNOMU 'NEG' MAVMU) ;
  1217. 'ERREUR' 'Il ne faut pas de multiplicateur dans THERMIQUE_AUGMENTEE';
  1218. 'FINSI';
  1219. 'FINSI';
  1220. 'FINSI';
  1221. ************************************************************************
  1222. * Verifications/initialisations propres a la DIFFUSION
  1223. ************************************************************************
  1224. 'SI' TWORK.'FOR_DIFF' ;
  1225. *
  1226. MOD_DIF = TWORK.'MOD_DIF' ;
  1227. PRIM_DIF ='EXTR' MOD_DIF 'DEPL' ;
  1228. TWORK.'PRIM_DIF' = PRIM_DIF ;
  1229.  
  1230. 'SI' ('EXIS' PRECED 'CTOL');
  1231. CTOL=PRECED.'CTOL' ;
  1232. 'SI' ('EGA' ('TYPE' CTOL) ('MOT' 'FLOTTANT'));
  1233. CTOL ='MANU' 'CHPO' ('EXTR' MOD_DIF 'MAIL') PRIM_DIF ('PROG' ('DIME' PRIM_DIF) '*' CTOL) 'NATURE' 'DIFFUS';
  1234. 'SINO';
  1235. 'SI' ('EGA' ('TYPE' CTOL) ('MOT' 'CHPOINT'));
  1236. 'SI' ('NON' ('EXIS' ('EXTR' CTOL 'COMP') PRIM_DIF 'ET'));
  1237. 'ERRE' 'CTOL ne contient pas toutes les composantes de la DIFFUSION';
  1238. 'FINS';
  1239. 'SINO';
  1240. 'ERRE' 'PAS_DEFA : l''indice ''CTOL'' ne peut etre qu''un CHPOINT ou un ''FLOTTANT''';
  1241. 'FINS';
  1242. 'FINS';
  1243.  
  1244. 'SI' ('EGA' ('TYPE' TWORK.'TTOL') ('MOT' 'CHPOINT'));
  1245. TWORK.'TTOL' = TWORK.'TTOL' 'ET' CTOL ;
  1246. 'SINO';
  1247. TWORK.'TTOL' = CTOL ;
  1248. 'FINS';
  1249. 'FINS';
  1250. TWORK.'PRIM_DIF' = PRIM_DIF 'ET' 'LX' ;
  1251. TWORK.'DUAL_DIF' =('EXTR' MOD_DIF 'FORC') 'ET' 'FLX' ;
  1252. *
  1253. 'SI' ('EXIS' PRECED 'BLOCAGES_DIFFUSIONS') ;
  1254. BLODIF1 = PRECED.'BLOCAGES_DIFFUSIONS' ;
  1255. TWORK.'BLOCAGES_DIFFUSIONS' = BLODIF1 ;
  1256. TWORK.'CHAR_BLOD' = 'EGA' ('TYPE' BLODIF1) 'CHARGEME' ;
  1257. 'FINSI' ;
  1258. *
  1259. 'SI' ('EXIS' PRECED 'RELAXATION_THETA' );
  1260. TWORK.'RELAXATION_THETA'=PRECED.'RELAXATION_THETA' ;
  1261. 'FINSI';
  1262. *
  1263. 'SI' ('EXIS' PRECED 'RELAXATION_DUPONT');
  1264. TWORK.'RELAXATION_DUPONT'= PRECED . 'RELAXATION_DUPONT' ;
  1265. 'FINSI';
  1266. *
  1267. 'SI' ('EXISTE' PRECED 'DIFFUSION_AUGMENTEE');
  1268. TWORK.'DIFFAUGM' = VRAI;
  1269. TWORK.'DIFFUSION_AUGMENTEE' = PRECED.'DIFFUSION_AUGMENTEE';
  1270. RR= PRECED.'DIFFUSION_AUGMENTEE';
  1271. MNOMU = ('EXTR' RR 'MAILLAGE' 'NOMU') 'NBNO';
  1272. MAVMU = ('EXTR' RR 'MAILLAGE' ) 'NBNO';
  1273. 'SI' (MNOMU 'NEG' MAVMU) ;
  1274. 'ERREUR' 'Il ne faut pas de multiplicateur dans DIFFUSION_AUGMENTEE';
  1275. 'FINSI';
  1276. 'FINSI';
  1277. 'FINSI';
  1278. ************************************************************************
  1279. * Verifications/initialisations propres a la MECANIQUE
  1280. ************************************************************************
  1281. 'SI' ('EXIS' PRECED 'BLOCAGES_MECANIQUES');
  1282. BLOMEC1 = PRECED.'BLOCAGES_MECANIQUES' ;
  1283. TWORK.'BLOCAGES_MECANIQUES' = BLOMEC1 ;
  1284. TWORK.'CHAR_BLOM' = 'EGA' ('TYPE' BLOMEC1) 'CHARGEME' ;
  1285. 'FINSI';
  1286. *
  1287. 'SI' TWORK.'FOR_MECA' ;
  1288. *
  1289. 'SI' ('EXISTE' PRECED 'PRECISION') ;
  1290. TWORK.'PRECFLEX' = PRECED.'PRECISION' ;
  1291. 'FINSI';
  1292. 'SI' ('EXISTE' PRECED 'PRECFLEX') ;
  1293. TWORK.'PRECFLEX' = PRECED.'PRECFLEX';
  1294. 'FINSI';
  1295. 'SI' ('EXISTE' PRECED 'PRECDECHARGE') ;
  1296. TWORK.'PRECDECHARGE' = PRECED.'PRECDECHARGE' ;
  1297. 'FINSI';
  1298. *
  1299. 'SI' ('EXISTE' PRECED 'K_TANGENT');
  1300. TWORK.'K_TANGENT' = PRECED.'K_TANGENT';
  1301. 'FINSI';
  1302. 'SI' ('EXISTE' PRECED 'K_TANGENT_PERT') ;
  1303. TWORK.'K_TANGENT_PERT' = PRECED.'K_TANGENT_PERT' ;
  1304. 'SI' TWORK.'K_TANGENT_PERT' ;
  1305. TWORK.'K_TANGENT' = VRAI ;
  1306. 'FINSI' ;
  1307. 'FINSI' ;
  1308. 'SI' ('EXISTE' PRECED 'K_TANG_PERT_C1') ;
  1309. TWORK.'K_TANG_PERT_C1' = PRECED.'K_TANG_PERT_C1' ;
  1310. 'FINSI' ;
  1311. 'SI' ('EXISTE' PRECED 'K_TANG_PERT_C2') ;
  1312. TWORK.'K_TANG_PERT_C2' = PRECED.'K_TANG_PERT_C2' ;
  1313. 'FINSI' ;
  1314. * Par defaut, C2 = C1/100 (C1 donne ou par defaut 1.D-3)
  1315. 'SI' ('EGA' TWORK.'K_TANG_PERT_C2' 'INCONNU') ;
  1316. TWORK.'K_TANG_PERT_C2' = TWORK.'K_TANG_PERT_C1' / 1.D+02 ;
  1317. 'FINSI' ;
  1318. * Matrice tangente a utiliser pour iteration 0 dans UNPAS
  1319. * Par defaut, matrice tangente precedemment calculee si existe
  1320. 'SI' ('EXISTE' PRECED 'K_TANGENT_ITER0') ;
  1321. TWORK.'K_TANGENT_ITER0' = PRECED.'K_TANGENT_ITER0' ;
  1322. 'FINSI' ;
  1323. * Utilisation matrice tangente symetrisee
  1324. 'SI' ('EXISTE' PRECED 'K_TANGENT_SYME') ;
  1325. TWORK.'K_TANGENT_SYME' = PRECED.'K_TANGENT_SYME' ;
  1326. 'FINSI' ;
  1327. 'SI' ( 'EXISTE' PRECED 'NITER_KTANGENT');
  1328. TWORK.'NITER_KTANGENT' =PRECED.'NITER_KTANGENT' ;
  1329. 'FINSI';
  1330. *----------MAN? ordre de la MAN?
  1331. 'SI' ('EXISTE' PRECED 'MAN' );
  1332. TWORK.'MAN'= PRECED.'MAN';
  1333. 'FINSI';
  1334. 'SI' ( 'EXISTE' PRECED 'ORDRE');
  1335. TWORK.'ORDRE'=PRECED.'ORDRE';
  1336. 'FINSI';
  1337. *-------------y-a-t-il du substepping?-----------
  1338. 'SI' ('EXISTE' PRECED 'SUBSTEPPING');
  1339. TWORK.'SUBSTEPPING'=PRECED.'SUBSTEPPING' ;
  1340. 'FINSI';
  1341. 'SI' ('EXISTE' PRECED 'PRECISINTER');
  1342. TWORK.'PRECISINTER' = PRECED.'PRECISINTER';
  1343. 'FINSI';
  1344. 'SI' ('EXISTE' PRECED 'NITERINTER_MAX');
  1345. TWORK.'NITERINTER_MAX' =PRECED.'NITERINTER_MAX';
  1346. 'FINSI';
  1347. 'SI' ('EXISTE' PRECED 'NMAXSUBSTEPS');
  1348. TWORK.'NMAXSUBSTEPS'=PRECED.'NMAXSUBSTEPS';
  1349. 'FINSI';
  1350. *------------- quelle est l'hypothese de calcul des deformations ?
  1351. 'SI' ('EXISTE' PRECED 'HYPOTHESE_DEFORMATIONS' );
  1352. HYPDEF = MOT PRECED.'HYPOTHESE_DEFORMATIONS';
  1353. 'SI' (('EGA' HYPDEF ('MOT' 'LINEAIRE')) 'OU' ('EGA' HYPDEF ('MOT' 'QUADRATIQUE')) 'OU'
  1354. ('EGA' HYPDEF ('MOT' 'TRUESDELL')) 'OU' ('EGA' HYPDEF ('MOT' 'JAUMANN')) 'OU'
  1355. ('EGA' HYPDEF ('MOT' 'UTILISATEUR')));
  1356. TWORK.'HYPOTHESE_DEFORMATIONS'='MOT' HYPDEF;
  1357. 'SINON';
  1358. 'MESS' 'Les valeurs permises pour HYPOTHESE_DEFORMATIONS sont :';
  1359. 'MESS' 'LINEAIRE, QUADRATIQUE, TRUESDELL, JAUMANN, UTILISATEUR';
  1360. 'ERRE' 308;
  1361. 'FINSI';
  1362. 'FINSI';
  1363. *------------- y-a-t-il du grand deplacement ?
  1364. 'SI' ('EXISTE' PRECED 'GRANDS_DEPLACEMENTS' );
  1365. 'SI' (TWORK.'CONTACT' 'ET' ('NON' PRECED.'GRANDS_DEPLACEMENTS'));
  1366. 'MESS' 'Un calcul avec un modele de CONTACT doit necessairement'
  1367. 'MESS' 'etre realise en GRANDS_DEPLACEMENTS !';
  1368. 'MESS' 'Arret de pasapas';
  1369. 'ERRE' 21;
  1370. 'FINSI';
  1371. TWORK.'GRANDS_DEPLACEMENTS' = PRECED.'GRANDS_DEPLACEMENTS';
  1372. 'FINSI';
  1373. *------------- quelques reglages forces en grands deplacements
  1374. 'SI' TWORK.'GRANDS_DEPLACEMENTS' ;
  1375. TWORK.'RECARI' = VRAI ;
  1376. *
  1377. * PV Quel interet d'avoir les deformations?
  1378. ** par defaut, on sauvegarde des def. totales en grands deplacements
  1379. ** 'SI' ('NON' ('EXIS' PRECED 'MES_SAUVEGARDES'));
  1380. ** TWORK.'TABSAUV'.'DEFTO'= VRAI;
  1381. ** 'FINS';
  1382. * par defaut, on calcule avec une deformation quadratique en grands deplacements
  1383. * mais on laisse faire l'utilisateur s'il souhaite autrement
  1384. 'SI' ('NON' ('EXIS' PRECED 'HYPOTHESE_DEFORMATIONS'));
  1385. TWORK.'HYPOTHESE_DEFORMATIONS'='MOT' 'QUADRATIQUE';
  1386. 'FINSI';
  1387. * par defaut, on active K_SIGMA en grands deplacements si pas de controle de stabilite
  1388. 'SI' ('NON' TWORK.'STABILITE');
  1389. TWORK.'K_SIGMA'=VRAI;
  1390. 'FINSI';
  1391. * par defaut, on active K_SIGMA en grands deplacements si deformations quadratiques
  1392. 'SI' ('EGA' TWORK.'HYPOTHESE_DEFORMATIONS' 'QUADRATIQUE');
  1393. TWORK.'K_SIGMA'=VRAI;
  1394. 'FINSI';
  1395.  
  1396. *------Y-a-t-il des elements dont il faudra reactualiser les caracteristiques?
  1397. MOCA = 'MOTS' 'VECT' 'VX ' 'VY ' 'VZ ' 'VXF ' 'VYF ' 'VZF '
  1398. 'V1X ' 'V1Y ' 'V1Z ' 'V2X ' 'V2Y ' 'V2Z ';
  1399. 'REPETER' BOU_CAR ('DIME' MOCA);
  1400. ITE2 = &BOU_CAR;
  1401. MOT1 = 'EXTR' MOCA ITE2;
  1402. 'SI' ('EXIS' TWORK.'MA_TOT' MOT1);
  1403. TWORK.'ITCAR' = VRAI;
  1404. 'QUITTER' BOU_CAR;
  1405. 'FINSI';
  1406. 'FIN' BOU_CAR;
  1407. 'FINSI';
  1408. * ---------- y-a-t-il une demande sur K_SIGMA ?
  1409. 'SI' ('EXISTE' PRECED 'K_SIGMA');
  1410. TWORK.'K_SIGMA' = PRECED.'K_SIGMA';
  1411. 'FINSI';
  1412. * ---------- y-a-t-il une demande sur LAGRANGIEN ?
  1413. 'SI' ('EXISTE' PRECED 'LAGRANGIEN');
  1414. 'SI' ('EGA' preced.'LAGRANGIEN' 'TOTAL');
  1415. TWORK.'LAG_TOT' = 1;
  1416. 'SINON';
  1417. 'SI' ('EGA' preced.'LAGRANGIEN' 'FIN_PAS');
  1418. TWORK.'LAG_TOT' = 2;
  1419. 'SINON';
  1420. 'SI' (('EGA' preced.'LAGRANGIEN' 'REACTUALISE') 'OU'
  1421. ('EGA' preced.'LAGRANGIEN' 'MI_PAS'));
  1422. TWORK.'LAG_TOT' = 3;
  1423. 'SINON';
  1424. 'ERRE' 'Seules les valeurs TOTAL, REACTUALISE (a MI_PAS) et FIN_PAS sont permises';
  1425. 'FINSI';
  1426. 'FINSI';
  1427. 'FINSI';
  1428. 'FINSI';
  1429. *
  1430. * MOdele TOTal si FOR_MECA :
  1431. MO_TOT = TWORK.'MO_TOT' ;
  1432. *--------- initialisation des comportements d'apres le modele
  1433. 'SI' ('EXISTE' MO_TOT 'MATE' 'PLASTIQUE');
  1434. TWORK.'PLASTIQUE' = VRAI;
  1435. TWORK.'IPLAVI' = VRAI;
  1436. 'FINSI';
  1437. 'SI' ('EXISTE' MO_TOT 'MATE' 'PLASTIQUE_ENDOM');
  1438. TWORK.'PLASTIQUE' = VRAI;
  1439. TWORK.'IPLAVI' = VRAI;
  1440. TWORK.'ENDOMMAGEMENT' = VRAI;
  1441. 'FINSI';
  1442. 'SI' (('EXISTE' MO_TOT 'MATE' 'VISCOPLASTIQUE') 'OU'
  1443. ('EXISTE' MO_TOT 'MATE' 'FLUAGE' ));
  1444. TWORK.'VISCOPLASTIQUE' = VRAI;
  1445. TWORK.'IPLAVI' = VRAI;
  1446. 'FINSI';
  1447. 'SI' ('EXISTE' MO_TOT 'MATE' 'VISCODOMMAGE');
  1448. TWORK.'VISCODOMMAGE' = VRAI;
  1449. TWORK.'IPLAVI' = VRAI;
  1450. 'FINSI';
  1451. 'SI' (('EXISTE' MO_TOT 'MATE' 'ENDOMMAGEMENT') 'OU'
  1452. ('EXISTE' MO_TOT 'MATE' 'ENDOMMAGEABLE'));
  1453. TWORK.'ENDOMMAGEMENT' = VRAI;
  1454. TWORK.'IPLAVI' = VRAI;
  1455. 'FINSI';
  1456. 'SI' ('EXISTE' MO_TOT 'MATE' 'NON_LINEAIRE') ;
  1457. TWORK.'NON_LINEAIRE' = VRAI;
  1458. TWORK.'IPLAVI' = VRAI;
  1459. TWORK.'UTILISATEUR' = 'EXISTE' MO_TOT 'MATE' 'UTILISATEUR' ;
  1460. 'FINSI';
  1461. 'SI' ('EXISTE' MO_TOT 'MATE' 'VISCO_EXTERNE') ;
  1462. TWORK.'VISCO_EXTERNE' = VRAI;
  1463. TWORK.'IPLAVI' = VRAI;
  1464. 'FINSI';
  1465. 'SI' ('EXISTE' MO_TOT 'MATE' 'CERAMIQUE');
  1466. TWORK.'CERAMIQUE' = VRAI;
  1467. TWORK.'IPLAVI' = VRAI;
  1468. 'FINSI';
  1469. 'SI' (('EXISTE' MO_TOT 'MATE' 'MODAL') 'OU'
  1470. ('EXISTE' MO_TOT 'MATE' 'STATIQUE' ));
  1471. TWORK.'MODAL' = VRAI;
  1472. TWORK.'IPLAVI' = VRAI;
  1473. 'FINSI';
  1474. 'SI' ('EXISTE' MO_TOT 'MATE' 'IMPEDANCE');
  1475. TWORK.'IMPEDANCE' = VRAI;
  1476. TWORK.'IPLAVI' = VRAI;
  1477. 'FINSI';
  1478. *
  1479. 'SI' ('OU' TWORK.'CERAMIQUE' TWORK.'ENDOMMAGEMENT' TWORK.'VISCODOMMAGE');
  1480. TWORK.'RECARI' = VRAI;
  1481. TWORK.'LAG_TOT' = 0 ;
  1482. 'FINS';
  1483. *
  1484. *- existe-t-il un chargement de flux neutronique pour le modele mistral
  1485. *- existe-t-il un chargement de densite de fissions pour gatt_monerie & uo2
  1486. *---- si oui on sort si non on le cree a zero
  1487. 'SI' ('EXIS' MO_TOT 'MATE' 'MISTRAL');
  1488. 'SI' ('NON' ('EXISTE' (TWORK.'CHARGEMENT') 'FI ')) ;
  1489. FIZER = 'MANU' 'CHPO' MAI_TOT 1 'FI ' 0. 'NATURE' 'DIFFUS' ;
  1490. TWORK.'CHARGEMENT' = TWORK.'CHARGEMENT' 'ET' ('CHAR' 'FI' FIZER
  1491. ('EVOL' 'MANU' ('PROG' 0. 10.e10 ) ('PROG' 1. 1.)));
  1492. 'FINSI';
  1493. 'FINSI';
  1494. 'SI' (('EXIS' MO_TOT 'MATE' 'UO2') 'OU'
  1495. ('EXIS' MO_TOT 'MATE' 'GATT_MONERIE') ) ;
  1496. 'SI' ('NON' ('EXISTE' (TWORK.'CHARGEMENT') 'DFIS')) ;
  1497. DFISZER = 'MANU' 'CHPO' MAI_TOT 1 'DFIS' 0. 'NATURE' 'DIFFUS' ;
  1498. TWORK.'CHARGEMENT' = TWORK.'CHARGEMENT' 'ET' ('CHAR' 'DFIS' DFISZER
  1499. ('EVOL' 'MANU' ('PROG' 0. 10.e10 ) ('PROG' 1. 1.))) ;
  1500. 'FINSI';
  1501. 'FINSI';
  1502. *
  1503. MAI_TOT = 'EXTR' MO_TOT 'MAIL' ;
  1504. TWORK.'LDEVA' = 'EXTR' TWORK.'MA_TOT' 'DEVA';
  1505. TWORK.'LPAR0' = 'EXTR' MO_TOT 'PARA' ;
  1506. 'SI' ('NEG' 0 ('DIME' TWORK.'LPAR0')) ;
  1507. TWORK.'PARA_EXTE'=VRAI;
  1508. 'FINSI';
  1509. *
  1510. *--------------y-a-t-il une formulation feFP
  1511. 'SI' ('EXISTE' PRECED 'FEFP_FORMULATION');
  1512. TWORK.'FEFP_FORMULATION' = PRECED.'FEFP_FORMULATION';
  1513. 'FINSI';
  1514. 'SI' TWORK.'FEFP_FORMULATION';
  1515. TWORK.'GRANDS_DEPLACEMENTS' = FAUX ;
  1516. TWORK.'K_SIGMA' = VRAI ;
  1517. TWORK.'K_TANGENT' = VRAI ;
  1518. TWORK.'SUBSTEPPING' = FAUX ;
  1519. TWORK.'RECARI' = VRAI ;
  1520. 'FINSI';
  1521. 'SI' ( 'EXISTE' PRECED 'UPDATE_LAGRANGIAN' );
  1522. TWORK.'UPDATE_LAGRANGIAN' = PRECED.'UPDATE_LAGRANGIAN' ;
  1523. 'FINSI';
  1524. 'SI' ('NON' TWORK.'GRANDS_DEPLACEMENTS');
  1525. TWORK.'LAG_TOT' = 0 ;
  1526. 'FINS';
  1527. *--------- y-a-t-il un sauver automatique des resultats ? ---------
  1528. 'SI' ('EXISTE' PRECED 'AUTORESU');
  1529. TWORK.'NAURES' = PRECED . 'AUTORESU';
  1530. 'FINSI';
  1531. *---------- en cas de pas automatique ?
  1532. 'SI' TWORK.'AUTOMATIQUE' ;
  1533. 'SI' ('EXISTE' PRECED 'AUTOCRIT');
  1534. TWORK.'AUTOCRIT'= PRECED.'AUTOCRIT';
  1535. 'FINSI';
  1536. 'SI' ('EXISTE' PRECED 'AUTOPAS');
  1537. TWORK.'AUTOPAS'= PRECED.'AUTOPAS';
  1538. 'FINSI';
  1539. TWORK.'DELTAITER'=TWORK.'MAXITERATION';
  1540. 'FINSI';
  1541. *------ y-a-t-il un nom de variable interne specifique ?
  1542. 'SI' ('EXISTE' PRECED 'MOVA');
  1543. TWORK.'MOVA' =PRECED.'MOVA';
  1544. 'SINON';
  1545. 'SI'(TWORK.'VISCO_EXTERNE' 'OU' TWORK.'UTILISATEUR');
  1546. TWORK.MOVA = 'MOT' 'RIEN';
  1547. 'FINSI';
  1548. 'SI' ('NON' ('EXISTE' ('EXTR' TWORK.'MODELE' 'VARI') 'EPSE'));
  1549. TWORK.'MOVA' = 'MOT' 'RIEN';
  1550. 'FINSI' ;
  1551. 'FINSI';
  1552. *---------- y-a-t-il des elements de rigidite constante ? --------
  1553. 'SI' ( 'EXISTE' PRECED 'RIGIDITE_CONSTANTE');
  1554. TWORK.'RAIDCONST' =VRAI;
  1555. TWORK.'RIGIDITE_CONSTANTE'=PRECED.'RIGIDITE_CONSTANTE';
  1556. RR= PRECED.'RIGIDITE_CONSTANTE';
  1557. MNOMU = ('EXTR' RR 'MAILLAGE' 'NOMU') 'NBNO';
  1558. MAVMU = ('EXTR' RR 'MAILLAGE' ) 'NBNO';
  1559. 'SI' ( MNOMU 'NEG' MAVMU) ;
  1560. 'ERREUR' 'Il ne faut pas de multiplicateur dans RIGIDITE_CONSTANTE';
  1561. 'FINSI';
  1562. 'FINSI';
  1563. *---------- y-a-t-il des elements de rigidite augmentee ? --------
  1564. 'SI' ('EXISTE' PRECED 'RIGIDITE_AUGMENTEE');
  1565. TWORK.'RAIDAUGM' =VRAI;
  1566. TWORK.'RIGIDITE_AUGMENTEE'=PRECED.'RIGIDITE_AUGMENTEE';
  1567. RR= PRECED.'RIGIDITE_AUGMENTEE';
  1568. MNOMU = ('EXTR' RR 'MAILLAGE' 'NOMU') 'NBNO';
  1569. MAVMU = ('EXTR' RR 'MAILLAGE' ) 'NBNO';
  1570. 'SI' ( MNOMU 'NEG' MAVMU) ;
  1571. 'ERREUR' 'Il ne faut pas de multiplicateur dans RIGIDITE_AUGMENTEE';
  1572. 'FINSI';
  1573. 'SINON';
  1574. 'SI' ('EXISTE' PRECED 'AUGMENTATION_AUTOMATIQUE');
  1575. TWORK.'RIGIDITE_AUGMENTEE'='MASSE' TWORK.'MODELE' TWORK.'CARACTERISTIQUES';
  1576. 'FINSI';
  1577. 'FINSI';
  1578.  
  1579. 'SI' ('EXISTE' PRECED 'AUGMENTATION_AUTOMATIQUE');
  1580. 'SI' PRECED.'AUGMENTATION_AUTOMATIQUE';
  1581. TWORK.'AUTOAUGM' = VRAI;
  1582. TWORK.'STABILITE' = VRAI ;
  1583. *** 'SI' ('NON' TWORK.'RAIDAUGM');
  1584. *** 'ERREUR' 'il faut donner la matrice d augmentation dans RIGIDITE_AUGMENTEE';
  1585. *** 'FINSI';
  1586. 'FINSI';
  1587. 'FINSI';
  1588. *---------- y-a-t-il des elements de masse constante ? ---------
  1589. 'SI' ('EXISTE' PRECED 'MASSE_CONSTANTE');
  1590. TWORK.'MASSE_CONSTANTE'=PRECED.'MASSE_CONSTANTE';
  1591. TWORK.'MASSCONST'=VRAI;
  1592. 'FINSI';
  1593. *---------- y-a-t-il un sous_increment ? ---------
  1594. 'SI' ('EXISTE' PRECED 'SOUS_INCREMENT');
  1595. LOGERR = FAUX ;
  1596. 'SI' ('EXIS' TWORK 'DYNAMIQUE') ;
  1597. 'SI' TWORK.'DYNAMIQUE' ;
  1598. TWORK.'SOUS_INCREMENT' = PRECED.'SOUS_INCREMENT';
  1599. 'SINON' ;
  1600. LOGERR = VRAI ;
  1601. 'FINSI' ;
  1602. 'SINON' ;
  1603. LOGERR = VRAI ;
  1604. 'FINSI' ;
  1605. 'SI' LOGERR ;
  1606. 'MESS' ' Option SOUS_INCREMENT utilisable QUE en DYNAMIQUE ';
  1607. 'MESS' ' Arret de Cast3M';
  1608. 'ERREUR' 5 ;
  1609. 'FINSI' ;
  1610. 'FINSI';
  1611. *------------------- Cas du non local :
  1612. 'SI' TWORK.'NLOC' ;
  1613. 'SI' ( 'EXISTE' PRECED 'CONN' );
  1614. 'MESS' 'On garde les connectivites dans TAB CONN';
  1615. TWORK.'CONN'=PRECED . 'CONN' ;
  1616. 'SINON';
  1617. 'SI' ('EGA' (TWORK.'NON_LOCAL') 'HELM' );
  1618. 'MESS' 'Pas besoin de la connectivite pour Helmholtz';
  1619. 'SINON';
  1620. 'MESS' 'Calcul des connectivites en mode normal.';
  1621. TWORK.'CONN'='CONN' TWORK.'NLOC_MODL'
  1622. ('REDU' TWORK.'MA_TOT' TWORK.'NLOC_MODL') 'NORMAL' ;
  1623. 'FINSI' ;
  1624. 'FINSI' ;
  1625. 'FINSI' ;
  1626. 'FINSI';
  1627. TWORK.'CHARGEMENT_I' = TWORK.'CHARGEMENT';
  1628. ************************************************************************
  1629. * Recapitulatif des options choisies
  1630. ************************************************************************
  1631. 'SAUTER' 1 'LIGNE';
  1632. 'SI' TWORK.'FOR_MECA' ;
  1633. 'SI' TWORK.'FOR_THER';
  1634. 'MESS' 'Couplage THERMIQUE-MECANIQUE';
  1635. 'SINON';
  1636. 'MESS' 'Calcul MECANIQUE';
  1637. 'FINSI';
  1638. 'MESS' ' *** Hypothese calcul des deformations :' ' ' TWORK.'HYPOTHESE_DEFORMATIONS' ' ***';
  1639. 'SI' ('NEG' TWORK.'PREDICTEUR' 'INCONNU');
  1640. 'MESS' ' *** Predicteur :' ' ' TWORK.'PREDICTEUR' ' ***' ;
  1641. 'FINSI';
  1642. 'SI' TWORK.'K_SIGMA';
  1643. 'MESS' ' *** K_SIGMA *** ';
  1644. 'FINSI';
  1645. 'SI' TWORK.'GRANDS_DEPLACEMENTS';
  1646. 'SI' (TWORK.'LAG_TOT' 'EGA' 1) ;
  1647. 'MESS' ' *** Calcul en lagrangien total *** ';
  1648. 'FINSI';
  1649. 'SI' (TWORK.'LAG_TOT' 'EGA' 2) ;
  1650. 'MESS' ' *** Calcul en lagrangien fin pas *** ';
  1651. 'FINSI';
  1652. 'SI' (TWORK.'LAG_TOT' 'EGA' 3) ;
  1653. 'MESS' ' *** Calcul en configuration mi-pas *** ';
  1654. 'FINSI';
  1655. 'FINSI';
  1656. 'SI' TWORK.'STABILITE';
  1657. 'MESS' ' *** Controle de la stabilite *** ';
  1658. 'FINSI';
  1659. 'SI' TWORK.'LINESEARCH';
  1660. 'MESS' ' *** Linesearch *** ';
  1661. 'FINSI';
  1662. 'SI' (non TWORK.'INITIALISATION');
  1663. 'MESS' ' *** Initialisation a partir du pas precedent interdite *** ';
  1664. 'FINSI';
  1665. 'SI' TWORK.'CONVERGENCE_MONOTONE' ;
  1666. 'MESS' ' *** Convergence monotone imposee *** ';
  1667. 'FINSI';
  1668. 'SI' TWORK.'RENORMALISATION' ;
  1669. 'MESS' ' *** Renormalisation des iteres *** ';
  1670. 'FINSI';
  1671. 'SI' TWORK.'POR1';
  1672. 'MESS' ' *** POREUX ***';
  1673. 'FINSI';
  1674. 'SI' TWORK.'DYNAMIQUE' ;
  1675. 'MESS' ' *** DYNAMIQUE PAS A PAS ***';
  1676. 'FINSI' ;
  1677. 'SI' TWORK.'FREQUENTIEL' ;
  1678. 'MESS' ' *** FREQUENTIEL PAS A PAS ***' ;
  1679. 'FINSI' ;
  1680. 'SI' TWORK.'LIAISON_PERSISTANTE' ;
  1681. 'MESS' ' *** LIAISON PERSISTANTE ***';
  1682. 'FINSI' ;
  1683. 'SI' TWORK.'CONSOLIDATION' ;
  1684. 'MESS' ' *** CONSOLIDATION ***';
  1685. 'FINSI' ;
  1686. 'SI' TWORK.'PLASTIQUE' ;
  1687. 'MESS' ' *** PLASTICITE ***';
  1688. 'FINSI';
  1689. 'SI' TWORK.'VISCOPLASTIQUE' ;
  1690. 'MESS' ' *** VISCO - PLASTICITE ***';
  1691. 'FINSI' ;
  1692. 'SI' TWORK.'NON_LINEAIRE';
  1693. 'SI' TWORK.'UTILISATEUR' ;
  1694. 'MESS' ' *** MODELE DE COMPORTEMENT NON LINEAIRE EXTERNE ***';
  1695. 'SINON';
  1696. 'MESS' ' *** ELASTICITE NON_LINEAIRE ***';
  1697. 'FINSI';
  1698. 'FINSI' ;
  1699. 'SI' TWORK.'VISCO_EXTERNE';
  1700. 'MESS' ' *** VISCO - PLASTICITE, MODELE EXTERNE ***';
  1701. 'FINSI' ;
  1702. 'SI' TWORK.'CHAR_THE';
  1703. 'MESS' ' *** CHARGEMENT THERMIQUE ***';
  1704. 'FINSI';
  1705. 'SI' TWORK.'CHAR_DEFI';
  1706. 'MESS' ' *** CHARGEMENT PAR DES DEFORMATIONS ***';
  1707. 'FINSI';
  1708. 'SI' TWORK.'CHAR_PRES';
  1709. 'MESS' ' *** CHARGEMENT PAR UNE PRESSION SUIVEUSE ***';
  1710. 'FINSI';
  1711. 'SI' TWORK.'CHAR_PILO';
  1712. 'MESS' ' *** CHARGEMENT PAR PILOTAGE INDIRECT ***';
  1713. 'FINSI';
  1714. 'SI' TWORK.'PARA_EXTE';
  1715. 'MESS' ' *** LE MODELE DEPEND DE PARAMETRES EXTERNES ***';
  1716. 'FINSI';
  1717. 'SI' TWORK.'GRANDS_DEPLACEMENTS' ;
  1718. 'MESS' ' *** GRANDS DEPLACEMENTS ***';
  1719. 'SI' ('NEG' TWORK.'HYPOTHESE_DEFORMATIONS' 'QUADRATIQUE');
  1720. 'MESS' ' ATTENTION : l''hypothese de deformations choisie est' ' ' PRECED.'HYPOTHESE_DEFORMATIONS';
  1721. 'MESS' ' on recommande plutot l''hypothese QUADRATIQUE';
  1722. 'FINSI';
  1723. 'FINSI';
  1724. 'SI' TWORK.'CONVERGENCE_FORCEE' ;
  1725. 'MESS' ' *** CONVERGENCE FORCEE ***';
  1726. 'FINSI';
  1727. 'SI' TWORK.'ENDOMMAGEMENT' ;
  1728. 'MESS' ' *** PLASTICITE + ENDOMMAGEMENT ***';
  1729. 'FINSI';
  1730. 'SI' TWORK.'VISCODOMMAGE' ;
  1731. 'MESS' ' *** VISCO-PLASTICITE + ENDOMMAGEMENT ***';
  1732. 'FINSI';
  1733. 'SI' TWORK.'CERAMIQUE' ;
  1734. 'MESS' ' ***CERAMIQUE FLUAGE + ENDOMMAGEMENT ***';
  1735. 'MESS' ' *** +OTTOSEN ***';
  1736. 'FINSI';
  1737. * 'SI' IUO2;
  1738. * 'MESS' ' *** VISCO-PLASTICITE + OTTOSEN ***';
  1739. * 'FINSI';
  1740. 'SI' TWORK.'NLOC' ;
  1741. 'MESS' ' *** EN NON-LOCAL *** ' ;
  1742. 'FINSI';
  1743. 'SI' TWORK.'CONTACT';
  1744. 'MESS' ' *** CONTACT ***';
  1745. 'FINSI';
  1746. 'SI' (TWORK.'SOUS_INCREMENT' > 1);
  1747. 'MESS' ' *** SOUS_INCREMENT :'TWORK.SOUS_INCREMENT;
  1748. 'FINSI';
  1749. 'SI' TWORK.'CAFROTTE';
  1750. 'MESS' ' *** FROTTEMENT ***';
  1751. 'FINSI';
  1752. 'SI' TWORK.'K_TANGENT' ;
  1753. 'SI' TWORK.'K_TANGENT_PERT' ;
  1754. 'MESS' ' *** MATRICE TANGENTE PAR PERTURBATION ***' ;
  1755. 'SINON' ;
  1756. 'MESS' ' *** MATRICE TANGENTE (COHERENTE) ***' ;
  1757. 'FINSI' ;
  1758. 'MESS' ' MATRICE EVALUEE TOUTES LES' TWORK.'NITER_KTANGENT'
  1759. 'ITERATIONS' ;
  1760. 'SI' TWORK.'K_TANGENT_SYME' ;
  1761. 'MESS' ' PARTIE SYMETRIQUE DE LA MATRICE TANGENTE UTILISEE';
  1762. 'FINSI' ;
  1763. 'FINSI';
  1764. 'SI' TWORK.'SUBSTEPPING';
  1765. 'MESS' ' *** SUBSTEPPING *** NUM_MAXI_SUBSTEPS ='TWORK.'NMAXSUBSTEPS' ;
  1766. 'MESS' ' *** SUBSTEPPING *** NUM_ITER_INTERNAS ='TWORK.'NITERINTER_MAX' ;
  1767. 'FINSI';
  1768. 'SI' TWORK.'UPDATE_LAGRANGIAN';
  1769. 'MESS' ' *** UPDATE LAGRANGIAN ***' ;
  1770. 'FINSI';
  1771. 'SI' TWORK.'FEFP_FORMULATION';
  1772. 'MESS' ' *** FORMULATION FeFp ***' ;
  1773. 'FINSI';
  1774. 'FINSI';
  1775. *
  1776. 'SI' TWORK.'FOR_THER';
  1777. 'MESS' 'Calcul THERMIQUE ';
  1778. 'FINSI';
  1779. *
  1780. 'SI' TWORK.'NVSTNL' ;
  1781. 'MESS' 'Calcul NAVIER-STOKES NLIN' ;
  1782. 'FINSI' ;
  1783. 'SAUTER' 1 'LIGNE';
  1784. 'SI' ('EGA' TWORK.'PROCESSEURS' 'MONO_PROCESSEUR') ;
  1785. 'MESS' ' *** Pas de parallelisation ***' ;
  1786. 'SINON' ;
  1787. 'SI' ('EGA' TWORK.'PROCESSEURS' 'COMPORTEMENT') ;
  1788. 'MESS' ' *** Parallelisation du comportement sur ' nbpart ' assistants ***';
  1789. 'SINON' ;
  1790. 'SI' ('EGA' TWORK.'PROCESSEURS' 'AUTOMATIQUE') ;
  1791. 'MESS' ' *** Parallelisation automatique sur ' nbpart ' assistants ***' ;
  1792. 'FINSI' ;
  1793. 'FINSI' ;
  1794. 'FINSI' ;
  1795. 'SAUTER' 1 'LIGNE';
  1796. 'FINPROC' ;
  1797.  
  1798.  
  1799.  
  1800.  
  1801.  
  1802.  

© Cast3M 2003 - Tous droits réservés.
Mentions légales