Télécharger deadutil.procedur

Retour à la liste

Numérotation des lignes :

  1. * DEADUTIL PROCEDUR GOUNAND 25/11/24 21:15:02 12406
  2. ************************************************************************
  3. * NOM : DEADUTIL
  4. * DESCRIPTION :
  5. *
  6. *
  7. *
  8. * LANGAGE : GIBIANE-CAST3M
  9. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  10. * mél : gounand@semt2.smts.cea.fr
  11. **********************************************************************
  12. * VERSION : v1, 05/04/2006, version initiale
  13. * HISTORIQUE : v1, 05/04/2006, création
  14. * HISTORIQUE : 2018/01/22 : chgt nom composante hors diago G21 au lieu
  15. * de G12 pour QEQU et QISO
  16. * HISTORIQUE : 2018/10/10 : NLINP au lieu de NLIN
  17. * HISTORIQUE :
  18. * HISTORIQUE :
  19. ************************************************************************
  20. * Prière de PRENDRE LE TEMPS de compléter les commentaires
  21. * en cas de modification de ce sous-programme afin de faciliter
  22. * la maintenance !
  23. ************************************************************************
  24. *
  25. *
  26. 'DEBPROC' DEADUTIL ;
  27. 'ARGUMENT' motcle*'MOT' ;
  28. *
  29. lmotcle = 'MOTS' 'DIMM' 'TYPM' 'AXI?' 'SPH?' 'QISO' 'QALI' 'QEQU'
  30. 'QALI2' 'QEQU2' ;
  31. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  32. cherr = 'CHAINE' 'Keyword' ' ' motcle ' unknown.' ;
  33. 'ERREUR' cherr ;
  34. 'FINSI' ;
  35. *
  36. 'SI' ('EGA' motcle 'AXI?') ;
  37. vmod = 'VALEUR' 'MODE' ;
  38. laxi = ('EGA' vmod 'AXIS') 'OU' ('EGA' vmod 'UNIDAXIS')
  39. 'OU' ('EGA' vmod 'UNIDAXISAXDZ') 'OU' ('EGA' vmod 'UNIDAXISAXCZ')
  40. 'OU' ('EGA' vmod 'UNIDAXISAXGZ') ;
  41. 'RESPRO' laxi ;
  42. 'FINSI' ;
  43. *
  44. 'SI' ('EGA' motcle 'SPH?') ;
  45. vmod = 'VALEUR' 'MODE' ;
  46. lsph = 'EGA' vmod 'UNIDSPHE' ;
  47. 'RESPRO' lsph ;
  48. 'FINSI' ;
  49. *
  50. 'SI' ('EGA' motcle 'DIMM') ;
  51. 'ARGUMENT' mt*'MAILLAGE' ;
  52. tabdim = 'TABLE' ;
  53. tabdim . 0 = 'MOTS' 'POI1' ;
  54. tabdim . 1 = 'MOTS' 'SEG2' 'SEG3' ;
  55. tabdim . 2 = 'MOTS' 'TRI3' 'TRI6' 'TRI7' 'QUA4' 'QUA8' 'QUA9' ;
  56. tabdim . 3 = 'MOTS' 'CUB8' 'CU20' 'PRI6' 'PR15' 'TET4' 'TE10'
  57. 'PYR5' 'PY13' 'CU27' 'PR21' 'TE15' 'PY19' ;
  58. fidim = FAUX ;
  59. dim = -1 ;
  60. lelem = 'ELEM' mt 'TYPE' ;
  61. nelem = 'DIME' lelem ;
  62. 'SI' ('EGA' nelem 0) ;
  63. cherr = 'CHAINE' 'Maillage vide ?' ;
  64. 'ERREUR' cherr ;
  65. 'FINSI' ;
  66. *
  67. 'REPETER' ielem nelem ;
  68. melem = 'EXTRAIRE' lelem &ielem ;
  69. 'REPETER' itdim 4 ;
  70. idim = ('-' &itdim 1) ;
  71. lli = tabdim . idim ;
  72. * id = ISINLIS melem lli ;
  73. * 'SI' ('NEG' id 0) ;
  74. id = 'EXISTE' lli melem ;
  75. 'SI' id ;
  76. 'SI' fidim ;
  77. 'SI' ('NEG' dim idim) ;
  78. cherr = 'CHAINE' 'Composite mesh not allowed' ;
  79. 'ERREUR' cherr ;
  80. 'FINSI' ;
  81. 'SINON' ;
  82. dim = idim ;
  83. fidim = VRAI ;
  84. 'FINSI' ;
  85. 'FINSI' ;
  86. 'FIN' itdim ;
  87. 'FIN' ielem ;
  88. *
  89. 'SI' ('NON' fidim) ;
  90. cherr = 'CHAINE' 'No known elements in this mesh' ;
  91. 'ERREUR' cherr ;
  92. 'FINSI' ;
  93. *
  94. 'RESPRO' dim ;
  95. 'FINSI' ;
  96. *
  97. *
  98. *
  99. 'SI' ('EGA' motcle 'TYPM') ;
  100. 'ARGUMENT' mt*'MAILLAGE' ;
  101. tabtyp = 'TABLE' ;
  102. tabtyp . 1 = 'MOTS' 'SEG2' 'TRI3' 'QUA4' 'CUB8' 'PRI6' 'TET4' 'PYR5' ;
  103. tabtyp . 2 = 'MOTS' 'TRI6' 'QUA8' 'CU20' 'PR15' 'TE10' 'PY13' ;
  104. tabtyp . 3 = 'MOTS' 'SEG3' 'TRI7' 'QUA9' 'CU27' 'PR21' 'TE15' 'PY19' ;
  105. listyp = 'MOTS' 'LINE' 'QUAI' 'QUAF' ;
  106. *
  107. fityp = FAUX ;
  108. typ = -1 ;
  109. lelem = 'ELEM' mt 'TYPE' ;
  110. nelem = 'DIME' lelem ;
  111. 'SI' ('EGA' nelem 0) ;
  112. cherr = 'CHAINE' 'Void mesh ?' ;
  113. 'MESSAGE' cherr ;
  114. 'QUITTER' TYPM ;
  115. 'FINSI' ;
  116. *
  117. 'REPETER' ielem nelem ;
  118. melem = 'EXTRAIRE' lelem &ielem ;
  119. 'REPETER' ittyp 3 ;
  120. ityp = &ittyp ;
  121. lli = tabtyp . ityp ;
  122. * id = ISINLIS melem lli ;
  123. * 'SI' ('NEG' id 0) ;
  124. id = 'EXISTE' lli melem ;
  125. 'SI' id ;
  126. 'SI' fityp ;
  127. 'SI' ('NEG' typ ityp) ;
  128. cherr = 'CHAINE' 'Composite mesh not allowed' ;
  129. 'ERREUR' cherr ;
  130. 'FINSI' ;
  131. 'SINON' ;
  132. typ = ityp ;
  133. fityp = VRAI ;
  134. 'FINSI' ;
  135. 'FINSI' ;
  136. 'FIN' ittyp ;
  137. 'FIN' ielem ;
  138. *
  139. 'SI' ('NON' fityp) ;
  140. cherr = 'CHAINE' 'No known elements in this mesh' ;
  141. 'ERREUR' cherr ;
  142. 'FINSI' ;
  143. *
  144. mtyp = 'EXTRAIRE' listyp typ ;
  145. 'RESPRO' mtyp ;
  146. 'FINSI' ;
  147. *
  148. * QISO PROCEDUR GOUNAND 06/04/06 17:53:15 5371
  149. ************************************************************************
  150. * NOM : QISO
  151. * DESCRIPTION : Critère de qualité d'un maillage : alignement
  152. * (= isotropie)
  153. *
  154. *
  155. *
  156. * LANGAGE : GIBIANE-CAST3M
  157. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  158. * mél : gounand@semt2.smts.cea.fr
  159. **********************************************************************
  160. * VERSION : v1, 11/05/2007, version initiale
  161. * HISTORIQUE : v1, 11/05/2007, création
  162. * HISTORIQUE : 2018/01/22 : chgt nom composante hors diago G21 au lieu
  163. * de G12
  164. * HISTORIQUE : 2025/11/20 : muutualisation avec QEQU
  165. * HISTORIQUE :
  166. ************************************************************************
  167. * Prière de PRENDRE LE TEMPS de compléter les commentaires
  168. * en cas de modification de ce sous-programme afin de faciliter
  169. * la maintenance !
  170. ************************************************************************
  171. *
  172. *
  173. *
  174. 'SI' ('EXIS' ('MOTS' 'QISO' 'QALI' 'QEQU' 'QALI2' 'QEQU2') motcle) ;
  175. *
  176. 'ARGUMENT' mail*'MAILLAGE' ;
  177. *
  178. lmotcle2 = 'MOTS' 'METR' 'DISG' 'METG' 'DENS' ;
  179. *
  180. lchad = FAUX ; lchp = FAUX ;
  181. ldisg = FAUX ;
  182. lmg = FAUX ;
  183. lmetdisc = faux ;
  184. *
  185. idim = 'VALEUR' 'DIME' ;
  186. *
  187. 'REPETER' imotcle2 ;
  188. 'ARGUMENT' motcle2/'MOT' ;
  189. 'SI' ('NON' ('EXISTE' motcle2)) ;
  190. 'QUITTER' imotcle2 ;
  191. 'FINSI' ;
  192. lmc = 'EXISTE' lmotcle2 motcle2 ;
  193. 'SI' ('NON' lmc) ;
  194. *1052 2
  195. *Mot-cle incorrect "%M1:4". Voici la liste des valeurs admises : %M5:40
  196. 'ERRE' 1052 'AVEC' ('CHAI' motcle2 'METR DISG METG DENS') ;
  197. 'FINSI' ;
  198. *
  199. 'SI' ('EGA' motcle2 'METR') ;
  200. 'ARGU' tai/'FLOTTANT' ;
  201. 'SI' ('EXIS' tai) ;
  202. itai2 = tai '**' -2 ;
  203. chpt = 'MANU' 'CHPO' 1 mail 'G' itai2 'NATURE' 'DIFFUS' ;
  204. chp = chpt ;
  205. lchp = vrai ; lchad = faux ;
  206. 'SINO' ;
  207. 'ARGUMENT' chad/'MCHAML' ;
  208. lchad = 'EXISTE' chad ;
  209. 'SI' ('NON' lchad) ;
  210. 'ARGUMENT' chp/'CHPOINT' ;
  211. lchp = 'EXISTE' chp ;
  212. 'SI' lchp ;
  213. 'ARGUMENT' metdisc/'MOT' ;
  214. 'FINS' ;
  215. lmetdisc = 'EXIS' metdisc ;
  216. 'SINON' ;
  217. argu kmodl1*'MMODEL' ;
  218. lchp = FAUX ;
  219. 'FINSI' ;
  220. 'FINS' ;
  221. 'FINS' ;
  222. 'SI' ('EGA' motcle2 'DENS') ;
  223. 'ARGUMENT' chp*'CHPOINT' ;
  224. chp = 'REDU' chp mail ;
  225. kmodl1 = 'MODE' mail 'THERMIQUE' ;
  226. chad = 'CHAN' 'CHAM' kmodl1 chp ;
  227. chad = (chad ** -2) 'NOMC' 'G' ;
  228. lchad = VRAI ;
  229. lchp = FAUX ;
  230. 'FINSI' ;
  231. *
  232. 'SI' ('EGA' motcle2 'DISG') ;
  233. 'ARGUMENT' gdisc*'MOT' ;
  234. ldisg = VRAI ;
  235. 'FINSI' ;
  236. *
  237. 'SI' ('EGA' motcle2 'METG') ;
  238. 'ARGUMENT' methgau*'MOT' ;
  239. lmg = VRAI ;
  240. 'FINSI' ;
  241. *
  242. 'FIN' imotcle2 ;
  243. lmet = 'OU' lchad lchp ;
  244. *
  245. * Initialisations
  246. *
  247. imod = 'VALEUR' 'MODE' ;
  248. vdim = DEADUTIL 'DIMM' mail ;
  249. vtyp = DEADUTIL 'TYPM' mail ;
  250. laxi = DEADUTIL 'AXI?' ;
  251. lsph = DEADUTIL 'SPH?' ;
  252. *
  253. 'SI' ('OU' ('<' idim 1) ('>' idim 3)) ;
  254. * 709 2 Fonction indisponible en dimension %i1.
  255. 'ERREUR' 709 'AVEC' idim ;
  256. 'FINSI' ;
  257. 'SI' (('EGA' imod 'AXIS') 'OU' ('EGA' imod 'UNIDAXIS') 'OU'
  258. ('EGA' imod 'FOUR') 'OU' ('EGA' imod 'SPHE')) ;
  259. *-105 0 Mode de calcul actuel %m1:32
  260. 'ERRE' -105 'AVEC' imod ;
  261. * 710 2 Fonction indisponible pour ce mode de calcul
  262. 'ERRE' 710 ;
  263. 'FINSI' ;
  264. *
  265. vquaf = ('EGA' vtyp 'QUAF') ;
  266. 'SI' ('ET' ldisg ('NON' vquaf)) ;
  267. 'MESS' 'DISG option :' ;
  268. * 66 2 L'objet %m1:8 doit etre de type %m9:16
  269. 'ERRE' 66 'AVEC' 'MAIL QUAF' ;
  270. 'FINSI' ;
  271. *
  272. * Maillage
  273. *
  274. *'SI' vquaf ;
  275. _mt = mail ;
  276. *'SINON' ;
  277. * _mt = 'CHANGER' mail 'QUAF' ;
  278. *'FINSI' ;
  279. *
  280. * Inconnus et discrétisation
  281. *
  282. 'SI' ('NON' lmg) ;
  283. 'SI' ('EGA' vtyp 'LINE') ;
  284. methgau = 'GAR1' ;
  285. 'SINON' ;
  286. methgau = 'GAR2' ;
  287. 'FINSI' ;
  288. 'FINSI' ;
  289. 'SI' ('NON' ldisg) ;
  290. gdisc = vtyp ;
  291. 'FINSI' ;
  292. *
  293. * Métrique
  294. *
  295. ncmet = '/' ('*' idim ('+' idim 1)) 2 ;
  296. lnmet = 'TABL' ;
  297. lnmet . 1 = 'MOTS' 'G11' ;
  298. lnmet . 2 = 'MOTS' 'G11' 'G22' 'G21' ;
  299. lnmet . 3 = 'MOTS' 'G11' 'G22' 'G21' 'G33' 'G31' 'G32' ;
  300. 'SI' lmet;
  301. 'SI' lchad ;
  302. chpmet = 'CHANGER' 'CHPO' kmodl1 chad ;
  303. metdisc = gdisc ;
  304. 'FINSI' ;
  305. 'SI' lchp ;
  306. chpmet = chp ;
  307. 'SI' ('NON' lmetdisc) ;
  308. metdisc = gdisc ;
  309. 'FINS' ;
  310. 'FINSI' ;
  311. lncom = 'EXTR' chpmet 'COMP' ;
  312. dncom = 'DIME' lncom ;
  313. 'SI' ('EGA' dncom 1) ;
  314. 'SI' ('EGA' ('TYPE' chpmet) 'CHPOINT') ;
  315. chpmet = 'NOMC' 'G11' chpmet 'NATURE' 'DIFFUS' ;
  316. 'SINO' ;
  317. chpmet = 'NOMC' 'G11' chpmet ;
  318. 'FINS' ;
  319. chpmett = chpmet ;
  320. 'SI' ('>' idim 1) ;
  321. chpmet0 = chpmet '*' 0. ;
  322. chpmet = chpmet 'ET' (chpmett 'NOMC' 'G22') 'ET' (chpmet0 'NOMC' 'G21') ;
  323. 'FINS' ;
  324. 'SI' ('>' idim 2) ;
  325. chpmet = chpmet 'ET' (chpmett 'NOMC' 'G33') 'ET' (chpmet0 'NOMC' 'G31') 'ET' (chpmet0 'NOMC' 'G32') ;
  326. 'FINS' ;
  327. lncom = 'EXTR' chpmet 'COMP' ;
  328. dncom = 'DIME' lncom ;
  329. 'FINS' ;
  330. 'SI' ('OU' ('NEG' dncom ncmet) ('NON' ('EXIS' (lnmet . idim) lncom 'ET' ))) ;
  331. 'MESS' 'Noms de composantes metrique pas OK :' ;
  332. 'LIST' lncom ;
  333. 'ERRE' 1127 avec 'DEADUTIL' ;
  334. 'FINS' ;
  335. 'FINSI' ;
  336.  
  337. *
  338. 'SI' ('EXIS' ('MOTS' 'QEQU' 'QEQU2') motcle) ;
  339. loi = 'CHAI' 'QEQU' ;
  340. nocom = 'CHAI' 'EQUI' ;
  341. 'SINO' ;
  342. loi = 'CHAI' 'QALI' ;
  343. nocom = 'CHAI' 'ALIG' ;
  344. 'FINS' ;
  345. *
  346. * Calcul de la fonctionnelle
  347. *
  348. numop = 1 ;
  349. numvar = 1 ;
  350. numder = vdim ;
  351. numdat = 0 ;
  352. numcof = 0 ;
  353. *
  354. A = ININLIN numop numvar numdat numcof numder ;
  355. A . 'VAR' . 1 . 'VALEUR' = 1.D0 ;
  356. *
  357. numvar = 1 ;
  358. numdat = ncmet ;
  359. numcof = 1 ;
  360. B = ININLIN numop numvar numdat numcof numder ;
  361. B . 'VAR' . 1 . 'VALEUR' = 1.D0 ;
  362. *
  363. idat = 0 ;
  364. 'REPETER' idi idim ;
  365. nomdat = 'CHAINE' 'G' &idi &idi ;
  366. * 'MESSAGE' ('CHAINE' 'nomdat=' nomdat) ;
  367. idat = '+' idat 1 ;
  368. B . 'DAT' . idat . 'NOMDDL' = 'MOTS' nomdat ;
  369. 'SI' lmet ;
  370. B . 'DAT' . idat . 'DISC' = metdisc ;
  371. B . 'DAT' . idat . 'VALEUR' = 'EXCO' nomdat chpmet nomdat ;
  372. 'SINON' ;
  373. B . 'DAT' . idat . 'VALEUR' = 1.D0 ;
  374. 'FINSI' ;
  375. 'FIN' idi ;
  376. 'REPETER' idi idim ;
  377. nj = '-' idim &idi ;
  378. * 'MESSAGE' ('CHAINE' 'nj=' nj) ;
  379. 'SI' ('>EG' nj 1) ;
  380. 'REPETER' jdi nj ;
  381. * Mise en cohérence avec Castem
  382. * nomdat = 'CHAINE' 'G' &idi ('+' &idi &jdi) ;
  383. nomdat = 'CHAINE' 'G' ('+' &idi &jdi) &idi ;
  384. * 'MESSAGE' ('CHAINE' 'nomdat=' nomdat) ;
  385. idat = '+' idat 1 ;
  386. B . 'DAT' . idat . 'NOMDDL' = 'MOTS' nomdat ;
  387. 'SI' lmet ;
  388. B . 'DAT' . idat . 'DISC' = metdisc ;
  389. B . 'DAT' . idat . 'VALEUR' = 'EXCO' nomdat chpmet nomdat ;
  390. 'SINON' ;
  391. B . 'DAT' . idat . 'VALEUR' = 0.D0 ;
  392. 'FINSI' ;
  393. 'FIN' jdi ;
  394. 'FINSI' ;
  395. 'FIN' idi ;
  396. lisdat = 'LECT' 1 'PAS' 1 'NPAS' ('-' numdat 1) ;
  397. *
  398. B . 'COF' . 1 . 'COMPOR' = loi ;
  399. B . 'COF' . 1 . 'LDAT' = lisdat ;
  400. *
  401. A . 1 . 1 . 0 = 0 ;
  402. B . 1 . 1 . 0 = 1 ;
  403. *
  404. 'SI' ('NON' ldisg) ;
  405. vfonc = NLINP gdisc _mt A B 'ERF1' 'CHAM' methgau ;
  406. 'SINO' ;
  407. vfonc = NLINP gdisc _mt A B 'ERF1' methgau ;
  408. 'FINS' ;
  409. *
  410. 'SI' ('EXIS' ('MOTS' 'QEQU' 'QEQU2') motcle) ;
  411. tvfonc = 'TYPE' vfonc ;
  412. 'SI' ('EGA' tvfonc 'CHPOINT') ;
  413. rvfonc = 'MAXI' ('RESU' vfonc) ;
  414. 'SINO' ;
  415. vfonc2 = 'CHAN' vfonc ('MODE' ('EXTR' vfonc 'MAIL') 'THERMIQUE') 'GRAVITE' ;
  416. rvfonc = 'SOMM' ('EXTR' vfonc2 'VALE' 'SCAL') ;
  417. 'FINS' ;
  418. rvelemr = 'FLOTTANT' ('NBEL' _mt) ;
  419. fac = '/' rvelemr rvfonc ;
  420. vfonc = '*' vfonc fac ;
  421. 'SI' ('EGA' motcle 'QEQU2') ;
  422. * On remet les valeurs entre 0 et 1
  423. mvfonc = 'MASQ' vfonc 'SUPERIEUR' 1. ;
  424. pvfonc = 1. '-' mvfonc ;
  425. ivfonc = '**' vfonc -1 ;
  426. vfonc = '+' ('*' mvfonc ivfonc) ('*' pvfonc vfonc) ;
  427. 'FINS' ;
  428. 'FINS' ;
  429. * On remet les valeurs entre 0 et 1
  430. 'SI' ('EGA' motcle 'QALI2') ;
  431. vfonc = '**' vfonc -1 ;
  432. 'FINS' ;
  433. *
  434. vfonc = 'NOMC' vfonc nocom ;
  435. *
  436. 'RESPRO' vfonc ;
  437. 'FINSI' ;
  438. *
  439. *
  440. * End of procedure file DEADUTIL
  441. *
  442. 'FINPROC' ;
  443.  
  444.  

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