Télécharger deadutil.procedur

Retour à la liste

Numérotation des lignes :

  1. * DEADUTIL PROCEDUR GOUNAND 26/06/09 21:15:04 12566
  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. 'SI' ('EXIS' lindic 'TOPO') ;
  268. 'ARGU' lrcrit/'LISTREEL' ;
  269. llrcrit = 'EXIS' lrcrit ;
  270. 'FINS' ;
  271. *
  272. * Initialisations
  273. *
  274. imod = 'VALEUR' 'MODE' ;
  275. vdim = DEADUTIL 'DIMM' mail ;
  276. vtyp = DEADUTIL 'TYPM' mail ;
  277. laxi = DEADUTIL 'AXI?' ;
  278. lsph = DEADUTIL 'SPH?' ;
  279. *
  280. 'SI' ('OU' ('<' idim 1) ('>' idim 3)) ;
  281. * 709 2 Fonction indisponible en dimension %i1.
  282. 'ERREUR' 709 'AVEC' idim ;
  283. 'FINSI' ;
  284. 'SI' (('EGA' imod 'AXIS') 'OU' ('EGA' imod 'UNIDAXIS') 'OU'
  285. ('EGA' imod 'FOUR') 'OU' ('EGA' imod 'SPHE')) ;
  286. *-105 0 Mode de calcul actuel %m1:32
  287. 'ERRE' -105 'AVEC' imod ;
  288. * 710 2 Fonction indisponible pour ce mode de calcul
  289. 'ERRE' 710 ;
  290. 'FINSI' ;
  291. *
  292. vquaf = ('EGA' vtyp 'QUAF') ;
  293. 'SI' ('ET' ldisg ('NON' vquaf)) ;
  294. 'MESS' 'DISG option :' ;
  295. * 66 2 L'objet %m1:8 doit etre de type %m9:16
  296. 'ERRE' 66 'AVEC' 'MAIL QUAF' ;
  297. 'FINSI' ;
  298. *
  299. * Maillage
  300. *
  301. *'SI' vquaf ;
  302. _mt = mail ;
  303. *'SINON' ;
  304. * _mt = 'CHANGER' mail 'QUAF' ;
  305. *'FINSI' ;
  306. *
  307. * Inconnus et discrétisation
  308. *
  309. 'SI' ('NON' lmg) ;
  310. 'SI' ('EGA' vtyp 'LINE') ;
  311. methgau = 'GAM1' ;
  312. 'SINON' ;
  313. methgau = 'GAM2' ;
  314. 'FINSI' ;
  315. 'FINSI' ;
  316. 'SI' ('NON' ldisg) ;
  317. gdisc = vtyp ;
  318. 'FINSI' ;
  319. *
  320. * Métrique
  321. *
  322. ncmet = '/' ('*' idim ('+' idim 1)) 2 ;
  323. lnmet = 'TABL' ;
  324. lnmet . 1 = 'MOTS' 'G11' ;
  325. lnmet . 2 = 'MOTS' 'G11' 'G22' 'G21' ;
  326. lnmet . 3 = 'MOTS' 'G11' 'G22' 'G21' 'G33' 'G31' 'G32' ;
  327. 'SI' lmet;
  328. 'SI' lchad ;
  329. chpmet = 'CHANGER' 'CHPO' kmodl1 chad ;
  330. metdisc = gdisc ;
  331. 'FINSI' ;
  332. 'SI' lchp ;
  333. chpmet = chp ;
  334. 'SI' ('NON' lmetdisc) ;
  335. metdisc = gdisc ;
  336. 'FINS' ;
  337. 'FINSI' ;
  338. lncom = 'EXTR' chpmet 'COMP' ;
  339. dncom = 'DIME' lncom ;
  340. 'SI' ('EGA' dncom 1) ;
  341. 'SI' ('EGA' ('TYPE' chpmet) 'CHPOINT') ;
  342. chpmet = 'NOMC' 'G11' chpmet 'NATURE' 'DIFFUS' ;
  343. 'SINO' ;
  344. chpmet = 'NOMC' 'G11' chpmet ;
  345. 'FINS' ;
  346. chpmett = chpmet ;
  347. 'SI' ('>' idim 1) ;
  348. chpmet0 = chpmet '*' 0. ;
  349. chpmet = chpmet 'ET' (chpmett 'NOMC' 'G22') 'ET' (chpmet0 'NOMC' 'G21') ;
  350. 'FINS' ;
  351. 'SI' ('>' idim 2) ;
  352. chpmet = chpmet 'ET' (chpmett 'NOMC' 'G33') 'ET' (chpmet0 'NOMC' 'G31') 'ET' (chpmet0 'NOMC' 'G32') ;
  353. 'FINS' ;
  354. lncom = 'EXTR' chpmet 'COMP' ;
  355. dncom = 'DIME' lncom ;
  356. 'FINS' ;
  357. 'SI' ('OU' ('NEG' dncom ncmet) ('NON' ('EXIS' (lnmet . idim) lncom 'ET' ))) ;
  358. 'MESS' 'Noms de composantes metrique pas OK :' ;
  359. 'LIST' lncom ;
  360. 'LIST' (lnmet . idim) ;
  361. 'ERRE' 1127 avec 'DEADUTIL' ;
  362. 'FINS' ;
  363. 'FINSI' ;
  364. *
  365. dlindic = 'DIME' lindic ;
  366. 'SI' ('NON' ldisg) ;
  367. cindict = 'VIDE' 'MCHAML' ;
  368. 'SINO' ;
  369. cindict = 'VIDE' 'CHPOINT'/'DIFFUS' ;
  370. 'FINS' ;
  371. lali = 'MOTS' 'QISO' 'QALI' 'COHE' 'EQLT' ;
  372. lequ = 'MOTS' 'QEQU' 'ISOD' 'DENS' ;
  373. 'REPE' ilindic dlindic ;
  374. nomindic = 'EXTR' lindic &ilindic ;
  375. 'SI' ('EGA' nomindic 'TOPO') ;
  376. 'SI' lmet ;
  377. 'SI' llrcrit ;
  378. vfonc = 'INDI' 'TOP2' mail lrcrit chpmet ;
  379. 'SINO' ;
  380. vfonc = 'INDI' 'TOP2' mail chpmet ;
  381. 'FINS' ;
  382. 'SINO' ;
  383. 'SI' llrcrit ;
  384. vfonc = 'INDI' 'TOP2' mail lrcrit ;
  385. 'SINO' ;
  386. vfonc = 'INDI' 'TOP2' mail ;
  387. 'FINS' ;
  388. 'FINS' ;
  389. ncompo = 'EXTR' vfonc 'COMP' ;
  390. ncompn = 'MOTS' ;
  391. 'REPE' iicomp ('DIME' ncompo) ;
  392. icomp = &iicomp ;
  393. 'SI' ('EGA' icomp 1) ;
  394. ncompi = 'CHAI' 'TOPO' ;
  395. 'SINO' ;
  396. ncompi = 'CHAI' 'TOPO' icomp ;
  397. 'FINS' ;
  398. ncompn = ncompn 'ET' ncompi ;
  399. 'FIN' iicomp ;
  400. cindic = 'EXCO' ncompo vfonc ncompn ;
  401. * Homogene a une longueur
  402. * 'SI' ('>' vdim 2) ;
  403. * vfonc = '**' vfonc ('/' 1. ('-' vdim 1)) ;
  404. * 'FINS' ;
  405. 'SINO' ;
  406. 'SI' ('EXIS' lali nomindic) ;
  407. loi = 'CHAI' 'QALI' ;
  408. 'FINS' ;
  409. 'SI' ('EXIS' lequ nomindic) ;
  410. loi = 'CHAI' 'QEQU' ;
  411. 'FINS' ;
  412. 'SI' ('EGA' nomindic 'EQLT') ;
  413. lmet2 = FAUX ;
  414. 'SINO' ;
  415. lmet2 = lmet ;
  416. 'FINS' ;
  417. *
  418. * Calcul de la fonctionnelle
  419. *
  420. numop = 1 ;
  421. numvar = 1 ;
  422. numder = vdim ;
  423. numdat = 0 ;
  424. numcof = 0 ;
  425. *
  426. A = ININLIN numop numvar numdat numcof numder ;
  427. A . 'VAR' . 1 . 'VALEUR' = 1.D0 ;
  428. *
  429. numvar = 1 ;
  430. numdat = ncmet ;
  431. numcof = 1 ;
  432. B = ININLIN numop numvar numdat numcof numder ;
  433. B . 'VAR' . 1 . 'VALEUR' = 1.D0 ;
  434. *
  435. idat = 0 ;
  436. 'REPETER' idi idim ;
  437. nomdat = 'CHAINE' 'G' &idi &idi ;
  438. * 'MESSAGE' ('CHAINE' 'nomdat=' nomdat) ;
  439. idat = '+' idat 1 ;
  440. B . 'DAT' . idat . 'NOMDDL' = 'MOTS' nomdat ;
  441. 'SI' lmet2 ;
  442. B . 'DAT' . idat . 'DISC' = metdisc ;
  443. B . 'DAT' . idat . 'VALEUR' = 'EXCO' nomdat chpmet nomdat ;
  444. 'SINON' ;
  445. B . 'DAT' . idat . 'VALEUR' = 1.D0 ;
  446. 'FINSI' ;
  447. 'FIN' idi ;
  448. 'REPETER' idi idim ;
  449. nj = '-' idim &idi ;
  450. * 'MESSAGE' ('CHAINE' 'nj=' nj) ;
  451. 'SI' ('>EG' nj 1) ;
  452. 'REPETER' jdi nj ;
  453. * Mise en cohérence avec Castem
  454. * nomdat = 'CHAINE' 'G' &idi ('+' &idi &jdi) ;
  455. nomdat = 'CHAINE' 'G' ('+' &idi &jdi) &idi ;
  456. * 'MESSAGE' ('CHAINE' 'nomdat=' nomdat) ;
  457. idat = '+' idat 1 ;
  458. B . 'DAT' . idat . 'NOMDDL' = 'MOTS' nomdat ;
  459. 'SI' lmet2 ;
  460. B . 'DAT' . idat . 'DISC' = metdisc ;
  461. B . 'DAT' . idat . 'VALEUR' = 'EXCO' nomdat chpmet nomdat ;
  462. 'SINON' ;
  463. B . 'DAT' . idat . 'VALEUR' = 0.D0 ;
  464. 'FINSI' ;
  465. 'FIN' jdi ;
  466. 'FINSI' ;
  467. 'FIN' idi ;
  468. lisdat = 'LECT' 1 'PAS' 1 'NPAS' ('-' numdat 1) ;
  469. *
  470. B . 'COF' . 1 . 'COMPOR' = loi ;
  471. B . 'COF' . 1 . 'LDAT' = lisdat ;
  472. *
  473. A . 1 . 1 . 0 = 0 ;
  474. B . 1 . 1 . 0 = 1 ;
  475. *
  476. 'SI' ('NON' ldisg) ;
  477. vfonc = NLINP gdisc _mt A B 'ERF1' 'CHAM' methgau ;
  478. 'SINO' ;
  479. vfonc = NLINP gdisc _mt A B 'ERF1' methgau ;
  480. 'FINS' ;
  481. *
  482. * 'LIST' nomindic ;
  483. * 'LIST' lmet2 ;
  484. * 'LIST' vfonc ;
  485. *
  486. 'SI' ('EXIS' lequ nomindic) ;
  487. 'SI' ('EGA' nomindic 'DENS') ;
  488. * Homogene a une longueur
  489. 'SI' ('>' vdim 1) ;
  490. vfonc = '**' vfonc ('/' 1. vdim) ;
  491. 'FINS' ;
  492. * On remet les valeurs entre 0 et 1
  493. * mvfonc = 'MASQ' vfonc 'SUPERIEUR' 1. ;
  494. * pvfonc = 1. '-' mvfonc ;
  495. * ivfonc = '**' vfonc -1 ;
  496. * vfonc = '+' ('*' mvfonc ivfonc) ('*' pvfonc vfonc) ;
  497. 'SINO' ;
  498. tvfonc = 'TYPE' vfonc ;
  499. 'SI' ('EGA' tvfonc 'CHPOINT') ;
  500. rvfonc = 'MAXI' ('RESU' vfonc) ;
  501. 'SINO' ;
  502. * 'LIST' 'RESU' vfonc ;
  503. * 'LIST' 'RESU' ('EXTR' vfonc 'MAIL') ;
  504. * On utilise un modele MECANIQUE car le modele THERMIQUE ne supporte pas les QUAFs
  505. vfonc2 = 'CHAN' vfonc ('MODE' ('EXTR' vfonc 'MAIL') 'MECANIQUE') 'GRAVITE' ;
  506. rvfonc = 'SOMM' ('EXTR' vfonc2 'VALE' 'SCAL') ;
  507. 'FINS' ;
  508. * Facteur de ponderation dependant du type d'element car l'element
  509. * de reference est equilateral d'arete 1, mais pas de volume 1
  510. rvelemr = 'FLOTTANT' ('NBEL' _mt) ;
  511. fac = '/' rvelemr rvfonc ;
  512. * 'MESS' 'FACTEUR EQU=' fac ;
  513. vfonc = '*' vfonc fac ;
  514. 'FINS' ;
  515. 'FINS' ;
  516. * On remet les valeurs entre 1 et +inf
  517. * 'SI' ('EXIS' ('MOTS' 'COHE' 'EQLT') nomindic) ;
  518. 'SI' ('EXIS' ('MOTS' 'QISO' 'QALI') nomindic) ;
  519. vfonc = '**' vfonc -1 ;
  520. 'FINS' ;
  521. cindic = 'NOMC' vfonc nomindic ;
  522. 'FINS' ;
  523. cindict = cindict 'ET' cindic ;
  524. 'FIN' ilindic ;
  525. *
  526. 'RESPRO' cindict ;
  527. 'FINSI' ;
  528. *
  529. *
  530. * End of procedure file DEADUTIL
  531. *
  532. 'FINPROC' ;
  533.  
  534.  

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