Télécharger waam2.dgibi

Retour à la liste

Numérotation des lignes :

  1. * fichier waam2.dgibi
  2. * section : thermique conduction convection mecanique plastique
  3. *----------------------------------------------------------------------*
  4. * W A A M 2 . D G I B I *
  5. *----------------------------------------------------------------------*
  6. * Objet :
  7. * -------
  8. *
  9. * Exemple de simulation thermomecanique d'un depot de matiere WAAM.
  10. * L'exemple simule la realisation d'un "mur" sur la tranche d'une tole
  11. * en acier inox (donnees 316L issues de la litterature, ref. fournie).
  12. *
  13. * On modelise la conduction, la convection avec le milieu ambiant
  14. * et la source de chaleur selon une distribution gaussienne.
  15. *
  16. * Le comportement mecanique est elastoplastique avec un ecrouissage
  17. * isotrope.
  18. *
  19. * L'apport de matiere est defini a l'aide d'un chargement de nom MODE
  20. * qui decrit l'evolution du modele au cours du temps. Un chargement de
  21. * nom MATE definit celle de ses caracteristiques.
  22. *
  23. * La modelisation fait appel aux procedures SOUDAGE et WAAM pour
  24. * definir la sequence de soudage et la mailler.
  25. *
  26. * On resout la thermique et la mecanique separemment, par deux appels
  27. * successifs a la procedure PASAPAS.
  28. *
  29. * Ce cas-test sert de cas de validation de la prise en compte de la
  30. * FUSION du materiau dans le calcul du comportement. Pour cela, on verifie
  31. * que les variables internes sont nulles aux pts d'integration ou T > Tfus
  32. * a l'aide de la procedure PERSO1.
  33. *
  34. * Il sert egalement de cas de validation de l'initialisation du
  35. * comportement mecanique lors d'un pas d'apport de matiere. Pour cela,
  36. * on sauvegarde la deformation initiale a chaque pas d'apport de matiere
  37. * (indice DEFORMATIONS_APPORT en sortie de PASAPAS) et on verifie que
  38. * la loi de Hooke est satisfaite. On doit avoir :
  39. *
  40. * Sig = C : (EpsT - EpsP - EpsTh - EpsAp)
  41. *
  42. * Sig : contrainte
  43. * C : tenseur de Hooke
  44. * EpsT : deformation totale, derivee du deplacement
  45. * EpsP : deformation plastique
  46. * EpsTh : deformation thermique
  47. * EpsAp : deformation initiale de l'apport de matiere
  48. *
  49. * Enfin, ce cas-test illustre egalement la donnee du chargement TAPP,
  50. * definissant la temperature initiale de l'apport de matiere, calculee
  51. * pour satisfaire la conservation de l'energie au cours de l'analyse
  52. * thermique.
  53. *
  54. * Description :
  55. * -------------
  56. *
  57. * Type de calcul : Thermique, Mecanique
  58. * Mode de calcul : 3D
  59. * Type d'element : CUB8
  60. * Chargement : Source de chaleur, Convection, Apport de matiere
  61. *
  62. *----------------------------------------------------------------------*
  63. *
  64. opti dime 3 elem cub8 ;
  65.  
  66. * icomplet = vrai : simulation de 10 passes de couches WAAM
  67. * icomplet = faux : 10 premiers pas de temps
  68. * ivalid : mettre a vrai pour verifier mise a zero EPIN et VARINT avec PERSO1
  69. icomplet = faux ;
  70. ivalid = vrai ;
  71.  
  72. * ig1 : mettre a vrai pour affichages
  73. ig1 = faux ;
  74. *opti trac psc eptr 5 ;
  75. ig1 = ig1 ou (ega (vale trac) 'PSC') ;
  76.  
  77. *----------------------- Parametres du probleme -----------------------*
  78.  
  79. * Parametres geometrie :
  80. * lw1 : longueur faite en WAAM
  81. * ls1 : longueur support
  82. * hs1 : hauteur support
  83. * e1 : epaisseur de la plaque
  84. lw1 = 80.e-3 ;
  85. ls1 = 124.e-3 ;
  86. hs1 = 50.e-3 ;
  87. e1 = 6.e-3 ;
  88.  
  89. * Position thermocouples :
  90. * Bord deport WAAM initial en (0 0 0) :
  91. TC1 = 40.e-3 0 -3.e-3 ;
  92. TC2 = 40.e-3 0 -5.e-3 ;
  93. TC3 = 0.e-3 0 -25.e-3 ;
  94. TC4 = 80.e-3 0 -10.e-3 ;
  95.  
  96. * Parametres apport de chaleur :
  97. * Us1 : tension electrique de soudage (V) 1ere couche
  98. * Us2 : tension electrique de soudage (V) couches suivantes
  99. * Is1 : intensite electrique soudage (A) 1ere couche
  100. * Is2 : intensite electrique soudage (A) couches suivantes
  101. * Vs1 : vitesse de soudage (m/s)
  102. * Eta1 : rendement de la source
  103. * R0 : rayon de la distribution Gaussienne
  104. Us1 = 15.0 ;
  105. Us2 = 13.0 ;
  106. Is1 = 120. ;
  107. Is2 = 100. ;
  108. Vs1 = 0.30 / 60. ;
  109. Eta1 = 0.8 ;
  110. R0 = 3.e-3 ;
  111.  
  112. * Parametres apport de matiere :
  113. * dfil1 : diametre file (m)
  114. * vfil1 : vitesse defilement fil (m/s) 1ere passe
  115. * vfil2 : vitesse defilement fil (m/s) autres passes
  116. dfil1 = 1.2e-3 ;
  117. vfil1 = 3.2 / 60. ;
  118. vfil2 = 2.5 / 60. ;
  119.  
  120. * Parametres sequence soudage :
  121. * dtini1 : delai initial avant debut deplacement torche
  122. * delai1 : delai entre 2 passes de WAAM
  123. * nbpass1: nombre de passes
  124. dtini1 = 0.8 ;
  125. delai1 = 30. ;
  126. nbpass1 = 10 ;
  127.  
  128. * Parametres conditions thermiques initiales et aux limites :
  129. * Tini1 : temperature initiale (degC)
  130. * Te1 : temperature de convection (degC)
  131. * h1 : coefficient d'echange convectif (W/m2)
  132. Tini1 = 20. ;
  133. Te1 = 20. ;
  134. h1 = 20. ;
  135.  
  136. *-------------------------- Proprietes 316 L --------------------------*
  137. * Ref. :
  138. * Camille Cambon, Issam Bendaoud, Sebastien Rouquette, Fabien Soulie.
  139. * "Influence of the first weld bead on strain and stress states in wire+arc additive manufacturing”.
  140. * The 12th International Seminar ”Numerical Analysis of Weldability",
  141. * Institute for Materials Science, Joining and Forming (IMAT),Sep 2018, Seggau, Austria.
  142. * hal-01954354 https://hal.archives-ouvertes.fr/hal-01954354
  143. *
  144. * rho1 : masse volumique (kg/m3)
  145. * Tfus1 : temperature de changement de phase solide-liquide (degC)
  146. * Qlat1 : chaleur latente de fusion de l'acier (J/m3)
  147. rho1 = 7760. ;
  148. Tfus1 = 1450. ;
  149. Qlat1 = 2.e9 ;
  150.  
  151. * k1 : conductivite thermique (W/m/K) en fonction de la temperature
  152. lt1 = prog 20. 100. pas 100. 1500. ;
  153. lk1 = prog 14. 15.2 16.6 17.9 19. 20.6 21.8 23.1 24.3 26. 27.3 28.6 29.9 45. 60. 60. ;
  154. k1 = evol vert manu 'T' lt1 'K' lk1 ;
  155. si ig1 ;
  156. dess k1 titr 'Conductivite thermique 316L (W/m/K)' ;
  157. fins ;
  158.  
  159. * Cp1 : capacite thermique massique (J/m3) en fonction de la temperature
  160. * On derive l'enthalpie :
  161. lt1 = prog 0. pas 100. 1500. ;
  162. lh1 = prog 0.983 1.36 1.76 2.19 2.62 3.06 3.51 3.96 4.43 4.92 5.42 5.92 6.44 6.97 9.51 ;
  163. lh2 = prog 1.36 1.76 2.19 2.62 3.06 3.51 3.96 4.43 4.92 5.42 5.92 6.44 6.97 9.51 10.1 ;
  164. dhdt1 = (lh2 - lh1) / 100. ;
  165. lc0 = dhdt1 * 1.e9 / rho1 ;
  166. lt0 = prog 50. pas 100. 1450. ;
  167. cp0 = evol manu 'T' lt0 'C' lc0 ;
  168. idx0 = posi (maxi lc0) dans lc0 ;
  169. lc2 = lc0 enle idx0 ;
  170. lt2 = lt0 enle idx0 ;
  171. cp2 = evol oran manu 'T' lt2 'C' lc2 ;
  172. cp1 = cp2 ;
  173. si ig1 ;
  174. tleg1 = table ;
  175. tleg1 . titre = table ;
  176. tleg1 . titre . 1 = mot 'Cp derivee publi.' ;
  177. tleg1 . titre . 2 = mot 'Cp utilisee' ;
  178. dess (cp0 et cp1) lege tleg1 titr ' Capacite thermique massique 316L (J/m3)' ;
  179. fins ;
  180.  
  181. * Proprietes mecaniques 316L (dependantes de T) :
  182. * nu1 : coefficient de Poisson
  183. nu1 = 0.3 ;
  184.  
  185. * Ym1 : module de Young (Pa)
  186. lt1 = prog 20. 100. pas 100. 1200. ;
  187. lym1 = prog 197000. 191500. 184000. 176500. 168000. 160000. 151500. 142500. 130000. 108000. 81500. 32000. 7400. ;
  188. lym1 = 1.e6 * lym1 ;
  189. ym1 = evol vert manu T lt1 youn lym1 ;
  190.  
  191. * Sy1 : limite d'elasticite (Pa)
  192. lt1 = prog 20. pas 100. 1400. ;
  193. lsy1 = prog 287. 237. 198. 172. 157. 151. 145. 136. 127. 115. 79. 38. 24. 18. 2. ;
  194. lsy1 = 1.e6 * lsy1 ;
  195. sy1 = evol vert manu T lt1 SIGY lsy1 ;
  196.  
  197. * Alph1 : dilatation thermique (/K)
  198. lt1 = prog 20. 100. 300. 400. 600. 700. 800. 1000. 1400. ;
  199. lalph1 = prog 1.55 1.60 1.71 1.75 1.84 1.87 1.90 1.94 1.96 ;
  200. lalph1 = 1.e-5 * lalph1 ;
  201. alph1 = evol vert manu T lt1 ALPH lalph1 ;
  202.  
  203. * Hx : module d'ecrouissage cinematique (Pa)
  204. lt1 = prog 20. 700. pas 100. 1300. ;
  205. lh1 = prog 2400. 2400. 2350. 1500. 800. 725. 150. 10. ;
  206. lh1 = 1.e6 * lh1 ;
  207. Hx1 = evol vert manu T lt1 H lh1 ;
  208.  
  209. * Courbes d'ecrouissage :
  210. nb1 = dime lt1 ;
  211. lep1 = prog 0. 1. ;
  212. nua1 = vide nuage ;
  213. repe b1 nb1 ;
  214. ti1 = extr lt1 &b1 ;
  215. syi1 = ipol sy1 ti1 ;
  216. hi1 = ipol Hx1 ti1 ;
  217. lmsi1 = prog syi1 (syi1+hi1) ;
  218. ecroi1 = evol oran manu eps lep1 sig lmsi1 ;
  219. ecroi1 = ecroi1 coul &b1 ;
  220. nua1 = nua1 et (nuag comp T ti1 comp ECRO ecroi1) ;
  221. fin b1 ;
  222.  
  223. tleg1 = legende nua1 T format '(F6.0)' ;
  224. si ig1 ;
  225. dess ym1 titr ' Module de Young (Pa)' ;
  226. dess sy1 titr ' Limite elastique (Pa)' ;
  227. dess alph1 titr ' Coef. dilatation thermique (/K)' ;
  228. dess (nua1 * 1.e-6 ecro) xbor 0. 0.2 ybor 0. 500.
  229. titr 'Courbes d ecrouissage a differentes temperatures (MPa)' lege tleg1 ;
  230. fins ;
  231.  
  232. *------------------- Sequence de soudage / Maillage -------------------*
  233.  
  234. * Parametres discretisation apport de matiere :
  235. * xp1 : "pas" de discetisation de l'apport de matiere en espace (m)
  236. * dz1 : increment WAAM selon (O,z) / hauteur cordon
  237. * debi1 : debit volumique de fil 1ere passe
  238. * debi2 : debit volumique de fil autres passes
  239. xp1 = e1 / 2. ;
  240. debi1 = 0.25 * dfil1 * dfil1 * pi * vfil1 ;
  241. debi2 = 0.25 * dfil1 * dfil1 * pi * vfil2 ;
  242. dz1 = debi1 / e1 / Vs1 ;
  243. dz2 = debi2 / e1 / Vs1 ;
  244.  
  245. * Parametres modele source Gaussienne 3D :
  246. Qtot1 = Eta1 * Us1 * Is1 ;
  247. Qtot2 = Eta1 * Us2 * Is2 ;
  248. *Qtot1 = Qtot1 - (Qlat1 * e1 * dz1 * Vs1) ;
  249. *Qtot2 = Qtot2 - (Qlat1 * e1 * dz2 * Vs1) ;
  250. *list Qtot1 ;
  251. *list Qtot2 ;
  252. Rg1 = ((2. / 3.) ** 0.5) * R0 ;
  253.  
  254. * Parametre geometrie / trajectoire :
  255. e1s2 = 0.5 * e1 ;
  256. dz1s2 = 0.5 * dz1 ;
  257.  
  258. * table SOUDAGE :
  259. tso1 = tabl ;
  260. tso1.vitesse_de_soudage = Vs1 ;
  261. tso1.puissance_de_soudage = Qtot2 ;
  262. tso1.diametre_de_fil = dfil1 ;
  263. tso1.vitesse_de_fil = vfil2 ;
  264. tso1.point_de_depart = (0 e1s2 dz1) ;
  265. tso1.largeur_de_passe = e1 ;
  266.  
  267. * Défintion de la sequence de soudage :
  268. * Repetition sequence de 2 passes en AR :
  269. si (nbpass1 mult 2) ;
  270. nb1 = nbpass1 / 2 ;
  271. sino ;
  272. nb1 = (nbpass1 - 1) / 2 ;
  273. fins ;
  274. soudage tso1 point dtini1 puis Qtot1 debi debi1 ;
  275. repe b1 nb1 ;
  276. si (&b1 ega 1) ;
  277. soudage tso1 passe droi (lw1 0 0) puis Qtot1 debi debi1 ;
  278. soudage tso1 depla couche debi debi2 pause delai1 ;
  279. sino ;
  280. soudage tso1 passe droi (lw1 0 0) ;
  281. soudage tso1 depla couche pause delai1 ;
  282. fins ;
  283. soudage tso1 passe droi ((-1.*lw1) 0 0) ;
  284. soudage tso1 depla couche pause delai1 ;
  285. fin b1 ;
  286. si ((nbpass1-1) mult 2) ;
  287. soudage tso1 passe droi (lw1 0 0) ;
  288. fins ;
  289. soudage tso1 point 60. puis 0. debi 0. ;
  290.  
  291. si ig1 ;
  292. trac tso1.trajectoire titr 'trajectoire depot WAAM mur' ;
  293. dess tso1.evolution_deplacement titr 'evolution deplacement depot WAAM mur' ;
  294. dess tso1.evolution_puissance titr 'evolution puissance thermique depot WAAM mur' ;
  295. dess tso1.evolution_debit titr 'evolution debit apport de matiere depot WAAM mur' ;
  296. fins ;
  297.  
  298. * Maillage du Mur :
  299. * On teste la donnee d'un LISTREEL pour la discretisation en espcace
  300. ne1 = 5 ;
  301. twa1 = waam tso1 mail pas (prog 2.e-3 xp1 4.e-3 xp1 2.e-3 xp1) dens 1.e-3 'TEMP' 0.1 ;
  302. elim twa1.maillage 1.e-6 ;
  303. mur1 = twa1.maillage coul vert ;
  304.  
  305. si ig1 ;
  306. trac cach mur1 titr ' Maillage global du mur' ;
  307. tmai1 = twa1.evolution_maillage.maillage ;
  308. waam twa1 visu cach ((tso1.trajectoire) plus (0 0 1.e-5)) ;
  309. fins ;
  310.  
  311. * Maillage du support sous-jacent :
  312. me1 = -1. * e1 ;
  313. mdz1 = -1. * dz1 ;
  314. zmin1 = (mur1 coor 3) mini ;
  315. pz0 = (mur1 coor 3) poin infe (zmin1 + 1.e-5) ;
  316. sz0 = (enve mur1) elem appu stri pz0 ;
  317. sup1 = sz0 volu tran ne1 (0 0 me1) ;
  318.  
  319. xmin1 = (sup1 coor 1) mini ;
  320. px0 = (sup1 coor 1) poin infe (xmin1 + 1.e-5) ;
  321. px1 = (sup1 coor 1) poin supe (xmin1 + lw1 - 1.e-5) ;
  322. sx0 = (enve sup1) elem appu stri px0 ;
  323. sx1 = (enve sup1) elem appu stri px1 ;
  324. sup1 = sup1 et (sx0 volu tran ne1 (me1 0 0)) et (sx1 volu tran ne1 (e1 0 0)) ;
  325. sup1 = sup1 coul gris ;
  326.  
  327. dx1 = (ls1 - lw1) * 0.5 - e1 ;
  328. me1 = -1. * e1 ;
  329. xmin2 = xmin1 + me1 ;
  330. zmin2 = zmin1 + me1 ;
  331. p1 = sup1 poin proc (xmin2 0 zmin1) ;
  332. p2 = sup1 poin proc (xmin2 0 zmin2) ;
  333. p3 = sup1 poin proc ((xmin1 + lw1 + e1) 0 zmin2) ;
  334. p4 = sup1 poin proc ((xmin1 + lw1 + e1) 0 zmin1) ;
  335. p5 = p4 plus (dx1 0 0) ;
  336. p6 = p5 moin (0 0 hs1) ;
  337. p7 = p6 moin (ls1 0 0) ;
  338. p8 = p7 plus (0 0 hs1) ;
  339. de1 = 0.5 * e1 ;
  340. de2 = 6.2e-3 ;
  341. cs2 = (p5 droi p6 dini de1 dfin de2) et
  342. (p6 droi p7 dini de2 dfin de2) et
  343. (p7 droi p8 dini de2 dfin de1) et
  344. (p8 droi p1 dini de1 dfin de1) et
  345. (p1 droi p2 dini de1 dfin de1) et
  346. (p2 droi p3 dini de1 dfin de1) et
  347. (p3 droi p4 dini de1 dfin de1) et
  348. (p4 droi p5 dini de1 dfin de1) ;
  349. fs2 = surf cs2 plan ;
  350. sup2 = fs2 volu tran (0 e1 0) 2 ;
  351. sup2 = sup2 coul turq ;
  352.  
  353. sup0 = sup1 et sup2 ;
  354.  
  355. mail1 = sup0 et mur1 ;
  356. si ig1 ;
  357. mot1 = chai 'Maillage total "Mur WAAM" et support :' (nbno mail1) ;
  358. mot1 = chai mot1 ' /' (nbel mail1) ' noeuds/elem.' ;
  359. trac face mail1 titr mot1 ;
  360. fins ;
  361.  
  362. *------------- Accrochage DDL thermique maillage support --------------*
  363.  
  364. * Relation cinematique DDL mecanique entre maillages non conformes :
  365. clu1 = sup1 rela accro sup2 ;
  366.  
  367. * Encastrement bord plaque support :
  368. ptx0 = (sup0 coor 1) poin infe ((sup0 coor 1 mini) + 1.e-5) ;
  369. clu2 = bloq depl ptx0 ;
  370.  
  371. * Relation cinematique DDL thermique entre maillages non conformes :
  372. clt1 = sup1 rela accro sup2 (mots 'T') ;
  373. clt2 = (TC1 et TC2 et TC3 et TC4) rela accro sup0 (mots 'T') ;
  374.  
  375. * Surface interface maillages support non-conformes :
  376. pinte1 = clt1 extr mail nomu ;
  377. sinte1 = (enve sup0) elem appu stri pinte1 ;
  378.  
  379. si ig1 ;
  380. trac cach (-1 -1 0.5) ((ptx0 coul roug) et mail1) titr 'Points encastrement support (rouge)' ;
  381. fins ;
  382.  
  383. *--------------------- Modele / Caracteristique -----------------------*
  384.  
  385. * Conduction / Convection :
  386. mod1 = mode sup0 thermique ;
  387. mat1 = mate mod1 rho rho1 k k1 'C' cp1 'TINI' Tini1 ;
  388. mod1b = mode mur1 thermique ;
  389. mat1b = mate mod1b rho rho1 k k1 'C' cp1 'TINI' Tini1 ;
  390. mod1 = mod1 et mod1b ;
  391. mat1 = mat1 et mat1b ;
  392.  
  393. * Source thermique :
  394. evqt1 = tso1.evolution_puissance ;
  395. evxs1 = tso1.evolution_deplacement ;
  396. chxs1 = tso1.trajectoire coor curv ;
  397. cgxs1 = char traj chxs1 evxs1 ;
  398. mod3 = mode mail1 thermique source gaussienne ;
  399. mat3 = mate mod3 qtot evqt1 orig cgxs1 rgau Rg1 ;
  400.  
  401. * Mecanique :
  402. mod4 = mode mail1 mecanique elastique plastique isotrope fusion cons 316L ;
  403. mat4 = mate mod4 youn ym1 nu nu1 alph alph1 ecro nua1 tref tini1 talp tini1 tfus tfus1 ;
  404.  
  405. * Tables d'evolution des modeles et caracteristiques :
  406. ttps1 = twa1.evolution_maillage.temps ;
  407. tmai1 = twa1.evolution_maillage.maillage ;
  408. nb1 = dime ttps1 ;
  409. ltps1 = prog ;
  410. lmod1 = enum ;
  411. lmod2 = enum ;
  412. lmod3 = enum ;
  413. lmod4 = enum ;
  414. lmat1 = enum ;
  415. lmat2 = enum ;
  416. lmat3 = enum ;
  417. lmat4 = enum ;
  418. repe b1 nb1 ;
  419. tps1 = ttps1 . (&b1 - 1) ;
  420. ltps1 = ltps1 et tps1 ;
  421. geoi1 = tmai1 . (&b1 - 1) ;
  422. geoi1 = geoi1 et sup0 ;
  423. modi1 = redu mod1 geoi1 ;
  424. mati1 = redu mat1 modi1 ;
  425. lmod1 = lmod1 et modi1 ;
  426. lmat1 = lmat1 et mati1 ;
  427. sconv1 = (enve geoi1) diff sinte1 ;
  428. modi2 = mode sconv1 thermique convection ;
  429. mati2 = mate modi2 'H' h1 'TC' Te1 ;
  430. lmod2 = lmod2 et modi2 ;
  431. lmat2 = lmat2 et mati2 ;
  432. modi3 = redu mod3 geoi1 ;
  433. mati3 = redu mat3 modi3 ;
  434. lmod3 = lmod3 et modi3 ;
  435. lmat3 = lmat3 et mati3 ;
  436. modi4 = redu mod4 geoi1 ;
  437. mati4 = redu mat4 modi4 ;
  438. lmod4 = lmod4 et modi4 ;
  439. lmat4 = lmat4 et mati4 ;
  440. fin b1 ;
  441.  
  442.  
  443. * Chargements MODE / MATE :
  444. cgmod1 = char mode ltps1 lmod1 ;
  445. cgmod2 = char mode ltps1 lmod2 ;
  446. cgmod3 = char mode ltps1 lmod3 ;
  447. cgmod4 = char mode ltps1 lmod4 ;
  448. cgmod0 = cgmod1 et cgmod2 et cgmod3 ;
  449.  
  450. cgmat1 = char mate ltps1 lmat1 ;
  451. cgmat2 = char mate ltps1 lmat2 ;
  452. cgmat3 = char mate ltps1 lmat3 ;
  453. cgmat4 = char mate ltps1 lmat4 ;
  454. cgmat0 = cgmat1 et cgmat2 et cgmat3 ;
  455.  
  456. *----------------------------------------------------------------------*
  457. * THERMIQUE *
  458. *----------------------------------------------------------------------*
  459. *
  460. * Liste des temps de calcul :
  461. ltca0 = twa1.temps_calcules ;
  462. si (non icomplet) ;
  463. ltca1 = ltca0 extr (lect 1 pas 1 15) ;
  464. sino ;
  465. ltca1 = ltca0 ;
  466. fins ;
  467.  
  468. *-------------------- Resolution Thermique PASAPAS --------------------*
  469.  
  470. * Table PASAPAS :
  471. tab1 = table ;
  472. tab1.modele = cgmod0 ;
  473. tab1.caracteristiques = cgmat0 ;
  474. tab1.blocages_thermiques = clt1 et clt2 ;
  475. tab1.temps_calcules = ltca1 ;
  476.  
  477.  
  478. pasapas tab1 ;
  479.  
  480. * Affichage temps de calcul :
  481. duree1 = temp horl ;
  482. duree1 = (duree1 / 1000) ;
  483. dmin1 = (duree1 / 60) ;
  484. dsec1 = duree1 - (60 * dmin1) ;
  485. mot1 = chai '***** DUREE DU CALCUL THERMIQUE (s) :' dmin1 ' min' dsec1 ' s' ;
  486. mess mot1 ;
  487.  
  488. *----------------------------------------------------------------------*
  489. * MECANIQUE *
  490. *----------------------------------------------------------------------*
  491. *
  492. *-------------------------- Procedure PERSO1 --------------------------*
  493. * Verification mise a zero variables internes et def. plastique si T>Tfusion :
  494. debp perso1 tu1*table ;
  495.  
  496. si (tu1.perso1_appel ega 1) ;
  497. quit perso1 ;
  498. fins ;
  499.  
  500. tfus1 = tu1.data_perso1.tfusio ;
  501. cht2 = (tu1.wtable.tet2) exco 'T' 'T' ;
  502. mod1 = tu1.wtable.modele extr form mecanique ;
  503. chamt2 = chan cham mod1 cht2 stresses ;
  504. si ((maxi chamt2) >EG tfus1) ;
  505. mess ' ****** PERSO1 : verif. option FUSION modele' ;
  506. masq1 = chamt2 masq supe tfus1 ;
  507. masq1 = masq1 nomc 'SCAL' ;
  508. * Var. Internes :
  509. var0 = tu1.estimation.variables_internes redu mod1 ;
  510. lmc0 = extr var0 comp ;
  511. lmc1 = mots (dime lmc0) * 'SCAL' ;
  512. var1 = masq1 * var0 lmc1 lmc0 lmc0 ;
  513. err1 = 0. ;
  514. err1 = (maxi abs var1) + err1 ;
  515. si (err1 > ((vale prec)*10.)) ; erre 308 ; fins ;
  516. *trac (0 1 1) 13 var1 mod1 titr ' MAJ var. inter.' ;
  517. fins ;
  518.  
  519. finp ;
  520. *-------------------- Resolution Mecanique PASAPAS --------------------*
  521.  
  522. * Chargement thermique :
  523. cgt1 = char 'T' (tab1.temps) (tab1.temperatures) ;
  524.  
  525. * Chargement TAPP (uniquement si modele de type chargement).
  526. * temperature apport de matiere a chaque pas d'apport pour calcul def. thermique initiale :
  527. cgt2 = char 'TAPP' (tab1.temps) (tab1.temperatures_apport) ;
  528.  
  529. * Table PASAPAS :
  530. tab2 = table ;
  531. tab2.modele = cgmod4 ;
  532. tab2.caracteristiques = cgmat4 ;
  533. tab2.chargement = cgt1 et cgt2 ;
  534. tab2.blocages_mecaniques = clu1 et clu2 ;
  535. tab2.temps_calcules = ltca1 ;
  536. tab2.processeurs = mot comportement ;
  537. tab2.mes_sauvegardes = table ;
  538. tab2.mes_sauvegardes.defin = vrai ;
  539. tab2.mes_sauvegardes.defap = vrai ;
  540.  
  541. si icomplet ;
  542. ntca1 = dime ltca1 ;
  543. tab2.temps_sauvegardes = ltca1 extr (lect 50 pas 50 (ntca1 / 50 * 50) ntca1) ;
  544. opti sauv 'waam2.sauv' ;
  545. fins ;
  546.  
  547. tab2.procedure_perso1 = ivalid ;
  548. tab2.data_perso1 = table ;
  549. tab2.data_perso1.tfusio = tfus1 ;
  550.  
  551.  
  552. pasapas tab2 ;
  553.  
  554. * Affichage temps de calcul :
  555. duree1 = temp horl ;
  556. duree1 = (duree1 / 1000) ;
  557. dmin1 = (duree1 / 60) ;
  558. dsec1 = duree1 - (60 * dmin1) ;
  559. mot1 = chai '***** DUREE DU CALCUL MECANIQUE (s) :' dmin1 ' min' dsec1 ' s' ;
  560. mess mot1 ;
  561.  
  562. *------------------------ Petit post-traitement -----------------------*
  563.  
  564. * Animation contrainte de von Mises :
  565.  
  566. si ig1 ;
  567. vtra1 = vale trac ;
  568. si (ega vtra1 'PSC') ;
  569. opti ftra 'Contrainte_Waam2_Anim.ps' ;
  570. fins ;
  571.  
  572. if1 = dime tab2.temps ;
  573. def1 = vide deforme ;
  574. liso1 = prog 25. pas 25. 350. ;
  575. mbox1 = boite mail1 ;
  576. repe b1 if1 ;
  577. i1 = &b1-1 ;
  578. modi1 = tab2.modeles.i1 ;
  579. maili1 = (extr modi1 form mecanique) extr mail ;
  580. depi1 = tab2.deplacements.i1 ;
  581. sigi1 = tab2.contraintes.i1 ;
  582. sigi1 = 1.e-6 * sigi1 ;
  583. sigi1 = vmis modi1 sigi1 ;
  584. defoi1 = defo maili1 depi1 5. sigi1 modi1 ;
  585. def1 = def1 et defoi1 ;
  586. si (ega vtra1 'PSC') ;
  587. mot1 = chai format '(F6.1)' 'Contrainte de von Mises (MPa) au temps (s) :' (tab2.temps.i1) ;
  588. trac (1 -1.2 1) defoi1 liso1 titr mot1 boit mbox1 ;
  589. fins ;
  590. fin b1 ;
  591. si (neg vtra1 'PSC') ;
  592. trac (1 -1.2 1) anim def1 liso1 ;
  593. fins ;
  594. fins ;
  595.  
  596. si icomplet ; sauv ; fins ;
  597.  
  598. *------------- Verif. comportement avec apport de matiere -------------*
  599. si (non ig1) ; i1 = 14 ; fins ;
  600. modi1 = tab2.modeles.i1 ;
  601. sigi1 = tab2.contraintes.i1 ;
  602. depi1 = tab2.deplacements.i1 ;
  603. epsi1 = epsi modi1 depi1 ;
  604. eini1 = tab2.deformations_inelastiques.i1 ;
  605.  
  606. tpsi1 = tab2.temps.i1 ;
  607. chti1 = tire cgt1 t tpsi1 ;
  608. mati1 = tire cgmat4 mate tpsi1 ;
  609. mati1 = vari nuag modi1 mati1 chti1 ;
  610. ethi1 = epth modi1 mati1 chti1 ;
  611.  
  612. epli1 = tab2.DEFORMATIONS_APPORT.i1 ;
  613.  
  614. epei1 = epsi1 - (eini1 exco (extr modi1 dein) (extr modi1 defo)) - ethi1 - epli1 ;
  615. sigxx = elas mati1 modi1 epei1 ;
  616. sigerr1 = (sigxx - sigi1) / (maxi abs sigi1) ;
  617.  
  618. si ig1 ;
  619. trac sigerr1 modi1 titr 'Erreur relative calcul champ de contrainte / ref.' ;
  620. fins ;
  621.  
  622. * Test calcul comportement avec apport de matiere :
  623. si ((maxi abs sigerr1) > 1.e-10) ;
  624. erre 5 ;
  625. fins ;
  626.  
  627. *------------------ F I N W A A M 2 . D G I B I -----------------*
  628. fin ;
  629.  
  630.  
  631.  
  632.  
  633.  
  634.  
  635.  

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