Télécharger matoutil.procedur

Retour à la liste

Numérotation des lignes :

  1. * MATOUTIL PROCEDUR GOUNAND 25/07/24 21:15:03 12334
  2. ************************************************************************
  3. * NOM : MATOUTIL
  4. * DESCRIPTION : Procédures utilitaires utilisées par la procédure
  5. * MAILTOPO
  6. *
  7. *
  8. * LANGAGE : GIBIANE-CAST3M
  9. * AUTEUR : Stephane GOUNAND (CEA/DES/ISAS/DM2S/SEMT/LTA)
  10. * mail : stephane.gounand@cea.fr
  11. **********************************************************************
  12. * VERSION : v1, 08/04/2021, version initiale
  13. * HISTORIQUE : v1, 08/04/2021, creation
  14. * HISTORIQUE :
  15. * HISTORIQUE :
  16. ************************************************************************
  17. *
  18. 'DEBPROC' MATOUTIL ;
  19. 'ARGUMENT' motcle*'MOT' ;
  20. *
  21. lmotcle = 'MOTS' 'GASTIDX' 'GENTABIN' 'VERTABIN' 'MESUINTE' 'AFFQUAL'
  22. 'BORD' 'FERMEPZ' 'OUVREPZ' 'MOYECHAM' 'AFFCAND' 'MAILINTE' ;
  23. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  24. 'ERREUR' 1052 'AVEC' ('CHAI' motcle
  25. 'GASTIDX GENTABIN VERTABIN MESUINTE AFFQUAL BORD FERMEPZ OUVREPZ'
  26. ' MOYECHAM AFFCAND MAILINTE') ;
  27. 'FINSI' ;
  28. *
  29. 'SI' ('EGA' motcle 'GASTIDX') ;
  30. ************************************************************************
  31. * NOM : GASTIDX
  32. * DESCRIPTION : Get and set table index
  33. *
  34. *
  35. *
  36. * LANGAGE : GIBIANE-CAST3M
  37. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  38. * mél : stephane.gounand@cea.fr
  39. **********************************************************************
  40. * VERSION : v1, 08/12/2017, version initiale
  41. * HISTORIQUE : v1, 08/12/2017, création
  42. * HISTORIQUE :
  43. * HISTORIQUE :
  44. ************************************************************************
  45. *
  46. *'DEBPROC' GASTIDX ;
  47. 'ARGU' tab*'TABLE' ;
  48. 'ARGUMENT' idx*'MOT' ;
  49. 'ARGU' valdef ;
  50. *
  51. valdefd = 'EXIS' valdef ;
  52. idxd = 'EXIS' tab idx ;
  53. setd = valdefd 'ET' ('NON' idxd) ;
  54. *
  55. *debug = 'VALE' debu ;
  56. *
  57. 'SI' setd ;
  58. tab . idx = valdef ;
  59. 'FINS' ;
  60. val = tab . idx ;
  61. *
  62. 'SI' faux ;
  63. tval = 'TYPE' val ;
  64. 'SI' (('EGA' tval 'ENTIER') 'OU' ('EGA' tval 'FLOTTANT') 'OU' ('EGA'
  65. tval 'MOT') 'OU' ('EGA' tval 'LOGIQUE')) ;
  66. mval = val ;
  67. 'SINO' ;
  68. mval = 'CHAI' '*' tval ;
  69. 'FINS' ;
  70. ch = 'CHAI' 'tab . ' idx*20 '='/21 mval*40 ;
  71. 'SI' setd ;
  72. ch = 'CHAI' ch '(defaut)'*60 ;
  73. 'FINS' ;
  74. 'MESS' ch ;
  75. 'FINS' ;
  76. *
  77. 'RESPRO' val ;
  78. *
  79. * End of procedure file GASTIDX
  80. *
  81. 'FINSI' ;
  82. 'SI' ('EGA' motcle 'GENTABIN') ;
  83. *$$$$ GENTABIN
  84. ************************************************************************
  85. * NOM : GENTABIN
  86. * DESCRIPTION : Construit une table dont les indices sont les mots
  87. * donnés en entrée.
  88. * Cette table sert ensuite dans VERTABIN pour vérifier
  89. * que tous les indices d'une autre table ne sont pas
  90. * différents de ceux de la première
  91. *
  92. * C'est un peu l'équivalent de MOTS et EXIS tab LISTMOTS
  93. * pour des mots de taille quelconque.
  94. *
  95. * LANGAGE : GIBIANE-CAST3M
  96. * AUTEUR : Stephane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  97. * mail : stephane.gounand@cea.fr
  98. **********************************************************************
  99. * VERSION : v1, 14/04/2020, version initiale
  100. * HISTORIQUE : v1, 14/04/2020, creation
  101. * HISTORIQUE :
  102. * HISTORIQUE :
  103. ************************************************************************
  104. *
  105. *'DEBPROC' GENTABIN ;
  106. 'ARGUMENT' tabin/'TABLE' ;
  107. 'SI' ('NON' ('EXIS' tabin)) ;
  108. tabin = 'TABL' ;
  109. 'FINS' ;
  110. 'REPE' bcl ;
  111. 'ARGU' titi/'MOT' ;
  112. 'SI' ('EXIS' titi) ;
  113. *dbg 'MESS' 'gentabin titi' ' ' titi ;
  114. tabin . titi = vrai ;
  115. 'SINO' ;
  116. 'QUIT' bcl ;
  117. 'FINS' ;
  118. 'FIN' bcl ;
  119. 'RESPRO' tabin ;
  120. *
  121. * End of procedure file GENTABIN
  122. *
  123. *'FINPROC' ;
  124. 'FINS' ;
  125. *
  126. 'SI' ('EGA' motcle 'VERTABIN') ;
  127. ************************************************************************
  128. * NOM : VERTABIN
  129. * DESCRIPTION : GENTABIN a construit une table dont les indices sont les
  130. * mots donnés en entrée.
  131. * Cette table sert ensuite dans VERTABIN pour vérifier
  132. * que tous les indices d'une autre table ne sont pas
  133. * différents de ceux de la première
  134. *
  135. * C'est un peu l'équivalent de MOTS et EXIS tab LISTMOTS
  136. * pour des mots de taille quelconque.
  137. *
  138. * LANGAGE : GIBIANE-CAST3M
  139. * AUTEUR : Stephane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  140. * mail : stephane.gounand@cea.fr
  141. **********************************************************************
  142. * VERSION : v1, 14/04/2020, version initiale
  143. * HISTORIQUE : v1, 14/04/2020, creation
  144. * HISTORIQUE :
  145. * HISTORIQUE :
  146. ************************************************************************
  147. *
  148. *'DEBPROC' VERTABIN ;
  149. 'ARGU' tverif*'TABLE' ;
  150. 'ARGU' tabin*'TABLE' ;
  151. tlicit = 'INDE' tverif ;
  152. *dbg 'LIST' tlicit ;
  153. dtl = 'DIME' tlicit ;
  154. 'REPE' itl dtl ;
  155. idx = 'CHAI' tlicit . &itl ;
  156. *dbg 'MESS' 'vertabin idx' ' ' idx ;
  157. 'SI' ('NON' ('EXIS' tabin idx)) ;
  158. * 791 2
  159. *Indice %m1:8 : N'est pas un indice de table reconnu
  160. 'ERRE' 791 'AVEC' idx ;
  161. 'FINS' ;
  162. 'FIN' itl ;
  163. *
  164. * End of procedure file VERTABIN
  165. *
  166. *'FINPROC' ;
  167. 'FINS' ;
  168. *
  169. 'SI' ('EGA' motcle 'MESUINTE') ;
  170. ************************************************************************
  171. * NOM : MESUINTE
  172. * DESCRIPTION :
  173. *
  174. *
  175. * Procédure MESUINTE qui devient MESU SURF (si dim 2) ou MESU VOLU (si dim 3)
  176. *
  177. *
  178. *
  179. * LANGAGE : GIBIANE-CAST3M
  180. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  181. * mél : stephane.gounand@cea.fr
  182. **********************************************************************
  183. * VERSION : v1, 25/08/2016, version initiale
  184. * HISTORIQUE : v1, 25/08/2016, création
  185. * HISTORIQUE :
  186. * HISTORIQUE :
  187. ************************************************************************
  188. *
  189. 'ARGUMENT' mai*'MAILLAGE' ;
  190. vdim = 'VALEUR' 'DIME' ;
  191. 'SI' ('EGA' vdim 2) ;
  192. vol = 'MESURE' mai 'SURF' ;
  193. 'SINON' ;
  194. vol = 'MESURE' mai 'VOLU' ;
  195. 'FINSI' ;
  196. 'RESPRO' vol ;
  197. *
  198. * End of procedure file MESUINTE
  199. *
  200. 'FINS' ;
  201. *
  202. 'SI' ('EGA' motcle 'AFFQUAL') ;
  203. ************************************************************************
  204. * NOM : AFFQUAL
  205. * DESCRIPTION : Affiche les qualités d'un maillage
  206. *
  207. *
  208. *
  209. * LANGAGE : GIBIANE-CAST3M
  210. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  211. * mél : stephane.gounand@cea.fr
  212. **********************************************************************
  213. * VERSION : v1, 25/08/2016, version initiale
  214. * HISTORIQUE : v1, 25/08/2016, création
  215. * HISTORIQUE :
  216. * HISTORIQUE :
  217. ************************************************************************
  218. *
  219. 'ARGUMENT' curtopo*'MAILLAGE' ;
  220. 'ARGU' volucib*'FLOTTANT' ;
  221. 'ARGU' volutol*'FLOTTANT' ;
  222. *
  223. *lmet=faux ;
  224.  
  225. laff=vrai ;
  226. lres=faux ;
  227. momet = 'ARIT' ;
  228.  
  229. lmotcle = 'MOTS' 'VMET' 'NAFF' 'REST' 'ARIT' 'GEOM' ;
  230. 'REPETER' imotcle ;
  231. 'ARGUMENT' motcle/'MOT' ;
  232. 'SI' ('NON' ('EXISTE' motcle)) ; 'QUITTER' imotcle ; 'FINSI' ;
  233. * 'MESS' ('CHAI' 'affqual.proc : mot-cle lu :' motcle) ;
  234. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  235. cherr = 'CHAINE' 'Keyword' ' ' motcle ' unknown.' ; 'ERREUR' cherr ;
  236. 'FINSI' ;
  237. 'SI' ('EGA' motcle 'VMET') ;
  238. 'ARGU' metva ;
  239. * 'MESS' ('CHAI' 'affqual.proc : metva=') ;
  240. * 'LIST' ('TYPE' metva);
  241. 'FINS' ;
  242. 'SI' ('EGA' motcle 'NAFF') ; laff=faux ; 'FINSI' ;
  243. 'SI' ('EGA' motcle 'REST') ; lres=vrai ; 'FINSI' ;
  244. 'SI' ('EGA' motcle 'ARIT') ; momet = motcle ; 'FINSI' ;
  245. 'SI' ('EGA' motcle 'GEOM') ; momet = motcle ; 'FINSI' ;
  246. 'FIN' imotcle ;
  247. *'MESS' ('CHAI' 'laff=' laff) ;
  248. *'MESS' ('CHAI' 'lmet=' lmet) ;
  249. *'MESS' ('CHAI' 'lres=' lres) ;
  250. * lmet = faux ;
  251. 'SI' ('EXIS' metva) ;
  252. qtopo = 'INDI' 'TOPO' curtopo metva momet ;
  253. 'SINO' ;
  254. qtopo = 'INDI' 'TOPO' curtopo ;
  255. 'FINS' ;
  256. *listreel nel = 'DIME' qtopo ;
  257. nel = 'NBEL' curtopo ;
  258. nno = 'NBNO' curtopo ;
  259. dvol = '-' ('MESURE' curtopo) volucib ;
  260. miq = 'MINIMUM' qtopo ; maq = 'MAXIMUM' qtopo ;
  261. *listreel moq = '/' ('SOMME' qtopo) nel ;
  262. moq = MATOUTIL 'MOYECHAM' qtopo ;
  263. *! Test des deux façons de calculer !
  264. 'SI' ('EXIS' metva) ;
  265. qtopo2 = 'INDI' 'TOPO' curtopo metva momet 'LISTREEL' ;
  266. 'SINO' ;
  267. qtopo2 = 'INDI' 'TOPO' curtopo 'LISTREEL' ;
  268. 'FINS' ;
  269. moq2 = ('SOMM' qtopo2) '/' ('DIME' qtopo2) ;
  270. * VALE prec un peu trop serré pour semt2
  271. 'SI' ('NEG' moq moq2 ('*' ('VALE' 'PREC') 10.)) ;
  272. 'MESS' 'moq,moq2,dmoq' moq moq2 ('-' moq moq2) ;
  273. 'FINS' ;
  274. * moqtopo = 'MODE' curtopo 'THERMIQUE' ;
  275. * moq = '/' ('INTG' qtopo moqtopo) ('MESU' curtopo) ;
  276. *listreel lvnul = POSI 0.D0 'DANS' qtopo volutol 'TOUS' ;
  277. *listreel nnul = 'DIME' lvnul ;
  278. nnul = 'MASQ' qtopo 'EGINFE' 'SOMME' volutol ;
  279. 'SI' lres ;
  280. 'RESP' dvol nel nnul nno miq maq moq ;
  281. 'FINS' ;
  282. 'SI' laff ;
  283. *'SI' ('EGA' nnul 0) ;
  284. titq = 'CHAINE' 'FORMAT' '(E9.2)'
  285. ' Dvol=' dvol ' Nel=' nel ' NelV0=' nnul ' Nno=' nno
  286. ' Qmin=' miq ' Qmax=' maq ' Qmoy=' moq ;
  287. *'SINON' ;
  288. * titq = 'CHAINE' ' Dvol=' dvol ' N=' nel
  289. * ' N0=' nnul ' max=' maq ' moy=' moq ;
  290. *'FINSI' ;
  291. * titv = 'CHAINE' 'Nb. Elements plats=' nnul ;
  292. 'MESSAGE' titq ;
  293. * 'MESSAGE' titv ;
  294. 'FINS' ;
  295. *
  296. * End of procedure file AFFQUAL
  297. *
  298. 'FINS' ;
  299. *
  300. 'SI' ('EGA' motcle 'BORD') ;
  301. ************************************************************************
  302. * NOM : BORD
  303. * DESCRIPTION :
  304. *
  305. *
  306. * Procédure BORD qui devient CONTOUR (si dim 2) ou ENVELOPPE (si dim 3)
  307. *
  308. *
  309. *
  310. * LANGAGE : GIBIANE-CAST3M
  311. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  312. * mél : stephane.gounand@cea.fr
  313. **********************************************************************
  314. * VERSION : v1, 25/08/2016, version initiale
  315. * HISTORIQUE : v1, 25/08/2016, création
  316. * HISTORIQUE :
  317. * HISTORIQUE :
  318. ************************************************************************
  319. *
  320. 'ARGUMENT' mail*'MAILLAGE' ;
  321. *vdim = 'VALEUR' 'DIME' ;
  322. mdim = DEADUTIL 'DIMM' mail ;
  323. mailb = faux ;
  324. 'SI' ('EGA' mdim 2) ;
  325. mailb = 'CONTOUR' mail 'NOID' ;
  326. 'FINSI' ;
  327. 'SI' ('EGA' mdim 3) ;
  328. mailb = 'ENVELOPPE' mail 'NOID' ;
  329. * mailb = 'ENVELOPPE' mail ;
  330. 'FINSI' ;
  331. 'SI' ('EGA' ('TYPE' mail) 'LOGIQUE') ;
  332. 'ERREUR' ('CHAINE' 'mdim=' mdim) ;
  333. 'FINSI' ;
  334. 'RESPRO' mailb ;
  335. *
  336. * End of procedure file BORD
  337. *
  338. 'FINS' ;
  339. *
  340. 'SI' ('EGA' motcle 'FERMEPZ') ;
  341. ************************************************************************
  342. * NOM : FERMEPZ
  343. * DESCRIPTION :
  344. *
  345. * Ferme une topologie en étoilant son contour avec un point donné
  346. *
  347. *
  348. *
  349. *
  350. * LANGAGE : GIBIANE-CAST3M
  351. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  352. * mél : stephane.gounand@cea.fr
  353. **********************************************************************
  354. * VERSION : v1, 25/08/2016, version initiale
  355. * HISTORIQUE : v1, 25/08/2016, création
  356. * HISTORIQUE : v2 11/06/2018, ajout 2eme maillage servant à la partie
  357. * du contour qui ne doit pas être changée
  358. * HISTORIQUE :
  359. ************************************************************************
  360. *
  361. *'DEBPROC' FERMEPZ ;
  362. 'ARGUMENT' topo*'MAILLAGE' ;
  363. 'ARGU' mailnoch/'MAILLAGE' ;
  364. 'ARGUMENT' pferm*'POINT' ;
  365. * Le inverse semble hyper important !!!!
  366. btopo = (MATOUTIL 'BORD' topo) ;
  367. 'SI' ('EXIS' mailnoch) ;
  368. btopo2 = 'DIFF' btopo mailnoch ;
  369. btopo = btopo2 ;
  370. 'FINS' ;
  371. ctopo = 'INVERSE' btopo ;
  372. * topof = topo 'ET' (ETOILE pferm ctopo) ;
  373. topof = topo 'ET' ('COUT' pferm ctopo) ;
  374. * Teste si la topologie résultante est sans bord
  375. *TESTIDMA (BORD topof) ('VIDE' 'MAILLAGE') ;
  376. 'RESPRO' topof ;
  377. *
  378. * End of procedure file FERMEPZ
  379. *
  380. *'FINPROC' ;
  381. 'FINS' ;
  382. *
  383. *
  384. 'SI' ('EGA' motcle 'OUVREPZ') ;
  385. ************************************************************************
  386. * NOM : OUVREPZ
  387. * DESCRIPTION :
  388. *
  389. *
  390. * Ouvre une topologie en enlevant les éléments touchant un point donné
  391. *
  392. *
  393. *
  394. * LANGAGE : GIBIANE-CAST3M
  395. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  396. * mél : stephane.gounand@cea.fr
  397. **********************************************************************
  398. * VERSION : v1, 25/08/2016, version initiale
  399. * HISTORIQUE : v1, 25/08/2016, création
  400. * HISTORIQUE :
  401. * HISTORIQUE :
  402. ************************************************************************
  403. *
  404. *'DEBPROC' OUVREPZ ;
  405. 'ARGUMENT' topo*'MAILLAGE' ;
  406. 'ARGUMENT' pferm*'POINT' ;
  407. touchp = 'ELEM' topo 'APPUYE' 'LARGEMENT' pferm 'NOVERIF' ;
  408. topoo = 'DIFF' topo touchp ;
  409. 'RESPRO' topoo ;
  410. *
  411. * End of procedure file OUVREPZ
  412. *
  413. *'FINPROC' ;
  414. 'FINS' ;
  415. *
  416. 'SI' ('EGA' motcle 'MOYECHAM') ;
  417. ************************************************************************
  418. * NOM : MOYECHAM
  419. * DESCRIPTION : Fait la moyenne d'un champ par élément (supposé scalaire
  420. * et constant par élément) au sens : somme des valeurs
  421. * sur les éléments divisée par le nombre d'éléments.
  422. *
  423. *
  424. *
  425. * LANGAGE : GIBIANE-CAST3M
  426. * AUTEUR : Stephane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  427. * mail : stephane.gounand@cea.fr
  428. **********************************************************************
  429. * VERSION : v1, 02/05/2020, version initiale
  430. * HISTORIQUE : v1, 02/05/2020, creation
  431. * HISTORIQUE :
  432. * HISTORIQUE :
  433. ************************************************************************
  434. *
  435. *'DEBPROC' MOYECHAM ;
  436. 'ARGUMENT' cha*'MCHAML' ;
  437. *
  438. lco = 'EXTR' cha 'COMP' ;
  439. dco = 'DIME' lco ;
  440. * 320 2
  441. * Il faut specifier un champ par element avec une seule composante
  442. 'SI' ('NEG' dco 1) ;
  443. 'ERRE' 320 ;
  444. 'FINS' ;
  445. * Change le nom de composante en scal plutôt que qualtopo
  446. * car sinon chan chpo supp plante.
  447. *cha = 'EXCO' ('EXTR' lco 1) cha 'SCAL ' ;
  448. cha = 'CHAN' 'COMP' 'SCAL ' cha ;
  449. mai = 'EXTR' cha 'MAIL' ;
  450. nel = 'NBEL' mai ;
  451. *moc = 'MODE' mai 'THERMIQUE' ;
  452. moc = 'MODE' mai 'MECANIQUE' ;
  453. *'MESS' 'moyecham : gravit' ;
  454. cha2 = 'CHAN' 'CHAM' cha moc 'GRAVITE' 'SCALAIRE' ;
  455. * Pb ici
  456. *cha1 = 'MANU' 'CHML' moc 'SCAL' 1. 'TYPE' 'SCALAIRE' 'GRAVITE' ;
  457. *chavol = 'INTG' moc cha1 'ELEM' ;
  458. *'LIST' 'RESU' chavol ;
  459. *'ERRE' stop ;
  460. *ms = 'MOTS' 'SCAL' ;
  461. *'LIST' 'RESU' cha ;
  462. *'LIST' 'RESU' cha2 ;
  463. *'LIST' 'RESU' cha1 ;
  464. *'LIST' 'RESU' chavol ;
  465. * chavol est nul sur les éléments de volume nul
  466. *cha2v = '/' cha2 chavol ms ms ms ;
  467. *som = 'INTG' moc cha2v ;
  468. * Plante sur une erreur 5.
  469. *'MESS' 'moyecham : chpo' ;
  470. chp2 = 'CHAN' 'CHPO' moc cha2 'SUPP' ;
  471. som = 'MAXI' ('RESU' chp2) ;
  472. moy = '/' som nel ;
  473. 'RESPRO' moy ;
  474. *
  475. * End of procedure file MOYECHAM
  476. *
  477. *'FINPROC' ;
  478. 'FINS' ;
  479. *
  480. 'SI' ('EGA' motcle 'AFFCAND') ;
  481. ************************************************************************
  482. * NOM : AFFCAND
  483. * DESCRIPTION :
  484. *
  485. * Procédure pour afficher une table de candidat + la valeur dun critère
  486. * en coloriant le candidat
  487. *
  488. *
  489. *
  490. *
  491. * LANGAGE : GIBIANE-CAST3M
  492. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  493. * mél : stephane.gounand@cea.fr
  494. **********************************************************************
  495. * VERSION : v1, 25/08/2016, version initiale
  496. * HISTORIQUE : v1, 25/08/2016, création
  497. * HISTORIQUE :
  498. * HISTORIQUE :
  499. ************************************************************************
  500. *
  501. *'DEBPROC' AFFCAND ;
  502. 'ARGUMENT' tcand/'TABLE' ;
  503. 'SI' ('NON' ('EXISTE' tcand)) ; tcand = 'TABLE' ; 'FINSI' ;
  504. 'REPETER' boumail ;
  505. 'ARGUMENT' mail/'MAILLAGE' ;
  506. 'SI' ('EXISTE' mail) ;
  507. itab = '+' ('DIME' tcand) 1 ;
  508. tcand . itab = mail ;
  509. 'SINON' ;
  510. 'QUITTER' boumail ;
  511. 'FINSI' ;
  512. 'FIN' boumail ;
  513. *
  514. ltypost = 'MOTS' 'MAIL' 'VOLU' 'QUAL' ;
  515. 'ARGU' typost*'MOT' ;
  516. itypost = 'POSI' typost 'DANS' ltypost ;
  517. 'SI' ('EGA' itypost 0) ;
  518. *Mot-clé incorrect "%M1:4". Voici la liste des valeurs admises :
  519. 'ERRE' 1052 'AVEC' ('CHAI' typost ' MAIL VOLU QUAL') ;
  520. 'FINS' ;
  521. *
  522. tit = 'GOONI FECIT' ;
  523. momet = 'ARIT' ;
  524. *
  525. lmotcle = 'MOTS' 'VMET' 'TITR' 'ARIT' 'GEOM' ;
  526. 'REPETER' imotcle ;
  527. 'ARGUMENT' motcle/'MOT' ;
  528. 'SI' ('NON' ('EXISTE' motcle)) ; 'QUITTER' imotcle ; 'FINSI' ;
  529. * 'MESS' ('CHAI' 'affcand.proc : mot-cle lu :' motcle) ;
  530. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  531. cherr = 'CHAINE' 'Keyword ' motcle ' unknown.' ; 'ERREUR' cherr ;
  532. 'FINSI' ;
  533. 'SI' ('EGA' motcle 'VMET') ;
  534. 'ARGU' metva ;
  535. * 'MESS' ('CHAI' 'affcand.proc : metva=') ;
  536. * 'LIST' ('TYPE' metva);
  537. 'FINS' ;
  538. 'SI' ('EGA' motcle 'TITR') ;
  539. 'ARGU' tit*'MOT' ;
  540. 'FINS' ;
  541. 'SI' ('EGA' motcle 'ARIT') ; momet = motcle ; 'FINS' ;
  542. 'SI' ('EGA' motcle 'GEOM') ; momet = motcle ; 'FINS' ;
  543. 'FIN' imotcle ;
  544. *
  545. ncand = 'DIME' tcand ;
  546. 'SI' ('NON' ('>' ncand 0)) ;
  547. 'ERREUR' 'Table vide' ;
  548. 'FINSI' ;
  549. dx = 0. ;
  550. mtot = 'VIDE' 'MAILLAGE' ;
  551. chvol = 'VIDE' 'CHPOINT'/'DIFFUS' ;
  552. mqual = 'VIDE' 'MMODEL' ;
  553. cqual = 'VIDE' 'MCHAML' ;
  554. vdim = 'VALEUR' 'DIME' ;
  555. 'REPETER' icand ncand ;
  556. tcandi = tcand . &icand ;
  557. mdec = tcandi ;
  558. mtot = 'ET' mtot mdec ;
  559. xm = 'COORDONNEE' 1 tcandi ;
  560. ddx = '*' ('-' ('MAXIMUM' xm) ('MINIMUM' xm)) 1.1 ;
  561. dx = '+' dx ddx ;
  562. 'SI' ('EGA' itypost 2) ;
  563. cdec = 'MANUEL' 'CHPO' mdec 1 'SCAL' ('MESURE' mdec)
  564. 'NATURE' 'DIFFUS' ;
  565. chvol = 'ET' chvol cdec ;
  566. 'FINSI' ;
  567. 'SI' ('EGA' itypost 3) ;
  568. modec = 'MODE' mdec 'THERMIQUE' ;
  569. mqual = 'ET' mqual modec ;
  570. 'SI' ('EXIS' metva) ;
  571. cdec = 'INDI' 'TOPO' mdec metva momet ;
  572. 'SINO' ;
  573. cdec = 'INDI' 'TOPO' mdec ;
  574. 'FINS' ;
  575. cqual = 'ET' cqual cdec ;
  576. 'FINSI' ;
  577. 'FIN' icand ;
  578. *mtra = mtot 'ET' cnt ;
  579. mtra = mtot ;
  580. echq = 'PROG' 0. 'PAS' ('/' 1. 20.) 1. ;
  581. *echv = 'PROG' volucib 'PAS' ('/' ('-' voluini volucib) 20.) voluini ;
  582. *'SI' lnclk ;
  583. * 'SI' ('EGA' itypost 1) ;
  584. * 'TRACER' mtra 'TITR' tit 'NCLK' ;
  585. * 'FINSI' ;
  586. * 'SI' ('EGA' itypost 2) ;
  587. * 'TRACER' chvol mtot mtra 'TITR' tit 'NCLK' ;
  588. * 'FINSI' ;
  589. * 'SI' ('EGA' itypost 3) ;
  590. * 'TRACER' cqual mqual mtra echq 'TITR' tit 'NCLK' ;
  591. * 'FINSI' ;
  592. *'SINON' ;
  593. 'SI' ('EGA' itypost 1) ;
  594. 'TRACER' mtra 'TITR' tit ;
  595. 'FINSI' ;
  596. 'SI' ('EGA' itypost 2) ;
  597. * 'LISTE' echv ; 'LISTE' mtot ;'LISTE' mtra ; 'LISTE' chvol ;
  598. 'TRACER' chvol mtot mtra 'TITR' tit ;
  599. 'FINSI' ;
  600. 'SI' ('EGA' itypost 3) ;
  601. 'TRACER' cqual mqual mtra echq 'TITR' tit ;
  602. 'FINSI' ;
  603. *'FINSI' ;
  604. *
  605. * End of procedure file AFFCAND
  606. *
  607. *'FINPROC' ;
  608. 'FINS' ;
  609. *
  610. 'SI' ('EGA' motcle 'MAILINTE') ;
  611. ************************************************************************
  612. * NOM : MAILINTE
  613. * DESCRIPTION :
  614. *
  615. *
  616. * Procédure MAILINTE qui devient SURF (si dim 2) ou VOLU (si dim 3)
  617. *
  618. *
  619. *
  620. * LANGAGE : GIBIANE-CAST3M
  621. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  622. * mél : stephane.gounand@cea.fr
  623. **********************************************************************
  624. * VERSION : v1, 25/09/2017, version initiale
  625. * HISTORIQUE : v1, 25/09/2017, création
  626. * HISTORIQUE :
  627. * HISTORIQUE :
  628. ************************************************************************
  629. *
  630. *'DEBPROC' MAILINTE ;
  631. 'ARGUMENT' mail*'MAILLAGE' ;
  632. vdim = 'VALEUR' 'DIME' ;
  633. mailb = faux ;
  634. 'SI' ('EGA' vdim 2) ;
  635. mailb = 'SURF' mail ;
  636. 'FINSI' ;
  637. 'SI' ('EGA' vdim 3) ;
  638. mailb = 'VOLU' mail 'VERB' ;
  639. 'FINSI' ;
  640. 'SI' ('EGA' ('TYPE' mail) 'LOGIQUE') ;
  641. 'ERREUR' ('CHAINE' 'vdim=' vdim) ;
  642. 'FINSI' ;
  643. 'RESPRO' mailb ;
  644. *
  645. * End of procedure file MAILINTE
  646. *
  647. *'FINPROC' ;
  648. 'FINS' ;
  649. *
  650. * End of procedure file MATOUTIL
  651. *
  652. 'FINPROC' ;
  653.  
  654.  

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