Télécharger matoutil.procedur

Retour à la liste

Numérotation des lignes :

  1. * MATOUTIL PROCEDUR GOUNAND 21/04/14 21:15:05 10960
  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.  
  228. lmotcle = 'MOTS' 'VMET' 'NAFF' 'REST' ;
  229. 'REPETER' imotcle ;
  230. 'ARGUMENT' motcle/'MOT' ;
  231. 'SI' ('NON' ('EXISTE' motcle)) ; 'QUITTER' imotcle ; 'FINSI' ;
  232. * 'MESS' ('CHAI' 'affqual.proc : mot-cle lu :' motcle) ;
  233. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  234. cherr = 'CHAINE' 'Keyword' ' ' motcle ' unknown.' ; 'ERREUR' cherr ;
  235. 'FINSI' ;
  236. 'SI' ('EGA' motcle 'VMET') ;
  237. 'ARGU' metva ;
  238. * 'MESS' ('CHAI' 'affqual.proc : metva=') ;
  239. * 'LIST' ('TYPE' metva);
  240. 'FINS' ;
  241. 'SI' ('EGA' motcle 'NAFF') ; laff=faux ; 'FINSI' ;
  242. 'SI' ('EGA' motcle 'REST') ; lres=vrai ; 'FINSI' ;
  243. 'FIN' imotcle ;
  244. *'MESS' ('CHAI' 'laff=' laff) ;
  245. *'MESS' ('CHAI' 'lmet=' lmet) ;
  246. *'MESS' ('CHAI' 'lres=' lres) ;
  247. * lmet = faux ;
  248. 'SI' ('EXIS' metva) ;
  249. qtopo = 'INDI' 'TOPO' curtopo metva ;
  250. 'SINO' ;
  251. qtopo = 'INDI' 'TOPO' curtopo ;
  252. 'FINS' ;
  253. *listreel nel = 'DIME' qtopo ;
  254. nel = 'NBEL' curtopo ;
  255. nno = 'NBNO' curtopo ;
  256. dvol = '-' ('MESURE' curtopo) volucib ;
  257. miq = 'MINIMUM' qtopo ; maq = 'MAXIMUM' qtopo ;
  258. *listreel moq = '/' ('SOMME' qtopo) nel ;
  259. moq = MATOUTIL 'MOYECHAM' qtopo ;
  260. *! Test des deux façons de calculer !
  261. 'SI' ('EXIS' metva) ;
  262. qtopo2 = 'INDI' 'TOPO' curtopo metva 'LISTREEL' ;
  263. 'SINO' ;
  264. qtopo2 = 'INDI' 'TOPO' curtopo 'LISTREEL' ;
  265. 'FINS' ;
  266. moq2 = ('SOMM' qtopo2) '/' ('DIME' qtopo2) ;
  267. * VALE prec un peu trop serré pour semt2
  268. 'SI' ('NEG' moq moq2 ('*' ('VALE' 'PREC') 10.)) ;
  269. 'MESS' 'moq,moq2,dmoq' moq moq2 ('-' moq moq2) ;
  270. 'FINS' ;
  271. * moqtopo = 'MODE' curtopo 'THERMIQUE' ;
  272. * moq = '/' ('INTG' qtopo moqtopo) ('MESU' curtopo) ;
  273. *listreel lvnul = POSI 0.D0 'DANS' qtopo volutol 'TOUS' ;
  274. *listreel nnul = 'DIME' lvnul ;
  275. nnul = 'MASQ' qtopo 'EGINFE' 'SOMME' volutol ;
  276. 'SI' lres ;
  277. 'RESP' dvol nel nnul nno miq maq moq ;
  278. 'FINS' ;
  279. 'SI' laff ;
  280. *'SI' ('EGA' nnul 0) ;
  281. titq = 'CHAINE' 'FORMAT' '(E9.2)'
  282. ' Dvol=' dvol ' Nel=' nel ' NelV0=' nnul ' Nno=' nno
  283. ' Qmin=' miq ' Qmax=' maq ' Qmoy=' moq ;
  284. *'SINON' ;
  285. * titq = 'CHAINE' ' Dvol=' dvol ' N=' nel
  286. * ' N0=' nnul ' max=' maq ' moy=' moq ;
  287. *'FINSI' ;
  288. * titv = 'CHAINE' 'Nb. Elements plats=' nnul ;
  289. 'MESSAGE' titq ;
  290. * 'MESSAGE' titv ;
  291. 'FINS' ;
  292. *
  293. * End of procedure file AFFQUAL
  294. *
  295. 'FINS' ;
  296. *
  297. 'SI' ('EGA' motcle 'BORD') ;
  298. ************************************************************************
  299. * NOM : BORD
  300. * DESCRIPTION :
  301. *
  302. *
  303. * Procédure BORD qui devient CONTOUR (si dim 2) ou ENVELOPPE (si dim 3)
  304. *
  305. *
  306. *
  307. * LANGAGE : GIBIANE-CAST3M
  308. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  309. * mél : stephane.gounand@cea.fr
  310. **********************************************************************
  311. * VERSION : v1, 25/08/2016, version initiale
  312. * HISTORIQUE : v1, 25/08/2016, création
  313. * HISTORIQUE :
  314. * HISTORIQUE :
  315. ************************************************************************
  316. *
  317. 'ARGUMENT' mail*'MAILLAGE' ;
  318. *vdim = 'VALEUR' 'DIME' ;
  319. mdim = DEADUTIL 'DIMM' mail ;
  320. mailb = faux ;
  321. 'SI' ('EGA' mdim 2) ;
  322. mailb = 'CONTOUR' mail 'NOID' ;
  323. 'FINSI' ;
  324. 'SI' ('EGA' mdim 3) ;
  325. mailb = 'ENVELOPPE' mail 'NOID' ;
  326. * mailb = 'ENVELOPPE' mail ;
  327. 'FINSI' ;
  328. 'SI' ('EGA' ('TYPE' mail) 'LOGIQUE') ;
  329. 'ERREUR' ('CHAINE' 'mdim=' mdim) ;
  330. 'FINSI' ;
  331. 'RESPRO' mailb ;
  332. *
  333. * End of procedure file BORD
  334. *
  335. 'FINS' ;
  336. *
  337. 'SI' ('EGA' motcle 'FERMEPZ') ;
  338. ************************************************************************
  339. * NOM : FERMEPZ
  340. * DESCRIPTION :
  341. *
  342. * Ferme une topologie en étoilant son contour avec un point donné
  343. *
  344. *
  345. *
  346. *
  347. * LANGAGE : GIBIANE-CAST3M
  348. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  349. * mél : stephane.gounand@cea.fr
  350. **********************************************************************
  351. * VERSION : v1, 25/08/2016, version initiale
  352. * HISTORIQUE : v1, 25/08/2016, création
  353. * HISTORIQUE : v2 11/06/2018, ajout 2eme maillage servant à la partie
  354. * du contour qui ne doit pas être changée
  355. * HISTORIQUE :
  356. ************************************************************************
  357. *
  358. *'DEBPROC' FERMEPZ ;
  359. 'ARGUMENT' topo*'MAILLAGE' ;
  360. 'ARGU' mailnoch/'MAILLAGE' ;
  361. 'ARGUMENT' pferm*'POINT' ;
  362. * Le inverse semble hyper important !!!!
  363. btopo = (MATOUTIL 'BORD' topo) ;
  364. 'SI' ('EXIS' mailnoch) ;
  365. btopo2 = 'DIFF' btopo mailnoch ;
  366. btopo = btopo2 ;
  367. 'FINS' ;
  368. ctopo = 'INVERSE' btopo ;
  369. * topof = topo 'ET' (ETOILE pferm ctopo) ;
  370. topof = topo 'ET' ('COUT' pferm ctopo) ;
  371. * Teste si la topologie résultante est sans bord
  372. *TESTIDMA (BORD topof) ('VIDE' 'MAILLAGE') ;
  373. 'RESPRO' topof ;
  374. *
  375. * End of procedure file FERMEPZ
  376. *
  377. *'FINPROC' ;
  378. 'FINS' ;
  379. *
  380. *
  381. 'SI' ('EGA' motcle 'OUVREPZ') ;
  382. ************************************************************************
  383. * NOM : OUVREPZ
  384. * DESCRIPTION :
  385. *
  386. *
  387. * Ouvre une topologie en enlevant les éléments touchant un point donné
  388. *
  389. *
  390. *
  391. * LANGAGE : GIBIANE-CAST3M
  392. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  393. * mél : stephane.gounand@cea.fr
  394. **********************************************************************
  395. * VERSION : v1, 25/08/2016, version initiale
  396. * HISTORIQUE : v1, 25/08/2016, création
  397. * HISTORIQUE :
  398. * HISTORIQUE :
  399. ************************************************************************
  400. *
  401. *'DEBPROC' OUVREPZ ;
  402. 'ARGUMENT' topo*'MAILLAGE' ;
  403. 'ARGUMENT' pferm*'POINT' ;
  404. touchp = 'ELEM' topo 'APPUYE' 'LARGEMENT' pferm 'NOVERIF' ;
  405. topoo = 'DIFF' topo touchp ;
  406. 'RESPRO' topoo ;
  407. *
  408. * End of procedure file OUVREPZ
  409. *
  410. *'FINPROC' ;
  411. 'FINS' ;
  412. *
  413. 'SI' ('EGA' motcle 'MOYECHAM') ;
  414. ************************************************************************
  415. * NOM : MOYECHAM
  416. * DESCRIPTION : Fait la moyenne d'un champ par élément (supposé scalaire
  417. * et constant par élément) au sens : somme des valeurs
  418. * sur les éléments divisée par le nombre d'éléments.
  419. *
  420. *
  421. *
  422. * LANGAGE : GIBIANE-CAST3M
  423. * AUTEUR : Stephane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  424. * mail : stephane.gounand@cea.fr
  425. **********************************************************************
  426. * VERSION : v1, 02/05/2020, version initiale
  427. * HISTORIQUE : v1, 02/05/2020, creation
  428. * HISTORIQUE :
  429. * HISTORIQUE :
  430. ************************************************************************
  431. *
  432. *'DEBPROC' MOYECHAM ;
  433. 'ARGUMENT' cha*'MCHAML' ;
  434. *
  435. lco = 'EXTR' cha 'COMP' ;
  436. dco = 'DIME' lco ;
  437. * 320 2
  438. * Il faut specifier un champ par element avec une seule composante
  439. 'SI' ('NEG' dco 1) ;
  440. 'ERRE' 320 ;
  441. 'FINS' ;
  442. * Change le nom de composante en scal plutôt que qualtopo
  443. * car sinon chan chpo supp plante.
  444. *cha = 'EXCO' ('EXTR' lco 1) cha 'SCAL ' ;
  445. cha = 'CHAN' 'COMP' 'SCAL ' cha ;
  446. mai = 'EXTR' cha 'MAIL' ;
  447. nel = 'NBEL' mai ;
  448. *moc = 'MODE' mai 'THERMIQUE' ;
  449. moc = 'MODE' mai 'MECANIQUE' ;
  450. *'MESS' 'moyecham : gravit' ;
  451. cha2 = 'CHAN' 'CHAM' cha moc 'GRAVITE' 'SCALAIRE' ;
  452. * Pb ici
  453. *cha1 = 'MANU' 'CHML' moc 'SCAL' 1. 'TYPE' 'SCALAIRE' 'GRAVITE' ;
  454. *chavol = 'INTG' moc cha1 'ELEM' ;
  455. *'LIST' 'RESU' chavol ;
  456. *'ERRE' stop ;
  457. *ms = 'MOTS' 'SCAL' ;
  458. *'LIST' 'RESU' cha ;
  459. *'LIST' 'RESU' cha2 ;
  460. *'LIST' 'RESU' cha1 ;
  461. *'LIST' 'RESU' chavol ;
  462. * chavol est nul sur les éléments de volume nul
  463. *cha2v = '/' cha2 chavol ms ms ms ;
  464. *som = 'INTG' moc cha2v ;
  465. * Plante sur une erreur 5.
  466. *'MESS' 'moyecham : chpo' ;
  467. chp2 = 'CHAN' 'CHPO' moc cha2 'SUPP' ;
  468. som = 'MAXI' ('RESU' chp2) ;
  469. moy = '/' som nel ;
  470. 'RESPRO' moy ;
  471. *
  472. * End of procedure file MOYECHAM
  473. *
  474. *'FINPROC' ;
  475. 'FINS' ;
  476. *
  477. 'SI' ('EGA' motcle 'AFFCAND') ;
  478. ************************************************************************
  479. * NOM : AFFCAND
  480. * DESCRIPTION :
  481. *
  482. * Procédure pour afficher une table de candidat + la valeur dun critère
  483. * en coloriant le candidat
  484. *
  485. *
  486. *
  487. *
  488. * LANGAGE : GIBIANE-CAST3M
  489. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  490. * mél : stephane.gounand@cea.fr
  491. **********************************************************************
  492. * VERSION : v1, 25/08/2016, version initiale
  493. * HISTORIQUE : v1, 25/08/2016, création
  494. * HISTORIQUE :
  495. * HISTORIQUE :
  496. ************************************************************************
  497. *
  498. *'DEBPROC' AFFCAND ;
  499. 'ARGUMENT' tcand/'TABLE' ;
  500. 'SI' ('NON' ('EXISTE' tcand)) ; tcand = 'TABLE' ; 'FINSI' ;
  501. 'REPETER' boumail ;
  502. 'ARGUMENT' mail/'MAILLAGE' ;
  503. 'SI' ('EXISTE' mail) ;
  504. itab = '+' ('DIME' tcand) 1 ;
  505. tcand . itab = mail ;
  506. 'SINON' ;
  507. 'QUITTER' boumail ;
  508. 'FINSI' ;
  509. 'FIN' boumail ;
  510. *
  511. ltypost = 'MOTS' 'MAIL' 'VOLU' 'QUAL' ;
  512. 'ARGU' typost*'MOT' ;
  513. itypost = 'POSI' typost 'DANS' ltypost ;
  514. 'SI' ('EGA' itypost 0) ;
  515. *Mot-clé incorrect "%M1:4". Voici la liste des valeurs admises :
  516. 'ERRE' 1052 'AVEC' ('CHAI' typost ' MAIL VOLU QUAL') ;
  517. 'FINS' ;
  518. *
  519. tit = 'GOONI FECIT' ;
  520. *
  521. lmotcle = 'MOTS' 'VMET' 'TITR' ;
  522. 'REPETER' imotcle ;
  523. 'ARGUMENT' motcle/'MOT' ;
  524. 'SI' ('NON' ('EXISTE' motcle)) ; 'QUITTER' imotcle ; 'FINSI' ;
  525. * 'MESS' ('CHAI' 'affcand.proc : mot-cle lu :' motcle) ;
  526. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  527. cherr = 'CHAINE' 'Keyword ' motcle ' unknown.' ; 'ERREUR' cherr ;
  528. 'FINSI' ;
  529. 'SI' ('EGA' motcle 'VMET') ;
  530. 'ARGU' metva ;
  531. * 'MESS' ('CHAI' 'affcand.proc : metva=') ;
  532. * 'LIST' ('TYPE' metva);
  533. 'FINS' ;
  534. 'SI' ('EGA' motcle 'TITR') ;
  535. 'ARGU' tit*'MOT' ;
  536. 'FINS' ;
  537. 'FIN' imotcle ;
  538. *
  539. ncand = 'DIME' tcand ;
  540. 'SI' ('NON' ('>' ncand 0)) ;
  541. 'ERREUR' 'Table vide' ;
  542. 'FINSI' ;
  543. dx = 0. ;
  544. mtot = 'VIDE' 'MAILLAGE' ;
  545. chvol = 'VIDE' 'CHPOINT'/'DIFFUS' ;
  546. mqual = 'VIDE' 'MMODEL' ;
  547. cqual = 'VIDE' 'MCHAML' ;
  548. vdim = 'VALEUR' 'DIME' ;
  549. 'REPETER' icand ncand ;
  550. tcandi = tcand . &icand ;
  551. mdec = tcandi ;
  552. mtot = 'ET' mtot mdec ;
  553. xm = 'COORDONNEE' 1 tcandi ;
  554. ddx = '*' ('-' ('MAXIMUM' xm) ('MINIMUM' xm)) 1.1 ;
  555. dx = '+' dx ddx ;
  556. 'SI' ('EGA' itypost 2) ;
  557. cdec = 'MANUEL' 'CHPO' mdec 1 'SCAL' ('MESURE' mdec)
  558. 'NATURE' 'DIFFUS' ;
  559. chvol = 'ET' chvol cdec ;
  560. 'FINSI' ;
  561. 'SI' ('EGA' itypost 3) ;
  562. modec = 'MODE' mdec 'THERMIQUE' ;
  563. mqual = 'ET' mqual modec ;
  564. 'SI' ('EXIS' metva) ;
  565. cdec = 'INDI' 'TOPO' mdec metva ;
  566. 'SINO' ;
  567. cdec = 'INDI' 'TOPO' mdec ;
  568. 'FINS' ;
  569. cqual = 'ET' cqual cdec ;
  570. 'FINSI' ;
  571. 'FIN' icand ;
  572. *mtra = mtot 'ET' cnt ;
  573. mtra = mtot ;
  574. echq = 'PROG' 0. 'PAS' ('/' 1. 20.) 1. ;
  575. *echv = 'PROG' volucib 'PAS' ('/' ('-' voluini volucib) 20.) voluini ;
  576. *'SI' lnclk ;
  577. * 'SI' ('EGA' itypost 1) ;
  578. * 'TRACER' mtra 'TITR' tit 'NCLK' ;
  579. * 'FINSI' ;
  580. * 'SI' ('EGA' itypost 2) ;
  581. * 'TRACER' chvol mtot mtra 'TITR' tit 'NCLK' ;
  582. * 'FINSI' ;
  583. * 'SI' ('EGA' itypost 3) ;
  584. * 'TRACER' cqual mqual mtra echq 'TITR' tit 'NCLK' ;
  585. * 'FINSI' ;
  586. *'SINON' ;
  587. 'SI' ('EGA' itypost 1) ;
  588. 'TRACER' mtra 'TITR' tit ;
  589. 'FINSI' ;
  590. 'SI' ('EGA' itypost 2) ;
  591. * 'LISTE' echv ; 'LISTE' mtot ;'LISTE' mtra ; 'LISTE' chvol ;
  592. 'TRACER' chvol mtot mtra 'TITR' tit ;
  593. 'FINSI' ;
  594. 'SI' ('EGA' itypost 3) ;
  595. 'TRACER' cqual mqual mtra echq 'TITR' tit ;
  596. 'FINSI' ;
  597. *'FINSI' ;
  598. *
  599. * End of procedure file AFFCAND
  600. *
  601. *'FINPROC' ;
  602. 'FINS' ;
  603. *
  604. 'SI' ('EGA' motcle 'MAILINTE') ;
  605. ************************************************************************
  606. * NOM : MAILINTE
  607. * DESCRIPTION :
  608. *
  609. *
  610. * Procédure MAILINTE qui devient SURF (si dim 2) ou VOLU (si dim 3)
  611. *
  612. *
  613. *
  614. * LANGAGE : GIBIANE-CAST3M
  615. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  616. * mél : stephane.gounand@cea.fr
  617. **********************************************************************
  618. * VERSION : v1, 25/09/2017, version initiale
  619. * HISTORIQUE : v1, 25/09/2017, création
  620. * HISTORIQUE :
  621. * HISTORIQUE :
  622. ************************************************************************
  623. *
  624. *'DEBPROC' MAILINTE ;
  625. 'ARGUMENT' mail*'MAILLAGE' ;
  626. vdim = 'VALEUR' 'DIME' ;
  627. mailb = faux ;
  628. 'SI' ('EGA' vdim 2) ;
  629. mailb = 'SURF' mail ;
  630. 'FINSI' ;
  631. 'SI' ('EGA' vdim 3) ;
  632. mailb = 'VOLU' mail 'VERB' ;
  633. 'FINSI' ;
  634. 'SI' ('EGA' ('TYPE' mail) 'LOGIQUE') ;
  635. 'ERREUR' ('CHAINE' 'vdim=' vdim) ;
  636. 'FINSI' ;
  637. 'RESPRO' mailb ;
  638. *
  639. * End of procedure file MAILINTE
  640. *
  641. *'FINPROC' ;
  642. 'FINS' ;
  643. *
  644. * End of procedure file MATOUTIL
  645. *
  646. 'FINPROC' ;
  647.  
  648.  
  649.  
  650.  

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