Télécharger g_decouplage_8.dgibi

Retour à la liste

Numérotation des lignes :

  1. * fichier : g_decouplage_8.dgibi
  2. ****************************************************
  3. ****************************************************
  4. * *
  5. * VERIFICATION DE LA PROCEDURE G_THETA *
  6. * POUR LE CALCUL DE KIII POUR UNE FISSURE *
  7. * PENNY-SHAPED DANS UN CYLINDRE *
  8. * - *
  9. * COMPARAISON ENTRE LE RESULTAT DE DECOUPLAGE *
  10. * EN 3D ET UNE SOLUTION ANALYTIQUE *
  11. * (XFEM) *
  12. * *
  13. * SOLUTION ANALYTIQUE TIREE DE : *
  14. * "THE STRESS ANALYSIS OF CRACKS HANDBOOK" *
  15. * TADA, PARIS AND IRWIN (2000) *
  16. * *
  17. ****************************************************
  18.  
  19. * I - CALCUL 3D
  20. * -------------
  21.  
  22. * OPTIONS ET BOOLEEN POUR LES TRACERS
  23. OPTI 'DIME' 3 'ELEM' 'CUB8' ;
  24. BTRAC = FAUX ;
  25.  
  26. * PROPRIETES MATERIAU
  27. YOUN1 NU1 = 2.E5 0.3 ;
  28.  
  29. * I.1 - MAILLAGE
  30. * **************
  31.  
  32. * PARAMETRES GEOMETRIQUES
  33. * LP = RAYON DE LA FISSURE
  34. * L1 = RAYON DU CYLINDRE
  35. * H1 = HAUTEUR DU CYLINDRE
  36. L1 H1 LP = 10. 15. 5. ;
  37. PRE1 = 1.E-10 ;
  38.  
  39. * RECTANGLE AUTOUR DE LA FISSURE
  40. P1 = (LP/2.) 0. 0. ;
  41. P2 = (LP/2.) (LP/2.) 0. ;
  42. P3 = (3.*LP/2.) (LP/2.) 0. ;
  43. P4 = (3.*LP/2.) 0. 0. ;
  44. N1 = 2 * 2 ;
  45. N2 = 2 * N1 ;
  46. D1 = DROI N1 P1 P2 ;
  47. D2 = DROI N2 P2 P3 ;
  48. D3 = DROI N1 P3 P4 ;
  49. DENS1 = LP / 2. / N1 ;
  50. CONT1 = D1 ET D2 ET D3 ;
  51.  
  52. * RAFFINEMENT VERS LA POINTE DE FISSURE
  53. RAPP2 = 0.2 ;
  54. DENS2 = DENS1*RAPP2 ;
  55. CONT2 = CONT1 HOMO RAPP2 (LP 0. 0.) ;
  56. S1 = CONT1 REGL CONT2 'DINI' DENS1 'DFIN' DENS2 ;
  57. CONT2 = DROI N2 CONT2 (CONT2 POIN 'INIT') ;
  58. S2 = SURF CONT2 'PLANE' ;
  59. S2 = S2 COUL 'ROUG' ;
  60. SURF1 = S1 ET S2 ;
  61. * TRAC SURF1 ;FIN ;
  62.  
  63. * DERAFFINEMENT VERS L'EXTERIEUR DU CYLINDRE
  64. RAPP3 = (L1 - (LP/2.)) / LP ;
  65. DENS3 = DENS1*RAPP3 ;
  66. CONT3 = (D2 ET D3) HOMO RAPP3 P1 ;
  67. S3 = (D2 ET D3) REGL CONT3 'DINI' DENS1 'DFIN' DENS3 ;
  68. S3 = S3 COUL 'BLEU' ;
  69. SURF1 = SURF1 ET S3 ;
  70. * TRAC SURF1 ;FIN ;
  71.  
  72. * EXTENSION VERTICALE
  73. PSUP = (COOR 2 S3) POIN 'MAXI' ;
  74. ELSUP = (CONT S3) ELEM 'APPUYE' PSUP ;
  75. H0 = MAXI (COOR 2 S3) ;
  76. DENS4 = DENS3 * H1 / H0 ;
  77. S4 = ELSUP TRAN 'DINI' DENS3 'DFIN' DENS4 (0. (H1 - H0) 0.) ;
  78. S4 = S4 COUL 'VERT' ;
  79. SURF1 = SURF1 ET S4 ;
  80. * TRAC SURF1 ;FIN ;
  81.  
  82. * DEFINITION DU VOLUME AVEC ROTA
  83. * NFRONT DOIT ETRE UN MULTIPLE DE 4
  84. NFRON = 8 ;
  85. NFRON = (NFRON / 4) * 4 ;
  86. VOLU1 = SURF1 VOLU NFRON 'ROTA' 360. (0. 1. 0.) (0. 0. 0.) ;
  87. ELIM VOLU1 PRE1 ;
  88. * TRAC 'CACH' VOLU1 'COUPE' (0. 0. 0.) (1. 0. 0.) (0. 1. 0.) ;FIN ;
  89.  
  90. * CENTRE DU CYLINDRE
  91. CERC1 = CERC NFRON 'ROTA' 360. P1 (0. 1. 0.) (0. 0. 0.) ;
  92. ELIM CERC1 VOLU1 PRE1 ;
  93. A1 = (LP/2.) / 2. ;
  94. N3 = NFRON / 4 ;
  95. DENS5 = A1 * (2.**0.5) / N3 ;
  96. CAR1 = DROI N3 (A1 0. 0.) (0. 0. A1) ;
  97. CAR1 = DROI N3 CAR1 ((0.-A1) 0. 0.) ;
  98. CAR1 = DROI N3 CAR1 (0. 0. (0.-A1)) ;
  99. CAR1 = DROI N3 CAR1 (CAR1 POIN 'INIT') ;
  100. S5 = SURF CAR1 'PLANE' ;
  101. S6 = CERC1 REGL 'DINI' DENS1 'DFIN' (DENS5) CAR1 ;
  102. SBASE = S5 ET S6 ;
  103. PL1 = (LP/2.) 0. 0. ;
  104. PL2 = (LP/2.) H1 0. ;
  105. PLIG1 = VOLU1 POIN 'DROIT' PL1 PL2 PRE1 ;
  106. LIG1 = (CHAN 'LIGNE' VOLU1) ELEM 'APPUYE' PLIG1 ;
  107. ELIM LIG1 (PL1 ET PL2) PRE1 ;
  108. LIG1 = LIG1 ELEM 'COMPRIS' PL1 PL2 ;
  109. VOLU2 = (SBASE VOLU 'GENE' LIG1) COUL 'VIOL' ;
  110. ELIM VOLU1 VOLU2 PRE1 ;
  111. * TRAC 'CACH' (VOLU1 ET VOLU2) 'COUPE' (0. 0. 0.) (1. 0. 0.) (0. 1. 0.) ;FIN ;
  112.  
  113. * DEFINITION DE LA FISSURE ET FUSION DES NOEUDS COINCIDENTS
  114. V1 = VOLU1 ET VOLU2 ;
  115. ENV1 = ENVE V1 ;
  116. V2 = V1 SYME 'PLAN' (0. 0. 0.) (1. 0. 0.) (0. 0. 1.) ;
  117. V0 = (V1 COUL 'BLEU') ET (V2 COUL 'ROUG') ;
  118. ELIM V1 V2 PRE1 ;
  119. PMED = V0 POIN 'PLAN' (0. 0. 0.) (1. 0. 0.) (0. 0. 1.) PRE1 ;
  120. X Y Z = COOR PMED ;
  121. R = ((X**2) + (Z**2))**0.5 ;
  122. PLEV = R POIN 'EGINFE' (LP + PRE1) ;
  123. LEV1 = ENV1 ELEM 'APPUYE' PLEV ;
  124. LEV1 = (LEV1 PLUS (0. 0. 0.)) COUL 'VIOL' ;
  125. LEV1 = ORIE LEV1 (0. 1. 0.) ;
  126.  
  127. * DEFINITION DU FRONT DE FISSURE
  128. FRON1 = (CONT LEV1) COUL 'VERT' ;
  129. * TRAC (LEV1 ET FRON1) ;FIN ;
  130.  
  131.  
  132. * I.2 - MODELE, MATERIAU ET CL
  133. * ****************************
  134.  
  135.  
  136. * DECOUPAGE EN ZONE XFEM ET ZONE FEM
  137. VXFEM = ENV1 ELEM 'APPUYE' PLEV ;
  138. NCOUCH = 2 ;
  139. REPE ICOUCH (NCOUCH + 1) ;
  140. VXFEM = V0 ELEM 'APPUYE' 'LARGEMENT' VXFEM ;
  141. FIN ICOUCH ;
  142. VXFEM = VXFEM COUL 'VERT' ;
  143. VFEM = (DIFF V0 VXFEM) COUL 'VIOL' ;
  144. P1 P2 P3 = (0. 0. 0.) (1. 0. 0.) (0. 1. 0.) ;
  145. SI BTRAC ;
  146. TRAC 'CACH' (VFEM ET VXFEM) 'COUPE' P1 P2 P3 ;
  147. FINSI ;
  148.  
  149. * MODELE ET MATERIAU ZONE XFEM
  150. MOD1 = MODE VXFEM 'MECANIQUE' 'ELASTIQUE' 'XC8R' ;
  151. MAT1 = MATE MOD1 'YOUN' YOUN1 'NU' NU1 ;
  152. PSI0 PHI0 = PSIP VXFEM LEV1 'DEUX' FRON1 ;
  153. CHE1X = TRIE MOD1 PSI0 PHI0 ;
  154. RELAX = RELA MOD1 ;
  155.  
  156. * MODELE ET MATERIAU ZONE FEM
  157. MOD2 = MODE VFEM 'MECANIQUE' 'ELASTIQUE' ;
  158. MAT2 = MATE MOD2 'YOUN' YOUN1 'NU' NU1 ;
  159.  
  160. MODTOT = MOD1 ET MOD2 ;
  161. MATTOT = MAT1 ET MAT2 ;
  162. RIGTOT = RIGI MATTOT MODTOT ;
  163.  
  164. * CL EN EFFORTS
  165. DV0 = ENVE V0 ;
  166. PSUP = (COOR 2 V0) POIN 'MAXI' ;
  167. SSUP = DV0 ELEM 'APPUYE' PSUP ;
  168. PINF = (COOR 2 V0) POIN 'MINI' ;
  169. SINF = DV0 ELEM 'APPUYE' PINF ;
  170. CHPO1 = PRES 'MASS' MODTOT 1. (SSUP ET SINF) ;
  171. X Y Z = COOR (SSUP ET SINF) ;
  172. CHPO2 = (NOMC 'FX' X) + (NOMC 'FY' (0.*Y)) + (NOMC 'FZ' Z) ;
  173. MFOR = MOTS 'FX' 'FY' 'FZ' ;
  174. NCHPO2 = (PSCA CHPO2 CHPO2 MFOR MFOR)**0.5 ;
  175. CHPO2 = CHPO2 / (NCHPO2 + 1.E-30) ;
  176. T1 = PVEC CHPO1 CHPO2 MFOR MFOR MFOR ;
  177. T1 = CHAN ATTRIBUT T1 NATURE DISCRET ;
  178. SI BTRAC ;
  179. VEC1 = VECT T1 'FORC' ;
  180. TRAC 'CACH' VEC1 V0 ;
  181. FINSI ;
  182.  
  183. * CL EN DEPLACEMENTS
  184. P1 = PSUP POIN 'DROIT' (0. 0. 0.) (0. 1. 0.) PRE1 ;
  185. P2 = PINF POIN 'DROIT' (0. 0. 0.) (0. 1. 0.) PRE1 ;
  186. PMIL = DV0 POIN 'PLAN' (0. 0. 0.) (1. 0. 0.) (0. 0. 1.) PRE1 ;
  187. P3 = (COOR 1 PMIL) POIN 'MAXI' ;
  188. P4 = (COOR 1 PMIL) POIN 'MINI' ;
  189. BLOQ1 = BLOQ (MOTS 'UX' 'UZ') (P1 ET P2) ;
  190. BLOQ3 = BLOQ 'UZ' P3 ;
  191. RELA1 = RELA 'UY' P1 + 'UY' P2 ;
  192. BLOQ0 = BLOQ1 ET BLOQ3 ET RELA1 ;
  193.  
  194.  
  195. * I.3 - RESOLUTION PUIS G-THETA
  196. * *****************************
  197.  
  198. * RESO
  199. U1 = RESO (RIGTOT ET BLOQ0 ET RELAX) T1 ;
  200.  
  201. * G_THETA
  202. SUPTAB = TABL ;
  203. SUPTAB.'MODELE' = MODTOT ;
  204. SUPTAB.'CARACTERISTIQUES' = MATTOT ;
  205. SUPTAB.'BLOCAGES_MECANIQUES' = BLOQ0 ;
  206. SUPTAB.'CHARGEMENTS_MECANIQUES' = T1 ;
  207. SUPTAB.'OBJECTIF' = MOT 'DECOUPLAGE' ;
  208. SUPTAB.'PSI' = PSI0 ;
  209. SUPTAB.'PHI' = PHI0 ;
  210. SUPTAB.'COUCHE' = NCOUCH ;
  211. SUPTAB.'FRONT_FISSURE' = FRON1 ;
  212. SUPTAB.'SOLUTION_RESO' = U1 ;
  213.  
  214. G_THETA SUPTAB ;
  215.  
  216. K3D = VIDE 'EVOLUTIO' ;
  217. REPE IMOD 3 ;
  218. MMOD = EXTR 'III' 1 &IMOD ;
  219. EVO1 = EVOL 'CHPO' SUPTAB.'CHPO_RESULTATS' (CHAI 'K' &IMOD) FRON1 ;
  220. K3D = K3D ET (EXTR EVO1 'COUR' 1) ;
  221. FIN IMOD ;
  222.  
  223.  
  224. * II - SOLUTION ANALYTIQUE
  225. * ------------------------
  226.  
  227. SFRO = EXTR (EXTR K3D 'COUR' 1) 'ABSC' ;
  228. * KI ET KII DOIVENT ETRE NULS
  229. KA1 = 0.*SFRO ;
  230. KA2 = 0.*SFRO ;
  231. A B = LP L1 ;
  232. T = 2.*PI*(B**3)/3. ;
  233. TAUN = 2.*T*A / (PI*((B**4) - (A**4))) ;
  234. ASB = A / B ;
  235. GASB = 4 / (3.*PI) * (1. + (0.5*ASB) + (3./8.*(ASB**2)) + (5./16.*(ASB**3))
  236. - (93./128.*(ASB**4)) + (0.038*(ASB**5))) ;
  237. F1ASB = GASB * ((1. - ASB)**0.5) ;
  238. KAIII = TAUN * ((PI*A)**0.5) *F1ASB ;
  239. * KIII EST CONSTANT
  240. KA3 = (0.*SFRO) + KAIII ;
  241. KANA = EVOL 'MANU' SFRO KA1 ;
  242. KANA = KANA ET (EVOL 'MANU' SFRO KA2) ;
  243. KANA = KANA ET (EVOL 'MANU' SFRO KA3) ;
  244.  
  245.  
  246. * III - COMPARAISON
  247. * -----------------
  248.  
  249. * PRECISIONS ATTENDUES POUR L'ERREUR RELATIVE EN NORME L2
  250. L_PREC = PROG 0.01 0.01 0.04 ;
  251. TAB1 = TABL ;
  252. * LES RESULTATS NUMERIQUES SONT IDENTIFIES AVEC DES CARRES
  253. TAB1.(1) = CHAI 'MARQ CARR' ;
  254. IND1 = 2 ;
  255. IND2 = (NBEL FRON1) - 1 ;
  256. REPE IMOD 3 ;
  257. * BOUCLE SUR LES MODES
  258. SAUT 'LIGNE' ;
  259. MMOD = EXTR 'III' 1 &IMOD ;
  260. KNUM1 = (EXTR K3D 'COUR' &IMOD) COUL 'BLEU' ;
  261. KANA1 = (EXTR KANA 'COUR' &IMOD) COUL 'ROUG' ;
  262. SI BTRAC ;
  263. DESS (KNUM1 ET KANA1) TAB1 'TITR' (CHAI 'K' &IMOD) ;
  264. FINSI ;
  265. * ERREUR EN NORME L2
  266. ERR1 = (INTG ((KNUM1 - KANA1)**2) 'INDI' IND1 IND2)**0.5 ;
  267. PRE1 = EXTR L_PREC &IMOD ;
  268. * VALEUR DE COMPARAISON POUR L'ERREUR RELATIVE
  269. CRI1 = ((INTG (KANA1**2) 'INDI' IND1 IND2)**0.5) * PRE1 ;
  270. SI (EGA CRI1 0.) ;
  271. CRI1 = CRI1 + 1.E-8 ;
  272. FINSI ;
  273. MESS 'ERREUR SUR LE CALCUL DE K' MMOD ' :'*30 ERR1 ;
  274. MESS 'CRITERE' ' :'*30 CRI1 ;
  275. SI (ERR1 >EG CRI1) ;
  276. MESS 'ERREUR : L''ERREUR SUR K' MMOD ' DEPASSE LE CRITERE' ;
  277. ERRE 5 ;
  278. FINSI ;
  279. FIN IMOD ;
  280.  
  281. FIN ;
  282.  
  283.  
  284.  
  285.  
  286.  
  287.  
  288.  

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