Télécharger matoutil.procedur

Retour à la liste

Numérotation des lignes :

  1. * MATOUTIL PROCEDUR GOUNAND 26/01/12 21:15:03 12448
  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' 'VERITOPO' ;
  23. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  24. 'ERREUR' 1052 'AVEC' motcle
  25. 'GASTIDX GENTABIN VERTABIN MESUINTE AFFQUAL BORD FERMEPZ OUVREPZ MOYECHAM AFFCAND MAILINTE VERITOPO' ;
  26. 'FINSI' ;
  27. *
  28. 'SI' ('EGA' motcle 'GASTIDX') ;
  29. ************************************************************************
  30. * NOM : GASTIDX
  31. * DESCRIPTION : Get and set table index
  32. *
  33. *
  34. *
  35. * LANGAGE : GIBIANE-CAST3M
  36. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  37. * mél : stephane.gounand@cea.fr
  38. **********************************************************************
  39. * VERSION : v1, 08/12/2017, version initiale
  40. * HISTORIQUE : v1, 08/12/2017, création
  41. * HISTORIQUE :
  42. * HISTORIQUE :
  43. ************************************************************************
  44. *
  45. *'DEBPROC' GASTIDX ;
  46. 'ARGU' tab*'TABLE' ;
  47. 'ARGUMENT' idx*'MOT' ;
  48. 'ARGU' valdef ;
  49. *
  50. valdefd = 'EXIS' valdef ;
  51. idxd = 'EXIS' tab idx ;
  52. setd = valdefd 'ET' ('NON' idxd) ;
  53. *
  54. *debug = 'VALE' debu ;
  55. *
  56. 'SI' setd ;
  57. tab . idx = valdef ;
  58. 'FINS' ;
  59. val = tab . idx ;
  60. *
  61. 'SI' faux ;
  62. tval = 'TYPE' val ;
  63. 'SI' (('EGA' tval 'ENTIER') 'OU' ('EGA' tval 'FLOTTANT') 'OU' ('EGA'
  64. tval 'MOT') 'OU' ('EGA' tval 'LOGIQUE')) ;
  65. mval = val ;
  66. 'SINO' ;
  67. mval = 'CHAI' '*' tval ;
  68. 'FINS' ;
  69. ch = 'CHAI' 'tab . ' idx*20 '='/21 mval*40 ;
  70. 'SI' setd ;
  71. ch = 'CHAI' ch '(defaut)'*60 ;
  72. 'FINS' ;
  73. 'MESS' ch ;
  74. 'FINS' ;
  75. *
  76. 'RESPRO' val ;
  77. *
  78. * End of procedure file GASTIDX
  79. *
  80. 'FINSI' ;
  81. 'SI' ('EGA' motcle 'GENTABIN') ;
  82. *$$$$ GENTABIN
  83. ************************************************************************
  84. * NOM : GENTABIN
  85. * DESCRIPTION : Construit une table dont les indices sont les mots
  86. * donnés en entrée.
  87. * Cette table sert ensuite dans VERTABIN pour vérifier
  88. * que tous les indices d'une autre table ne sont pas
  89. * différents de ceux de la première
  90. *
  91. * C'est un peu l'équivalent de MOTS et EXIS tab LISTMOTS
  92. * pour des mots de taille quelconque.
  93. *
  94. * LANGAGE : GIBIANE-CAST3M
  95. * AUTEUR : Stephane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  96. * mail : stephane.gounand@cea.fr
  97. **********************************************************************
  98. * VERSION : v1, 14/04/2020, version initiale
  99. * HISTORIQUE : v1, 14/04/2020, creation
  100. * HISTORIQUE :
  101. * HISTORIQUE :
  102. ************************************************************************
  103. *
  104. *'DEBPROC' GENTABIN ;
  105. 'ARGUMENT' tabin/'TABLE' ;
  106. 'SI' ('NON' ('EXIS' tabin)) ;
  107. tabin = 'TABL' ;
  108. 'FINS' ;
  109. 'REPE' bcl ;
  110. 'ARGU' titi/'MOT' ;
  111. 'SI' ('EXIS' titi) ;
  112. *dbg 'MESS' 'gentabin titi' ' ' titi ;
  113. tabin . titi = vrai ;
  114. 'SINO' ;
  115. 'QUIT' bcl ;
  116. 'FINS' ;
  117. 'FIN' bcl ;
  118. 'RESPRO' tabin ;
  119. *
  120. * End of procedure file GENTABIN
  121. *
  122. *'FINPROC' ;
  123. 'FINS' ;
  124. *
  125. 'SI' ('EGA' motcle 'VERTABIN') ;
  126. ************************************************************************
  127. * NOM : VERTABIN
  128. * DESCRIPTION : GENTABIN a construit une table dont les indices sont les
  129. * mots donnés en entrée.
  130. * Cette table sert ensuite dans VERTABIN pour vérifier
  131. * que tous les indices d'une autre table ne sont pas
  132. * différents de ceux de la première
  133. *
  134. * C'est un peu l'équivalent de MOTS et EXIS tab LISTMOTS
  135. * pour des mots de taille quelconque.
  136. *
  137. * LANGAGE : GIBIANE-CAST3M
  138. * AUTEUR : Stephane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  139. * mail : stephane.gounand@cea.fr
  140. **********************************************************************
  141. * VERSION : v1, 14/04/2020, version initiale
  142. * HISTORIQUE : v1, 14/04/2020, creation
  143. * HISTORIQUE :
  144. * HISTORIQUE :
  145. ************************************************************************
  146. *
  147. *'DEBPROC' VERTABIN ;
  148. 'ARGU' tverif*'TABLE' ;
  149. 'ARGU' tabin*'TABLE' ;
  150. tlicit = 'INDE' tverif ;
  151. *dbg 'LIST' tlicit ;
  152. dtl = 'DIME' tlicit ;
  153. 'REPE' itl dtl ;
  154. idx = 'CHAI' tlicit . &itl ;
  155. *dbg 'MESS' 'vertabin idx' ' ' idx ;
  156. 'SI' ('NON' ('EXIS' tabin idx)) ;
  157. * 791 2
  158. *Indice %m1:8 : N'est pas un indice de table reconnu
  159. 'ERRE' 791 'AVEC' idx ;
  160. 'FINS' ;
  161. 'FIN' itl ;
  162. *
  163. * End of procedure file VERTABIN
  164. *
  165. *'FINPROC' ;
  166. 'FINS' ;
  167. *
  168. 'SI' ('EGA' motcle 'MESUINTE') ;
  169. ************************************************************************
  170. * NOM : MESUINTE
  171. * DESCRIPTION :
  172. *
  173. *
  174. * Procédure MESUINTE qui devient MESU SURF (si dim 2) ou MESU VOLU (si dim 3)
  175. *
  176. *
  177. *
  178. * LANGAGE : GIBIANE-CAST3M
  179. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  180. * mél : stephane.gounand@cea.fr
  181. **********************************************************************
  182. * VERSION : v1, 25/08/2016, version initiale
  183. * HISTORIQUE : v1, 25/08/2016, création
  184. * HISTORIQUE :
  185. * HISTORIQUE :
  186. ************************************************************************
  187. *
  188. 'ARGUMENT' mai*'MAILLAGE' ;
  189. vdim = 'VALEUR' 'DIME' ;
  190. 'SI' ('EGA' vdim 2) ;
  191. vol = 'MESURE' mai 'SURF' ;
  192. 'SINON' ;
  193. vol = 'MESURE' mai 'VOLU' ;
  194. 'FINSI' ;
  195. 'RESPRO' vol ;
  196. *
  197. * End of procedure file MESUINTE
  198. *
  199. 'FINS' ;
  200. *
  201. 'SI' ('EGA' motcle 'AFFQUAL') ;
  202. ************************************************************************
  203. * NOM : AFFQUAL
  204. * DESCRIPTION : Affiche les qualités d'un maillage
  205. *
  206. *
  207. *
  208. * LANGAGE : GIBIANE-CAST3M
  209. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  210. * mél : stephane.gounand@cea.fr
  211. **********************************************************************
  212. * VERSION : v1, 25/08/2016, version initiale
  213. * HISTORIQUE : v1, 25/08/2016, création
  214. * HISTORIQUE :
  215. * HISTORIQUE :
  216. ************************************************************************
  217. *
  218. 'ARGUMENT' curtopo*'MAILLAGE' ;
  219. 'ARGU' volucib*'FLOTTANT' ;
  220. 'ARGU' denstol*'FLOTTANT' ;
  221. *
  222. *lmet=faux ;
  223.  
  224. laff=vrai ;
  225. lres=faux ;
  226. momet = 'ARIT' ;
  227.  
  228. lmotcle = 'MOTS' 'VMET' 'NAFF' 'REST' 'ARIT' 'GEOM' ;
  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. 'SI' ('EGA' motcle 'ARIT') ; momet = motcle ; 'FINSI' ;
  244. 'SI' ('EGA' motcle 'GEOM') ; momet = motcle ; 'FINSI' ;
  245. 'FIN' imotcle ;
  246. *'MESS' ('CHAI' 'laff=' laff) ;
  247. *'MESS' ('CHAI' 'lmet=' lmet) ;
  248. *'MESS' ('CHAI' 'lres=' lres) ;
  249. * lmet = faux ;
  250. 'SI' ('EXIS' metva) ;
  251. qtopo = 'INDI' 'TOP2' curtopo metva momet ;
  252. 'SINO' ;
  253. qtopo = 'INDI' 'TOP2' curtopo ;
  254. 'FINS' ;
  255. *listreel nel = 'DIME' qtopo ;
  256. nel = 'NBEL' curtopo ;
  257. nno = 'NBNO' curtopo ;
  258. dvol = '-' ('MESURE' curtopo) volucib ;
  259. cqalo = 'EXTR' qtopo 'VALE' 'TOP2' ;
  260. cqalo = 'ORDO' cqalo ; dcqalo = 'DIME' cqalo ;
  261. miq = 'EXTR' cqalo 1 ; maq = 'EXTR' cqalo dcqalo ;
  262. meq = 'EXTR' cqalo ('/' ('+' 1 dcqalo) 2) ;
  263. * miq = 'MINIMUM' qtopo ; maq = 'MAXIMUM' qtopo ;
  264. **listreel moq = '/' ('SOMME' qtopo) nel ;
  265. * moq = MATOUTIL 'MOYECHAM' qtopo ;
  266. *! Test des deux façons de calculer !
  267. 'SI' ('EXIS' metva) ;
  268. qtopo2 = 'INDI' 'TOP2' curtopo metva momet 'LISTREEL' ;
  269. 'SINO' ;
  270. qtopo2 = 'INDI' 'TOP2' curtopo 'LISTREEL' ;
  271. 'FINS' ;
  272. cqalo2 = 'ORDO' qtopo2 ; dcqalo2 = 'DIME' cqalo2 ;
  273. meq2 = 'EXTR' cqalo2 ('/' ('+' 1 dcqalo2) 2) ;
  274. * moq2 = ('SOMM' qtopo2) '/' ('DIME' qtopo2) ;
  275. * VALE prec un peu trop serré pour semt2
  276. 'SI' ('NEG' meq meq2 ('*' ('VALE' 'PREC') 10.)) ;
  277. 'MESS' 'meq,meq2,dmeq' meq meq2 ('-' meq meq2) ;
  278. 'FINS' ;
  279. * moqtopo = 'MODE' curtopo 'THERMIQUE' ;
  280. * moq = '/' ('INTG' qtopo moqtopo) ('MESU' curtopo) ;
  281. *listreel lvnul = POSI 0.D0 'DANS' qtopo volutol 'TOUS' ;
  282. *listreel nnul = 'DIME' lvnul ;
  283. *non ! Les qtopo sont des rapports de longueurs au carré
  284. * Les qtopo sont des rapports de longueurs
  285. nnul = 'MASQ' ('EXCO' 'TOP2' qtopo) 'EGINFE' 'SOMME' denstol ;
  286. 'SI' lres ;
  287. 'RESP' dvol nel nnul nno miq maq meq ;
  288. 'FINS' ;
  289. 'SI' laff ;
  290. *'SI' ('EGA' nnul 0) ;
  291. titq = 'CHAINE' 'FORMAT' '(E9.2)'
  292. ' Dvol=' dvol ' Nel=' nel ' Nel0=' nnul ' Nno=' nno
  293. ' Qmin=' miq ' Qmax=' maq ' Qmed=' meq ;
  294. *'SINON' ;
  295. * titq = 'CHAINE' ' Dvol=' dvol ' N=' nel
  296. * ' N0=' nnul ' max=' maq ' moy=' moq ;
  297. *'FINSI' ;
  298. * titv = 'CHAINE' 'Nb. Elements plats=' nnul ;
  299. 'MESSAGE' titq ;
  300. * 'MESSAGE' titv ;
  301. 'FINS' ;
  302. *
  303. * End of procedure file AFFQUAL
  304. *
  305. 'FINS' ;
  306. *
  307. 'SI' ('EGA' motcle 'BORD') ;
  308. ************************************************************************
  309. * NOM : BORD
  310. * DESCRIPTION :
  311. *
  312. *
  313. * Procédure BORD qui devient CONTOUR (si dim 2) ou ENVELOPPE (si dim 3)
  314. *
  315. *
  316. *
  317. * LANGAGE : GIBIANE-CAST3M
  318. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  319. * mél : stephane.gounand@cea.fr
  320. **********************************************************************
  321. * VERSION : v1, 25/08/2016, version initiale
  322. * HISTORIQUE : v1, 25/08/2016, création
  323. * HISTORIQUE :
  324. * HISTORIQUE :
  325. ************************************************************************
  326. *
  327. 'ARGUMENT' mail*'MAILLAGE' ;
  328. *vdim = 'VALEUR' 'DIME' ;
  329. mdim = DEADUTIL 'DIMM' mail ;
  330. mailb = faux ;
  331. 'SI' ('EGA' mdim 2) ;
  332. mailb = 'CONTOUR' mail 'NOID' ;
  333. 'FINSI' ;
  334. 'SI' ('EGA' mdim 3) ;
  335. mailb = 'ENVELOPPE' mail 'NOID' ;
  336. * mailb = 'ENVELOPPE' mail ;
  337. 'FINSI' ;
  338. 'SI' ('EGA' ('TYPE' mail) 'LOGIQUE') ;
  339. 'ERREUR' ('CHAINE' 'mdim=' mdim) ;
  340. 'FINSI' ;
  341. 'RESPRO' mailb ;
  342. *
  343. * End of procedure file BORD
  344. *
  345. 'FINS' ;
  346. *
  347. 'SI' ('EGA' motcle 'FERMEPZ') ;
  348. ************************************************************************
  349. * NOM : FERMEPZ
  350. * DESCRIPTION :
  351. *
  352. * Ferme une topologie en étoilant son contour avec un point donné
  353. *
  354. *
  355. *
  356. *
  357. * LANGAGE : GIBIANE-CAST3M
  358. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  359. * mél : stephane.gounand@cea.fr
  360. **********************************************************************
  361. * VERSION : v1, 25/08/2016, version initiale
  362. * HISTORIQUE : v1, 25/08/2016, création
  363. * HISTORIQUE : v2 11/06/2018, ajout 2eme maillage servant à la partie
  364. * du contour qui ne doit pas être changée
  365. * HISTORIQUE : v3 on decoupe le bord en morceaux plats...
  366. ************************************************************************
  367. *
  368. *'DEBPROC' FERMEPZ ;
  369. 'ARGUMENT' topo*'MAILLAGE' ;
  370. 'ARGU' mailnoch*'MAILLAGE' ;
  371. 'ARGU' ialgo*'ENTIER' ;
  372. 'ARGU' denstol*'FLOTTANT' ;
  373. 'ARGU' impr*'ENTIER' ;
  374. *'ARGUMENT' pferm*'POINT' ;
  375. * Le inverse semble hyper important !!!!
  376. btopo = MATOUTIL 'BORD' topo ;
  377. 'SI' ('EXIS' mailnoch) ;
  378. btopo2 = 'DIFF' btopo mailnoch ;
  379. btopo = btopo2 ;
  380. 'FINS' ;
  381. * Partitionnement
  382. *old Si ialgo=0, il faut verifier l'absence d'elements degeneres au bord
  383. * Si ialgo=0, il faut supprimer les elements degeneres du bord
  384. * sinon part ne peut fonctionner
  385. lpart= vrai ;
  386. 'SI' ('EGA' ialgo 0) ;
  387. * ttopo = 'ELEM' topo 'APPUYE' 'ELEM' btopo ;
  388. * jttopo = DEADJACO ttopo ;
  389. imetopo = DEADMETR btopo ;
  390. spetopo = 'TENS' 'PRIN' imetopo ;
  391. * On prend l'avant-derniere valeur propre (la derniere est nulle car element surfacique)
  392. avdim = '-' ('VALE' 'DIME') 1 ;
  393. navvp = 'CHAI' 'SI' avdim avdim ;
  394. avvp = 'EXCO' navvp spetopo ;
  395. lavvp = '**' ('ABS' avvp) 0.5 ;
  396. milavvp = 'MINI' lavvp ; malavvp = 'MAXI' lavvp ;
  397. * vtol2 = '**' vtol 0.7 ;
  398. * 'MESS' 'FERMEPZ : milavvp=' milavvp ' malavvp=' malavvp ' denstol=' denstol ;
  399. etopo0 = 'ELEM' lavvp 'EGINFE' denstol ;
  400. nel0 = 'NBEL' etopo0 ;
  401. 'SI' ('>' nel0 0) ;
  402. 'MESS' '!! FERMEPZ : on enleve' ' ' nel0 ' elements du bord qui sont singuliers.' ;
  403. 'MESS' '!! : milavvp=' milavvp ' malavvp=' malavvp ' denstol=' denstol ;
  404. btopo3 = 'DIFF' btopo etopo0 ;
  405. btopo = btopo3 ;
  406. * lpart = faux ;
  407. * btopo0 = MATOUTIL 'BORD' ttopo0 ;
  408. * ibt = 'INTE' btopo0 btopo ;
  409. * nibt = 'NBEL' ibt ;
  410. * 'SI' ('>' nibt 0) ;
  411. * 'MESS' '!! :' ' ' nibt ' elements du bord ne seront pas etoiles.' ;
  412. * btopo3 = 'DIFF' btopo ibt ;
  413. * btopo = btopo3 ;
  414. * 'FINS' ;
  415. 'FINS' ;
  416. *old2 jctopo = 'INDI' 'ISOD' ctopo ;
  417. *old2 mijct = 'MINI' jctopo ; majct = 'MAXI' jctopo ;
  418. *old2 ctopo2 = 'ELEM' jctopo 'SUPERIEUR' vtol 'STRI' ;
  419. *old2 nelv = '-' ('NBEL' ctopo) ('NBEL' ctopo2) ;
  420. *old2 'MESS' 'FERMEPZ : mijct=' mijct ' majct=' majct ' vtol=' vtol ;
  421. *old2 'SI' ('>' nelv 0) ;
  422. *old2 'MESS' '!! FERMEPZ : on enleve' ' ' nelv ' elements du bord.' ;
  423. *old2 'FINS' ;
  424. *old2 ctopo = ctopo2 ;
  425. *old ttopo = 'ELEM' topo 'APPUYE' 'ELEM' btopo ;
  426. *old ctop = 'INDI' 'TOP2' ttopo ;
  427. *old mictop = 'MINI' ctop ;
  428. *old 'SI' ('<' mictop vtol) ;
  429. *old 'SI' ('>EG' impr 2) ;
  430. *old 'MESS' 'minivol=' mictop ' => elements degeneres touchant le bord : pas* de noeud virtuel pour cette passe' ;
  431. *old 'FINS' ;
  432. *old lpart = faux ;
  433. *old 'FINS' ;
  434. 'FINS' ;
  435. ctopo = 'INVERSE' btopo ;
  436. * Important que pfermi et tout les noeuds de la face soient coplanaires.
  437. 'SI' lpart ;
  438. tbor = 'PART' 'SEPA' ctopo 'ANGL' 0.01 'TELQ' ;
  439. lbor = 'ENUM' 'TABL' tbor ;
  440. topof = 'ENUM' topo ;
  441. mpferm = 'ENUM' ;
  442. * topof = topo 'ET' (ETOILE pferm ctopo) ;
  443. * topof = topo 'ET' ('COUT' pferm ctopo) ;
  444. dlbor = 'DIME' lbor ;
  445. 'REPE' iilbor dlbor ;
  446. ilbor = &iilbor ;
  447. ibor = 'EXTR' lbor ilbor ;
  448. pfermi = 'BARY' ibor ;
  449. topof = 'ET' topof ('COUT' pfermi ibor) ;
  450. mpferm = 'ET' mpferm pfermi ;
  451. 'FIN' iilbor ;
  452. * Teste si la topologie résultante est sans bord
  453. *TESTIDMA (BORD topof) ('VIDE' 'MAILLAGE') ;
  454. *'RESPRO' topof ;
  455. 'RESP' ('ETG' topof) ('ETG' mpferm) ;
  456. 'SINO' ;
  457. 'RESP' topo ('VIDE' 'MAILLAGE'/'POI1') ;
  458. 'FINS' ;
  459. * Pas de noeud virtuel
  460. *
  461. * End of procedure file FERMEPZ
  462. *
  463. *'FINPROC' ;
  464. 'FINS' ;
  465. *
  466. *
  467. 'SI' ('EGA' motcle 'OUVREPZ') ;
  468. ************************************************************************
  469. * NOM : OUVREPZ
  470. * DESCRIPTION :
  471. *
  472. *
  473. * Ouvre une topologie en enlevant les éléments touchant un point donné
  474. *
  475. *
  476. *
  477. * LANGAGE : GIBIANE-CAST3M
  478. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  479. * mél : stephane.gounand@cea.fr
  480. **********************************************************************
  481. * VERSION : v1, 25/08/2016, version initiale
  482. * HISTORIQUE : v1, 25/08/2016, création
  483. * HISTORIQUE :
  484. * HISTORIQUE :
  485. ************************************************************************
  486. *
  487. *'DEBPROC' OUVREPZ ;
  488. 'ARGUMENT' xltopo/'LISTOBJE' ;
  489. lxltopo = 'EXIS' xltopo ;
  490. 'SI' ('NON' lxltopo) ;
  491. 'ARGU' topo*'MAILLAGE' ;
  492. xltopo = 'ENUM' topo ;
  493. 'FINS' ;
  494. *'ARGUMENT' pferm*'POINT' ;
  495. 'ARGUMENT' mpferm*'MAILLAGE' ;
  496. dltopo = 'DIME' xltopo ;
  497. xltopoo = 'ENUM' ;
  498. 'REPE' iltopo dltopo ;
  499. topo = 'EXTR' xltopo &iltopo ;
  500. touchp = 'ELEM' topo 'APPUYE' 'LARGEMENT' mpferm 'NOVERIF' ;
  501. topoo = 'DIFF' topo touchp ;
  502. xltopoo = xltopoo 'ET' topoo ;
  503. 'FIN' iltopo ;
  504. *
  505. 'SI' lxltopo ;
  506. 'RESPRO' xltopoo ;
  507. 'SINO' ;
  508. 'RESPRO' topoo ;
  509. 'FINS' ;
  510. *
  511. * End of procedure file OUVREPZ
  512. *
  513. *'FINPROC' ;
  514. 'FINS' ;
  515. *
  516. 'SI' ('EGA' motcle 'MOYECHAM') ;
  517. ************************************************************************
  518. * NOM : MOYECHAM
  519. * DESCRIPTION : Fait la moyenne d'un champ par élément (supposé scalaire
  520. * et constant par élément) au sens : somme des valeurs
  521. * sur les éléments divisée par le nombre d'éléments.
  522. *
  523. *
  524. *
  525. * LANGAGE : GIBIANE-CAST3M
  526. * AUTEUR : Stephane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  527. * mail : stephane.gounand@cea.fr
  528. **********************************************************************
  529. * VERSION : v1, 02/05/2020, version initiale
  530. * HISTORIQUE : v1, 02/05/2020, creation
  531. * HISTORIQUE :
  532. * HISTORIQUE :
  533. ************************************************************************
  534. *
  535. *'DEBPROC' MOYECHAM ;
  536. 'ARGUMENT' cha*'MCHAML' ;
  537. *
  538. lco = 'EXTR' cha 'COMP' ;
  539. dco = 'DIME' lco ;
  540. * 320 2
  541. * Il faut specifier un champ par element avec une seule composante
  542. 'SI' ('NEG' dco 1) ;
  543. 'ERRE' 320 ;
  544. 'FINS' ;
  545. * Change le nom de composante en scal plutôt que qualtopo
  546. * car sinon chan chpo supp plante.
  547. *cha = 'EXCO' ('EXTR' lco 1) cha 'SCAL ' ;
  548. cha = 'CHAN' 'COMP' 'SCAL ' cha ;
  549. mai = 'EXTR' cha 'MAIL' ;
  550. nel = 'NBEL' mai ;
  551. *moc = 'MODE' mai 'THERMIQUE' ;
  552. moc = 'MODE' mai 'MECANIQUE' ;
  553. *'MESS' 'moyecham : gravit' ;
  554. cha2 = 'CHAN' 'CHAM' cha moc 'GRAVITE' 'SCALAIRE' ;
  555. * Pb ici
  556. *cha1 = 'MANU' 'CHML' moc 'SCAL' 1. 'TYPE' 'SCALAIRE' 'GRAVITE' ;
  557. *chavol = 'INTG' moc cha1 'ELEM' ;
  558. *'LIST' 'RESU' chavol ;
  559. *'ERRE' stop ;
  560. *ms = 'MOTS' 'SCAL' ;
  561. *'LIST' 'RESU' cha ;
  562. *'LIST' 'RESU' cha2 ;
  563. *'LIST' 'RESU' cha1 ;
  564. *'LIST' 'RESU' chavol ;
  565. * chavol est nul sur les éléments de volume nul
  566. *cha2v = '/' cha2 chavol ms ms ms ;
  567. *som = 'INTG' moc cha2v ;
  568. * Plante sur une erreur 5.
  569. *'MESS' 'moyecham : chpo' ;
  570. chp2 = 'CHAN' 'CHPO' moc cha2 'SUPP' ;
  571. som = 'MAXI' ('RESU' chp2) ;
  572. moy = '/' som nel ;
  573. 'RESPRO' moy ;
  574. *
  575. * End of procedure file MOYECHAM
  576. *
  577. *'FINPROC' ;
  578. 'FINS' ;
  579. *
  580. 'SI' ('EGA' motcle 'AFFCAND') ;
  581. ************************************************************************
  582. * NOM : AFFCAND
  583. * DESCRIPTION :
  584. *
  585. * Procédure pour afficher une table de candidat + la valeur dun critère
  586. * en coloriant le candidat
  587. *
  588. *
  589. *
  590. *
  591. * LANGAGE : GIBIANE-CAST3M
  592. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  593. * mél : stephane.gounand@cea.fr
  594. **********************************************************************
  595. * VERSION : v1, 25/08/2016, version initiale
  596. * HISTORIQUE : v1, 25/08/2016, création
  597. * HISTORIQUE :
  598. * HISTORIQUE :
  599. ************************************************************************
  600. *
  601. *'DEBPROC' AFFCAND ;
  602. 'ARGUMENT' tcand/'TABLE' ;
  603. 'SI' ('NON' ('EXISTE' tcand)) ; tcand = 'TABLE' ; 'FINSI' ;
  604. 'REPETER' boumail ;
  605. 'ARGUMENT' mail/'MAILLAGE' ;
  606. 'SI' ('EXISTE' mail) ;
  607. itab = '+' ('DIME' tcand) 1 ;
  608. tcand . itab = mail ;
  609. 'SINON' ;
  610. 'QUITTER' boumail ;
  611. 'FINSI' ;
  612. 'FIN' boumail ;
  613. *
  614. ltypost = 'MOTS' 'MAIL' 'VOLU' 'QUAL' ;
  615. 'ARGU' typost*'MOT' ;
  616. itypost = 'POSI' typost 'DANS' ltypost ;
  617. 'SI' ('EGA' itypost 0) ;
  618. *Mot-clé incorrect "%M1:4". Voici la liste des valeurs admises :
  619. 'ERRE' 1052 'AVEC' typost 'MAIL VOLU QUAL' ;
  620. 'FINS' ;
  621. *
  622. tit = 'GOONI FECIT' ;
  623. momet = 'ARIT' ;
  624. *
  625. lmotcle = 'MOTS' 'VMET' 'TITR' 'ARIT' 'GEOM' ;
  626. 'REPETER' imotcle ;
  627. 'ARGUMENT' motcle/'MOT' ;
  628. 'SI' ('NON' ('EXISTE' motcle)) ; 'QUITTER' imotcle ; 'FINSI' ;
  629. * 'MESS' ('CHAI' 'affcand.proc : mot-cle lu :' motcle) ;
  630. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  631. cherr = 'CHAINE' 'Keyword ' motcle ' unknown.' ; 'ERREUR' cherr ;
  632. 'FINSI' ;
  633. 'SI' ('EGA' motcle 'VMET') ;
  634. 'ARGU' metva ;
  635. * 'MESS' ('CHAI' 'affcand.proc : metva=') ;
  636. * 'LIST' ('TYPE' metva);
  637. 'FINS' ;
  638. 'SI' ('EGA' motcle 'TITR') ;
  639. 'ARGU' tit*'MOT' ;
  640. 'FINS' ;
  641. 'SI' ('EGA' motcle 'ARIT') ; momet = motcle ; 'FINS' ;
  642. 'SI' ('EGA' motcle 'GEOM') ; momet = motcle ; 'FINS' ;
  643. 'FIN' imotcle ;
  644. *
  645. ncand = 'DIME' tcand ;
  646. 'SI' ('NON' ('>' ncand 0)) ;
  647. 'ERREUR' 'Table vide' ;
  648. 'FINSI' ;
  649. dx = 0. ;
  650. mtot = 'VIDE' 'MAILLAGE' ;
  651. chvol = 'VIDE' 'CHPOINT'/'DIFFUS' ;
  652. mqual = 'VIDE' 'MMODEL' ;
  653. cqual = 'VIDE' 'MCHAML' ;
  654. vdim = 'VALEUR' 'DIME' ;
  655. 'REPETER' icand ncand ;
  656. tcandi = tcand . &icand ;
  657. mdec = tcandi ;
  658. mtot = 'ET' mtot mdec ;
  659. xm = 'COORDONNEE' 1 tcandi ;
  660. ddx = '*' ('-' ('MAXIMUM' xm) ('MINIMUM' xm)) 1.1 ;
  661. dx = '+' dx ddx ;
  662. 'SI' ('EGA' itypost 2) ;
  663. cdec = 'MANUEL' 'CHPO' mdec 1 'SCAL' ('MESURE' mdec)
  664. 'NATURE' 'DIFFUS' ;
  665. chvol = 'ET' chvol cdec ;
  666. 'FINSI' ;
  667. 'SI' ('EGA' itypost 3) ;
  668. modec = 'MODE' mdec 'THERMIQUE' ;
  669. mqual = 'ET' mqual modec ;
  670. 'SI' ('EXIS' metva) ;
  671. cdec = 'INDI' 'TOP2' mdec metva momet ;
  672. 'SINO' ;
  673. cdec = 'INDI' 'TOP2' mdec ;
  674. 'FINS' ;
  675. cqual = 'ET' cqual cdec ;
  676. 'FINSI' ;
  677. 'FIN' icand ;
  678. *mtra = mtot 'ET' cnt ;
  679. mtra = mtot ;
  680. echq = 'PROG' 0. 'PAS' ('/' 1. 20.) 1. ;
  681. *echv = 'PROG' volucib 'PAS' ('/' ('-' voluini volucib) 20.) voluini ;
  682. *'SI' lnclk ;
  683. * 'SI' ('EGA' itypost 1) ;
  684. * 'TRACER' mtra 'TITR' tit 'NCLK' ;
  685. * 'FINSI' ;
  686. * 'SI' ('EGA' itypost 2) ;
  687. * 'TRACER' chvol mtot mtra 'TITR' tit 'NCLK' ;
  688. * 'FINSI' ;
  689. * 'SI' ('EGA' itypost 3) ;
  690. * 'TRACER' cqual mqual mtra echq 'TITR' tit 'NCLK' ;
  691. * 'FINSI' ;
  692. *'SINON' ;
  693. 'SI' ('EGA' itypost 1) ;
  694. 'TRACER' mtra 'TITR' tit ;
  695. 'FINSI' ;
  696. 'SI' ('EGA' itypost 2) ;
  697. * 'LISTE' echv ; 'LISTE' mtot ;'LISTE' mtra ; 'LISTE' chvol ;
  698. 'TRACER' chvol mtot mtra 'TITR' tit ;
  699. 'FINSI' ;
  700. 'SI' ('EGA' itypost 3) ;
  701. 'TRACER' cqual mqual mtra echq 'TITR' tit ;
  702. 'FINSI' ;
  703. *'FINSI' ;
  704. *
  705. * End of procedure file AFFCAND
  706. *
  707. *'FINPROC' ;
  708. 'FINS' ;
  709. *
  710. 'SI' ('EGA' motcle 'MAILINTE') ;
  711. ************************************************************************
  712. * NOM : MAILINTE
  713. * DESCRIPTION :
  714. *
  715. *
  716. * Procédure MAILINTE qui devient SURF (si dim 2) ou VOLU (si dim 3)
  717. *
  718. *
  719. *
  720. * LANGAGE : GIBIANE-CAST3M
  721. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  722. * mél : stephane.gounand@cea.fr
  723. **********************************************************************
  724. * VERSION : v1, 25/09/2017, version initiale
  725. * HISTORIQUE : v1, 25/09/2017, création
  726. * HISTORIQUE :
  727. * HISTORIQUE :
  728. ************************************************************************
  729. *
  730. *'DEBPROC' MAILINTE ;
  731. 'ARGUMENT' mail*'MAILLAGE' ;
  732. vdim = 'VALEUR' 'DIME' ;
  733. mailb = faux ;
  734. 'SI' ('EGA' vdim 2) ;
  735. mailb = 'SURF' mail ;
  736. 'FINSI' ;
  737. 'SI' ('EGA' vdim 3) ;
  738. mailb = 'VOLU' mail 'VERB' ;
  739. 'FINSI' ;
  740. 'SI' ('EGA' ('TYPE' mail) 'LOGIQUE') ;
  741. 'ERREUR' ('CHAINE' 'vdim=' vdim) ;
  742. 'FINSI' ;
  743. 'RESPRO' mailb ;
  744. *
  745. * End of procedure file MAILINTE
  746. *
  747. *'FINPROC' ;
  748. 'FINS' ;
  749. 'SI' ('EGA' motcle 'VERITOPO') ;
  750. ************************************************************************
  751. * NOM : VERITOPO
  752. * DESCRIPTION :
  753. *
  754. *
  755. * Procédure VERITOPO qui verifie une topologie (i.e. un maillage massif)
  756. *
  757. *
  758. *
  759. * LANGAGE : GIBIANE-CAST3M
  760. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  761. * mél : stephane.gounand@cea.fr
  762. **********************************************************************
  763. * VERSION : v1, 03/11/2025, version initiale
  764. * HISTORIQUE : v1, 03/11/2025, création
  765. * HISTORIQUE :
  766. * HISTORIQUE :
  767. ************************************************************************
  768. *
  769. *'DEBPROC' VERITOPO ;
  770. 'ARGUMENT' xxxtopo*'MAILLAGE' ;
  771. 'ARGU' xxxvolucib/'FLOTTANT' ;
  772. lvolucib = 'EXIS' xxxvolucib ;
  773. 'SI' lvolucib ;
  774. 'ARGU' volutol*'FLOTTANT' ;
  775. 'FINS' ;
  776. 'ARGU' xxxdesc*'MOT' ;
  777. 'SI' ('NON' ('EXIS' xxxdesc)) ; xxxdesc = 'CHAI' 'VERITOPO :' ; 'FINS' ;
  778. 'ARGU' xxxmbnc/'MAILLAGE' ;
  779. lok = vrai ;
  780. vdim = 'VALEUR' 'DIME' ;
  781. *
  782. * Verification pas d'elements en double
  783. *
  784. xxxtopou = 'UNIQ' xxxtopo ;
  785. dnode = '-' ('NBEL' xxxtopo) ('NBEL' xxxtopou) ;
  786. 'SI' ('NEG' dnode 0) ;
  787. 'MESSAGE' xxxdesc ' ' dnode ' elements en double' ;
  788. lok = lok 'ET' faux ;
  789. 'FINS' ;
  790. *
  791. * Verification que le bord est ferme
  792. *
  793. lbord = vrai ;
  794. 'SI' ('EGA' vdim 2) ;
  795. bxxxtopo = 'CONT' 'EXTE' xxxtopo ;
  796. citopo = 'CONT' 'INTE' xxxtopo 'NOID' ;
  797. 'SI' ('NEG' ('NBEL' citopo) 0) ;
  798. 'MESS' xxxdesc ' Aretes partagees par plus de deux elements' ;
  799. lbord = lbord 'ET' faux ;
  800. 'FINS' ;
  801. pbor = 'POIN' bxxxtopo 'EXTR' ;
  802. 'SI' ('NEG' ('NBEL' pbor) 0) ;
  803. 'MESS' xxxdesc ' Bord non ferme' ;
  804. lbord = lbord 'ET' faux ;
  805. 'FINS' ;
  806. 'FINS' ;
  807. 'SI' ('EGA' vdim 3) ;
  808. bxxxtopo = 'ENVE' xxxtopo ;
  809. cnext = 'CONT' 'EXTE' bxxxtopo 'NOID' ;
  810. 'SI' ('NEG' ('NBEL' cnext) 0) ;
  811. 'MESS' xxxdesc ' Bord non ferme' ;
  812. lbord = lbord 'ET' faux ;
  813. 'FINS' ;
  814. cnint = 'CONT' 'INTE' bxxxtopo 'NOID' ;
  815. 'SI' ('NEG' ('NBEL' cnint) 0) ;
  816. 'MESS' xxxdesc ' Bord non simple' ;
  817. * lbord = lbord 'ET' faux ;
  818. 'FINS' ;
  819. 'FINS' ;
  820. lok = lok 'ET' lbord ;
  821. *
  822. * Volume toujours correct ?
  823. *
  824. 'SI' lvolucib ;
  825. volv = 'MESU' xxxtopo ;
  826. dvolv = '-' xxxvolucib volv ;
  827. 'SI' ('NEG' dvolv 0 volutol) ;
  828. 'MESSAGE' xxxdesc ' Volume (mesu) modifie vol=' volv ' / volucib=' xxxvolucib ;
  829. 'MESSAGE' xxxdesc ' dvol=' dvolv ;
  830. lok = lok 'ET' faux ;
  831. 'FINS' ;
  832. 'SI' lbord ;
  833. vols = MATOUTIL 'MESUINTE' bxxxtopo ;
  834. dvols = '-' xxxvolucib vols ;
  835. 'SI' ('NEG' dvols 0 volutol) ;
  836. 'MESSAGE' xxxdesc ' Volume (mesuinte) modifie vol=' vols ' / volucib=' xxxvolucib ;
  837. 'MESSAGE' xxxdesc ' dvol=' dvols ;
  838. lok = lok 'ET' faux ;
  839. 'FINS' ;
  840. 'FINS' ;
  841. 'FINS' ;
  842. *
  843. * mbnc toujours inclus dans le bord ?
  844. *
  845. 'SI' ('EXIS' xxxmbnc) ;
  846. mi = 'INTE' xxxmbnc bxxxtopo 'NOVERIF' ;
  847. 'SI' ('NEG' ('NBEL' ('DIFF' mi xxxmbnc)) 0) ;
  848. 'MESSAGE' xxxdesc ' bord_no_chan non inclus dans le bord' ;
  849. 'TRAC' (mi 'ET' ('COUL' bxxxtopo 'ROUG')) ;
  850. lok = lok 'ET' faux ;
  851. 'FINS' ;
  852. 'FINS' ;
  853. 'RESPRO' lok ;
  854. *
  855. * End of procedure file VERITOPO
  856. *
  857. *'FINPROC' ;
  858. 'FINS' ;
  859. *
  860. * End of procedure file MATOUTIL
  861. *
  862. 'FINPROC' ;
  863.  
  864.  

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