Télécharger waam1.dgibi

Retour à la liste

Numérotation des lignes :

  1. * fichier waam1.dgibi
  2. * section : thermique conduction convection
  3. *----------------------------------------------------------------------*
  4. * W A A M 1 . D G I B I *
  5. *----------------------------------------------------------------------*
  6. * Objet :
  7. * -------
  8. *
  9. * Exemple de simulation thermique d'un depot de matiere par 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. * L'apport de matiere est defini a l'aide d'un chargement de nom MODE
  17. * qui decrit l'evolution du modele au cours du temps. Un chargement de
  18. * nom MATE definit celle de ses caracteristiques.
  19. *
  20. * La modelisation fait appel aux procedures SOUDAGE et WAAM pour
  21. * definir la sequence de soudage et la mailler.
  22. *
  23. * Description :
  24. * -------------
  25. *
  26. * Type de calcul : Thermique Transitoire
  27. * Mode de calcul : 3D
  28. * Type d'element : CUB8
  29. * Chargement : Source de chaleur, Convection, Apport de matiere
  30. *
  31. *----------------------------------------------------------------------*
  32. *
  33. opti dime 3 elem cub8 ;
  34.  
  35. icomplet = faux ;
  36.  
  37. ig1 = faux ;
  38. *opti trac psc eptr 5 ;
  39. ig1 = ig1 ou (ega (vale trac) 'PSC') ;
  40.  
  41. *----------------------- Parametres du probleme -----------------------*
  42.  
  43. * Parametres geometrie :
  44. * lw1 : longueur faite en WAAM
  45. * ls1 : longueur support
  46. * hs1 : hauteur support
  47. * e1 : epaisseur de la plaque
  48. lw1 = 80.e-3 ;
  49. ls1 = 124.e-3 ;
  50. hs1 = 50.e-3 ;
  51. e1 = 6.e-3 ;
  52.  
  53. * Position thermocouples :
  54. * Bord deport WAAM initial en (0 0 0) :
  55. TC1 = 40.e-3 0 -3.e-3 ;
  56. TC2 = 40.e-3 0 -5.e-3 ;
  57. TC3 = 0.e-3 0 -25.e-3 ;
  58. TC4 = 80.e-3 0 -10.e-3 ;
  59.  
  60. * Parametres apport de chaleur :
  61. * Us1 : tension electrique de soudage (V) 1ere couche
  62. * Us2 : tension electrique de soudage (V) couches suivantes
  63. * Is1 : intensite electrique soudage (A) 1ere couche
  64. * Is2 : intensite electrique soudage (A) couches suivantes
  65. * Vs1 : vitesse de soudage (m/s)
  66. * Eta1 : rendement de la source
  67. * R0 : rayon de la distribution Gaussienne
  68. Us1 = 15.0 ;
  69. Us2 = 13.0 ;
  70. Is1 = 120. ;
  71. Is2 = 100. ;
  72. Vs1 = 0.30 / 60. ;
  73. Eta1 = 0.8 ;
  74. R0 = 3.e-3 ;
  75.  
  76. * Parametres apport de matiere :
  77. * dfil1 : diametre file (m)
  78. * vfil1 : vitesse defilement fil (m/s) 1ere passe
  79. * vfil2 : vitesse defilement fil (m/s) autres passes
  80. dfil1 = 1.2e-3 ;
  81. vfil1 = 3.2 / 60. ;
  82. vfil2 = 2.5 / 60. ;
  83.  
  84. * Parametres sequence soudage :
  85. * dtini1 : delai initial avant debut deplacement torche
  86. * delai1 : delai entre 2 passes de WAAM
  87. * nbpass1: nombre de passes
  88. dtini1 = 0.8 ;
  89. delai1 = 30. ;
  90. nbpass1 = 10 ;
  91.  
  92. * Parametres conditions thermiques initiales et aux limites :
  93. * Tini1 : temperature initiale (degC)
  94. * Te1 : temperature de convection (degC)
  95. * h1 : coefficient d'echange convectif (W/m2)
  96. Tini1 = 20. ;
  97. Te1 = 20. ;
  98. h1 = 20. ;
  99.  
  100. *-------------------------- Proprietes 316 L --------------------------*
  101. * Ref. :
  102. * Camille Cambon, Issam Bendaoud, Sebastien Rouquette, Fabien Soulie.
  103. * “Influence of the first weld bead on strain and stress states in wire+arc additive manufacturing”.
  104. * The 12th International Seminar ”Numerical Analysis of Weldability”,
  105. * Institute for Materials Science, Joining and Forming (IMAT),Sep 2018, Seggau, Austria.
  106. * hal-01954354 https://hal.archives-ouvertes.fr/hal-01954354
  107. *
  108. * Donnees fournies par la procedure BIBLIO :
  109. t316L = biblio 316L refe 2 ;
  110.  
  111. * rho1 : masse volumique (kg/m3) (pas dans ref. biblio)
  112. rho1 = 7760. ;
  113. * Tfus1 : temperature de changement de phase solide-liquide (degC)
  114. * Qlat1 : chaleur latente de fusion de l'acier (J/m3)
  115. * k1 : conductivite thermique (W/m/K) en fonction de la temperature
  116. Tfus1 = t316L.tfus ;
  117. Qlat1 = t316L.qlat ;
  118. k1 = t316L.k ;
  119. si ig1 ;
  120. dess k1 titr 'Conductivite thermique 316L (W/m/K)' ;
  121. fins ;
  122.  
  123. * Cp1 : capacite thermique massique (J/m3) en fonction de la temperature
  124. * On la derive de l'enthalpie :
  125. enth1 = t316L.enth ;
  126. lh0 = extr enth1 ordo ;
  127. lh1 = lh0 enle (dime lh0) ;
  128. lh2 = lh0 enle 1 ;
  129. dhdt1 = (lh2 - lh1) / 100. ;
  130. lc0 = dhdt1 / rho1 ;
  131. lt0 = prog 50. pas 100. 1450. ;
  132. cp0 = evol manu 'T' lt0 'C' lc0 ;
  133. idx0 = posi (maxi lc0) dans lc0 ;
  134. lc2 = lc0 enle idx0 ;
  135. lt2 = lt0 enle idx0 ;
  136. cp2 = evol oran manu 'T' lt2 'C' lc2 ;
  137. cp1 = cp2 ;
  138. si ig1 ;
  139. tleg1 = table ;
  140. tleg1 . titre = table ;
  141. tleg1 . titre . 1 = 'Cp derivee publi.' ;
  142. tleg1 . titre . 2 = 'Cp utilisee' ;
  143. dess (cp0 et cp1) titr ' Capacite thermique massique 316L (J/m3)' lege tleg1 ;
  144. fins ;
  145.  
  146. *------------------- Sequence de soudage / Maillage -------------------*
  147.  
  148. * Parametres discretisation apport de matiere :
  149. * xp1 : "pas" de discetisation de l'apport de matiere en espace (m)
  150. * dz1 : increment WAAM selon (O,z) / hauteur cordon
  151. * debi1 : debit volumique de fil 1ere passe
  152. * debi2 : debit volumique de fil autres passes
  153. xp1 = e1 / 2. ;
  154. debi1 = 0.25 * dfil1 * dfil1 * pi * vfil1 ;
  155. debi2 = 0.25 * dfil1 * dfil1 * pi * vfil2 ;
  156. dz1 = debi1 / e1 / Vs1 ;
  157. dz2 = debi2 / e1 / Vs1 ;
  158.  
  159. * Parametres modele source Gaussienne 3D :
  160. Qtot1 = Eta1 * Us1 * Is1 ;
  161. Qtot2 = Eta1 * Us2 * Is2 ;
  162. *Qtot1 = Qtot1 - (Qlat1 * e1 * dz1 * Vs1) ;
  163. *Qtot2 = Qtot2 - (Qlat1 * e1 * dz2 * Vs1) ;
  164. *list Qtot1 ;
  165. *list Qtot2 ;
  166. Rg1 = ((2. / 3.) ** 0.5) * R0 ;
  167.  
  168. * Parametre geometrie / trajectoire :
  169. e1s2 = 0.5 * e1 ;
  170. dz1s2 = 0.5 * dz1 ;
  171.  
  172. * table SOUDAGE :
  173. tso1 = tabl ;
  174. tso1.vitesse_de_soudage = Vs1 ;
  175. tso1.puissance_de_soudage = Qtot2 ;
  176. tso1.orientation_soudure = (0 0 1) ;
  177. tso1.diametre_de_fil = dfil1 ;
  178. tso1.vitesse_de_fil = vfil2 ;
  179. tso1.point_de_depart = (0 e1s2 dz1) ;
  180. tso1.largeur_de_passe = e1 ;
  181.  
  182. * Défintion de la sequence de soudage :
  183. * Repetition sequence de 2 passes en AR :
  184. si (nbpass1 mult 2) ;
  185. nb1 = nbpass1 / 2 ;
  186. sino ;
  187. nb1 = (nbpass1 - 1) / 2 ;
  188. fins ;
  189. soudage tso1 point dtini1 puis Qtot1 debi debi1 ;
  190. repe b1 nb1 ;
  191. si (&b1 ega 1) ;
  192. soudage tso1 passe droi (lw1 0 0) puis Qtot1 debi debi1 ;
  193. soudage tso1 depla couche debi debi2 pause delai1 ;
  194. sino ;
  195. soudage tso1 passe droi (lw1 0 0) ;
  196. soudage tso1 depla couche pause delai1 ;
  197. fins ;
  198. soudage tso1 passe droi ((-1.*lw1) 0 0) ;
  199. soudage tso1 depla couche pause delai1 ;
  200. mess 'hello' ;
  201. fin b1 ;
  202. si ((nbpass1-1) mult 2) ;
  203. soudage tso1 passe droi (lw1 0 0) ;
  204. fins ;
  205. soudage tso1 point 90. puis 0. debi 0. ;
  206.  
  207. si ig1 ;
  208. trac tso1.trajectoire titr 'trajectoire depot WAAM mur' ;
  209. dess tso1.evolution_deplacement titr 'evolution deplacement depot WAAM mur' ;
  210. dess tso1.evolution_puissance titr 'evolution puissance thermique depot WAAM mur' ;
  211. dess tso1.evolution_debit titr 'evolution debit apport de matiere depot WAAM mur' ;
  212. fins ;
  213.  
  214. * Maillage du Mur :
  215. tab2 = waam tso1 mail pas xp1 larg e1 dens 1.e-3 'TEMP' 0.1 ;
  216. elim tab2.maillage 1.e-5 ;
  217. mur1 = tab2.maillage coul vert ;
  218.  
  219. si ig1 ;
  220. trac cach mur1 titr ' Maillage global du mur' ;
  221. tmai1 = tab2.evolution_maillage.maillage ;
  222. waam tab2 visu cach ((tso1.trajectoire) plus (0 0 1.e-5)) ;
  223. fins ;
  224.  
  225. * Maillage du support sous-jacent :
  226. ne1 = 5 ;
  227. me1 = -1. * e1 ;
  228. mdz1 = -1. * dz1 ;
  229. zmin1 = (mur1 coor 3) mini ;
  230. pz0 = (mur1 coor 3) poin infe (zmin1 + 1.e-5) ;
  231. sz0 = (enve mur1) elem appu stri pz0 ;
  232. sup1 = sz0 volu tran ne1 (0 0 me1) ;
  233.  
  234. xmin1 = (sup1 coor 1) mini ;
  235. px0 = (sup1 coor 1) poin infe (xmin1 + 1.e-5) ;
  236. px1 = (sup1 coor 1) poin supe (xmin1 + lw1 - 1.e-5) ;
  237. sx0 = (enve sup1) elem appu stri px0 ;
  238. sx1 = (enve sup1) elem appu stri px1 ;
  239. sup1 = sup1 et (sx0 volu tran ne1 (me1 0 0)) et (sx1 volu tran ne1 (e1 0 0)) ;
  240. sup1 = sup1 coul gris ;
  241.  
  242. dx1 = (ls1 - lw1) * 0.5 - e1 ;
  243. me1 = -1. * e1 ;
  244. xmin2 = xmin1 + me1 ;
  245. zmin2 = zmin1 + me1 ;
  246. p1 = sup1 poin proc (xmin2 0 zmin1) ;
  247. p2 = sup1 poin proc (xmin2 0 zmin2) ;
  248. p3 = sup1 poin proc ((xmin1 + lw1 + e1) 0 zmin2) ;
  249. p4 = sup1 poin proc ((xmin1 + lw1 + e1) 0 zmin1) ;
  250. p5 = p4 plus (dx1 0 0) ;
  251. p6 = p5 moin (0 0 hs1) ;
  252. p7 = p6 moin (ls1 0 0) ;
  253. p8 = p7 plus (0 0 hs1) ;
  254. de1 = 0.5 * e1 ;
  255. de2 = 6.2e-3 ;
  256. cs2 = (p5 droi p6 dini de1 dfin de2) et
  257. (p6 droi p7 dini de2 dfin de2) et
  258. (p7 droi p8 dini de2 dfin de1) et
  259. (p8 droi p1 dini de1 dfin de1) et
  260. (p1 droi p2 dini de1 dfin de1) et
  261. (p2 droi p3 dini de1 dfin de1) et
  262. (p3 droi p4 dini de1 dfin de1) et
  263. (p4 droi p5 dini de1 dfin de1) ;
  264. fs2 = surf cs2 plan ;
  265. sup2 = fs2 volu tran (0 e1 0) 2 ;
  266. sup2 = sup2 coul turq ;
  267.  
  268. sup0 = sup1 et sup2 ;
  269.  
  270. mail1 = sup0 et mur1 ;
  271. si ig1 ;
  272. mot1 = chai 'Maillage total "Mur WAAM" et support :' (nbno mail1) ;
  273. mot1 = chai mot1 ' /' (nbel mail1) ' noeuds/elem.' ;
  274. trac face mail1 titr mot1 ;
  275. fins ;
  276.  
  277. *------------- Accrochage DDL thermique maillage support --------------*
  278. clt1 = sup1 rela accro sup2 (mots 'T') ;
  279. clt2 = (TC1 et TC2 et TC3 et TC4) rela accro sup0 (mots 'T') ;
  280.  
  281. * Surface interface maillages support non-conformes :
  282. pinte1 = clt1 extr mail nomu ;
  283. sinte1 = (enve sup0) elem appu stri pinte1 ;
  284.  
  285. *--------------------- Modele / Caracteristique -----------------------*
  286.  
  287. * Conduction / Convection :
  288. mod1 = mode mail1 thermique ;
  289. mat1 = mate mod1 rho rho1 k k1 'C' cp1 'TINI' Tini1 ;
  290.  
  291. * Source thermique :
  292. evqt1 = tso1.evolution_puissance ;
  293. evxs1 = tso1.evolution_deplacement ;
  294. chxs1 = tso1.trajectoire coor curv ;
  295. cgxs1 = char traj chxs1 evxs1 ;
  296. mod3 = mode mail1 thermique source gaussienne ;
  297. mat3 = mate mod3 qtot evqt1 orig cgxs1 rgau Rg1 ;
  298.  
  299. * Tables d'evolution des modeles et caracteristiques :
  300. ttps1 = tab2.evolution_maillage.temps ;
  301. tmai1 = tab2.evolution_maillage.maillage ;
  302. nb1 = dime ttps1 ;
  303. ltps1 = prog ;
  304. lmod1 = enum ;
  305. lmod2 = enum ;
  306. lmod3 = enum ;
  307. lmat1 = enum ;
  308. lmat2 = enum ;
  309. lmat3 = enum ;
  310. repe b1 nb1 ;
  311. tps1 = ttps1 . (&b1 - 1) ;
  312. ltps1 = ltps1 et tps1 ;
  313. geoi1 = tmai1 . (&b1 - 1) ;
  314. geoi1 = geoi1 et sup0 ;
  315. modi1 = redu mod1 geoi1 ;
  316. mati1 = redu mat1 modi1 ;
  317. lmod1 = lmod1 et modi1 ;
  318. lmat1 = lmat1 et mati1 ;
  319. sconv1 = (enve geoi1) diff sinte1 ;
  320. modi2 = mode sconv1 thermique convection ;
  321. mati2 = mate modi2 'H' h1 'TC' Te1 ;
  322. lmod2 = lmod2 et modi2 ;
  323. lmat2 = lmat2 et mati2 ;
  324. modi3 = redu mod3 geoi1 ;
  325. mati3 = redu mat3 modi3 ;
  326. lmod3 = lmod3 et modi3 ;
  327. lmat3 = lmat3 et mati3 ;
  328. fin b1 ;
  329.  
  330. * Chargements MODE / MATE :
  331. cgmod1 = char mode ltps1 lmod1 ;
  332. cgmod2 = char mode ltps1 lmod2 ;
  333. cgmod3 = char mode ltps1 lmod3 ;
  334. cgmod0 = cgmod1 et cgmod2 et cgmod3 ;
  335.  
  336. cgmat1 = char mate ltps1 lmat1 ;
  337. cgmat2 = char mate ltps1 lmat2 ;
  338. cgmat3 = char mate ltps1 lmat3 ;
  339. cgmat0 = cgmat1 et cgmat2 et cgmat3 ;
  340.  
  341. * Temps calcules :
  342. ltca0 = tab2.temps_calcules ;
  343. si icomplet ;
  344. ltca1 = ltca0 ;
  345. sino ;
  346. ltca1 = ltca0 extr (lect 1 pas 1 21) ;
  347. fins ;
  348.  
  349. * Rendement effectif de la source :
  350. eta0 = rendsour cgmod3 cgmat3 ltca1 moye ;
  351. eveta0 = rendsour cgmod3 cgmat3 ltca1 ;
  352.  
  353. si ig1 ;
  354. mot1 = chai format '(F6.3)' 'Rendement de la source de chaleur en fonction du temp. Moy. =' eta0 ;
  355. eveta0 = eveta0 coul oran ;
  356. dess eveta0 titr mot1 ;
  357. fins ;
  358.  
  359. *------------------------- Resolution PASAPAS -------------------------*
  360.  
  361. tab1 = table ;
  362. tab1.modele = cgmod0 ;
  363. tab1.caracteristiques = cgmat0 ;
  364. tab1.blocages_thermiques = clt1 et clt2 ;
  365. tab1.temps_calcules = ltca1 ;
  366.  
  367.  
  368. * ajout d'une reprise :
  369. tab1.temps_calcules = ltca1 extr (lect 1 pas 1 11) ;
  370. pasapas tab1 ;
  371.  
  372. tab1.temps_calcules = ltca1 ;
  373. pasapas tab1 ;
  374.  
  375.  
  376. * Affichage temps de calcul :
  377. duree1 = temp horl ;
  378. duree1 = (duree1 / 1000) ;
  379. dmin1 = (duree1 / 60) ;
  380. dsec1 = duree1 - (60 * dmin1) ;
  381. mot1 = chai '***** DUREE DU CALCUL (s) :' dmin1 ' min' dsec1 ' s' ;
  382. mess mot1 ;
  383.  
  384. si icomplet ;
  385. opti sauv 'waam1.sauv' ;
  386. sauv ;
  387. fins ;
  388.  
  389. *------------------------ Petit post-traitement -----------------------*
  390.  
  391. si ig1 ;
  392.  
  393. * Evolution temporelle temperature thermocouples :
  394. evtc1 = evol bleu temp tab1 temperatures 'T' tc1 ;
  395. evtc2 = evol vert temp tab1 temperatures 'T' tc2 ;
  396. evtc3 = evol roug temp tab1 temperatures 'T' tc3 ;
  397. evtc4 = evol turq temp tab1 temperatures 'T' tc4 ;
  398.  
  399. tleg1 = table ;
  400. tleg1 . titre = table ;
  401. tleg1 . titre . 1 = 'TC1' ;
  402. tleg1 . titre . 2 = 'TC2' ;
  403. tleg1 . titre . 3 = 'TC3' ;
  404. tleg1 . titre . 4 = 'TC4' ;
  405. trac qual (((mur1 plus (0 0 0) aret) et (sup1 plus (0 0 0) aret) et (sup2 plus (0 0 0) aret) coul defa)
  406. et ((tc1 et tc2 et tc3 et tc4) coul roug)) titr 'Position des thermocouples' ;
  407. si icomplet ;
  408. dess (evtc1 et evtc2 et evtc3 et evtc4) titr 'Thermogrammes (degC)' lege tleg1 xbor 0. 800. xgra 100 gril poin ;
  409. sino ;
  410. dess (evtc1 et evtc2 et evtc3 et evtc4) titr 'Thermogrammes (degC)' lege tleg1 gril poin ;
  411. fins ;
  412.  
  413. * Animation du champ de temperature :
  414. if1 = (dime tab1.temps) - 1 ;
  415. modf1 = tab1.modeles.if1 ;
  416. mailf1 = (extr modf1 mate conduction) extr mail ;
  417. dep0 = manu chpo mailf1 3 ux 0. uy 0. uz 0. ;
  418. def1 = vide deforme ;
  419. liso1 = prog 0. 50. 100. PAS 150. 1450. ;
  420. vtra1 = vale trac ;
  421. si (ega vtra1 'PSC') ;
  422. opti ftra 'Temperature_Waam1_Anim.ps' ;
  423. fins ;
  424. repe b1 if1 ;
  425. modi1 = tab1.modeles.(&b1-1) ;
  426. maili1 = (extr modi1 mate conduction) extr mail ;
  427. chti1 = tab1.temperatures.(&b1-1) ;
  428. defoi1 = defo maili1 dep0 chti1 ;
  429. def1 = def1 et defoi1 ;
  430. si (ega vtra1 'PSC') ;
  431. mot1 = chai format '(F6.1)' 'Temperature (degC) au temps (s) :' (tab1.temps.(&b1-1)) ;
  432. trac chti1 maili1 liso1 titr mot1 ;
  433. fins ;
  434. fin b1 ;
  435. si (neg vtra1 'PSC') ;
  436. trac anim def1 liso1 ;
  437. fins ;
  438.  
  439. fins ;
  440.  
  441. *----------------------- Test de non regression -----------------------*
  442.  
  443. ttest1 = tab1.temps.19 ;
  444. temp1 = peche tab1 temperatures ttest1 ipol ;
  445. tmaxref1 = 3006.8 ;
  446. tmax1 = maxi abs temp1 ;
  447. si (Tmax1 < 2000.) ;
  448. erre 5 ;
  449. fins ;
  450.  
  451. *------------------ F I N W A A M 1 . D G I B I -----------------*
  452. fin ;
  453.  
  454.  
  455.  
  456.  
  457.  
  458.  
  459.  
  460.  
  461.  
  462.  

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