Télécharger deadutil.procedur

Retour à la liste

Numérotation des lignes :

  1. * DEADUTIL PROCEDUR GOUNAND 26/01/12 21:15:02 12448
  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. *
  28. 'ARGUMENT' motcle*'MOT' ;
  29. *
  30. lmotcle = 'MOTS' 'DIMM' 'TYPM' 'AXI?' 'SPH?' 'QISO' 'QALI' 'QEQU' 'INDI' ;
  31. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  32. 'ERRE' 1052 'AVEC' motcle 'DIMM TYPM AXI? SPH? QISO QALI QEQU INDI' ;
  33. 'FINSI' ;
  34. *
  35. 'SI' ('EGA' motcle 'AXI?') ;
  36. vmod = 'VALEUR' 'MODE' ;
  37. laxi = ('EGA' vmod 'AXIS') 'OU' ('EGA' vmod 'UNIDAXIS')
  38. 'OU' ('EGA' vmod 'UNIDAXISAXDZ') 'OU' ('EGA' vmod 'UNIDAXISAXCZ')
  39. 'OU' ('EGA' vmod 'UNIDAXISAXGZ') ;
  40. 'RESPRO' laxi ;
  41. 'FINSI' ;
  42. *
  43. 'SI' ('EGA' motcle 'SPH?') ;
  44. vmod = 'VALEUR' 'MODE' ;
  45. lsph = 'EGA' vmod 'UNIDSPHE' ;
  46. 'RESPRO' lsph ;
  47. 'FINSI' ;
  48. *
  49. 'SI' ('EGA' motcle 'DIMM') ;
  50. 'ARGUMENT' mt*'MAILLAGE' ;
  51. tabdim = 'TABLE' ;
  52. tabdim . 0 = 'MOTS' 'POI1' ;
  53. tabdim . 1 = 'MOTS' 'SEG2' 'SEG3' ;
  54. tabdim . 2 = 'MOTS' 'TRI3' 'TRI6' 'TRI7' 'QUA4' 'QUA8' 'QUA9' ;
  55. tabdim . 3 = 'MOTS' 'CUB8' 'CU20' 'PRI6' 'PR15' 'TET4' 'TE10'
  56. 'PYR5' 'PY13' 'CU27' 'PR21' 'TE15' 'PY19' ;
  57. fidim = FAUX ;
  58. dim = -1 ;
  59. lelem = 'ELEM' mt 'TYPE' ;
  60. nelem = 'DIME' lelem ;
  61. 'SI' ('EGA' nelem 0) ;
  62. *1027 2
  63. *Une donnee de type %M1:8 est vide
  64. 'ERRE' 1027 'AVEC' 'MAILLAGE' ;
  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. *1027 2
  113. *Une donnee de type %M1:8 est vide
  114. 'ERRE' 1027 'AVEC' 'MAILLAGE' ;
  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 : mutualisation 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' 'INDI') motcle) ;
  175. *
  176. 'SI' ('EGA' motcle 'INDI') ;
  177. lindic = 'MOTS' ;
  178. lindic2 = 'MOTS' ;
  179. lindicv = 'MOTS' 'COHE' 'EQLT' 'ISOD' 'DENS' 'TOPO' ;
  180. 'REPE' bmcle ;
  181. 'ARGU' mindic/'MOT' ;
  182. 'SI' ('NON' ('EXIS' mindic)) ; 'QUIT' bmcle ; 'FINS' ;
  183. indicok = 'EXIS' lindicv mindic ;
  184. 'SI' ('NON' indicok) ;
  185. lindic2 = lindic2 'ET' mindic ;
  186. 'SINO' ;
  187. lindic = lindic 'ET' mindic ;
  188. 'FINS' ;
  189. 'FIN' bmcle ;
  190. 'SINO' ;
  191. lindic = 'MOTS' motcle ;
  192. lindic2 = 'MOTS' ;
  193. 'REPE' bmcle ;
  194. 'ARGU' mindic/'MOT' ;
  195. 'SI' ('NON' ('EXIS' mindic)) ; 'QUIT' bmcle ; 'FINS' ;
  196. lindic2 = lindic2 'ET' mindic ;
  197. 'FIN' bmcle ;
  198. 'FINS' ;
  199. *
  200. 'ARGUMENT' mail*'MAILLAGE' ;
  201. *
  202. *lmotcle2 = 'MOTS' 'METR' 'DISG' 'METG' 'DENS' ;
  203. lmotcle2 = 'MOTS' 'METR' 'DISG' 'METG' ;
  204. *
  205. lchad = FAUX ; lchp = FAUX ;
  206. ldisg = FAUX ;
  207. lmg = FAUX ;
  208. lmetdisc = faux ;
  209. *
  210. idim = 'VALEUR' 'DIME' ;
  211. *
  212. 'REPETER' imcle2 ('DIME' lindic2) ;
  213. motcle2 = 'EXTR' lindic2 &imcle2 ;
  214. lmc = 'EXISTE' lmotcle2 motcle2 ;
  215. 'SI' ('NON' lmc) ;
  216. *1052 2
  217. *Mot-cle incorrect "%M1:4". Voici la liste des valeurs admises : %M5:40
  218. * 'ERRE' 1052 'AVEC' ('CHAI' motcle2 'METR DISG METG DENS') ;
  219. 'ERRE' 1052 'AVEC' motcle2 'METR DISG METG' ;
  220. 'FINSI' ;
  221. *
  222. 'SI' ('EGA' motcle2 'METR') ;
  223. 'ARGU' tai/'FLOTTANT' ;
  224. 'SI' ('EXIS' tai) ;
  225. itai2 = tai '**' -2 ;
  226. chpt = 'MANU' 'CHPO' 1 mail 'G' itai2 'NATURE' 'DIFFUS' ;
  227. chp = chpt ;
  228. lchp = vrai ; lchad = faux ;
  229. 'SINO' ;
  230. 'ARGUMENT' chad/'MCHAML' ;
  231. lchad = 'EXISTE' chad ;
  232. 'SI' ('NON' lchad) ;
  233. 'ARGUMENT' chp/'CHPOINT' ;
  234. lchp = 'EXISTE' chp ;
  235. 'SI' lchp ;
  236. 'ARGUMENT' metdisc/'MOT' ;
  237. 'FINS' ;
  238. lmetdisc = 'EXIS' metdisc ;
  239. 'SINON' ;
  240. argu kmodl1*'MMODEL' ;
  241. lchp = FAUX ;
  242. 'FINSI' ;
  243. 'FINS' ;
  244. 'FINS' ;
  245. * 'SI' ('EGA' motcle2 'DENS') ;
  246. * 'ARGUMENT' chp*'CHPOINT' ;
  247. * chp = 'REDU' chp mail ;
  248. * kmodl1 = 'MODE' mail 'THERMIQUE' ;
  249. * chad = 'CHAN' 'CHAM' kmodl1 chp ;
  250. * chad = (chad ** -2) 'NOMC' 'G' ;
  251. * lchad = VRAI ;
  252. * lchp = FAUX ;
  253. * 'FINSI' ;
  254. *
  255. 'SI' ('EGA' motcle2 'DISG') ;
  256. 'ARGUMENT' gdisc*'MOT' ;
  257. ldisg = VRAI ;
  258. 'FINSI' ;
  259. *
  260. 'SI' ('EGA' motcle2 'METG') ;
  261. 'ARGUMENT' methgau*'MOT' ;
  262. lmg = VRAI ;
  263. 'FINSI' ;
  264. *
  265. 'FIN' imcle2 ;
  266. lmet = 'OU' lchad lchp ;
  267. *
  268. * Initialisations
  269. *
  270. imod = 'VALEUR' 'MODE' ;
  271. vdim = DEADUTIL 'DIMM' mail ;
  272. vtyp = DEADUTIL 'TYPM' mail ;
  273. laxi = DEADUTIL 'AXI?' ;
  274. lsph = DEADUTIL 'SPH?' ;
  275. *
  276. 'SI' ('OU' ('<' idim 1) ('>' idim 3)) ;
  277. * 709 2 Fonction indisponible en dimension %i1.
  278. 'ERREUR' 709 'AVEC' idim ;
  279. 'FINSI' ;
  280. 'SI' (('EGA' imod 'AXIS') 'OU' ('EGA' imod 'UNIDAXIS') 'OU'
  281. ('EGA' imod 'FOUR') 'OU' ('EGA' imod 'SPHE')) ;
  282. *-105 0 Mode de calcul actuel %m1:32
  283. 'ERRE' -105 'AVEC' imod ;
  284. * 710 2 Fonction indisponible pour ce mode de calcul
  285. 'ERRE' 710 ;
  286. 'FINSI' ;
  287. *
  288. vquaf = ('EGA' vtyp 'QUAF') ;
  289. 'SI' ('ET' ldisg ('NON' vquaf)) ;
  290. 'MESS' 'DISG option :' ;
  291. * 66 2 L'objet %m1:8 doit etre de type %m9:16
  292. 'ERRE' 66 'AVEC' 'MAIL QUAF' ;
  293. 'FINSI' ;
  294. *
  295. * Maillage
  296. *
  297. *'SI' vquaf ;
  298. _mt = mail ;
  299. *'SINON' ;
  300. * _mt = 'CHANGER' mail 'QUAF' ;
  301. *'FINSI' ;
  302. *
  303. * Inconnus et discrétisation
  304. *
  305. 'SI' ('NON' lmg) ;
  306. 'SI' ('EGA' vtyp 'LINE') ;
  307. methgau = 'GAM1' ;
  308. 'SINON' ;
  309. methgau = 'GAM2' ;
  310. 'FINSI' ;
  311. 'FINSI' ;
  312. 'SI' ('NON' ldisg) ;
  313. gdisc = vtyp ;
  314. 'FINSI' ;
  315. *
  316. * Métrique
  317. *
  318. ncmet = '/' ('*' idim ('+' idim 1)) 2 ;
  319. lnmet = 'TABL' ;
  320. lnmet . 1 = 'MOTS' 'G11' ;
  321. lnmet . 2 = 'MOTS' 'G11' 'G22' 'G21' ;
  322. lnmet . 3 = 'MOTS' 'G11' 'G22' 'G21' 'G33' 'G31' 'G32' ;
  323. 'SI' lmet;
  324. 'SI' lchad ;
  325. chpmet = 'CHANGER' 'CHPO' kmodl1 chad ;
  326. metdisc = gdisc ;
  327. 'FINSI' ;
  328. 'SI' lchp ;
  329. chpmet = chp ;
  330. 'SI' ('NON' lmetdisc) ;
  331. metdisc = gdisc ;
  332. 'FINS' ;
  333. 'FINSI' ;
  334. lncom = 'EXTR' chpmet 'COMP' ;
  335. dncom = 'DIME' lncom ;
  336. 'SI' ('EGA' dncom 1) ;
  337. 'SI' ('EGA' ('TYPE' chpmet) 'CHPOINT') ;
  338. chpmet = 'NOMC' 'G11' chpmet 'NATURE' 'DIFFUS' ;
  339. 'SINO' ;
  340. chpmet = 'NOMC' 'G11' chpmet ;
  341. 'FINS' ;
  342. chpmett = chpmet ;
  343. 'SI' ('>' idim 1) ;
  344. chpmet0 = chpmet '*' 0. ;
  345. chpmet = chpmet 'ET' (chpmett 'NOMC' 'G22') 'ET' (chpmet0 'NOMC' 'G21') ;
  346. 'FINS' ;
  347. 'SI' ('>' idim 2) ;
  348. chpmet = chpmet 'ET' (chpmett 'NOMC' 'G33') 'ET' (chpmet0 'NOMC' 'G31') 'ET' (chpmet0 'NOMC' 'G32') ;
  349. 'FINS' ;
  350. lncom = 'EXTR' chpmet 'COMP' ;
  351. dncom = 'DIME' lncom ;
  352. 'FINS' ;
  353. 'SI' ('OU' ('NEG' dncom ncmet) ('NON' ('EXIS' (lnmet . idim) lncom 'ET' ))) ;
  354. 'MESS' 'Noms de composantes metrique pas OK :' ;
  355. 'LIST' lncom ;
  356. 'LIST' (lnmet . idim) ;
  357. 'ERRE' 1127 avec 'DEADUTIL' ;
  358. 'FINS' ;
  359. 'FINSI' ;
  360. *
  361. dlindic = 'DIME' lindic ;
  362. 'SI' ('NON' ldisg) ;
  363. cindict = 'VIDE' 'MCHAML' ;
  364. 'SINO' ;
  365. cindict = 'VIDE' 'CHPOINT'/'DIFFUS' ;
  366. 'FINS' ;
  367. lali = 'MOTS' 'QISO' 'QALI' 'COHE' 'EQLT' ;
  368. lequ = 'MOTS' 'QEQU' 'ISOD' 'DENS' ;
  369. 'REPE' ilindic dlindic ;
  370. nomindic = 'EXTR' lindic &ilindic ;
  371. 'SI' ('EGA' nomindic 'TOPO') ;
  372. 'SI' lmet ;
  373. vfonc = 'INDI' 'TOP2' mail chpmet ;
  374. 'SINO' ;
  375. vfonc = 'INDI' 'TOP2' mail ;
  376. 'FINS' ;
  377. ncompo = 'EXTR' vfonc 'COMP' ;
  378. ncompn = 'MOTS' ;
  379. 'REPE' iicomp ('DIME' ncompo) ;
  380. icomp = &iicomp ;
  381. 'SI' ('EGA' icomp 1) ;
  382. ncompi = 'CHAI' 'TOPO' ;
  383. 'SINO' ;
  384. ncompi = 'CHAI' 'TOPO' icomp ;
  385. 'FINS' ;
  386. ncompn = ncompn 'ET' ncompi ;
  387. 'FIN' iicomp ;
  388. cindic = 'EXCO' ncompo vfonc ncompn ;
  389. * Homogene a une longueur
  390. * 'SI' ('>' vdim 2) ;
  391. * vfonc = '**' vfonc ('/' 1. ('-' vdim 1)) ;
  392. * 'FINS' ;
  393. 'SINO' ;
  394. 'SI' ('EXIS' lali nomindic) ;
  395. loi = 'CHAI' 'QALI' ;
  396. 'FINS' ;
  397. 'SI' ('EXIS' lequ nomindic) ;
  398. loi = 'CHAI' 'QEQU' ;
  399. 'FINS' ;
  400. 'SI' ('EGA' nomindic 'EQLT') ;
  401. lmet2 = FAUX ;
  402. 'SINO' ;
  403. lmet2 = lmet ;
  404. 'FINS' ;
  405. *
  406. * Calcul de la fonctionnelle
  407. *
  408. numop = 1 ;
  409. numvar = 1 ;
  410. numder = vdim ;
  411. numdat = 0 ;
  412. numcof = 0 ;
  413. *
  414. A = ININLIN numop numvar numdat numcof numder ;
  415. A . 'VAR' . 1 . 'VALEUR' = 1.D0 ;
  416. *
  417. numvar = 1 ;
  418. numdat = ncmet ;
  419. numcof = 1 ;
  420. B = ININLIN numop numvar numdat numcof numder ;
  421. B . 'VAR' . 1 . 'VALEUR' = 1.D0 ;
  422. *
  423. idat = 0 ;
  424. 'REPETER' idi idim ;
  425. nomdat = 'CHAINE' 'G' &idi &idi ;
  426. * 'MESSAGE' ('CHAINE' 'nomdat=' nomdat) ;
  427. idat = '+' idat 1 ;
  428. B . 'DAT' . idat . 'NOMDDL' = 'MOTS' nomdat ;
  429. 'SI' lmet2 ;
  430. B . 'DAT' . idat . 'DISC' = metdisc ;
  431. B . 'DAT' . idat . 'VALEUR' = 'EXCO' nomdat chpmet nomdat ;
  432. 'SINON' ;
  433. B . 'DAT' . idat . 'VALEUR' = 1.D0 ;
  434. 'FINSI' ;
  435. 'FIN' idi ;
  436. 'REPETER' idi idim ;
  437. nj = '-' idim &idi ;
  438. * 'MESSAGE' ('CHAINE' 'nj=' nj) ;
  439. 'SI' ('>EG' nj 1) ;
  440. 'REPETER' jdi nj ;
  441. * Mise en cohérence avec Castem
  442. * nomdat = 'CHAINE' 'G' &idi ('+' &idi &jdi) ;
  443. nomdat = 'CHAINE' 'G' ('+' &idi &jdi) &idi ;
  444. * 'MESSAGE' ('CHAINE' 'nomdat=' nomdat) ;
  445. idat = '+' idat 1 ;
  446. B . 'DAT' . idat . 'NOMDDL' = 'MOTS' nomdat ;
  447. 'SI' lmet2 ;
  448. B . 'DAT' . idat . 'DISC' = metdisc ;
  449. B . 'DAT' . idat . 'VALEUR' = 'EXCO' nomdat chpmet nomdat ;
  450. 'SINON' ;
  451. B . 'DAT' . idat . 'VALEUR' = 0.D0 ;
  452. 'FINSI' ;
  453. 'FIN' jdi ;
  454. 'FINSI' ;
  455. 'FIN' idi ;
  456. lisdat = 'LECT' 1 'PAS' 1 'NPAS' ('-' numdat 1) ;
  457. *
  458. B . 'COF' . 1 . 'COMPOR' = loi ;
  459. B . 'COF' . 1 . 'LDAT' = lisdat ;
  460. *
  461. A . 1 . 1 . 0 = 0 ;
  462. B . 1 . 1 . 0 = 1 ;
  463. *
  464. 'SI' ('NON' ldisg) ;
  465. vfonc = NLINP gdisc _mt A B 'ERF1' 'CHAM' methgau ;
  466. 'SINO' ;
  467. vfonc = NLINP gdisc _mt A B 'ERF1' methgau ;
  468. 'FINS' ;
  469. *
  470. * 'LIST' nomindic ;
  471. * 'LIST' lmet2 ;
  472. * 'LIST' vfonc ;
  473. *
  474. 'SI' ('EXIS' lequ nomindic) ;
  475. 'SI' ('EGA' nomindic 'DENS') ;
  476. * Homogene a une longueur
  477. 'SI' ('>' vdim 1) ;
  478. vfonc = '**' vfonc ('/' 1. vdim) ;
  479. 'FINS' ;
  480. * On remet les valeurs entre 0 et 1
  481. mvfonc = 'MASQ' vfonc 'SUPERIEUR' 1. ;
  482. pvfonc = 1. '-' mvfonc ;
  483. ivfonc = '**' vfonc -1 ;
  484. vfonc = '+' ('*' mvfonc ivfonc) ('*' pvfonc vfonc) ;
  485. 'SINO' ;
  486. tvfonc = 'TYPE' vfonc ;
  487. 'SI' ('EGA' tvfonc 'CHPOINT') ;
  488. rvfonc = 'MAXI' ('RESU' vfonc) ;
  489. 'SINO' ;
  490. * 'LIST' 'RESU' vfonc ;
  491. * 'LIST' 'RESU' ('EXTR' vfonc 'MAIL') ;
  492. * On utilise un modele MECANIQUE car le modele THERMIQUE ne supporte pas les QUAFs
  493. vfonc2 = 'CHAN' vfonc ('MODE' ('EXTR' vfonc 'MAIL') 'MECANIQUE') 'GRAVITE' ;
  494. rvfonc = 'SOMM' ('EXTR' vfonc2 'VALE' 'SCAL') ;
  495. 'FINS' ;
  496. * Facteur de ponderation dependant du type d'element car l'element
  497. * de reference est equilateral d'arete 1, mais pas de volume 1
  498. rvelemr = 'FLOTTANT' ('NBEL' _mt) ;
  499. fac = '/' rvelemr rvfonc ;
  500. * 'MESS' 'FACTEUR EQU=' fac ;
  501. vfonc = '*' vfonc fac ;
  502. 'FINS' ;
  503. 'FINS' ;
  504. * On remet les valeurs entre 1 et +inf
  505. * 'SI' ('EXIS' ('MOTS' 'COHE' 'EQLT') nomindic) ;
  506. 'SI' ('EXIS' ('MOTS' 'QISO' 'QALI') nomindic) ;
  507. vfonc = '**' vfonc -1 ;
  508. 'FINS' ;
  509. cindic = 'NOMC' vfonc nomindic ;
  510. 'FINS' ;
  511. cindict = cindict 'ET' cindic ;
  512. 'FIN' ilindic ;
  513. *
  514. 'RESPRO' cindict ;
  515. 'FINSI' ;
  516. *
  517. *
  518. * End of procedure file DEADUTIL
  519. *
  520. 'FINPROC' ;
  521.  
  522.  

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