Télécharger matoutil.procedur

Retour à la liste

Numérotation des lignes :

  1. * MATOUTIL PROCEDUR GOUNAND 26/06/11 21:15:06 12570
  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. 'ARGU' lcritq*'LISTREEL' ;
  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. lmetva = 'EXIS' metva ;
  251. 'SI' lmetva ;
  252. qtopo = 'INDI' 'TOP2' curtopo metva momet lcritq ;
  253. 'SINO' ;
  254. qtopo = 'INDI' 'TOP2' curtopo lcritq ;
  255. 'FINS' ;
  256. *listreel nel = 'DIME' qtopo ;
  257. nel = 'NBEL' curtopo ;
  258. nno = 'NBNO' curtopo ;
  259. dvol = '-' ('MESURE' curtopo) volucib ;
  260. cqalo = 'EXTR' qtopo 'VALE' 'TOP2' ;
  261. cqalo = 'ORDO' cqalo ; dcqalo = 'DIME' cqalo ;
  262. miq = 'EXTR' cqalo 1 ; maq = 'EXTR' cqalo dcqalo ;
  263. meq = 'EXTR' cqalo ('/' ('+' 1 dcqalo) 2) ;
  264. * miq = 'MINIMUM' qtopo ; maq = 'MAXIMUM' qtopo ;
  265. **listreel moq = '/' ('SOMME' qtopo) nel ;
  266. * moq = MATOUTIL 'MOYECHAM' qtopo ;
  267. *! Test des deux façons de calculer !
  268. 'SI' lmetva ;
  269. qtopo2 = 'INDI' 'TOP2' curtopo metva momet 'LISTREEL' lcritq ;
  270. 'SINO' ;
  271. qtopo2 = 'INDI' 'TOP2' curtopo 'LISTREEL' lcritq ;
  272. 'FINS' ;
  273. cqalo2 = 'ORDO' qtopo2 ; dcqalo2 = 'DIME' cqalo2 ;
  274. meq2 = 'EXTR' cqalo2 ('/' ('+' 1 dcqalo2) 2) ;
  275. * moq2 = ('SOMM' qtopo2) '/' ('DIME' qtopo2) ;
  276. * VALE prec un peu trop serré pour semt2
  277. 'SI' ('NEG' meq meq2 ('*' ('VALE' 'PREC') 10.)) ;
  278. 'MESS' 'meq,meq2,dmeq' meq meq2 ('-' meq meq2) ;
  279. 'FINS' ;
  280. * moqtopo = 'MODE' curtopo 'THERMIQUE' ;
  281. * moq = '/' ('INTG' qtopo moqtopo) ('MESU' curtopo) ;
  282. *listreel lvnul = POSI 0.D0 'DANS' qtopo volutol 'TOUS' ;
  283. *listreel nnul = 'DIME' lvnul ;
  284. *non ! Les qtopo sont des rapports de longueurs au carré
  285. * Les qtopo sont des rapports de longueurs
  286. nnul = 'MASQ' ('EXCO' 'TOP2' qtopo) 'EGINFE' 'SOMME' denstol ;
  287. 'SI' lres ;
  288. 'RESP' dvol nel nnul nno miq maq meq ;
  289. 'FINS' ;
  290. 'SI' laff ;
  291. *'SI' ('EGA' nnul 0) ;
  292. jcritq = 'ENTI' ('EXTR' lcritq 1) 'PROC' ;
  293. titq = 'CHAINE' 'FORMAT' '(E11.3)'
  294. ' Dvol=' dvol ' Nel=' nel ' Nel0=' nnul ' Nno=' nno
  295. ' Qmin=' miq ' Qmax=' maq ' Qmed=' meq ' crit=' jcritq ;
  296. 'SI' lmetva ;
  297. pcritq = 'EXTR' lcritq 2 ;
  298. qcritq = 'EXTR' lcritq 3 ;
  299. titq = 'CHAINE' 'FORMAT' '(F4.1)' titq ' p=' pcritq ' q=' qcritq ;
  300. 'FINS' ;
  301. *'SINON' ;
  302. * titq = 'CHAINE' ' Dvol=' dvol ' N=' nel
  303. * ' N0=' nnul ' max=' maq ' moy=' moq ;
  304. *'FINSI' ;
  305. * titv = 'CHAINE' 'Nb. Elements plats=' nnul ;
  306. 'MESSAGE' titq ;
  307. * 'MESSAGE' titv ;
  308. 'FINS' ;
  309. *
  310. * End of procedure file AFFQUAL
  311. *
  312. 'FINS' ;
  313. *
  314. 'SI' ('EGA' motcle 'BORD') ;
  315. ************************************************************************
  316. * NOM : BORD
  317. * DESCRIPTION :
  318. *
  319. *
  320. * Procédure BORD qui devient CONTOUR (si dim 2) ou ENVELOPPE (si dim 3)
  321. *
  322. *
  323. *
  324. * LANGAGE : GIBIANE-CAST3M
  325. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  326. * mél : stephane.gounand@cea.fr
  327. **********************************************************************
  328. * VERSION : v1, 25/08/2016, version initiale
  329. * HISTORIQUE : v1, 25/08/2016, création
  330. * HISTORIQUE :
  331. * HISTORIQUE :
  332. ************************************************************************
  333. *
  334. 'ARGUMENT' mail*'MAILLAGE' ;
  335. *vdim = 'VALEUR' 'DIME' ;
  336. mdim = DEADUTIL 'DIMM' mail ;
  337. mailb = faux ;
  338. 'SI' ('EGA' mdim 2) ;
  339. mailb = 'CONTOUR' mail 'NOID' ;
  340. 'FINSI' ;
  341. 'SI' ('EGA' mdim 3) ;
  342. mailb = 'ENVELOPPE' mail 'NOID' ;
  343. * mailb = 'ENVELOPPE' mail ;
  344. 'FINSI' ;
  345. 'SI' ('EGA' ('TYPE' mail) 'LOGIQUE') ;
  346. 'ERREUR' ('CHAINE' 'mdim=' mdim) ;
  347. 'FINSI' ;
  348. 'RESPRO' mailb ;
  349. *
  350. * End of procedure file BORD
  351. *
  352. 'FINS' ;
  353. *
  354. 'SI' ('EGA' motcle 'FERMEPZ') ;
  355. ************************************************************************
  356. * NOM : FERMEPZ
  357. * DESCRIPTION :
  358. *
  359. * Ferme une topologie en étoilant son contour avec un point donné
  360. *
  361. *
  362. *
  363. *
  364. * LANGAGE : GIBIANE-CAST3M
  365. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  366. * mél : stephane.gounand@cea.fr
  367. **********************************************************************
  368. * VERSION : v1, 25/08/2016, version initiale
  369. * HISTORIQUE : v1, 25/08/2016, création
  370. * HISTORIQUE : v2 11/06/2018, ajout 2eme maillage servant à la partie
  371. * du contour qui ne doit pas être changée
  372. * HISTORIQUE : v3 on decoupe le bord en morceaux plats...
  373. ************************************************************************
  374. *
  375. *'DEBPROC' FERMEPZ ;
  376. 'ARGUMENT' topo*'MAILLAGE' ;
  377. 'ARGU' mailnoch*'MAILLAGE' ;
  378. 'ARGU' ialgo*'ENTIER' ;
  379. 'ARGU' denstol*'FLOTTANT' ;
  380. 'ARGU' impr*'ENTIER' ;
  381. *'ARGUMENT' pferm*'POINT' ;
  382. * Le inverse semble hyper important !!!!
  383. btopo = MATOUTIL 'BORD' topo ;
  384. *dbg atopo = 'COUL' ('ARET' btopo) 'VERT' ;
  385. *dbg btopo = 'COUL' btopo 'ROUG' ;
  386. *dbg 'TRAC' (topo 'ET' btopo 'ET' atopo) 'TITR' 'Topologie et son bord' ;
  387. 'SI' ('EXIS' mailnoch) ;
  388. btopo2 = 'DIFF' btopo mailnoch ;
  389. btopo = btopo2 ;
  390. 'FINS' ;
  391. * Partitionnement
  392. *old Si ialgo=0, il faut verifier l'absence d'elements degeneres au bord
  393. * Si ialgo=0, il faut supprimer les elements degeneres du bord
  394. * sinon part ne peut fonctionner
  395. lpart= vrai ;
  396. 'SI' ('EGA' ialgo 0) ;
  397. * ttopo = 'ELEM' topo 'APPUYE' 'ELEM' btopo ;
  398. * jttopo = DEADJACO ttopo ;
  399. imetopo = DEADMETR btopo ;
  400. spetopo = 'TENS' 'PRIN' imetopo ;
  401. * On prend l'avant-derniere valeur propre (la derniere est nulle car element surfacique)
  402. avdim = '-' ('VALE' 'DIME') 1 ;
  403. navvp = 'CHAI' 'SI' avdim avdim ;
  404. avvp = 'EXCO' navvp spetopo ;
  405. lavvp = '**' ('ABS' avvp) 0.5 ;
  406. milavvp = 'MINI' lavvp ; malavvp = 'MAXI' lavvp ;
  407. * vtol2 = '**' vtol 0.7 ;
  408. * 'MESS' 'FERMEPZ : milavvp=' milavvp ' malavvp=' malavvp ' denstol=' denstol ;
  409. etopo0 = 'ELEM' lavvp 'EGINFE' denstol ;
  410. nel0 = 'NBEL' etopo0 ;
  411. 'SI' ('>' nel0 0) ;
  412. 'MESS' '!! FERMEPZ : on enleve' ' ' nel0 ' elements du bord qui sont singuliers.' ;
  413. 'MESS' '!! : milavvp=' milavvp ' malavvp=' malavvp ' denstol=' denstol ;
  414. btopo3 = 'DIFF' btopo etopo0 ;
  415. btopo = btopo3 ;
  416. * lpart = faux ;
  417. * btopo0 = MATOUTIL 'BORD' ttopo0 ;
  418. * ibt = 'INTE' btopo0 btopo ;
  419. * nibt = 'NBEL' ibt ;
  420. * 'SI' ('>' nibt 0) ;
  421. * 'MESS' '!! :' ' ' nibt ' elements du bord ne seront pas etoiles.' ;
  422. * btopo3 = 'DIFF' btopo ibt ;
  423. * btopo = btopo3 ;
  424. * 'FINS' ;
  425. 'FINS' ;
  426. *old2 jctopo = 'INDI' 'ISOD' ctopo ;
  427. *old2 mijct = 'MINI' jctopo ; majct = 'MAXI' jctopo ;
  428. *old2 ctopo2 = 'ELEM' jctopo 'SUPERIEUR' vtol 'STRI' ;
  429. *old2 nelv = '-' ('NBEL' ctopo) ('NBEL' ctopo2) ;
  430. *old2 'MESS' 'FERMEPZ : mijct=' mijct ' majct=' majct ' vtol=' vtol ;
  431. *old2 'SI' ('>' nelv 0) ;
  432. *old2 'MESS' '!! FERMEPZ : on enleve' ' ' nelv ' elements du bord.' ;
  433. *old2 'FINS' ;
  434. *old2 ctopo = ctopo2 ;
  435. *old ttopo = 'ELEM' topo 'APPUYE' 'ELEM' btopo ;
  436. *old ctop = 'INDI' 'TOP2' ttopo ;
  437. *old mictop = 'MINI' ctop ;
  438. *old 'SI' ('<' mictop vtol) ;
  439. *old 'SI' ('>EG' impr 2) ;
  440. *old 'MESS' 'minivol=' mictop ' => elements degeneres touchant le bord : pas* de noeud virtuel pour cette passe' ;
  441. *old 'FINS' ;
  442. *old lpart = faux ;
  443. *old 'FINS' ;
  444. 'FINS' ;
  445. ctopo = 'INVERSE' btopo ;
  446. * Important que pfermi et tout les noeuds de la face soient coplanaires.
  447. 'SI' lpart ;
  448. tbor = 'PART' 'SEPA' ctopo 'ANGL' 0.01 'TELQ' ;
  449. lbor = 'ENUM' 'TABL' tbor ;
  450. * lbor = 'ENUM' ctopo ;
  451. topof = 'ENUM' topo ;
  452. mpferm = 'ENUM' ;
  453. * topof = topo 'ET' (ETOILE pferm ctopo) ;
  454. * topof = topo 'ET' ('COUT' pferm ctopo) ;
  455. dlbor = 'DIME' lbor ;
  456. *impr 'MESS' 'FERMEPZ: Partitionnement du bord en' ' ' dlbor ' morceaux' ;
  457. 'REPE' iilbor dlbor ;
  458. ilbor = &iilbor ;
  459. ibor = 'EXTR' lbor ilbor ;
  460. pfermi = 'BARY' ibor ;
  461. topof = 'ET' topof ('COUT' pfermi ibor) ;
  462. mpferm = 'ET' mpferm pfermi ;
  463. 'FIN' iilbor ;
  464. * Teste si la topologie résultante est sans bord
  465. *TESTIDMA (BORD topof) ('VIDE' 'MAILLAGE') ;
  466. *'RESPRO' topof ;
  467. 'RESP' ('ETG' topof) ('ETG' mpferm) ;
  468. 'SINO' ;
  469. 'RESP' topo ('VIDE' 'MAILLAGE'/'POI1') ;
  470. 'FINS' ;
  471. * Pas de noeud virtuel
  472. *
  473. * End of procedure file FERMEPZ
  474. *
  475. *'FINPROC' ;
  476. 'FINS' ;
  477. *
  478. *
  479. 'SI' ('EGA' motcle 'OUVREPZ') ;
  480. ************************************************************************
  481. * NOM : OUVREPZ
  482. * DESCRIPTION :
  483. *
  484. *
  485. * Ouvre une topologie en enlevant les éléments touchant un point donné
  486. *
  487. *
  488. *
  489. * LANGAGE : GIBIANE-CAST3M
  490. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  491. * mél : stephane.gounand@cea.fr
  492. **********************************************************************
  493. * VERSION : v1, 25/08/2016, version initiale
  494. * HISTORIQUE : v1, 25/08/2016, création
  495. * HISTORIQUE :
  496. * HISTORIQUE :
  497. ************************************************************************
  498. *
  499. *'DEBPROC' OUVREPZ ;
  500. 'ARGUMENT' xltopo/'LISTOBJE' ;
  501. lxltopo = 'EXIS' xltopo ;
  502. 'SI' ('NON' lxltopo) ;
  503. 'ARGU' topo*'MAILLAGE' ;
  504. xltopo = 'ENUM' topo ;
  505. 'FINS' ;
  506. *'ARGUMENT' pferm*'POINT' ;
  507. 'ARGUMENT' mpferm*'MAILLAGE' ;
  508. dltopo = 'DIME' xltopo ;
  509. xltopoo = 'ENUM' ;
  510. 'REPE' iltopo dltopo ;
  511. topo = 'EXTR' xltopo &iltopo ;
  512. touchp = 'ELEM' topo 'APPUYE' 'LARGEMENT' mpferm 'NOVERIF' ;
  513. topoo = 'DIFF' topo touchp ;
  514. xltopoo = xltopoo 'ET' topoo ;
  515. 'FIN' iltopo ;
  516. *
  517. 'SI' lxltopo ;
  518. 'RESPRO' xltopoo ;
  519. 'SINO' ;
  520. 'RESPRO' topoo ;
  521. 'FINS' ;
  522. *
  523. * End of procedure file OUVREPZ
  524. *
  525. *'FINPROC' ;
  526. 'FINS' ;
  527. *
  528. 'SI' ('EGA' motcle 'MOYECHAM') ;
  529. ************************************************************************
  530. * NOM : MOYECHAM
  531. * DESCRIPTION : Fait la moyenne d'un champ par élément (supposé scalaire
  532. * et constant par élément) au sens : somme des valeurs
  533. * sur les éléments divisée par le nombre d'éléments.
  534. *
  535. *
  536. *
  537. * LANGAGE : GIBIANE-CAST3M
  538. * AUTEUR : Stephane GOUNAND (CEA/DEN/DM2S/SEMT/LTA)
  539. * mail : stephane.gounand@cea.fr
  540. **********************************************************************
  541. * VERSION : v1, 02/05/2020, version initiale
  542. * HISTORIQUE : v1, 02/05/2020, creation
  543. * HISTORIQUE :
  544. * HISTORIQUE :
  545. ************************************************************************
  546. *
  547. *'DEBPROC' MOYECHAM ;
  548. 'ARGUMENT' cha*'MCHAML' ;
  549. *
  550. lco = 'EXTR' cha 'COMP' ;
  551. dco = 'DIME' lco ;
  552. * 320 2
  553. * Il faut specifier un champ par element avec une seule composante
  554. 'SI' ('NEG' dco 1) ;
  555. 'ERRE' 320 ;
  556. 'FINS' ;
  557. * Change le nom de composante en scal plutôt que qualtopo
  558. * car sinon chan chpo supp plante.
  559. *cha = 'EXCO' ('EXTR' lco 1) cha 'SCAL ' ;
  560. cha = 'CHAN' 'COMP' 'SCAL ' cha ;
  561. mai = 'EXTR' cha 'MAIL' ;
  562. nel = 'NBEL' mai ;
  563. *moc = 'MODE' mai 'THERMIQUE' ;
  564. moc = 'MODE' mai 'MECANIQUE' ;
  565. *'MESS' 'moyecham : gravit' ;
  566. cha2 = 'CHAN' 'CHAM' cha moc 'GRAVITE' 'SCALAIRE' ;
  567. * Pb ici
  568. *cha1 = 'MANU' 'CHML' moc 'SCAL' 1. 'TYPE' 'SCALAIRE' 'GRAVITE' ;
  569. *chavol = 'INTG' moc cha1 'ELEM' ;
  570. *'LIST' 'RESU' chavol ;
  571. *'ERRE' stop ;
  572. *ms = 'MOTS' 'SCAL' ;
  573. *'LIST' 'RESU' cha ;
  574. *'LIST' 'RESU' cha2 ;
  575. *'LIST' 'RESU' cha1 ;
  576. *'LIST' 'RESU' chavol ;
  577. * chavol est nul sur les éléments de volume nul
  578. *cha2v = '/' cha2 chavol ms ms ms ;
  579. *som = 'INTG' moc cha2v ;
  580. * Plante sur une erreur 5.
  581. *'MESS' 'moyecham : chpo' ;
  582. chp2 = 'CHAN' 'CHPO' moc cha2 'SUPP' ;
  583. som = 'MAXI' ('RESU' chp2) ;
  584. moy = '/' som nel ;
  585. 'RESPRO' moy ;
  586. *
  587. * End of procedure file MOYECHAM
  588. *
  589. *'FINPROC' ;
  590. 'FINS' ;
  591. *
  592. 'SI' ('EGA' motcle 'AFFCAND') ;
  593. ************************************************************************
  594. * NOM : AFFCAND
  595. * DESCRIPTION :
  596. *
  597. * Procédure pour afficher une table de candidat + la valeur dun critère
  598. * en coloriant le candidat
  599. *
  600. *
  601. *
  602. *
  603. * LANGAGE : GIBIANE-CAST3M
  604. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  605. * mél : stephane.gounand@cea.fr
  606. **********************************************************************
  607. * VERSION : v1, 25/08/2016, version initiale
  608. * HISTORIQUE : v1, 25/08/2016, création
  609. * HISTORIQUE :
  610. * HISTORIQUE :
  611. ************************************************************************
  612. *
  613. *'DEBPROC' AFFCAND ;
  614. 'ARGUMENT' tcand/'TABLE' ;
  615. 'SI' ('NON' ('EXISTE' tcand)) ; tcand = 'TABLE' ; 'FINSI' ;
  616. 'REPETER' boumail ;
  617. 'ARGUMENT' mail/'MAILLAGE' ;
  618. 'SI' ('EXISTE' mail) ;
  619. itab = '+' ('DIME' tcand) 1 ;
  620. tcand . itab = mail ;
  621. 'SINON' ;
  622. 'QUITTER' boumail ;
  623. 'FINSI' ;
  624. 'FIN' boumail ;
  625. *
  626. ltypost = 'MOTS' 'MAIL' 'VOLU' 'QUAL' ;
  627. 'ARGU' typost*'MOT' ;
  628. itypost = 'POSI' typost 'DANS' ltypost ;
  629. 'SI' ('EGA' itypost 0) ;
  630. *Mot-clé incorrect "%M1:4". Voici la liste des valeurs admises :
  631. 'ERRE' 1052 'AVEC' typost 'MAIL VOLU QUAL' ;
  632. 'FINS' ;
  633. *
  634. tit = 'GOONI FECIT' ;
  635. momet = 'ARIT' ;
  636. *
  637. lmotcle = 'MOTS' 'VMET' 'TITR' 'ARIT' 'GEOM' ;
  638. 'REPETER' imotcle ;
  639. 'ARGUMENT' motcle/'MOT' ;
  640. 'SI' ('NON' ('EXISTE' motcle)) ; 'QUITTER' imotcle ; 'FINSI' ;
  641. * 'MESS' ('CHAI' 'affcand.proc : mot-cle lu :' motcle) ;
  642. 'SI' ('NON' ('EXISTE' lmotcle motcle)) ;
  643. cherr = 'CHAINE' 'Keyword ' motcle ' unknown.' ; 'ERREUR' cherr ;
  644. 'FINSI' ;
  645. 'SI' ('EGA' motcle 'VMET') ;
  646. 'ARGU' metva ;
  647. * 'MESS' ('CHAI' 'affcand.proc : metva=') ;
  648. * 'LIST' ('TYPE' metva);
  649. 'FINS' ;
  650. 'SI' ('EGA' motcle 'TITR') ;
  651. 'ARGU' tit*'MOT' ;
  652. 'FINS' ;
  653. 'SI' ('EGA' motcle 'ARIT') ; momet = motcle ; 'FINS' ;
  654. 'SI' ('EGA' motcle 'GEOM') ; momet = motcle ; 'FINS' ;
  655. 'FIN' imotcle ;
  656. *
  657. ncand = 'DIME' tcand ;
  658. 'SI' ('NON' ('>' ncand 0)) ;
  659. 'ERREUR' 'Table vide' ;
  660. 'FINSI' ;
  661. dx = 0. ;
  662. mtot = 'VIDE' 'MAILLAGE' ;
  663. chvol = 'VIDE' 'CHPOINT'/'DIFFUS' ;
  664. mqual = 'VIDE' 'MMODEL' ;
  665. cqual = 'VIDE' 'MCHAML' ;
  666. vdim = 'VALEUR' 'DIME' ;
  667. 'REPETER' icand ncand ;
  668. tcandi = tcand . &icand ;
  669. mdec = tcandi ;
  670. mtot = 'ET' mtot mdec ;
  671. xm = 'COORDONNEE' 1 tcandi ;
  672. ddx = '*' ('-' ('MAXIMUM' xm) ('MINIMUM' xm)) 1.1 ;
  673. dx = '+' dx ddx ;
  674. 'SI' ('EGA' itypost 2) ;
  675. cdec = 'MANUEL' 'CHPO' mdec 1 'SCAL' ('MESURE' mdec)
  676. 'NATURE' 'DIFFUS' ;
  677. chvol = 'ET' chvol cdec ;
  678. 'FINSI' ;
  679. 'SI' ('EGA' itypost 3) ;
  680. modec = 'MODE' mdec 'THERMIQUE' ;
  681. mqual = 'ET' mqual modec ;
  682. 'SI' ('EXIS' metva) ;
  683. cdec = 'INDI' 'TOP2' mdec metva momet ;
  684. 'SINO' ;
  685. cdec = 'INDI' 'TOP2' mdec ;
  686. 'FINS' ;
  687. cqual = 'ET' cqual cdec ;
  688. 'FINSI' ;
  689. 'FIN' icand ;
  690. *mtra = mtot 'ET' cnt ;
  691. mtra = mtot ;
  692. echq = 'PROG' 0. 'PAS' ('/' 1. 20.) 1. ;
  693. *echv = 'PROG' volucib 'PAS' ('/' ('-' voluini volucib) 20.) voluini ;
  694. *'SI' lnclk ;
  695. * 'SI' ('EGA' itypost 1) ;
  696. * 'TRACER' mtra 'TITR' tit 'NCLK' ;
  697. * 'FINSI' ;
  698. * 'SI' ('EGA' itypost 2) ;
  699. * 'TRACER' chvol mtot mtra 'TITR' tit 'NCLK' ;
  700. * 'FINSI' ;
  701. * 'SI' ('EGA' itypost 3) ;
  702. * 'TRACER' cqual mqual mtra echq 'TITR' tit 'NCLK' ;
  703. * 'FINSI' ;
  704. *'SINON' ;
  705. 'SI' ('EGA' itypost 1) ;
  706. 'TRACER' mtra 'TITR' tit ;
  707. 'FINSI' ;
  708. 'SI' ('EGA' itypost 2) ;
  709. * 'LISTE' echv ; 'LISTE' mtot ;'LISTE' mtra ; 'LISTE' chvol ;
  710. 'TRACER' chvol mtot mtra 'TITR' tit ;
  711. 'FINSI' ;
  712. 'SI' ('EGA' itypost 3) ;
  713. 'TRACER' cqual mqual mtra echq 'TITR' tit ;
  714. 'FINSI' ;
  715. *'FINSI' ;
  716. *
  717. * End of procedure file AFFCAND
  718. *
  719. *'FINPROC' ;
  720. 'FINS' ;
  721. *
  722. 'SI' ('EGA' motcle 'MAILINTE') ;
  723. ************************************************************************
  724. * NOM : MAILINTE
  725. * DESCRIPTION :
  726. *
  727. *
  728. * Procédure MAILINTE qui devient SURF (si dim 2) ou VOLU (si dim 3)
  729. *
  730. *
  731. *
  732. * LANGAGE : GIBIANE-CAST3M
  733. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  734. * mél : stephane.gounand@cea.fr
  735. **********************************************************************
  736. * VERSION : v1, 25/09/2017, version initiale
  737. * HISTORIQUE : v1, 25/09/2017, création
  738. * HISTORIQUE :
  739. * HISTORIQUE :
  740. ************************************************************************
  741. *
  742. *'DEBPROC' MAILINTE ;
  743. 'ARGUMENT' mail*'MAILLAGE' ;
  744. vdim = 'VALEUR' 'DIME' ;
  745. mailb = faux ;
  746. 'SI' ('EGA' vdim 2) ;
  747. mailb = 'SURF' mail ;
  748. 'FINSI' ;
  749. 'SI' ('EGA' vdim 3) ;
  750. mailb = 'VOLU' mail 'VERB' ;
  751. 'FINSI' ;
  752. 'SI' ('EGA' ('TYPE' mail) 'LOGIQUE') ;
  753. 'ERREUR' ('CHAINE' 'vdim=' vdim) ;
  754. 'FINSI' ;
  755. 'RESPRO' mailb ;
  756. *
  757. * End of procedure file MAILINTE
  758. *
  759. *'FINPROC' ;
  760. 'FINS' ;
  761. 'SI' ('EGA' motcle 'VERITOPO') ;
  762. ************************************************************************
  763. * NOM : VERITOPO
  764. * DESCRIPTION :
  765. *
  766. *
  767. * Procédure VERITOPO qui verifie une topologie (i.e. un maillage massif)
  768. *
  769. *
  770. *
  771. * LANGAGE : GIBIANE-CAST3M
  772. * AUTEUR : Stéphane GOUNAND (CEA/DEN/DM2S/SFME/LTMF)
  773. * mél : stephane.gounand@cea.fr
  774. **********************************************************************
  775. * VERSION : v1, 03/11/2025, version initiale
  776. * HISTORIQUE : v1, 03/11/2025, création
  777. * HISTORIQUE :
  778. * HISTORIQUE :
  779. ************************************************************************
  780. *
  781. *'DEBPROC' VERITOPO ;
  782. 'ARGUMENT' xxxtopo*'MAILLAGE' ;
  783. 'ARGU' xxxvolucib/'FLOTTANT' ;
  784. lvolucib = 'EXIS' xxxvolucib ;
  785. 'SI' lvolucib ;
  786. 'ARGU' volutol*'FLOTTANT' ;
  787. 'FINS' ;
  788. 'ARGU' xxxdesc*'MOT' ;
  789. 'SI' ('NON' ('EXIS' xxxdesc)) ; xxxdesc = 'CHAI' 'VERITOPO :' ; 'FINS' ;
  790. 'ARGU' xxxmbnc/'MAILLAGE' ;
  791. lok = vrai ;
  792. vdim = 'VALEUR' 'DIME' ;
  793. *
  794. * Verification pas d'elements en double
  795. *
  796. xxxtopou = 'UNIQ' xxxtopo ;
  797. dnode = '-' ('NBEL' xxxtopo) ('NBEL' xxxtopou) ;
  798. 'SI' ('NEG' dnode 0) ;
  799. 'MESSAGE' xxxdesc ' ' dnode ' elements en double' ;
  800. lok = lok 'ET' faux ;
  801. 'FINS' ;
  802. *
  803. * Verification que le bord est ferme
  804. *
  805. lbord = vrai ;
  806. 'SI' ('EGA' vdim 2) ;
  807. bxxxtopo = 'CONT' 'EXTE' xxxtopo ;
  808. citopo = 'CONT' 'INTE' xxxtopo 'NOID' ;
  809. 'SI' ('NEG' ('NBEL' citopo) 0) ;
  810. 'MESS' xxxdesc ' Aretes partagees par plus de deux elements' ;
  811. lbord = lbord 'ET' faux ;
  812. 'FINS' ;
  813. pbor = 'POIN' bxxxtopo 'EXTR' ;
  814. 'SI' ('NEG' ('NBEL' pbor) 0) ;
  815. 'MESS' xxxdesc ' Bord non ferme' ;
  816. lbord = lbord 'ET' faux ;
  817. 'FINS' ;
  818. 'FINS' ;
  819. 'SI' ('EGA' vdim 3) ;
  820. bxxxtopo = 'ENVE' xxxtopo ;
  821. cnext = 'CONT' 'EXTE' bxxxtopo 'NOID' ;
  822. 'SI' ('NEG' ('NBEL' cnext) 0) ;
  823. 'MESS' xxxdesc ' Bord non ferme' ;
  824. lbord = lbord 'ET' faux ;
  825. 'FINS' ;
  826. cnint = 'CONT' 'INTE' bxxxtopo 'NOID' ;
  827. 'SI' ('NEG' ('NBEL' cnint) 0) ;
  828. 'MESS' xxxdesc ' Bord non simple' ;
  829. * lbord = lbord 'ET' faux ;
  830. 'FINS' ;
  831. 'FINS' ;
  832. lok = lok 'ET' lbord ;
  833. *
  834. * Volume toujours correct ?
  835. *
  836. 'SI' lvolucib ;
  837. volv = 'MESU' xxxtopo ;
  838. dvolv = '-' xxxvolucib volv ;
  839. 'SI' ('NEG' dvolv 0 volutol) ;
  840. 'MESSAGE' xxxdesc ' Volume (mesu) modifie vol=' volv ' / volucib=' xxxvolucib ;
  841. 'MESSAGE' xxxdesc ' dvol=' dvolv ;
  842. lok = lok 'ET' faux ;
  843. 'FINS' ;
  844. 'SI' lbord ;
  845. vols = MATOUTIL 'MESUINTE' bxxxtopo ;
  846. dvols = '-' xxxvolucib vols ;
  847. 'SI' ('NEG' dvols 0 volutol) ;
  848. 'MESSAGE' xxxdesc ' Volume (mesuinte) modifie vol=' vols ' / volucib=' xxxvolucib ;
  849. 'MESSAGE' xxxdesc ' dvol=' dvols ;
  850. lok = lok 'ET' faux ;
  851. 'FINS' ;
  852. 'FINS' ;
  853. 'FINS' ;
  854. *
  855. * mbnc toujours inclus dans le bord ?
  856. *
  857. 'SI' ('EXIS' xxxmbnc) ;
  858. mi = 'INTE' xxxmbnc bxxxtopo 'NOVERIF' ;
  859. 'SI' ('NEG' ('NBEL' ('DIFF' mi xxxmbnc)) 0) ;
  860. 'MESSAGE' xxxdesc ' bord_no_chan non inclus dans le bord' ;
  861. 'TRAC' (mi 'ET' ('COUL' bxxxtopo 'ROUG')) ;
  862. lok = lok 'ET' faux ;
  863. 'FINS' ;
  864. 'FINS' ;
  865. 'RESPRO' lok ;
  866. *
  867. * End of procedure file VERITOPO
  868. *
  869. *'FINPROC' ;
  870. 'FINS' ;
  871. *
  872. * End of procedure file MATOUTIL
  873. *
  874. 'FINPROC' ;
  875.  
  876.  

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