Télécharger idmatr.eso

Retour à la liste

Numérotation des lignes :

idmatr
  1. C IDMATR SOURCE JK148537 25/12/12 21:15:05 12418
  2. *--------------------------------------------------------------------*
  3. * Noms de composantes de materiaux *
  4. *--------------------------------------------------------------------*
  5. * *
  6. * ENTREES: *
  7. * MFR Numero de formulation *
  8. * IPMODL objet modele elementaire ( segment actif ) *
  9. * *
  10. * SORTIES: *
  11. * IPNOMC pointeur sur les listes de noms de composantes *
  12. * obligatoires et facultatives *
  13. * NBROBL nombre de composantes obligatoires *
  14. * NBRFAC nombre de composantes facultatives *
  15. * *
  16. * *
  17. * Remarque : Voir INOMID ou CCOPTIO pour signification IFOUR *
  18. *--------------------------------------------------------------------*
  19. C
  20. SUBROUTINE IDMATR(MFR,IPMODL,IPNOMC,NBROBL,NBRFAC)
  21. C
  22. IMPLICIT INTEGER(I-N)
  23. IMPLICIT REAL*8(A-H,O-Z)
  24. C
  25. -INC PPARAM
  26. -INC CCOPTIO
  27. C==DEB= FORMULATION HHO == Include specifique ==========================
  28. -INC CCHHOPA
  29. C==FIN= FORMULATION HHO ================================================
  30. -INC SMLMOTS
  31. -INC SMMODEL
  32. POINTEUR NOMID1.NOMID
  33.  
  34. ******Modif SELLIER ****************************************************
  35. * augmentation nombre de caracteristiques
  36. PARAMETER (ITA=500)
  37. CHARACTER*16 MOMODL(500)
  38. c nombre de variables et de parametres par variables
  39. c include './nombre_helmholtz.h'
  40. -INC HNBRHEL
  41. CHARACTER*1 motnl1,motnlv1,motnld1,motnla1
  42. CHARACTER*2 motnl2
  43. CHARACTER*3 motnl3
  44. CHARACTER*4 motnl4
  45. ******fin modif SELLIER ************************************************
  46.  
  47. CHARACTER*(LOCOMP) TABOBL(ITA),TABFAC(ITA)
  48. LOGICAL bDARCY
  49.  
  50. IMODEL=IPMODL
  51. NOMID =IMODEL.LNOMID(6)
  52. C
  53. C Ne pas recreer le NOMID si deja present
  54. IF (NOMID.NE.0) THEN
  55. NBROBL=LESOBL(/2)
  56. NBRFAC=LESFAC(/2)
  57. IPNOMC=NOMID
  58. RETURN
  59. ENDIF
  60. C
  61. JGOBL=0
  62. JGFAC=0
  63. IPNOMC=0
  64. IRET = 1
  65. C
  66. NMAT=MATMOD(/2)
  67. NFOR=FORMOD(/2)
  68. MELE=NEFMOD
  69. MFR2=NUMFOR(IMODEL)
  70. C
  71. C== FORMULATION HHO == MECANIQUE + idem qu'en MASSIF ==> MFR = 1 =======
  72. C== Les composantes specifiques seront ajoutees dans HHOIDC via INOMID.
  73. IF (MFR.EQ.HHO_MFR_ELEMENT) MFR = 1
  74. C== FORMULATION HHO ====================================================
  75. C =================================================================
  76. C FORMULATION THERMOHYDRIQUE
  77. C =================================================================
  78. IF (MFR2.EQ.65) THEN
  79. C
  80. IF (IMATEE.EQ.1) THEN
  81. JGOBL = 20
  82. TABOBL(1)='KGG'
  83. TABOBL(2)='KGC'
  84. TABOBL(3)='KGT'
  85. TABOBL(4)='KCG'
  86. TABOBL(5)='KCC'
  87. TABOBL(6)='KCT'
  88. TABOBL(7)='KTG'
  89. TABOBL(8)='KTC'
  90. TABOBL(9)='KTT'
  91. TABOBL(10)='CGG'
  92. TABOBL(11)='CGC'
  93. TABOBL(12)='CGT'
  94. TABOBL(13)='CCG'
  95. TABOBL(14)='CCC'
  96. TABOBL(15)='CCT'
  97. TABOBL(16)='CTG'
  98. TABOBL(17)='CTC'
  99. TABOBL(18)='CTT'
  100. TABOBL(19)='KTGG'
  101. TABOBL(20)='KTCG'
  102. ENDIF
  103. C =================================================================
  104. C FORMULATION THERMIQUE/DARCY
  105. C =================================================================
  106. ELSE IF ((MFR2.EQ.29) .OR. (MFR2.EQ.34)) THEN
  107. C
  108. bDARCY=(MFR2.EQ.34)
  109. C
  110. C MATERIAU THERMIQUE CONDUCTION OU MATERIAU DARCY
  111. C ===============================================
  112. CALL PLACE(MATMOD,NMAT,ICONDU,'CONDUCTION')
  113. IF (ICONDU.NE.0.OR.bDARCY) THEN
  114. IF (MFR.EQ.75) THEN
  115. JGFAC = 4
  116. TABFAC(1)='M'
  117. TABFAC(2)='C'
  118. TABFAC(3)='TINI'
  119. ELSE
  120. JGFAC = 4
  121. TABFAC(1)='RHO '
  122. TABFAC(2)='C '
  123. TABFAC(3)='H '
  124. TABFAC(4)='TINI'
  125. ENDIF
  126. C
  127. C Isotrope
  128. IF (IMATEE.EQ.1) THEN
  129. JGOBL = 1
  130. IF(MFR .EQ. 75)THEN
  131. TABOBL(1)='KT'
  132. ELSE
  133. TABOBL(1)='K '
  134. ENDIF
  135. C
  136. C Orthotrope
  137. ELSEIF (IMATEE.EQ.2) THEN
  138. IF (MFR.EQ.3.OR.MFR.EQ.5.OR.MFR.EQ.9) THEN
  139. JGOBL=5
  140. TABOBL(1)='K1 '
  141. TABOBL(2)='K2 '
  142. TABOBL(3)='K3 '
  143. TABOBL(4)='V1X '
  144. TABOBL(5)='V1Y '
  145. ELSEIF (MFR.EQ.1.OR.MFR.EQ.45) THEN
  146. IF (IDIM.EQ.2) THEN
  147. IF (IFOMOD.EQ.1) THEN
  148. JGOBL=5
  149. TABOBL(1)='K1 '
  150. TABOBL(2)='K2 '
  151. TABOBL(3)='V1X '
  152. TABOBL(4)='V1Y '
  153. TABOBL(5)='K3 '
  154. ELSE
  155. JGOBL=4
  156. TABOBL(1)='K1 '
  157. TABOBL(2)='K2 '
  158. TABOBL(3)='V1X '
  159. TABOBL(4)='V1Y '
  160. ENDIF
  161. ELSEIF (IDIM.EQ.3) THEN
  162. JGOBL=9
  163. TABOBL(1)='K1 '
  164. TABOBL(2)='K2 '
  165. TABOBL(3)='K3 '
  166. TABOBL(4)='V1X '
  167. TABOBL(5)='V1Y '
  168. TABOBL(6)='V1Z '
  169. TABOBL(7)='V2X '
  170. TABOBL(8)='V2Y '
  171. TABOBL(9)='V2Z '
  172. ENDIF
  173. ENDIF
  174. C
  175. C Anisotrope
  176. ELSEIF (IMATEE.EQ.3) THEN
  177. IF (MFR.EQ.1.OR.MFR.EQ.45) THEN
  178. IF (IDIM.EQ.2) THEN
  179. IF (IFOMOD.EQ.1) THEN
  180. JGOBL=6
  181. TABOBL(1)='K11 '
  182. TABOBL(2)='K22 '
  183. TABOBL(3)='K21 '
  184. TABOBL(4)='V1X '
  185. TABOBL(5)='V1Y '
  186. TABOBL(6)='K33 '
  187. ELSE
  188. JGOBL=5
  189. TABOBL(1)='K11 '
  190. TABOBL(2)='K22 '
  191. TABOBL(3)='K21 '
  192. TABOBL(4)='V1X '
  193. TABOBL(5)='V1Y '
  194. ENDIF
  195. ELSEIF (IDIM.EQ.3) THEN
  196. JGOBL=12
  197. TABOBL(1)='K11 '
  198. TABOBL(2)='K22 '
  199. TABOBL(3)='K33 '
  200. TABOBL(4)='K21 '
  201. TABOBL(5)='K31 '
  202. TABOBL(6)='K32 '
  203. TABOBL(7)='V1X '
  204. TABOBL(8)='V1Y '
  205. TABOBL(9)='V1Z '
  206. TABOBL(10)='V2X '
  207. TABOBL(11)='V2Y '
  208. TABOBL(12)='V2Z '
  209. ENDIF
  210. ENDIF
  211. ENDIF
  212. ENDIF
  213. C
  214. IF (bDARCY) GOTO 9999
  215. C
  216. C ===============================================================
  217. C MATERIAU THERMIQUE PHASE
  218. C ===============================================================
  219. CALL PLACE(MATMOD,NMAT,IPHA,'PHASE')
  220. IF (IPHA.NE.0) THEN
  221. JGOBL0 = JGOBL
  222. JGOBL = JGOBL0+4
  223. TABOBL(JGOBL0+1)='RHO '
  224. TABOBL(JGOBL0+2)='C '
  225. TABOBL(JGOBL0+3)='QLAT'
  226. TABOBL(JGOBL0+4)='TPHA'
  227.  
  228. JGFAC=1
  229. TABFAC(1)='H '
  230. ENDIF
  231. C ===============================================================
  232. C MATERIAU THERMIQUE CONVECTION
  233. C ===============================================================
  234. IF (CMATEE.EQ.'CONVECTI') THEN
  235. C IF (MFR.EQ.3.OR.MFR.EQ.5.OR.MFR.EQ.9) THEN
  236. CC Coques thermiques
  237. C JGOBL =2
  238. C TABOBL(1)='HINF'
  239. C TABOBL(2)='HSUP'
  240. C JGFAC =2
  241. C TABFAC(1)='TCINF'
  242. C TABFAC(2)='TCSUP'
  243. C else
  244. C Elements massifs
  245. JGOBL = 1
  246. TABOBL(1)='H'
  247. JGFAC=1
  248. TABFAC(1)='TC'
  249. C endif
  250. ENDIF
  251. C ===============================================================
  252. C MATERIAU THERMIQUE RAYONNEMENT
  253. C ===============================================================
  254. IF (CMATEE.EQ.'RAYONNEM') THEN
  255. C
  256. C RAYONNEMENT en CAVITE
  257. IF (IMATEE.EQ.4) THEN
  258. IF (MFR.EQ.3.OR.MFR.EQ.5.OR.MFR.EQ.9) THEN
  259. JGOBL=2
  260. TABOBL(1)='EINF'
  261. TABOBL(2)='ESUP'
  262. ELSE
  263. JGOBL=1
  264. TABOBL(1)='EMIS'
  265. ENDIF
  266.  
  267. JGFAC=3
  268. TABFAC(1)='CABS'
  269. TABFAC(2)='TABS'
  270. TABFAC(3)='H'
  271.  
  272. C RAYONNEMENT FACE_A_FACE
  273. ELSEIF (IMATEE.EQ.2) THEN
  274. JGOBL=1
  275. TABOBL(1)='EMIS'
  276. JGFAC = 1
  277. TABFAC(1)='H'
  278.  
  279. C RAYONNEMENT a l'INFINI
  280. ELSEIF (IMATEE.EQ.3) THEN
  281. IF (MFR.EQ.3.OR.MFR.EQ.5.OR.MFR.EQ.9) THEN
  282. JGOBL=3
  283. TABOBL(1)='EINF'
  284. TABOBL(2)='ESUP'
  285. TABOBL(3)='T_IN'
  286. ELSE
  287. JGOBL=2
  288. TABOBL(1)='EMIS'
  289. TABOBL(2)='T_IN'
  290. ENDIF
  291.  
  292. JGFAC = 2
  293. TABFAC(1)='E_IN'
  294. TABFAC(2)='H'
  295. ELSE
  296. IRET = 0
  297. CALL ERREUR(5)
  298. ENDIF
  299. ENDIF
  300. C ===============================================================
  301. C MATERIAU THERMIQUE ADVECTION
  302. C ===============================================================
  303. CALL PLACE(MATMOD,NMAT,IADVE,'ADVECTION')
  304. IF (IADVE.NE.0) THEN
  305. C Cas des Tuyaux 1D (MFR=79)
  306. IF (MFR .EQ. 79) THEN
  307. JGFAC = 3
  308. TABFAC(1)='RHO '
  309. TABFAC(2)='C '
  310. TABFAC(3)='VITE'
  311.  
  312. C Cas Massif (MFR=1)
  313. ELSEIF (MFR.EQ.1) THEN
  314. IF (IFOUR.EQ.-3) THEN
  315. JGFAC = 5
  316. TABFAC(1)='RHO '
  317. TABFAC(2)='C '
  318. TABFAC(3)='VITX'
  319. TABFAC(4)='VITY'
  320. TABFAC(5)='VITZ'
  321. ELSEIF (IFOUR.EQ.-2 .OR. IFOUR.EQ.-1) THEN
  322. JGFAC = 4
  323. TABFAC(1)='RHO '
  324. TABFAC(2)='C '
  325. TABFAC(3)='VITX'
  326. TABFAC(4)='VITY'
  327. ELSEIF (IFOUR .EQ. 0) THEN
  328. JGFAC = 4
  329. TABFAC(1)='RHO '
  330. TABFAC(2)='C '
  331. TABFAC(3)='VITR'
  332. TABFAC(4)='VITZ'
  333. ELSEIF (IFOUR.EQ.1) THEN
  334. CALL ERREUR(21)
  335. RETURN
  336. C JGFAC = 5C
  337. C TABFAC(1)='RHO '
  338. C TABFAC(2)='C '
  339. C TABFAC(3)='VITR'
  340. C TABFAC(4)='VITZ'
  341. C TABFAC(5)='VITT'
  342. ELSEIF (IFOUR.EQ.2) THEN
  343. JGFAC = 5
  344. TABFAC(1)='RHO '
  345. TABFAC(2)='C '
  346. TABFAC(3)='VITX'
  347. TABFAC(4)='VITY'
  348. TABFAC(5)='VITZ'
  349. ELSEIF (IFOUR.GE.3.AND.IFOUR.LE.15) THEN
  350. IF (IFOUR.LE.6) THEN
  351. JGFAC = 3
  352. TABFAC(1)='RHO '
  353. TABFAC(2)='C '
  354. TABFAC(3)='VITX'
  355. ELSEIF (IFOUR.EQ.7.OR.IFOUR.EQ.8) THEN
  356. JGFAC = 4
  357. C Verifier l'utilite des composantes au dela de 4
  358. TABFAC(1)='RHO '
  359. TABFAC(2)='C '
  360. TABFAC(3)='VITX'
  361. TABFAC(4)='VITY'
  362. ELSEIF (IFOUR.EQ.9.OR.IFOUR.EQ.10) THEN
  363. JGFAC = 4
  364. C Verifier l'utilite des composantes au dela de 4
  365. TABFAC(1)='RHO '
  366. TABFAC(2)='C '
  367. TABFAC(3)='VITX'
  368. TABFAC(4)='VITZ'
  369. ELSEIF (IFOUR.EQ.11) THEN
  370. JGFAC = 5
  371. C Verifier l'utilite des composantes au dela de 4
  372. TABFAC(1)='RHO '
  373. TABFAC(2)='C '
  374. TABFAC(3)='VITX'
  375. TABFAC(4)='VITY'
  376. TABFAC(5)='VITZ'
  377. ELSEIF (IFOUR.EQ.12.OR.IFOUR.EQ.13.OR.IFOUR.EQ.15) THEN
  378. JGFAC = 3
  379. TABFAC(1)='RHO '
  380. TABFAC(2)='C '
  381. TABFAC(3)='VITR'
  382. ELSEIF (IFOUR.EQ.14) THEN
  383. JGFAC = 4
  384. C Verifier l'utilite des composantes au dela de 4
  385. TABFAC(1)='RHO '
  386. TABFAC(2)='C '
  387. TABFAC(3)='VITR'
  388. TABFAC(4)='VITZ'
  389. ENDIF
  390. ENDIF
  391. ENDIF
  392. ENDIF
  393. C ===============================================================
  394. C MATERIAU THERMIQUE SOURCE
  395. C ===============================================================
  396. IF (CMATEE.EQ.'SOURCE') THEN
  397. IF (INATUU.EQ.1.AND.IMATEE.EQ.1) THEN
  398. JGOBL = 1
  399. TABOBL(1)='QVOL'
  400. JGFAC = 2
  401. TABFAC(1)='QINF'
  402. TABFAC(2)='QSUP'
  403. ELSEIF (INATUU.EQ.2.AND.IMATEE.EQ.1) THEN
  404. JGOBL = 3
  405. TABOBL(1)='QTOT'
  406. TABOBL(2)='ORIG'
  407. TABOBL(3)='RGAU'
  408. ELSEIF (INATUU.EQ.2.AND.IMATEE.EQ.2) THEN
  409. JGOBL = 5
  410. TABOBL(1)='QTOT'
  411. TABOBL(2)='ORIG'
  412. TABOBL(3)='RGAU'
  413. TABOBL(4)='DIRE'
  414. TABOBL(5)='ZGAU'
  415. ELSEIF (INATUU.EQ.2.AND.IMATEE.EQ.3) THEN
  416. JGOBL = 7
  417. TABOBL(1)='QTOT'
  418. TABOBL(2)='ORIG'
  419. TABOBL(3)='RGAU'
  420. TABOBL(4)='DIRE'
  421. TABOBL(5)='ZGAU'
  422. TABOBL(6)='DIRL'
  423. TABOBL(7)='LGAU'
  424. ELSE
  425. WRITE(6,*) ' Dans IDMATR : numero IMATEE non prevu'
  426. CALL ERREUR(21)
  427. RETURN
  428. ENDIF
  429. ENDIF
  430. C =================================================================
  431. C FORMULATION LIQUIDE/MECANIQUE+LIQUIDE
  432. C =================================================================
  433. ELSE IF ((MFR2.EQ.11) .OR. (MFR2.EQ.44)) THEN
  434. C
  435. IF (MFR.NE.41.AND.MFR.NE.43) THEN
  436. JGOBL = 6
  437. TABOBL(1)='RHO '
  438. TABOBL(2)='CSON'
  439. TABOBL(3)='RORF'
  440. TABOBL(4)='CREF'
  441. TABOBL(5)='LCAR'
  442. TABOBL(6)='G '
  443. ELSEIF (MFR.EQ.41) THEN
  444. JGOBL = 5
  445. TABOBL(1)='RHO '
  446. TABOBL(2)='CSON'
  447. TABOBL(3)='RORF'
  448. TABOBL(4)='CREF'
  449. TABOBL(5)='LCAR'
  450. ELSE
  451. JGOBL = 3
  452. TABOBL(1)='RHO '
  453. TABOBL(2)='LCAR'
  454. TABOBL(3)='RORF'
  455. ENDIF
  456. C =================================================================
  457. C FORMULATION MECANIQUE
  458. C =================================================================
  459. ELSE IF (MFR2.EQ.2) THEN
  460. C
  461. CALL MODLIN(MOMODL,NMOD)
  462. CALL PLACE(MOMODL,NMOD,IRET,MATMOD(1))
  463. IF (IRET.EQ.0) GOTO 9999
  464. C
  465. IF (NMAT.LT.2) GOTO 13
  466. C
  467. CALL MODELA(MOMODL,NMOD)
  468. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(2))
  469. C
  470. INMAT=3
  471. IF (IPLAC.EQ.0) INMAT=2
  472. C =============================================================
  473. C MATERIAU MECANIQUE ELASTIQUE IMPEDANCE
  474. C =============================================================
  475. CALL PLACE(MATMOD,NMAT,IIMPE,'IMPEDANCE')
  476. IF (IIMPE.EQ.0) GOTO 13
  477. C
  478. INMAT = INMAT + 1
  479. JGOBL = 0
  480. JGFAC = 0
  481.  
  482. IF(CMATEE.EQ.'IMPELAST') THEN
  483. JGOBL = 1
  484. TABOBL(1)='RAID'
  485.  
  486. JGFAC = 7
  487. TABFAC(1)='AMOR'
  488. TABFAC(2)='CPLE'
  489. TABFAC(3)='INER'
  490. TABFAC(4)='AROT'
  491. TABFAC(5)='ZNU'
  492. TABFAC(6)='MASS'
  493. TABFAC(7)='ALPH'
  494. ELSEIF (CMATEE.EQ.'IMPVOIGT'.or.CMATEE.EQ.'IMPREUSS') THEN
  495. JGOBL = 2
  496. TABOBL(1)='RAID'
  497. TABOBL(2)='VISC'
  498.  
  499. JGFAC = 5
  500. TABFAC(1)='MASS'
  501. TABFAC(2)='AMOR'
  502. TABFAC(3)='CPLE'
  503. TABFAC(4)='INER'
  504. TABFAC(5)='AROT'
  505. ELSEIF (CMATEE.EQ.'IMPCOMPL') then
  506. JGOBL = 1
  507. TABOBL(1)='RAID'
  508.  
  509. JGFAC = 7
  510. TABFAC(1)='MOCO'
  511. TABFAC(2)='VISC'
  512. TABFAC(3)='MASS'
  513. TABFAC(4)='AMOR'
  514. TABFAC(5)='CPLE'
  515. TABFAC(6)='INER'
  516. TABFAC(7)='AROT'
  517. ENDIF
  518. GOTO 9999
  519. C =============================================================
  520. 13 CONTINUE
  521. C =============================================================
  522. C MATERIAU MECANIQUE ELASTIQUE ISOTROPE (PAR DEFAUT)
  523. C =============================================================
  524. IF (IMATEE.EQ.1) THEN
  525. IF (MFR.EQ.35) THEN
  526. JGOBL=2
  527. TABOBL(1)='KS '
  528. TABOBL(2)='KN '
  529.  
  530. JGFAC=2
  531. TABFAC(1)='RHO '
  532. TABFAC(2)='ALPN'
  533. ELSEIF (MFR.EQ.78) THEN
  534. JGOBL=2
  535. TABOBL(1)='KS '
  536. TABOBL(2)='KN '
  537. ELSEIF (MFR.EQ.53) THEN
  538. JGOBL=1
  539. TABOBL(1)='KS '
  540. *
  541. JGFAC=2
  542. TABFAC(1)='RHO '
  543. TABFAC(2)='ALPN'
  544. ELSE
  545. JGOBL=2
  546. TABOBL(1)='YOUN'
  547. TABOBL(2)='NU '
  548. *
  549. IF((MFR.EQ.1.OR.MFR.EQ.3.OR.MFR.EQ.31.OR.MFR.EQ.63).AND.
  550. & IFOUR.EQ.-2) THEN
  551. JGFAC=4
  552. TABFAC(3)='DIM3'
  553. TABFAC(4)='VISQ'
  554. ELSE
  555. JGFAC=3
  556. TABFAC(3)='VISQ'
  557. ENDIF
  558. TABFAC(1)='RHO '
  559. TABFAC(2)='ALPH'
  560.  
  561. * AM CAS FORMULATION NON-LOCALE
  562.  
  563. INLOC = 0
  564. MN3 = INFMOD(/1)
  565. IF (MN3.GE.13) INLOC=-1*INFMOD(13)
  566. IF (INLOC.GT.0) THEN
  567. JGOBL0 = JGFAC
  568. * moyenne
  569. IF(INLOC.EQ.1) THEN
  570. JGFAC=JGOBL0+1
  571. TABFAC(JGOBL0+1)='LCAR'
  572. * stress-based
  573. ELSEIF(INLOC.EQ.2) THEN
  574. JGFAC=JGOBL0+2
  575. TABFAC(JGOBL0+1)='LCAR'
  576. TABFAC(JGOBL0+2)='SBFT'
  577.  
  578. * helmholtz
  579. ELSE IF(INLOC.EQ.3) THEN
  580. * sellier 03/07/20
  581. * JGFAC=JGOBL0+6
  582. * TABFAC(JGOBL0+1)='LCAR'
  583. * TABFAC(JGOBL0+2)='LCF1'
  584. * TABFAC(JGOBL0+3)='LCF2'
  585. * TABFAC(JGOBL0+4)='LCF3'
  586. * TABFAC(JGOBL0+5)='LCF4'
  587. * TABFAC(JGOBL0+6)='LCF5'
  588. JGFAC=JGOBL0+NB_PARA_HELM
  589. c variables de Helmholtz a diffusions ORThotropes
  590. c modif liste para heilmholtz sellier 10//11/22
  591. c print*,'Dans IDMATR ', NB_HELM, 'formulationss Helmholtz'
  592. do I=1,NB_HELM
  593. c numero de la variable de Helmholtz
  594. write (motnl1,'(I1)') I
  595. c Capacité (infinie si BH=1)
  596. motnl3='CAP'
  597. motnl4=motnl3//motnl1
  598. TABFAC(JGOBL0+NB_PARA_PAR_HELM*(I-1)+1)=motnl4
  599. c print*,motnl4
  600. c Blocage de Dirichlet si 1 sinon 0
  601. motnl3='BLO'
  602. motnl4=motnl3//motnl1
  603. TABFAC(JGOBL0+NB_PARA_PAR_HELM*(I-1)+2)=motnl4
  604. c print*,motnl4
  605. c Valeur imposee a la zone de blocage de Dirichlet
  606. motnl3='DEP'
  607. motnl4=motnl3//motnl1
  608. TABFAC(JGOBL0+NB_PARA_PAR_HELM*(I-1)+3)=motnl4
  609. c print*,motnl4
  610. c Valeur initiale de la variable de Helmholtz
  611. motnl3='INI'
  612. motnl4=motnl3//motnl1
  613. TABFAC(JGOBL0+NB_PARA_PAR_HELM*(I-1)+4)=motnl4
  614. c print*,motnl4
  615. c indicateur logique de lineratite pour ne pas passer par istep=3 si 1
  616. motnl3='LIN'
  617. motnl4=motnl3//motnl1
  618. TABFAC(JGOBL0+NB_PARA_PAR_HELM*(I-1)+5)=motnl4
  619. c print*,motnl4
  620. do J=1,3
  621. c coefficients de diffusion
  622. write (motnld1,'(I1)') J
  623. c diffusion
  624. motnl2='DH'
  625. c 1er indice: numero de la variable d helmholtz
  626. motnl3=motnl2//motnl1
  627. c 2eme indice : direction
  628. motnl4=motnl3//motnld1
  629. TABFAC(JGOBL0+(I-1)*NB_PARA_PAR_HELM+
  630. # 5+(J-1)*4+1)=motnl4
  631. c print*,motnl4
  632. do K=1,3
  633. write (motnla1,'(I1)') K
  634. c direction principales de diffusion
  635. motnlv1='V'
  636. c indice numero de la variable
  637. motnl2=motnlv1//motnl1
  638. c indice direction principale
  639. motnl3=motnl2//motnld1
  640. c projection sur axe indice de base fixe
  641. motnl4=motnl3//motnla1
  642. TABFAC(JGOBL0+(I-1)*NB_PARA_PAR_HELM+
  643. # 5+(J-1)*4+1+K)=motnl4
  644. c print*,motnl4
  645. end do
  646. end do
  647. end do
  648. Cc on rajoute 2 inutiles pour compenser un decalage constatte dans castem20
  649. C TABFAC(JGOBL0+NB_PARA_HELM+1)='FAC1'
  650. C TABFAC(JGOBL0+NB_PARA_HELM+2)='FAC2'
  651. * fin modif sellier
  652. * cas non prevu
  653. ELSE
  654. IRET = 0
  655. CALL ERREUR(5)
  656. ENDIF
  657. ENDIF
  658. ENDIF
  659. C
  660. IF (NMAT.LT.2) GOTO 9999
  661. C
  662. CALL PLACE(MATMOD,NMAT,IADVE,'ADVECTION')
  663. IF (IADVE.NE.0) THEN
  664. JG0FAC = JGFAC
  665. C Cas des Tuyaux 1D (MFR=79)
  666. IF (MFR .EQ. 79) THEN
  667. JGFAC = JG0FAC + 3
  668. TABFAC(JG0FAC +1)='RHO '
  669. TABFAC(JG0FAC +2)='C '
  670. TABFAC(JG0FAC +3)='VITE'
  671.  
  672. C Cas Massif (MFR=1)
  673. ELSEIF (MFR.EQ.1) THEN
  674. C Bidimensionnel PLAN DPGE
  675. IF (IFOUR.EQ.-3) THEN
  676. JGFAC = JG0FAC +5
  677. TABFAC(JG0FAC +1)='RHO '
  678. TABFAC(JG0FAC +2)='C '
  679. TABFAC(JG0FAC +3)='VITX'
  680. TABFAC(JG0FAC +4)='VITY'
  681. TABFAC(JG0FAC +5)='VITZ'
  682.  
  683. C Bidimensionnel PLAN (CP/DP)
  684. ELSEIF (IFOUR.EQ.-2 .OR. IFOUR.EQ.-1) THEN
  685. JGFAC = JG0FAC +4
  686. TABFAC(JG0FAC +1)='RHO '
  687. TABFAC(JG0FAC +2)='C '
  688. TABFAC(JG0FAC +3)='VITX'
  689. TABFAC(JG0FAC +4)='VITY'
  690.  
  691. C Axisymetrie
  692. ELSEIF (IFOUR .EQ. 0) THEN
  693. JGFAC = JG0FAC +4
  694. TABFAC(JG0FAC +1)='RHO '
  695. TABFAC(JG0FAC +2)='C '
  696. TABFAC(JG0FAC +3)='VITR'
  697. TABFAC(JG0FAC +4)='VITZ'
  698.  
  699. C Fourier
  700. ELSEIF (IFOUR.EQ.1) THEN
  701. CALL ERREUR(21)
  702. RETURN
  703. C JGFAC = 5C
  704. C TABFAC(1)='RHO '
  705. C TABFAC(2)='C '
  706. C TABFAC(3)='VITR'
  707. C TABFAC(4)='VITZ'
  708. C TABFAC(5)='VITT'
  709.  
  710. C Tridimensionnel
  711. ELSEIF (IFOUR.EQ.2) THEN
  712. JGFAC = JG0FAC +5
  713. TABFAC(JG0FAC +1)='RHO '
  714. TABFAC(JG0FAC +2)='C '
  715. TABFAC(JG0FAC +3)='VITX'
  716. TABFAC(JG0FAC +4)='VITY'
  717. TABFAC(JG0FAC +5)='VITZ'
  718.  
  719. C Unidimensionnel (1D)
  720. ELSE
  721. ENDIF
  722. ENDIF
  723. GOTO 9999
  724. ENDIF
  725. C =============================================================
  726. C MATERIAU MECANIQUE ELASTIQUE ORTHOTROPE
  727. C =============================================================
  728. ELSEIF (IMATEE.EQ.2) THEN
  729. C
  730. * JOINT UNIDIMENSIONNEL JOI1
  731. IF (MFR.EQ.75) THEN
  732. IF(IFOUR.EQ.2)THEN
  733. JGOBL=12
  734. TABOBL(1)='V1X '
  735. TABOBL(2)='V1Y '
  736. TABOBL(3)='V1Z '
  737. TABOBL(4)='V2X '
  738. TABOBL(5)='V2Y '
  739. TABOBL(6)='V2Z '
  740. TABOBL(7)='KN '
  741. TABOBL(8)='KS1 '
  742. TABOBL(9)='KS2 '
  743. TABOBL(10)='QN '
  744. TABOBL(11)='QS1 '
  745. TABOBL(12)='QS2 '
  746. *
  747. JGFAC=10
  748. TABFAC(1)='MASS'
  749. TABFAC(2)='JX '
  750. TABFAC(3)='JY '
  751. TABFAC(4)='JZ '
  752. TABFAC(5)='ALPN'
  753. TABFAC(6)='ALP1'
  754. TABFAC(7)='ALP2'
  755. TABFAC(8)='ALQN'
  756. TABFAC(9)='ALQ1'
  757. TABFAC(10)='ALQ2'
  758. ELSEIF(IFOUR.EQ.-2.OR.IFOUR.EQ.-1)THEN
  759. JGOBL=5
  760. TABOBL(1)='V1X '
  761. TABOBL(2)='V1Y '
  762. TABOBL(3)='KN '
  763. TABOBL(4)='KS '
  764. TABOBL(5)='QS '
  765. *
  766. JGFAC=6
  767. TABFAC(1)='MASS'
  768. TABFAC(2)='JZ'
  769. TABFAC(4)='ALPN'
  770. TABFAC(5)='ALPS'
  771. TABFAC(6)='ALQS'
  772. ENDIF
  773. *
  774. * COQUES MINCES
  775. ELSEIF (MFR.EQ.3) THEN
  776. JGOBL=6
  777. TABOBL(1)='YG1 '
  778. TABOBL(2)='YG2 '
  779. TABOBL(3)='NU12'
  780. TABOBL(4)='G12 '
  781. TABOBL(5)='V1X '
  782. TABOBL(6)='V1Y '
  783. IF(IFOUR.EQ.-2) THEN
  784. JGFAC=4
  785. ELSE
  786. JGFAC=3
  787. ENDIF
  788. TABFAC(1)='ALP1'
  789. TABFAC(2)='ALP2'
  790. TABFAC(3)='RHO '
  791. IF(IFOUR.EQ.-2) TABFAC(4)='DIM3'
  792.  
  793. * COQUES AVEC CISAILLEMENT TRANSVERSE
  794. ELSEIF (MFR.EQ.9.OR.MFR.EQ.5) THEN
  795. JGOBL=8
  796. TABOBL(1)='YG1 '
  797. TABOBL(2)='YG2 '
  798. TABOBL(3)='NU12'
  799. TABOBL(4)='G12 '
  800. TABOBL(5)='G23 '
  801. TABOBL(6)='G13 '
  802. TABOBL(7)='V1X '
  803. TABOBL(8)='V1Y '
  804. *
  805. JGFAC=3
  806. TABFAC(1)='RHO '
  807. TABFAC(2)='ALP1'
  808. TABFAC(3)='ALP2'
  809.  
  810. * ELEMENTS MASSIFS
  811. ELSEIF (MFR.EQ.1.OR.MFR.EQ.31) THEN
  812. IF(IDIM.EQ.3)THEN
  813. JGOBL=15
  814. TABOBL(1)='YG1 '
  815. TABOBL(2)='YG2 '
  816. TABOBL(3)='YG3 '
  817. TABOBL(4)='NU12'
  818. TABOBL(5)='NU23'
  819. TABOBL(6)='NU13'
  820. TABOBL(7)='G12 '
  821. TABOBL(8)='G23 '
  822. TABOBL(9)='G13 '
  823. TABOBL(10)='V1X '
  824. TABOBL(11)='V1Y '
  825. TABOBL(12)='V1Z '
  826. TABOBL(13)='V2X '
  827. TABOBL(14)='V2Y '
  828. TABOBL(15)='V2Z '
  829. *
  830. JGFAC=4
  831. TABFAC(1)='RHO '
  832. TABFAC(2)='ALP1'
  833. TABFAC(3)='ALP2'
  834. TABFAC(4)='ALP3'
  835. ELSEIF (IDIM.EQ.2) THEN
  836. IF(IFOUR.EQ.-2)THEN
  837. JGOBL=9
  838. TABOBL(1)='YG1 '
  839. TABOBL(2)='YG2 '
  840. TABOBL(3)='NU12'
  841. TABOBL(4)='G12 '
  842. TABOBL(5)='V1X '
  843. TABOBL(6)='V1Y '
  844. TABOBL(7)='YG3 '
  845. TABOBL(8)='NU23'
  846. TABOBL(9)='NU13'
  847. *
  848. JGFAC=4
  849. TABFAC(1)='RHO '
  850. TABFAC(2)='ALP1'
  851. TABFAC(3)='ALP2'
  852. TABFAC(4)='DIM3'
  853. ELSEIF (IFOUR.EQ.-1.OR.IFOUR.EQ.0.OR.IFOUR.EQ.-3) THEN
  854. JGOBL=9
  855. TABOBL(1)='YG1 '
  856. TABOBL(2)='YG2 '
  857. TABOBL(3)='YG3 '
  858. TABOBL(4)='NU12'
  859. TABOBL(5)='NU23'
  860. TABOBL(6)='NU13'
  861. TABOBL(7)='G12 '
  862. TABOBL(8)='V1X '
  863. TABOBL(9)='V1Y '
  864. *
  865. JGFAC=4
  866. TABFAC(1)='RHO '
  867. TABFAC(2)='ALP1'
  868. TABFAC(3)='ALP2'
  869. TABFAC(4)='ALP3'
  870. ELSEIF (IFOUR.EQ.1) THEN
  871. JGOBL=15
  872. TABOBL(1)='YG1 '
  873. TABOBL(2)='YG2 '
  874. TABOBL(3)='YG3 '
  875. TABOBL(4)='NU12'
  876. TABOBL(5)='NU23'
  877. TABOBL(6)='NU13'
  878. TABOBL(7)='G12 '
  879. TABOBL(8)='G23 '
  880. TABOBL(9)='G13 '
  881. TABOBL(10)='V1X '
  882. TABOBL(11)='V1Y '
  883. TABOBL(12)='V1Z '
  884. TABOBL(13)='V2X '
  885. TABOBL(14)='V2Y '
  886. TABOBL(15)='V2Z '
  887. *
  888. JGFAC=4
  889. TABFAC(1)='RHO '
  890. TABFAC(2)='ALP1'
  891. TABFAC(3)='ALP2'
  892. TABFAC(4)='ALP3'
  893. ENDIF
  894. ELSEIF (IDIM.EQ.1) THEN
  895. C= Dans le cas UNID SPHErique, on doit avoir YG2=YG3 et NU12=NU13
  896. C= et dans le cas thermomecanique ALP2=ALP3.
  897. JGOBL=6
  898. TABOBL(1)='YG1 '
  899. TABOBL(2)='YG2 '
  900. TABOBL(3)='YG3 '
  901. TABOBL(4)='NU12'
  902. TABOBL(5)='NU23'
  903. TABOBL(6)='NU13'
  904. IF (IFOUR.EQ.6) THEN
  905. JGFAC=2
  906. ELSEIF (IFOUR.EQ.5 .OR. IFOUR.EQ.10) THEN
  907. JGFAC=3
  908. TABFAC(3)='ALP3'
  909. ELSEIF (IFOUR.EQ.4.OR.IFOUR.EQ.8.OR.
  910. & IFOUR.EQ.13) THEN
  911. JGFAC=3
  912. TABFAC(3)='ALP2'
  913. ELSE
  914. JGFAC=4
  915. TABFAC(3)='ALP2'
  916. TABFAC(4)='ALP3'
  917. ENDIF
  918. TABFAC(1)='RHO '
  919. TABFAC(2)='ALP1'
  920. ENDIF
  921.  
  922. * ELEMENTS JOINTS
  923. ELSEIF (MFR.EQ.35) THEN
  924. IF (IFOUR.EQ.2) THEN
  925. JGOBL=5
  926. TABOBL(1)='KS1 '
  927. TABOBL(2)='KS2 '
  928. TABOBL(3)='KN '
  929. TABOBL(4)='V1X '
  930. TABOBL(5)='V1Y '
  931. *
  932. JGFAC=2
  933. TABFAC(1)='RHO '
  934. TABFAC(2)='ALPN'
  935. ENDIF
  936. ENDIF
  937. C =============================================================
  938. C MATERIAU MECANIQUE ELASTIQUE ANISOTROPE
  939. C =============================================================
  940. ELSEIF (IMATEE.EQ.3)THEN
  941. C
  942. C JOINT UNIDIMESIONNEL JOI1
  943. IF(MFR.EQ.75)THEN
  944. IF (IFOUR.EQ.2) THEN
  945. JGOBL=27
  946. TABOBL(1)='V1X '
  947. TABOBL(2)='V1Y '
  948. TABOBL(3)='V1Z '
  949. TABOBL(4)='V2X '
  950. TABOBL(5)='V2Y '
  951. TABOBL(6)='V2Z '
  952. TABOBL(7)='D11 '
  953. TABOBL(8)='D22 '
  954. TABOBL(9)='D33 '
  955. TABOBL(10)='D44 '
  956. TABOBL(11)='D55 '
  957. TABOBL(12)='D66 '
  958. TABOBL(13)='D21 '
  959. TABOBL(14)='D31 '
  960. TABOBL(15)='D32 '
  961. TABOBL(16)='D41 '
  962. TABOBL(17)='D42 '
  963. TABOBL(18)='D43 '
  964. TABOBL(19)='D51 '
  965. TABOBL(20)='D52 '
  966. TABOBL(21)='D53 '
  967. TABOBL(22)='D54 '
  968. TABOBL(23)='D61 '
  969. TABOBL(24)='D62 '
  970. TABOBL(25)='D63 '
  971. TABOBL(26)='D64 '
  972. TABOBL(27)='D65 '
  973. *
  974. JGFAC=10
  975. * MASS: masse totale de l'élément joint
  976. TABFAC(1)='MASS'
  977. TABFAC(2)='JX '
  978. TABFAC(3)='JY '
  979. TABFAC(4)='JZ '
  980. TABFAC(5)='ALP1'
  981. TABFAC(6)='ALP2'
  982. TABFAC(7)='ALP3'
  983. TABFAC(8)='ALQ1'
  984. TABFAC(9)='ALQ2'
  985. TABFAC(10)='ALQ3'
  986. ELSEIF (IFOUR.EQ.-2.OR.IFOUR.EQ.-1) THEN
  987. JGOBL=8
  988. TABOBL(1)='V1X '
  989. TABOBL(2)='V1Y '
  990. TABOBL(3)='D11 '
  991. TABOBL(4)='D22 '
  992. TABOBL(5)='D33 '
  993. TABOBL(6)='D21 '
  994. TABOBL(7)='D31 '
  995. TABOBL(8)='D32 '
  996. *
  997. JGFAC=5
  998. * MASS: masse totale de l'élément joint
  999. TABFAC(1)='MASS'
  1000. TABFAC(2)='JZ '
  1001. TABFAC(3)='ALP1'
  1002. TABFAC(4)='ALP2'
  1003. TABFAC(5)='ALQ3'
  1004. ENDIF
  1005. ENDIF
  1006. *
  1007. * ELEMENTS MASSIFS
  1008. *
  1009. IF(MFR.EQ.1.OR.MFR.EQ.31)THEN
  1010. IF(IDIM.EQ.3)THEN
  1011. JGOBL=27
  1012. TABOBL(1)='D11 '
  1013. TABOBL(2)='D21 '
  1014. TABOBL(3)='D22 '
  1015. TABOBL(4)='D31 '
  1016. TABOBL(5)='D32 '
  1017. TABOBL(6)='D33 '
  1018. TABOBL(7)='D41 '
  1019. TABOBL(8)='D42 '
  1020. TABOBL(9)='D43 '
  1021. TABOBL(10)='D44 '
  1022. TABOBL(11)='D51 '
  1023. TABOBL(12)='D52 '
  1024. TABOBL(13)='D53 '
  1025. TABOBL(14)='D54 '
  1026. TABOBL(15)='D55 '
  1027. TABOBL(16)='D61 '
  1028. TABOBL(17)='D62 '
  1029. TABOBL(18)='D63 '
  1030. TABOBL(19)='D64 '
  1031. TABOBL(20)='D65 '
  1032. TABOBL(21)='D66 '
  1033. TABOBL(22)='V1X '
  1034. TABOBL(23)='V1Y '
  1035. TABOBL(24)='V1Z '
  1036. TABOBL(25)='V2X '
  1037. TABOBL(26)='V2Y '
  1038. TABOBL(27)='V2Z '
  1039. *
  1040. JGFAC=7
  1041. TABFAC(1)='RHO '
  1042. TABFAC(2)='ALP1'
  1043. TABFAC(3)='ALP2'
  1044. TABFAC(4)='ALP3'
  1045. TABFAC(5)='AL12'
  1046. TABFAC(6)='AL13'
  1047. TABFAC(7)='AL23'
  1048. ELSEIF (IDIM.EQ.2) THEN
  1049. IF (IFOUR.EQ.-2) THEN
  1050. JGOBL=12
  1051. TABOBL(1)='D11 '
  1052. TABOBL(2)='D21 '
  1053. TABOBL(3)='D22 '
  1054. TABOBL(4)='D41 '
  1055. TABOBL(5)='D42 '
  1056. TABOBL(6)='D44 '
  1057. TABOBL(7)='V1X '
  1058. TABOBL(8)='V1Y '
  1059. TABOBL(9)='D31 '
  1060. TABOBL(10)='D32 '
  1061. TABOBL(11)='D33 '
  1062. TABOBL(12)='D43 '
  1063. *
  1064. JGFAC=5
  1065. TABFAC(1)='RHO '
  1066. TABFAC(2)='ALP1'
  1067. TABFAC(3)='ALP2'
  1068. TABFAC(4)='AL12'
  1069. TABFAC(5)='DIM3'
  1070. ELSEIF (IFOUR.EQ.-1.OR.IFOUR.EQ.0.OR.IFOUR.EQ.-3) THEN
  1071. JGOBL=12
  1072. TABOBL(1)='D11 '
  1073. TABOBL(2)='D21 '
  1074. TABOBL(3)='D22 '
  1075. TABOBL(4)='D31 '
  1076. TABOBL(5)='D32 '
  1077. TABOBL(6)='D33 '
  1078. TABOBL(7)='D41 '
  1079. TABOBL(8)='D42 '
  1080. TABOBL(9)='D43 '
  1081. TABOBL(10)='D44 '
  1082. TABOBL(11)='V1X '
  1083. TABOBL(12)='V1Y '
  1084. *
  1085. JGFAC=5
  1086. TABFAC(1)='RHO '
  1087. TABFAC(2)='ALP1'
  1088. TABFAC(3)='ALP2'
  1089. TABFAC(4)='AL12'
  1090. TABFAC(5)='ALP3'
  1091. ELSEIF (IFOUR.EQ.1) THEN
  1092. JGOBL=15
  1093. TABOBL(1)='D11 '
  1094. TABOBL(2)='D21 '
  1095. TABOBL(3)='D22 '
  1096. TABOBL(4)='D31 '
  1097. TABOBL(5)='D32 '
  1098. TABOBL(6)='D33 '
  1099. TABOBL(7)='D41 '
  1100. TABOBL(8)='D42 '
  1101. TABOBL(9)='D43 '
  1102. TABOBL(10)='D44 '
  1103. TABOBL(11)='D55 '
  1104. TABOBL(12)='D65 '
  1105. TABOBL(13)='D66 '
  1106. TABOBL(14)='V1X '
  1107. TABOBL(15)='V1Y '
  1108. *
  1109. JGFAC=5
  1110. TABFAC(1)='RHO '
  1111. TABFAC(2)='ALP1'
  1112. TABFAC(3)='ALP2'
  1113. TABFAC(4)='AL12'
  1114. TABFAC(5)='ALP3'
  1115. ENDIF
  1116. ENDIF
  1117. ENDIF
  1118. C =============================================================
  1119. C MATERIAU MECANIQUE ELASTIQUE POREUX ISOTROPE
  1120. C =============================================================
  1121. ELSEIF (IMATEE.EQ.7) THEN
  1122. IF (MFR.EQ.33) THEN
  1123. JGOBL=12
  1124. TABOBL(1) ='YOUN'
  1125. TABOBL(2) ='NU '
  1126. TABOBL(3) ='RHO '
  1127. TABOBL(4) ='ALPH'
  1128. TABOBL(5) ='COB '
  1129. TABOBL(6) ='MOB '
  1130. TABOBL(7) ='ALPM'
  1131. TABOBL(8) ='PERM'
  1132. TABOBL(9) ='VISC'
  1133. TABOBL(10)='KF '
  1134. TABOBL(11)='RHOF'
  1135. TABOBL(12)='ALPF'
  1136. IF (IFOUR.EQ.-2) THEN
  1137. JGFAC=1
  1138. TABFAC(1)='DIM3'
  1139. ENDIF
  1140. ENDIF
  1141. C =============================================================
  1142. C MATERIAU MECANIQUE ELASTIQUE HOMOGENEISE
  1143. C =============================================================
  1144. ELSEIF (IMATEE.EQ.5) THEN
  1145. IF (MFR.EQ.37) THEN
  1146. JGOBL=16
  1147. TABOBL( 1)='B11 '
  1148. TABOBL( 2)='B22 '
  1149. TABOBL( 3)='B12 '
  1150. TABOBL( 4)='ROF '
  1151. TABOBL( 5)='ROS '
  1152. TABOBL( 6)='YOUN'
  1153. TABOBL( 7)='CSON'
  1154. TABOBL( 8)='RORF'
  1155. TABOBL( 9)='CREF'
  1156. TABOBL(10)='LCAR'
  1157. TABOBL(11)='E111'
  1158. TABOBL(12)='E112'
  1159. TABOBL(13)='E121'
  1160. TABOBL(14)='E122'
  1161. TABOBL(15)='E221'
  1162. TABOBL(16)='E222'
  1163. ENDIF
  1164. C =============================================================
  1165. C MATERIAU MECANIQUE ELASTIQUE UNIDIRECTIONNEL
  1166. C =============================================================
  1167. ELSEIF (IMATEE.EQ.4) THEN
  1168. IF ((MFR.EQ.1.OR.MFR.EQ.31).AND.IDIM.EQ.3) THEN
  1169. JGOBL=7
  1170. TABOBL(1)='YOUN'
  1171. TABOBL(2)='V1X '
  1172. TABOBL(3)='V1Y '
  1173. TABOBL(4)='V1Z '
  1174. TABOBL(5)='V2X '
  1175. TABOBL(6)='V2Y '
  1176. TABOBL(7)='V2Z '
  1177. ELSE
  1178. JGOBL=3
  1179. TABOBL(1)='YOUN'
  1180. TABOBL(2)='V1X '
  1181. TABOBL(3)='V1Y '
  1182. ENDIF
  1183.  
  1184. IF((MFR.EQ.1.OR.MFR.EQ.3.OR.MFR.EQ.31).AND.
  1185. & IFOUR.EQ.-2) THEN
  1186. JGFAC=3
  1187. TABFAC(3)='DIM3'
  1188. ELSE
  1189. JGFAC=2
  1190. ENDIF
  1191. TABFAC(1)='RHO '
  1192. TABFAC(2)='ALPH'
  1193. C =============================================================
  1194. C MATERIAU MECANIQUE ELASTIQUE SECTION DU MODELE A FIBRE
  1195. C =============================================================
  1196. ELSEIF (IMATEE.EQ.11) THEN
  1197. JGOBL=2
  1198. TABOBL(1)='MODS'
  1199. TABOBL(2)='MATS'
  1200.  
  1201. JGFAC=1
  1202. TABFAC(1)='MANO'
  1203. C =============================================================
  1204. C MATERIAU MECANIQUE ELASTIQUE ARMATURE POUR CABLE PRECONTRAINT
  1205. C =============================================================
  1206. ELSEIF (IMATEE.EQ.8) THEN
  1207. JGOBL=1
  1208. TABOBL(1)='YOUN'
  1209.  
  1210. JGFAC=8
  1211. TABFAC(1)='FF'
  1212. TABFAC(2)='PHIF'
  1213. TABFAC(3)='GANC'
  1214. TABFAC(4)='RMU0'
  1215. TABFAC(5)='FPRG'
  1216. TABFAC(6)='RH10'
  1217. TABFAC(7)='ALPH'
  1218. TABFAC(8)='RHO '
  1219. C =============================================================
  1220. C MATERIAU MECANIQUE ELASTIQUE MODAL
  1221. C =============================================================
  1222. ELSEIF (IMATEE.EQ.9) THEN
  1223. JGOBL=3
  1224. TABOBL(1)='FREQ'
  1225. TABOBL(2)='MASS'
  1226. TABOBL(3)='DEFO'
  1227.  
  1228. JGFAC = 9
  1229. TABFAC(1) = 'AMOR'
  1230. TABFAC(2) = 'CGRA'
  1231. TABFAC(3) = 'MADE'
  1232. TABFAC(4) = 'RICR'
  1233. TABFAC(5) = 'MAIB'
  1234. TABFAC(6) = 'MACR'
  1235. TABFAC(7) = 'AMCR'
  1236. TABFAC(8) = 'ALP0'
  1237. TABFAC(9) = 'ECRO'
  1238. C =============================================================
  1239. C MATERIAU MECANIQUE ELASTIQUE STATIQUE
  1240. C =============================================================
  1241. ELSEIF (IMATEE.EQ.10) THEN
  1242. JGOBL=3
  1243. TABOBL(1)='DEFO'
  1244. TABOBL(2)='RIDE'
  1245. TABOBL(3)='MADE'
  1246.  
  1247. JGFAC = 8
  1248. TABFAC(1) = 'AMOR'
  1249. TABFAC(2) = 'RICR'
  1250. TABFAC(3) = 'MAIA'
  1251. TABFAC(4) = 'MAIB'
  1252. TABFAC(5) = 'MACR'
  1253. TABFAC(6) = 'AMCR'
  1254. TABFAC(7) = 'BET0'
  1255. TABFAC(8) = 'ECRO'
  1256. C =============================================================
  1257. C MATERIAU MECANIQUE ELASTIQUE ZONE_COHESIVE
  1258. C =============================================================
  1259. ELSEIF (IMATEE.EQ.12) THEN
  1260. JGOBL=2
  1261. TABOBL(1)='KS'
  1262. TABOBL(2)='KN'
  1263. ENDIF
  1264. C
  1265. C LECTURE DES AUTRES MOTS-CLES DE MATMOD (DE INMAT A NMAT)
  1266. IF (NMAT.GE.INMAT) THEN
  1267. CALL MODNLI(MOMODL,NMOD)
  1268. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1269. INMAT=INMAT+1
  1270. IRET = 1
  1271. C ===========================================================
  1272. C MATERIAU MECANIQUE ELASTIQUE ... PLASTIQUE (ISOTROPE)
  1273. C ===========================================================
  1274. IF (IPLAC.EQ.1) THEN
  1275. CALL MODPLA(MOMODL,NMOD)
  1276. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1277. IF (IPLAC.EQ.0) IPLAC=1
  1278. CALL IDPLAS(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1279. C ===========================================================
  1280. C MATERIAU MECANIQUE ELASTIQUE ... FLUAGE (NORTON)
  1281. C ===========================================================
  1282. ELSEIF (IPLAC.EQ.2) THEN
  1283. CALL MODFLU(MOMODL,NMOD)
  1284. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1285. IF (IPLAC.EQ.0) IPLAC=1
  1286. CALL IDFLUA(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1287. C ===========================================================
  1288. C MATERIAU MECANIQUE ELASTIQUE ... VISCOPLASTIQUE (ONERA)
  1289. C ===========================================================
  1290. ELSEIF (IPLAC.EQ.3) THEN
  1291. CALL MODVIS(MOMODL,NMOD)
  1292. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1293. IF (IPLAC.EQ.0) IPLAC=2
  1294. C
  1295. C Cas particulier des modeles GATT_MONERIE et UO2
  1296. C 'RHO ' et 'ALPH' sont obligatoires
  1297. IF (IPLAC.EQ.18.OR.IPLAC.EQ.19) THEN
  1298. JGOBL0 = JGOBL
  1299. JGOBL=JGOBL0+2
  1300. TABOBL(JGOBL0+1)='RHO '
  1301. TABOBL(JGOBL0+2)='ALPH'
  1302.  
  1303. JGOBL0=JGFAC
  1304. JGFAC=JGOBL0-2
  1305. IF (JGFAC.GT.0) THEN
  1306. DO 200 I=1,JGFAC
  1307. TABFAC(I)=TABFAC(I+2)
  1308. 200 CONTINUE
  1309. ENDIF
  1310. ENDIF
  1311. CALL IDVISC(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1312. C ===========================================================
  1313. C MATERIAU MECANIQUE ELASTIQUE ... ENDOMMAGEMENT (MAZARS)
  1314. C ===========================================================
  1315. ELSEIF (IPLAC.EQ.4) THEN
  1316. CALL MODEND(MOMODL,NMOD)
  1317. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1318. IF (IPLAC.EQ.0) IPLAC=1
  1319. CALL IDENDO(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1320. C ===========================================================
  1321. C MATERIAU MECANIQUE ELASTIQUE ... PLASTIQUE_ENDOM (PSURY)
  1322. C ===========================================================
  1323. ELSEIF (IPLAC.EQ.5) THEN
  1324. CALL MODPLE(MOMODL,NMOD)
  1325. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1326. IF (IPLAC.EQ.0) IPLAC=1
  1327. CALL IDPLEN(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1328. C ===========================================================
  1329. C MATERIAU MECANIQUE ELASTIQUE ... NON LINEAIRE (EQUIPLAS)
  1330. C ===========================================================
  1331. ELSEIF (IPLAC.EQ.6) THEN
  1332. CALL MODENL(MOMODL,NMOD)
  1333. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1334. IF (IPLAC.EQ.0) IPLAC=1
  1335. CALL IDELNL(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1336. C ===========================================================
  1337. ENDIF
  1338. IF (IRET.EQ.0) GOTO 9999
  1339. ENDIF
  1340. C
  1341. C Parametre CRIP
  1342. CALL PLACE(MATMOD,NMAT,ICRIP,'CRIP')
  1343. IF (ICRIP.NE.0) THEN
  1344. JGOBL = JGOBL + 1
  1345. TABOBL(JGOBL) = 'LIMP'
  1346. ENDIF
  1347. C
  1348. C Parametre FUSION
  1349. CALL PLACE(MATMOD,NMAT,IFUSI,'FUSION')
  1350. IF (IFUSI.NE.0) THEN
  1351. JGOBL = JGOBL + 1
  1352. TABOBL(JGOBL) = 'TFUS'
  1353. ENDIF
  1354. C =================================================================
  1355. C FORMULATION POREUX
  1356. C =================================================================
  1357. ELSE IF (MFR2.EQ.33) THEN
  1358. C
  1359. CALL MODLIN(MOMODL,NMOD)
  1360. CALL PLACE(MOMODL,NMOD,IRET,MATMOD(1))
  1361. IF (IRET.EQ.0) GOTO 9999
  1362. C
  1363. IF (NMAT.LT.2) GOTO 14
  1364. C
  1365. CALL MODELA(MOMODL,NMOD)
  1366. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(2))
  1367. C
  1368. INMAT=3
  1369. IF (IPLAC.EQ.0) INMAT=2
  1370. C
  1371. 14 CONTINUE
  1372. C
  1373. C MATERIAU POREUX ELASTIQUE ISOTROPE (PAR DEFAUT)
  1374. C ===============================================
  1375. IF (IMATEE.EQ.1) THEN
  1376. IF(MELE.GE.79.AND.MELE.LE.83)THEN
  1377. JGOBL=4
  1378. TABOBL(1) ='YOUN'
  1379. TABOBL(2) ='NU '
  1380. TABOBL(3) ='COB '
  1381. TABOBL(4) ='MOB '
  1382. *
  1383. JGFAC=8
  1384. IF(IFOUR.EQ.-2) THEN
  1385. JGFAC=9
  1386. TABFAC(9)='DIM3'
  1387. ENDIF
  1388. TABFAC(1)='RHOF'
  1389. TABFAC(2)='ALPF'
  1390. TABFAC(3)='ALPM'
  1391. TABFAC(4)='PERM'
  1392. TABFAC(5)='VISC'
  1393. TABFAC(6)='KF '
  1394. TABFAC(7)='RHO '
  1395. TABFAC(8)='ALPH'
  1396. ELSEIF(MELE.GE.108.AND.MELE.LE.110)THEN
  1397. JGOBL=4
  1398. TABOBL(1)='KS '
  1399. TABOBL(2)='KN '
  1400. TABOBL(3)='COB '
  1401. TABOBL(4)='MOB '
  1402. *
  1403. JGFAC=4
  1404. TABFAC(1)='PERT'
  1405. TABFAC(2)='PERH'
  1406. TABFAC(3)='PERB'
  1407. TABFAC(4)='VISC'
  1408. ELSEIF(MELE.GE.173.AND.MELE.LE.177)THEN
  1409. JGOBL=10
  1410. TABOBL(1) ='YOUN'
  1411. TABOBL(2) ='NU '
  1412. TABOBL(3) ='COP1'
  1413. TABOBL(4) ='COP2'
  1414. TABOBL(5) ='CPP1'
  1415. TABOBL(6) ='CPP2'
  1416. TABOBL(7) ='KK11'
  1417. TABOBL(8) ='KK12'
  1418. TABOBL(9) ='KK21'
  1419. TABOBL(10)='KK22'
  1420. *
  1421. JGFAC=8
  1422. IF(IFOUR.EQ.-2) THEN
  1423. JGFAC=9
  1424. TABFAC(9)='DIM3'
  1425. ENDIF
  1426. TABFAC(1)='RHOF'
  1427. TABFAC(2)='ALPF'
  1428. TABFAC(3)='ALPM'
  1429. TABFAC(4)='PK11'
  1430. TABFAC(5)='PK12'
  1431. TABFAC(6)='PK21'
  1432. TABFAC(7)='PK22'
  1433. TABFAC(8)='ALPH'
  1434. ELSEIF(MELE.GE.178.AND.MELE.LE.182)THEN
  1435. JGOBL=17
  1436. TABOBL(1)='YOUN'
  1437. TABOBL(2)='NU '
  1438. TABOBL(3)='COP1'
  1439. TABOBL(4)='COP2'
  1440. TABOBL(5)='COP3'
  1441. TABOBL(6)='CPP1'
  1442. TABOBL(7)='CPP2'
  1443. TABOBL(8)='CPP3'
  1444. TABOBL(9)='KK11'
  1445. TABOBL(10)='KK12'
  1446. TABOBL(11)='KK13'
  1447. TABOBL(12)='KK21'
  1448. TABOBL(13)='KK22'
  1449. TABOBL(14)='KK23'
  1450. TABOBL(15)='KK31'
  1451. TABOBL(16)='KK32'
  1452. TABOBL(17)='KK33'
  1453. *
  1454. JGFAC=14
  1455. IF(IFOUR.EQ.-2) THEN
  1456. JGFAC=15
  1457. TABFAC(15)='DIM3'
  1458. ENDIF
  1459. TABFAC(1)='RHOF'
  1460. TABFAC(2)='ALPF'
  1461. TABFAC(3)='ALPM'
  1462. TABFAC(4)='PK11'
  1463. TABFAC(5)='PK12'
  1464. TABFAC(6)='PK13'
  1465. TABFAC(7)='PK21'
  1466. TABFAC(8)='PK22'
  1467. TABFAC(9)='PK23'
  1468. TABFAC(10)='PK31'
  1469. TABFAC(11)='PK32'
  1470. TABFAC(12)='PK33'
  1471. TABFAC(13)='RHO '
  1472. TABFAC(14)='ALPH'
  1473. ELSEIF(MELE.GE.185.AND.MELE.LE.187)THEN
  1474. JGOBL=10
  1475. TABOBL(1)='KS '
  1476. TABOBL(2)='KN '
  1477. TABOBL(3)='COP1'
  1478. TABOBL(4)='COP2'
  1479. TABOBL(5)='CPP1'
  1480. TABOBL(6)='CPP2'
  1481. TABOBL(7)='KK11'
  1482. TABOBL(8)='KK12'
  1483. TABOBL(9)='KK21'
  1484. TABOBL(10)='KK22'
  1485. *
  1486. JGFAC=17
  1487. IF(IFOUR.EQ.-2) THEN
  1488. JGFAC=18
  1489. TABFAC(18)='DIM3'
  1490. ENDIF
  1491. TABFAC(1)='RHOF'
  1492. TABFAC(2)='ALPF'
  1493. TABFAC(3)='ALPM'
  1494. TABFAC(4)='PT11'
  1495. TABFAC(5)='PH11'
  1496. TABFAC(6)='PB11'
  1497. TABFAC(7)='PT12'
  1498. TABFAC(8)='PH12'
  1499. TABFAC(9)='PB12'
  1500. TABFAC(10)='PT21'
  1501. TABFAC(11)='PH21'
  1502. TABFAC(12)='PB21'
  1503. TABFAC(13)='PT22'
  1504. TABFAC(14)='PH22'
  1505. TABFAC(15)='PB22'
  1506. TABFAC(16)='RHO '
  1507. TABFAC(17)='ALPH'
  1508. ELSEIF(MELE.GE.188.AND.MELE.LE.190)THEN
  1509. JGOBL=17
  1510. TABOBL(1)='KS '
  1511. TABOBL(2)='KN '
  1512. TABOBL(3)='COP1'
  1513. TABOBL(4)='COP2'
  1514. TABOBL(5)='COP3'
  1515. TABOBL(6)='CPP1'
  1516. TABOBL(7)='CPP2'
  1517. TABOBL(8)='CPP3'
  1518. TABOBL(9)='KK11'
  1519. TABOBL(10)='KK12'
  1520. TABOBL(11)='KK13'
  1521. TABOBL(12)='KK21'
  1522. TABOBL(13)='KK22'
  1523. TABOBL(14)='KK23'
  1524. TABOBL(15)='KK31'
  1525. TABOBL(16)='KK32'
  1526. TABOBL(17)='KK33'
  1527. *
  1528. JGFAC=32
  1529. IF(IFOUR.EQ.-2) THEN
  1530. JGFAC=33
  1531. TABFAC(33)='DIM3'
  1532. ENDIF
  1533. TABFAC(1)='RHOF'
  1534. TABFAC(2)='ALPF'
  1535. TABFAC(3)='ALPM'
  1536. TABFAC(4)='PT11'
  1537. TABFAC(5)='PH11'
  1538. TABFAC(6)='PB11'
  1539. TABFAC(7)='PT12'
  1540. TABFAC(8)='PH12'
  1541. TABFAC(9)='PB12'
  1542. TABFAC(10)='PT13'
  1543. TABFAC(11)='PH13'
  1544. TABFAC(12)='PB13'
  1545. TABFAC(13)='PT21'
  1546. TABFAC(14)='PH21'
  1547. TABFAC(15)='PB21'
  1548. TABFAC(16)='PT22'
  1549. TABFAC(17)='PH22'
  1550. TABFAC(18)='PB22'
  1551. TABFAC(19)='PT23'
  1552. TABFAC(20)='PH23'
  1553. TABFAC(21)='PB23'
  1554. TABFAC(22)='PT31'
  1555. TABFAC(23)='PH31'
  1556. TABFAC(24)='PB31'
  1557. TABFAC(25)='PT32'
  1558. TABFAC(26)='PH32'
  1559. TABFAC(27)='PB32'
  1560. TABFAC(28)='PT33'
  1561. TABFAC(29)='PH33'
  1562. TABFAC(30)='PB33'
  1563. TABFAC(31)='RHO '
  1564. TABFAC(32)='ALPH'
  1565. ENDIF
  1566. C
  1567. C MATERIAU POREUX ELASTIQUE ORTHOTROPE
  1568. C ====================================
  1569. ELSEIF (IMATEE.EQ.2) THEN
  1570. IF (MFR.EQ.33) THEN
  1571. IF(IDIM.EQ.3)THEN
  1572. * ELEMENTS 3D
  1573. JGOBL=19
  1574. TABOBL(1)='YG1 '
  1575. TABOBL(2)='YG2 '
  1576. TABOBL(3)='YG3 '
  1577. TABOBL(4)='NU12'
  1578. TABOBL(5)='NU23'
  1579. TABOBL(6)='NU13'
  1580. TABOBL(7)='G12 '
  1581. TABOBL(8)='G23 '
  1582. TABOBL(9)='G13 '
  1583. TABOBL(10)='V1X '
  1584. TABOBL(11)='V1Y '
  1585. TABOBL(12)='V1Z '
  1586. TABOBL(13)='V2X '
  1587. TABOBL(14)='V2Y '
  1588. TABOBL(15)='V2Z '
  1589. TABOBL(16)='COB1'
  1590. TABOBL(17)='COB2'
  1591. TABOBL(18)='COB3'
  1592. TABOBL(19)='MOB '
  1593. *
  1594. JGFAC=12
  1595. TABFAC(1)='RHO '
  1596. TABFAC(2)='ALP1'
  1597. TABFAC(3)='ALP2'
  1598. TABFAC(4)='ALP3'
  1599. TABFAC(5)='ALPM'
  1600. TABFAC(6)='PER1'
  1601. TABFAC(7)='PER2'
  1602. TABFAC(8)='PER3'
  1603. TABFAC(9)='VISC'
  1604. TABFAC(10)='KF '
  1605. TABFAC(11)='RHOF'
  1606. TABFAC(12)='ALPF'
  1607. ELSEIF (IDIM.EQ.2) THEN
  1608. IF(IFOUR.EQ.-2)THEN
  1609. JGOBL=12
  1610. TABOBL(1)='YG1 '
  1611. TABOBL(2)='YG2 '
  1612. TABOBL(3)='NU12'
  1613. TABOBL(4)='G12 '
  1614. TABOBL(5)='V1X '
  1615. TABOBL(6)='V1Y '
  1616. TABOBL(7)='COB1'
  1617. TABOBL(8)='COB2'
  1618. TABOBL(9)='MOB '
  1619. TABOBL(10)='YG3 '
  1620. TABOBL(11)='NU23'
  1621. TABOBL(12)='NU13'
  1622. *
  1623. JGFAC=11
  1624. TABFAC(1)='RHO '
  1625. TABFAC(2)='ALP1'
  1626. TABFAC(3)='ALP2'
  1627. TABFAC(4)='ALPM'
  1628. TABFAC(5)='PER1'
  1629. TABFAC(6)='PER2'
  1630. TABFAC(7)='VISC'
  1631. TABFAC(8)='KF '
  1632. TABFAC(9)='RHOF'
  1633. TABFAC(10)='ALPF'
  1634. TABFAC(11)='DIM3'
  1635. ELSEIF (IFOUR.EQ.-1.OR.IFOUR.EQ.0.OR.IFOUR.EQ.-3) THEN
  1636. JGOBL=13
  1637. TABOBL(1)='YG1 '
  1638. TABOBL(2)='YG2 '
  1639. TABOBL(3)='YG3 '
  1640. TABOBL(4)='NU12'
  1641. TABOBL(5)='NU23'
  1642. TABOBL(6)='NU13'
  1643. TABOBL(7)='G12 '
  1644. TABOBL(8)='V1X '
  1645. TABOBL(9)='V1Y '
  1646. TABOBL(10)='COB1'
  1647. TABOBL(11)='COB2'
  1648. TABOBL(12)='COB3'
  1649. TABOBL(13)='MOB '
  1650. *
  1651. JGFAC=11
  1652. TABFAC(1)='RHO '
  1653. TABFAC(2)='ALP1'
  1654. TABFAC(3)='ALP2'
  1655. TABFAC(4)='ALP3'
  1656. TABFAC(5)='ALPM'
  1657. TABFAC(6)='PER1'
  1658. TABFAC(7)='PER2'
  1659. TABFAC(8)='VISC'
  1660. TABFAC(9)='KF '
  1661. TABFAC(10)='RHOF'
  1662. TABFAC(11)='ALPF'
  1663. ELSEIF (IFOUR.EQ.1) THEN
  1664. JGOBL=15
  1665. TABOBL(1)='YG1 '
  1666. TABOBL(2)='YG2 '
  1667. TABOBL(3)='YG3 '
  1668. TABOBL(4)='NU12'
  1669. TABOBL(5)='NU23'
  1670. TABOBL(6)='NU13'
  1671. TABOBL(7)='G12 '
  1672. TABOBL(8)='G23 '
  1673. TABOBL(9)='G13 '
  1674. TABOBL(10)='V1X '
  1675. TABOBL(11)='V1Y '
  1676. TABOBL(12)='COB1'
  1677. TABOBL(13)='COB2'
  1678. TABOBL(14)='COB3'
  1679. TABOBL(15)='MOB '
  1680. *
  1681. JGFAC=12
  1682. TABFAC(1)='RHO '
  1683. TABFAC(2)='ALP1'
  1684. TABFAC(3)='ALP2'
  1685. TABFAC(4)='ALP3'
  1686. TABFAC(5)='ALPM'
  1687. TABFAC(6)='PER1'
  1688. TABFAC(7)='PER2'
  1689. TABFAC(8)='PER3'
  1690. TABFAC(9)='VISC'
  1691. TABFAC(10)='KF '
  1692. TABFAC(11)='RHOF'
  1693. TABFAC(12)='ALPF'
  1694. ENDIF
  1695. ENDIF
  1696. ELSE
  1697. IRET = 0
  1698. GOTO 9999
  1699. ENDIF
  1700. C
  1701. C MATERIAU POREUX ELASTIQUE ANISOTROPE
  1702. C ====================================
  1703. ELSEIF (IMATEE.EQ.3)THEN
  1704. IF(MFR.EQ.33)THEN
  1705. IF(IDIM.EQ.3)THEN
  1706. JGOBL=34
  1707. TABOBL(1)='D11 '
  1708. TABOBL(2)='D21 '
  1709. TABOBL(3)='D22 '
  1710. TABOBL(4)='D31 '
  1711. TABOBL(5)='D32 '
  1712. TABOBL(6)='D33 '
  1713. TABOBL(7)='D41 '
  1714. TABOBL(8)='D42 '
  1715. TABOBL(9)='D43 '
  1716. TABOBL(10)='D44 '
  1717. TABOBL(11)='D51 '
  1718. TABOBL(12)='D52 '
  1719. TABOBL(13)='D53 '
  1720. TABOBL(14)='D54 '
  1721. TABOBL(15)='D55 '
  1722. TABOBL(16)='D61 '
  1723. TABOBL(17)='D62 '
  1724. TABOBL(18)='D63 '
  1725. TABOBL(19)='D64 '
  1726. TABOBL(20)='D65 '
  1727. TABOBL(21)='D66 '
  1728. TABOBL(22)='V1X '
  1729. TABOBL(23)='V1Y '
  1730. TABOBL(24)='V1Z '
  1731. TABOBL(25)='V2X '
  1732. TABOBL(26)='V2Y '
  1733. TABOBL(27)='V2Z '
  1734. TABOBL(28)='COB1'
  1735. TABOBL(29)='COB2'
  1736. TABOBL(30)='COB3'
  1737. TABOBL(31)='CO12'
  1738. TABOBL(32)='CO13'
  1739. TABOBL(33)='CO23'
  1740. TABOBL(34)='MOB '
  1741. *
  1742. JGFAC=18
  1743. TABFAC(1)='RHO '
  1744. TABFAC(2)='ALP1'
  1745. TABFAC(3)='ALP2'
  1746. TABFAC(4)='ALP3'
  1747. TABFAC(5)='AL12'
  1748. TABFAC(6)='AL13'
  1749. TABFAC(7)='AL23'
  1750. TABFAC(8)='ALPM'
  1751. TABFAC(9 )='PER1'
  1752. TABFAC(10)='PER2'
  1753. TABFAC(11)='PER3'
  1754. TABFAC(12)='PE12'
  1755. TABFAC(13)='PE13'
  1756. TABFAC(14)='PE23'
  1757. TABFAC(15)='VISC'
  1758. TABFAC(16)='KF '
  1759. TABFAC(17)='RHOF'
  1760. TABFAC(18)='ALPF'
  1761. ELSEIF (IDIM.EQ.2) THEN
  1762. IF (IFOUR.EQ.-2) THEN
  1763. JGOBL=16
  1764. TABOBL(1)='D11 '
  1765. TABOBL(2)='D21 '
  1766. TABOBL(3)='D22 '
  1767. TABOBL(4)='D41 '
  1768. TABOBL(5)='D42 '
  1769. TABOBL(6)='D44 '
  1770. TABOBL(7)='V1X '
  1771. TABOBL(8)='V1Y '
  1772. TABOBL(9 )='COB1'
  1773. TABOBL(10)='COB2'
  1774. TABOBL(11)='CO12'
  1775. TABOBL(12)='MOB '
  1776. TABOBL(13)='D31 '
  1777. TABOBL(14)='D32 '
  1778. TABOBL(15)='D33 '
  1779. TABOBL(16)='D43 '
  1780. *
  1781. JGFAC=13
  1782. TABFAC(1)='RHO '
  1783. TABFAC(2)='ALP1'
  1784. TABFAC(3)='ALP2'
  1785. TABFAC(4)='AL12'
  1786. TABFAC(5)='ALPM'
  1787. TABFAC(6)='PER1'
  1788. TABFAC(7)='PER2'
  1789. TABFAC(8)='PE12'
  1790. TABFAC(9)='VISC'
  1791. TABFAC(10)='KF '
  1792. TABFAC(11)='RHOF'
  1793. TABFAC(12)='ALPF'
  1794. TABFAC(13)='DIM3'
  1795. *
  1796. ELSEIF (IFOUR.EQ.-1.OR.IFOUR.EQ.0.OR.IFOUR.EQ.-3) THEN
  1797. JGOBL=17
  1798. TABOBL(1)='D11 '
  1799. TABOBL(2)='D21 '
  1800. TABOBL(3)='D22 '
  1801. TABOBL(4)='D31 '
  1802. TABOBL(5)='D32 '
  1803. TABOBL(6)='D33 '
  1804. TABOBL(7)='D41 '
  1805. TABOBL(8)='D42 '
  1806. TABOBL(9)='D43 '
  1807. TABOBL(10)='D44 '
  1808. TABOBL(11)='V1X '
  1809. TABOBL(12)='V1Y '
  1810. TABOBL(13)='COB1'
  1811. TABOBL(14)='COB2'
  1812. TABOBL(15)='CO12'
  1813. TABOBL(16)='COB3'
  1814. TABOBL(17)='MOB '
  1815. *
  1816. JGFAC=13
  1817. TABFAC(1)='RHO '
  1818. TABFAC(2)='ALP1'
  1819. TABFAC(3)='ALP2'
  1820. TABFAC(4)='AL12'
  1821. TABFAC(5)='ALP3'
  1822. TABFAC(6)='ALPM'
  1823. TABFAC(7)='PER1'
  1824. TABFAC(8)='PER2'
  1825. TABFAC(9)='PE12'
  1826. TABFAC(10)='VISC'
  1827. TABFAC(11)='KF '
  1828. TABFAC(12)='RHOF'
  1829. TABFAC(13)='ALPF'
  1830. ELSEIF (IFOUR.EQ.1) THEN
  1831. JGOBL=20
  1832. TABOBL(1)='D11 '
  1833. TABOBL(2)='D21 '
  1834. TABOBL(3)='D22 '
  1835. TABOBL(4)='D31 '
  1836. TABOBL(5)='D32 '
  1837. TABOBL(6)='D33 '
  1838. TABOBL(7)='D41 '
  1839. TABOBL(8)='D42 '
  1840. TABOBL(9)='D43 '
  1841. TABOBL(10)='D44 '
  1842. TABOBL(11)='D55 '
  1843. TABOBL(12)='D65 '
  1844. TABOBL(13)='D66 '
  1845. TABOBL(14)='V1X '
  1846. TABOBL(15)='V1Y '
  1847. TABOBL(16)='COB1'
  1848. TABOBL(17)='COB2'
  1849. TABOBL(18)='CO12'
  1850. TABOBL(19)='COB3'
  1851. TABOBL(20)='MOB '
  1852. *
  1853. JGFAC=14
  1854. TABFAC(1)='RHO '
  1855. TABFAC(2)='ALP1'
  1856. TABFAC(3)='ALP2'
  1857. TABFAC(4)='AL12'
  1858. TABFAC(5)='ALP3'
  1859. TABFAC(6)='ALPM'
  1860. TABFAC(7)='PER1'
  1861. TABFAC(8)='PER2'
  1862. TABFAC(9)='PE12'
  1863. TABFAC(10)='PER3'
  1864. TABFAC(11)='VISC'
  1865. TABFAC(12)='KF '
  1866. TABFAC(13)='RHOF'
  1867. TABFAC(14)='ALPF'
  1868. ENDIF
  1869. ENDIF
  1870. ELSE
  1871. IRET = 0
  1872. GOTO 9999
  1873. ENDIF
  1874. C
  1875. C MATERIAU POREUX ELASTIQUE UNIDIRECTIONNEL
  1876. C =========================================
  1877. ELSEIF (IMATEE.EQ.4) THEN
  1878. IF(MFR.EQ.33)THEN
  1879. IF (IDIM.EQ.3) THEN
  1880. JGOBL=9
  1881. TABOBL(1)='YOUN'
  1882. TABOBL(2)='V1X '
  1883. TABOBL(3)='V1Y '
  1884. TABOBL(4)='V1Z '
  1885. TABOBL(5)='V2X '
  1886. TABOBL(6)='V2Y '
  1887. TABOBL(7)='V2Z '
  1888. TABOBL(8)='COB '
  1889. TABOBL(9)='MOB '
  1890. ELSE
  1891. JGOBL=5
  1892. TABOBL(1)='YOUN'
  1893. TABOBL(2)='V1X '
  1894. TABOBL(3)='V1Y '
  1895. TABOBL(4)='COB '
  1896. TABOBL(5)='MOB '
  1897. ENDIF
  1898. *
  1899. JGFAC=8
  1900. IF(IFOUR.EQ.-2) THEN
  1901. JGFAC=9
  1902. TABFAC(9)='DIM3'
  1903. ENDIF
  1904. TABFAC(1)='RHO '
  1905. TABFAC(2)='ALPH'
  1906. TABFAC(3)='ALPM'
  1907. TABFAC(4)='PERM'
  1908. TABFAC(5)='VISC'
  1909. TABFAC(6)='KF '
  1910. TABFAC(7)='RHOF'
  1911. TABFAC(8)='ALPF'
  1912. ELSE
  1913. IRET = 0
  1914. GOTO 9999
  1915. ENDIF
  1916. C =============================================================
  1917. ENDIF
  1918. C
  1919. IF (NMAT.LT.2) GOTO 9999
  1920. C
  1921. C LECTURE DES AUTRES MOTS-CLES DE MATMOD (DE INMAT A NMAT)
  1922. IF (NMAT.GE.INMAT) THEN
  1923. CALL MODNLI(MOMODL,NMOD)
  1924. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1925. INMAT=INMAT+1
  1926. IRET = 1
  1927. C ===========================================================
  1928. C MATERIAU POREUX ELASTIQUE ... PLASTIQUE (ISOTROPE)
  1929. C ===========================================================
  1930. IF (IPLAC.EQ.1) THEN
  1931. CALL MODPLA(MOMODL,NMOD)
  1932. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1933. IF (IPLAC.EQ.0) IPLAC=1
  1934. CALL IDPLAS(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1935. C ===========================================================
  1936. C MATERIAU POREUX ELASTIQUE ... FLUAGE (NORTON)
  1937. C ===========================================================
  1938. ELSEIF (IPLAC.EQ.2) THEN
  1939. CALL MODFLU(MOMODL,NMOD)
  1940. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1941. IF (IPLAC.EQ.0) IPLAC=1
  1942. CALL IDFLUA(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1943. C ===========================================================
  1944. C MATERIAU POREUX ELASTIQUE ... VISCOPLASTIQUE (ONERA)
  1945. C ===========================================================
  1946. ELSEIF (IPLAC.EQ.3) THEN
  1947. CALL MODVIS(MOMODL,NMOD)
  1948. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1949. IF (IPLAC.EQ.0) IPLAC=2
  1950. CALL IDVISC(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1951. C ===========================================================
  1952. C MATERIAU POREUX ELASTIQUE ... ENDOMMAGEMENT (MAZARS)
  1953. C ===========================================================
  1954. ELSEIF (IPLAC.EQ.4) THEN
  1955. CALL MODEND(MOMODL,NMOD)
  1956. CALL PLACE(MOMODL,NMOD,IPLAC,MATMOD(INMAT))
  1957. IF (IPLAC.EQ.0) IPLAC=1
  1958. CALL IDENDO(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IPLAC,IRET)
  1959. C ===========================================================
  1960. ENDIF
  1961. IF (IRET.EQ.0) GOTO 9999
  1962. C
  1963. C En cas de creation de materiaux combinant plusieurs materiaux
  1964. C deja existant Ex ELASTIQUE ISOTROPE PLASTIQUE PARFAIT FLUAGE N
  1965. C GOTO 40
  1966. C
  1967. ENDIF
  1968. C =================================================================
  1969. C FORMULATION CONTACT
  1970. C =================================================================
  1971. ELSE IF (MFR2.EQ.4) THEN
  1972. C
  1973. IF (INATUU.EQ.2) THEN
  1974. JGOBL=2
  1975. TABOBL(1)='FF '
  1976. TABOBL(2)='PHIF'
  1977.  
  1978. JGFAC=0
  1979. ELSEIF (INATUU.EQ.1) THEN
  1980. JGOBL=1
  1981. TABOBL(1)='MU '
  1982.  
  1983. JGFAC=3
  1984. TABFAC(1)='COHE'
  1985. TABFAC(2)='ADHE'
  1986. TABFAC(3)='JEU'
  1987. ELSE
  1988. JGOBL=0
  1989.  
  1990. JGFAC=2
  1991. TABFAC(1)='JEU'
  1992. TABFAC(2)='ADHE'
  1993. ENDIF
  1994. C =================================================================
  1995. C FORMULATION CONTRAINTE
  1996. C =================================================================
  1997. ELSE IF (MFR2.EQ.6) THEN
  1998. C
  1999. IF (CMATEE.EQ.'ROTATION') THEN
  2000. JGOBL=1
  2001. TABOBL(1)='ANGL'
  2002. ELSEIF (CMATEE.EQ.'DEPLACEMENT') THEN
  2003. JGOBL=1
  2004. TABOBL(1)='AMPL'
  2005. ENDIF
  2006. C =================================================================
  2007. C FORMULATION MAGNETODYNAMIQUE
  2008. C =================================================================
  2009. ELSE IF (MFR2.EQ.69) THEN
  2010. C
  2011. IF(MFR.EQ.3) THEN
  2012. IF(IMATEE.EQ.1) THEN
  2013. JGOBL=3
  2014. TABOBL(1)='ETA'
  2015. TABOBL(2)='PERM'
  2016. TABOBL(3)='EPAI'
  2017. ELSEIF (IMATEE.EQ.3) THEN
  2018. JGOBL=4
  2019. TABOBL(1)='ETA1'
  2020. TABOBL(2)='ETA2'
  2021. TABOBL(3)='PERM'
  2022. TABOBL(4)='EPAI'
  2023. ENDIF
  2024. ENDIF
  2025. C =================================================================
  2026. C FORMULATION FISSURE
  2027. C =================================================================
  2028. ELSE IF (MFR2.EQ.40) THEN
  2029. C
  2030. C si POISEU_BLASIUS ou POISEU_COLEBROOK ou par defaut
  2031. JGOBL=1
  2032. TABOBL(1)='RUGO'
  2033. CALL PLACE(MATMOD,NMAT,IFT1,'FROTTEMENT1')
  2034. CALL PLACE(MATMOD,NMAT,IFT2,'FROTTEMENT2')
  2035. IF(IFT1.NE.0.OR.IFT2.NE.0) THEN
  2036. JGOBL=7
  2037. TABOBL(2)='REC'
  2038. TABOBL(3)='FK'
  2039. TABOBL(4)='FA'
  2040. TABOBL(5)='FB'
  2041. TABOBL(6)='FC'
  2042. TABOBL(7)='FD'
  2043. ELSE
  2044. CALL PLACE(MATMOD,NMAT,IFT1,'FROTTEMENT3')
  2045. CALL PLACE(MATMOD,NMAT,IFT2,'FROTTEMENT4')
  2046. IF(IFT1.NE.0.OR.IFT2.NE.0) THEN
  2047. JGOBL=2
  2048. TABOBL(2)='FK'
  2049. ENDIF
  2050. ENDIF
  2051. C =================================================================
  2052. C FORMULATION NAVIER_STOKES
  2053. C =================================================================
  2054. ELSE IF (MFR2.EQ.52) THEN
  2055. C
  2056. IF (IMATEE.EQ.4) THEN
  2057. *NLIN
  2058. JGOBL = 2
  2059. TABOBL(1) ='RHO '
  2060. TABOBL(2) ='MU '
  2061.  
  2062. JGFAC = 1
  2063. TABFAC(1) ='FREQ'
  2064. ENDIF
  2065. C =================================================================
  2066. C FORMULATION MELANGE
  2067. C =================================================================
  2068. ELSE IF (MFR2.EQ.38) THEN
  2069. C
  2070. IF (IMATEE.NE.3.AND.IMATEE.NE.4) THEN
  2071. CALL IDMETA(MFR,TABOBL,TABFAC,JGOBL,JGFAC,ITA,IMATEE,IRET)
  2072. IF (IRET.EQ.0) GOTO 9999
  2073. ENDIF
  2074. C =================================================================
  2075. C FORMULATION LIAISON
  2076. C =================================================================
  2077. ELSE IF (MFR2.EQ.24) THEN
  2078. C
  2079. IF (IMATEE.EQ.0) THEN
  2080. IRET = 0
  2081. GOTO 9999
  2082. *
  2083. ELSEIF (IMATEE.EQ.1) THEN
  2084. *PO_PL_FL
  2085. JGOBL = 7
  2086. TABOBL(1) ='NORM'
  2087. TABOBL(2) ='INER'
  2088. TABOBL(3) ='CONV'
  2089. TABOBL(4) ='VISC'
  2090. TABOBL(5) ='PELO'
  2091. TABOBL(6) ='PRAP'
  2092. TABOBL(7) ='JFLU'
  2093.  
  2094. ELSEIF (IMATEE.EQ.2) THEN
  2095. *PO_PL_FR
  2096. JGOBL = 7
  2097. TABOBL(1) ='NORM'
  2098. TABOBL(2) ='RAID'
  2099. TABOBL(3) ='JEU'
  2100. TABOBL(4) ='GLIS'
  2101. TABOBL(5) ='ADHE'
  2102. TABOBL(6) ='RTAN'
  2103. TABOBL(7) ='ATAN'
  2104.  
  2105. JGFAC = 2
  2106. TABFAC(1) = 'AMOR'
  2107. TABFAC(2) = 'LOIC'
  2108.  
  2109. ELSEIF (IMATEE.EQ.3) THEN
  2110. *PO_PL
  2111. JGOBL= 3
  2112. TABOBL(1) ='NORM'
  2113. TABOBL(2) ='RAID'
  2114. TABOBL(3) ='JEU'
  2115.  
  2116. JGFAC = 4
  2117. TABFAC(1) = 'LOIC'
  2118. TABFAC(2) = 'PERM'
  2119. TABFAC(3) ='SPLA'
  2120. TABFAC(4) ='AMOR'
  2121.  
  2122. ELSEIF (IMATEE.EQ.4) THEN
  2123. *PO_PO_FR
  2124. JGOBL = 8
  2125. TABOBL(1) ='NORM'
  2126. TABOBL(2) ='RAID'
  2127. TABOBL(3) ='JEU'
  2128. TABOBL(4) ='POIB'
  2129. TABOBL(5) ='ADHE'
  2130. TABOBL(6) ='RTAN'
  2131. TABOBL(7) ='ATAN'
  2132. TABOBL(8) ='GLIS'
  2133.  
  2134. JGFAC = 3
  2135. TABFAC(1) = 'AMOR'
  2136. TABFAC(2) = 'LOIC'
  2137. TABFAC(3) = 'MODE'
  2138.  
  2139. ELSEIF (IMATEE.EQ.5) THEN
  2140. *PO_PO_DP
  2141. JGOBL = 6
  2142. TABOBL(1) ='NORM'
  2143. TABOBL(2) ='ECRO'
  2144. TABOBL(3) ='JEU'
  2145. TABOBL(4) ='POIB'
  2146. TABOBL(5) ='PERM'
  2147. TABOBL(6) ='LOIC'
  2148.  
  2149. JGFAC = 1
  2150. TABFAC(1) = 'AMOR'
  2151.  
  2152. ELSEIF (IMATEE.EQ.6) THEN
  2153. *PO_PO_RP
  2154. JGOBL = 6
  2155. TABOBL(1) ='AXRO'
  2156. TABOBL(2) ='ECRO'
  2157. TABOBL(3) ='JEU'
  2158. TABOBL(4) ='POIB'
  2159. TABOBL(5) ='PERM'
  2160. TABOBL(6) ='LOIC'
  2161.  
  2162. JGFAC = 2
  2163. TABFAC(1) = 'AMOR'
  2164. TABFAC(2) = 'ELAS'
  2165.  
  2166. ELSEIF (IMATEE.EQ.7) THEN
  2167. *PO_PO
  2168. JGOBL = 5
  2169. TABOBL(1) ='NORM'
  2170. TABOBL(2) ='RAID'
  2171. TABOBL(3) ='JEU'
  2172. TABOBL(4) ='POIB'
  2173. TABOBL(5) ='PERM'
  2174.  
  2175. JGFAC = 2
  2176. TABFAC(1) = 'AMOR'
  2177. TABFAC(2) = 'LOIC'
  2178.  
  2179. ELSEIF (IMATEE.EQ.8) THEN
  2180. *PO_CE_MO
  2181. JGOBL = 8
  2182. TABOBL(1) ='NORM'
  2183. TABOBL(2) ='RAID'
  2184. TABOBL(3) ='PCER'
  2185. TABOBL(4) ='RAYO'
  2186. TABOBL(5) ='GLIS'
  2187. TABOBL(6) ='ADHE'
  2188. TABOBL(7) ='RTAN'
  2189. TABOBL(8) ='ATAN'
  2190.  
  2191. JGFAC= 2
  2192. TABFAC(1) = 'CINT'
  2193. TABFAC(2) = 'AMOR'
  2194.  
  2195. ELSEIF (IMATEE.EQ.9) THEN
  2196. *PO_CE_FR
  2197. JGOBL = 8
  2198. TABOBL(1) ='NORM'
  2199. TABOBL(2) ='RAID'
  2200. TABOBL(3) ='EXCE'
  2201. TABOBL(4) ='RAYO'
  2202. TABOBL(5) ='GLIS'
  2203. TABOBL(6) ='ADHE'
  2204. TABOBL(7) ='RTAN'
  2205. TABOBL(8) ='ATAN'
  2206.  
  2207. JGFAC = 2
  2208. TABFAC(1) = 'CINT'
  2209. TABFAC(2) = 'AMOR'
  2210.  
  2211. ELSEIF (IMATEE.EQ.10) THEN
  2212. *PO_CE
  2213. JGOBL = 4
  2214. TABOBL(1) ='NORM'
  2215. TABOBL(2) ='RAID'
  2216. TABOBL(3) ='EXCE'
  2217. TABOBL(4) ='RAYO'
  2218.  
  2219. JGFAC = 1
  2220. TABFAC(1) = 'AMOR'
  2221.  
  2222. ELSEIF (IMATEE.EQ.11) THEN
  2223. *CE_PL_FR
  2224. JGOBL = 8
  2225. TABOBL(1) ='NORM'
  2226. TABOBL(2) ='RAID'
  2227. TABOBL(3) ='JEU'
  2228. TABOBL(4) ='RAYS'
  2229. TABOBL(5) ='GLIS'
  2230. TABOBL(6) ='ADHE'
  2231. TABOBL(7) ='RTAN'
  2232. TABOBL(8) ='ATAN'
  2233.  
  2234. JGFAC = 1
  2235. TABFAC(1) = 'AMOR'
  2236.  
  2237. ELSEIF (IMATEE.EQ.12) THEN
  2238. *CE_CE_FR
  2239. JGOBL = 9
  2240. TABOBL(1) ='NORM'
  2241. TABOBL(2) ='RAID'
  2242. TABOBL(3) ='EXCE'
  2243. TABOBL(4) ='RAYS'
  2244. TABOBL(5) ='GLIS'
  2245. TABOBL(6) ='ADHE'
  2246. TABOBL(7) ='RTAN'
  2247. TABOBL(8) ='ATAN'
  2248. TABOBL(9) ='RAYB'
  2249.  
  2250. JGFAC = 2
  2251. TABFAC(1) = 'AMOR'
  2252. TABFAC(2) = 'CINT'
  2253.  
  2254. ELSEIF (IMATEE.EQ.13.OR.IMATEE.EQ.14) THEN
  2255. *PR_PR_IN ou PR_PR_EX
  2256. JGOBL = 5
  2257. TABOBL(1) ='NORM'
  2258. TABOBL(2) ='RAID'
  2259. TABOBL(3) ='PFIX'
  2260. TABOBL(4) ='PMOB'
  2261. TABOBL(5) ='ERAI'
  2262.  
  2263. ELSEIF (IMATEE.EQ.15) THEN
  2264. *LI_LI_FR
  2265. JGOBL = 8
  2266. TABOBL(1) ='NORM'
  2267. TABOBL(2) ='LIMA'
  2268. TABOBL(3) ='LIES'
  2269. TABOBL(4) ='RAID'
  2270. TABOBL(5) ='GLIS'
  2271. TABOBL(6) ='ADHE'
  2272. TABOBL(7) ='RTAN'
  2273. TABOBL(8) ='ATAN'
  2274.  
  2275. JGFAC = 4
  2276. TABFAC(1) = 'JEU'
  2277. TABFAC(2) = 'AMOR'
  2278. TABFAC(3) = 'RECH'
  2279. TABFAC(4) = 'SYME'
  2280.  
  2281. ELSEIF (IMATEE.EQ.16) THEN
  2282. *LI_CE_FR
  2283. JGOBL = 8
  2284. TABOBL(1) ='NORM'
  2285. TABOBL(2) ='LIMA'
  2286. TABOBL(3) ='LIES'
  2287. TABOBL(4) ='RAID'
  2288. TABOBL(5) ='GLIS'
  2289. TABOBL(6) ='ADHE'
  2290. TABOBL(7) ='RTAN'
  2291. TABOBL(8) ='ATAN'
  2292.  
  2293. JGFAC = 5
  2294. TABFAC(1) = 'AMOR'
  2295. TABFAC(2) = 'RECH'
  2296. TABFAC(3) = 'RAYO'
  2297. TABFAC(4) = 'ACTN'
  2298. TABFAC(5) = 'INVE'
  2299.  
  2300. ELSEIF (IMATEE.EQ.17) THEN
  2301. *PA_FL_RO
  2302. JGOBL =10
  2303. TABOBL(1) ='LONG'
  2304. TABOBL(2) ='RAYO'
  2305. TABOBL(3) ='VISC'
  2306. TABOBL(4) ='RHOF'
  2307. TABOBL(5) ='PADM'
  2308. TABOBL(6) ='VROT'
  2309. TABOBL(7) ='EPSI'
  2310. TABOBL(8) ='PHII'
  2311. TABOBL(9) ='AFFI'
  2312. TABOBL(10)='TLOB'
  2313.  
  2314. JGFAC = 1
  2315. TABFAC(1) = 'AMOR'
  2316.  
  2317. ELSEIF (IMATEE.EQ.23) THEN
  2318. *NEWMARK MODAL
  2319. JGOBL =3
  2320. TABOBL(1) ='JEU'
  2321. TABOBL(2) ='MASS'
  2322. TABOBL(3) ='FREQ'
  2323.  
  2324. JGFAC = 3
  2325. TABFAC(1) = 'EXCE'
  2326. TABFAC(2) = 'FROT'
  2327. TABFAC(3) = 'MOFR'
  2328. ENDIF
  2329.  
  2330. C 'SORT' facultatif dans tous les cas
  2331. JGOBL0 = JGFAC
  2332. JGFAC= JGOBL0+1
  2333. TABFAC(JGOBL0+1) = 'SORT'
  2334. C =================================================================
  2335. C FORMULATION ELECTROSTATIQUE
  2336. C =================================================================
  2337. ELSE IF (MFR2.EQ.71) THEN
  2338. C
  2339. C Permittivite isotrope
  2340. IF (IMATEE.EQ.1) THEN
  2341. JGOBL = 1
  2342. TABOBL(1)='PEL '
  2343. C
  2344. C Permittivite orthotrope
  2345. ELSEIF (IMATEE.EQ.2) THEN
  2346. IF (IDIM.EQ.2) THEN
  2347. IF (IFOMOD.NE.1) THEN
  2348. JGOBL = 4
  2349. TABOBL(1) = 'PE1 '
  2350. TABOBL(2) = 'PE2 '
  2351. TABOBL(3) = 'V1X '
  2352. TABOBL(4) = 'V1Y '
  2353. ELSE
  2354. JGOBL = 5
  2355. TABOBL(1) = 'PE1 '
  2356. TABOBL(2) = 'PE2 '
  2357. TABOBL(3) = 'PE3 '
  2358. TABOBL(4) = 'V1X '
  2359. TABOBL(5) = 'V1Y '
  2360. ENDIF
  2361. ELSEIF (IDIM.EQ.3) THEN
  2362. JGOBL = 9
  2363. TABOBL(1) = 'PE1 '
  2364. TABOBL(2) = 'PE2 '
  2365. TABOBL(3) = 'PE3 '
  2366. TABOBL(4) = 'V1X '
  2367. TABOBL(5) = 'V1Y '
  2368. TABOBL(6) = 'V1Z '
  2369. TABOBL(7) = 'V2X '
  2370. TABOBL(8) = 'V2Y '
  2371. TABOBL(9) = 'V2Z '
  2372. ENDIF
  2373. C
  2374. C Permittivite anisotrope
  2375. ELSEIF (IMATEE.EQ.3) THEN
  2376. IF (IDIM.EQ.2) THEN
  2377. IF (IFOMOD.NE.1) THEN
  2378. JGOBL = 5
  2379. TABOBL(1) = 'PE11 '
  2380. TABOBL(2) = 'PE22 '
  2381. TABOBL(3) = 'PE21 '
  2382. TABOBL(4) = 'V1X '
  2383. TABOBL(5) = 'V1Y '
  2384. ELSE
  2385. JGOBL = 6
  2386. TABOBL(1) = 'PE11 '
  2387. TABOBL(2) = 'PE22 '
  2388. TABOBL(3) = 'PE21 '
  2389. TABOBL(4) = 'PE33 '
  2390. TABOBL(5) = 'V1X '
  2391. TABOBL(6) = 'V1Y '
  2392. ENDIF
  2393. ELSEIF (IDIM.EQ.3) THEN
  2394. JGOBL = 12
  2395. TABOBL( 1) = 'PE11 '
  2396. TABOBL( 2) = 'PE22 '
  2397. TABOBL( 3) = 'PE33 '
  2398. TABOBL( 4) = 'PE21 '
  2399. TABOBL( 5) = 'PE31 '
  2400. TABOBL( 6) = 'PE32 '
  2401. TABOBL( 7) = 'V1X '
  2402. TABOBL( 8) = 'V1Y '
  2403. TABOBL( 9) = 'V1Z '
  2404. TABOBL(10) = 'V2X '
  2405. TABOBL(11) = 'V2Y '
  2406. TABOBL(12) = 'V2Z '
  2407. ENDIF
  2408. ENDIF
  2409. C =================================================================
  2410. C FORMULATION DIFFUSION
  2411. C =================================================================
  2412. ELSE IF (MFR2.EQ.73) THEN
  2413. C
  2414. JGFAC = 1
  2415. TABFAC(1)='CDIF'
  2416. C
  2417. C Diffusion isotrope
  2418. IF (IMATEE.EQ.1) THEN
  2419. JGOBL = 1
  2420. C*8 TABOBL(1) = 'KDIFF '
  2421. TABOBL(1) = 'KD '
  2422. C
  2423. C Diffusion orthotrope
  2424. ELSEIF (IMATEE.EQ.2) THEN
  2425. IF (IDIM.EQ.2) THEN
  2426. IF (IFOMOD.NE.1) THEN
  2427. JGOBL = 4
  2428. TABOBL(1) = 'KD1 '
  2429. TABOBL(2) = 'KD2 '
  2430. TABOBL(3) = 'V1X '
  2431. TABOBL(4) = 'V1Y '
  2432. ELSE
  2433. JGOBL = 5
  2434. TABOBL(1) = 'KD1 '
  2435. TABOBL(2) = 'KD2 '
  2436. TABOBL(3) = 'KD3 '
  2437. TABOBL(4) = 'V1X '
  2438. TABOBL(5) = 'V1Y '
  2439. ENDIF
  2440. ELSEIF (IDIM.EQ.3) THEN
  2441. JGOBL = 9
  2442. TABOBL(1) = 'KD1 '
  2443. TABOBL(2) = 'KD2 '
  2444. TABOBL(3) = 'KD3 '
  2445. TABOBL(4) = 'V1X '
  2446. TABOBL(5) = 'V1Y '
  2447. TABOBL(6) = 'V1Z '
  2448. TABOBL(7) = 'V2X '
  2449. TABOBL(8) = 'V2Y '
  2450. TABOBL(9) = 'V2Z '
  2451. ENDIF
  2452. C
  2453. C Diffusion anisotrope
  2454. ELSEIF (IMATEE.EQ.3) THEN
  2455. IF (IDIM.EQ.2) THEN
  2456. IF (IFOMOD.NE.1) THEN
  2457. JGOBL = 5
  2458. TABOBL(1) = 'KD11 '
  2459. TABOBL(2) = 'KD22 '
  2460. TABOBL(3) = 'KD21 '
  2461. TABOBL(4) = 'V1X '
  2462. TABOBL(5) = 'V1Y '
  2463. ELSE
  2464. JGOBL = 6
  2465. TABOBL(1) = 'KD11 '
  2466. TABOBL(2) = 'KD22 '
  2467. TABOBL(3) = 'KD21 '
  2468. TABOBL(4) = 'KD33 '
  2469. TABOBL(5) = 'V1X '
  2470. TABOBL(6) = 'V1Y '
  2471. ENDIF
  2472. ELSEIF (IDIM.EQ.3) THEN
  2473. JGOBL = 12
  2474. TABOBL( 1) = 'KD11 '
  2475. TABOBL( 2) = 'KD22 '
  2476. TABOBL( 3) = 'KD33 '
  2477. TABOBL( 4) = 'KD21 '
  2478. TABOBL( 5) = 'KD31 '
  2479. TABOBL( 6) = 'KD32 '
  2480. TABOBL( 7) = 'V1X '
  2481. TABOBL( 8) = 'V1Y '
  2482. TABOBL( 9) = 'V1Z '
  2483. TABOBL(10) = 'V2X '
  2484. TABOBL(11) = 'V2Y '
  2485. TABOBL(12) = 'V2Z '
  2486. ENDIF
  2487. ENDIF
  2488. C
  2489. JGOBL0 = JGOBL
  2490. JGFAC0 = JGFAC
  2491. C
  2492. * Loi FICK :
  2493. * ------------
  2494. IF (INATUU.EQ.0) THEN
  2495. * Rien a ajouter
  2496.  
  2497. * Loi SORET :
  2498. * -------------
  2499. ELSEIF (INATUU.EQ.1) THEN
  2500. C -- Diffusion isotrope
  2501. IF (IMATEE.EQ.1) THEN
  2502. JGOBL = JGOBL+1
  2503. C*8 TABOBL(JGOBL0+1) = 'KSORET '
  2504. TABOBL(JGOBL0+1) = 'KS '
  2505.  
  2506. C -- Diffusion orthotrope
  2507. ELSEIF (IMATEE.EQ.2) THEN
  2508. C ---- Elements massifs bidimensionnels PLAN et AXISYMETRIQUE
  2509. IF (IFOMOD.LE.0) THEN
  2510. JGOBL = JGOBL + 2
  2511. C*8 TABOBL(JGOBL0+1) = 'KSORET1 '
  2512. C*8 TABOBL(JGOBL0+2) = 'KSORET2 '
  2513. TABOBL(JGOBL0+1) = 'KS1 '
  2514. TABOBL(JGOBL0+2) = 'KS2 '
  2515.  
  2516. C ---- Elements massifs bidimensionnels FOURIER
  2517. C ---- Elements massifs TRIDimensionnels
  2518. ELSE
  2519. JGOBL = JGOBL + 3
  2520. C*8 TABOBL(JGOBL0+1) = 'KSORET1 '
  2521. C*8 TABOBL(JGOBL0+2) = 'KSORET2 '
  2522. C*8 TABOBL(JGOBL0+3) = 'KSORET3 '
  2523. TABOBL(JGOBL0+1) = 'KS1 '
  2524. TABOBL(JGOBL0+2) = 'KS2 '
  2525. TABOBL(JGOBL0+3) = 'KS3 '
  2526. ENDIF
  2527.  
  2528. C -- Diffusion anisotrope
  2529. ELSEIF (IMATEE.EQ.3) THEN
  2530. C ---- Elements massifs bidimensionnels PLAN et AXISYMETRIQUE
  2531. IF (IFOMOD.LE.0) THEN
  2532. JGOBL = JGOBL + 3
  2533. C*8 TABOBL(JGOBL0+1) = 'KSORET11'
  2534. C*8 TABOBL(JGOBL0+2) = 'KSORET22'
  2535. C*8 TABOBL(JGOBL0+3) = 'KSORET21'
  2536. TABOBL(JGOBL0+1) = 'KS11 '
  2537. TABOBL(JGOBL0+2) = 'KS22 '
  2538. TABOBL(JGOBL0+3) = 'KS21 '
  2539.  
  2540. C ---- Elements massifs bidimensionnels FOURIER
  2541. ELSEIF (IFOMOD.EQ.1) THEN
  2542. JGOBL = JGOBL + 4
  2543. C*8 TABOBL(JGOBL0+1) = 'KSORET11'
  2544. C*8 TABOBL(JGOBL0+2) = 'KSORET22'
  2545. C*8 TABOBL(JGOBL0+3) = 'KSORET21'
  2546. C*8 TABOBL(JGOBL0+4) = 'KSORET33'
  2547. TABOBL(JGOBL0+1) = 'KS11 '
  2548. TABOBL(JGOBL0+2) = 'KS22 '
  2549. TABOBL(JGOBL0+3) = 'KS21 '
  2550. TABOBL(JGOBL0+4) = 'KS33 '
  2551.  
  2552. C ---- Elements massifs TRIDimensionnels
  2553. ELSEIF (IFOMOD.EQ.2) THEN
  2554. JGOBL = JGOBL + 6
  2555. C*8 TABOBL(JGOBL0+1) = 'KSORET11'
  2556. C*8 TABOBL(JGOBL0+2) = 'KSORET22'
  2557. C*8 TABOBL(JGOBL0+3) = 'KSORET33'
  2558. C*8 TABOBL(JGOBL0+4) = 'KSORET21'
  2559. C*8 TABOBL(JGOBL0+5) = 'KSORET31'
  2560. C*8 TABOBL(JGOBL0+6) = 'KSORET32'
  2561. TABOBL(JGOBL0+1) = 'KS11 '
  2562. TABOBL(JGOBL0+2) = 'KS22 '
  2563. TABOBL(JGOBL0+3) = 'KS33 '
  2564. TABOBL(JGOBL0+4) = 'KS21 '
  2565. TABOBL(JGOBL0+5) = 'KS31 '
  2566. TABOBL(JGOBL0+6) = 'KS32 '
  2567. ENDIF
  2568.  
  2569. ELSE
  2570. C -- Erreur ne devant pas survenir
  2571. CALL ERREUR(261)
  2572. RETURN
  2573. ENDIF
  2574.  
  2575. * Loi UTILISATEUR :
  2576. * -------------------
  2577. * ELSEIF (INATUU.EQ.2) THEN
  2578. * Par defaut pas de composantes autres que celles de l'utilisateur
  2579.  
  2580. ELSEIF (INATUU.EQ.5) THEN
  2581. * diffusion avec dissipation affine
  2582. JGOBL = JGOBL+2
  2583. TABOBL(JGOBL0+1)='DAF0'
  2584. TABOBL(JGOBL0+2)='DAF1'
  2585.  
  2586. ELSEIF (INATUU.EQ.6) THEN
  2587. * diffusion avec dissipation visqueuse
  2588. JGOBL = JGOBL+2
  2589. TABOBL(JGOBL0+1)='DVQ0'
  2590. TABOBL(JGOBL0+2)='DVQ1'
  2591.  
  2592. * Loi inconnue : ERREUR
  2593. * ----------------
  2594. ELSE
  2595. CALL ERREUR(261)
  2596. RETURN
  2597. ENDIF
  2598.  
  2599. * Composantes ADVECTION :
  2600. * -------------------
  2601. CALL PLACE(MATMOD,NMAT,IADVE,'ADVECTION')
  2602. IF (IADVE.NE.0) THEN
  2603.  
  2604. C Cas des Tuyaux 1D (MFR=79)
  2605. C ===========================
  2606. IF (MFR .EQ. 79) THEN
  2607. JGOBL = JGOBL + 1
  2608. TABOBL(JGOBL0 + 1)='VITE'
  2609.  
  2610. JGFAC = JGFAC + 1
  2611. TABFAC(JGFAC0 + 1)='DL'
  2612.  
  2613. C Cas Diffusion Massif
  2614. C ============================
  2615. ELSEIF (MFR .EQ. 1) THEN
  2616. IF (IFOUR.EQ.-3) THEN
  2617. JGOBL = JGOBL + 3
  2618. TABOBL(JGOBL0 + 1)='VITX'
  2619. TABOBL(JGOBL0 + 2)='VITY'
  2620. TABOBL(JGOBL0 + 3)='VITZ'
  2621.  
  2622. JGFAC = JGFAC + 3
  2623. TABFAC(JGFAC0 + 1)='DX'
  2624. TABFAC(JGFAC0 + 2)='DY'
  2625. TABFAC(JGFAC0 + 3)='DZ'
  2626. ELSEIF (IFOUR.EQ.-2 .OR. IFOUR.EQ.-1) THEN
  2627. JGOBL = JGOBL + 2
  2628. TABOBL(JGOBL0 + 1)='VITX'
  2629. TABOBL(JGOBL0 + 2)='VITY'
  2630.  
  2631. JGFAC = JGFAC + 2
  2632. TABFAC(JGFAC0 + 1)='DX'
  2633. TABFAC(JGFAC0 + 2)='DY'
  2634. ELSEIF (IFOUR .EQ. 0) THEN
  2635. JGOBL = JGOBL + 2
  2636. TABOBL(JGOBL0 + 1)='VITR'
  2637. TABOBL(JGOBL0 + 2)='VITZ'
  2638.  
  2639. JGFAC = JGFAC + 2
  2640. TABFAC(JGFAC0 + 1)='DR'
  2641. TABFAC(JGFAC0 + 2)='DZ'
  2642. ELSEIF (IFOUR .EQ. 1) THEN
  2643. CALL ERREUR(21)
  2644. RETURN
  2645. C JGOBL = JGOBL + 3
  2646. C TABOBL(JGOBL0 + 1)='VITR'
  2647. C TABOBL(JGOBL0 + 2)='VITZ'
  2648. C TABOBL(JGOBL0 + 3)='VITT'
  2649. C
  2650. C JGFAC = JGFAC + 3
  2651. C TABFAC(JGFAC0 + 1)='DR'
  2652. C TABFAC(JGFAC0 + 2)='DZ'
  2653. C TABFAC(JGFAC0 + 3)='DT'
  2654. ELSEIF (IFOUR .EQ. 2) THEN
  2655. JGOBL = JGOBL + 3
  2656. TABOBL(JGOBL0 + 1)='VITX'
  2657. TABOBL(JGOBL0 + 2)='VITY'
  2658. TABOBL(JGOBL0 + 3)='VITZ'
  2659.  
  2660. JGFAC = JGFAC + 3
  2661. TABFAC(JGFAC0 + 1)='DX'
  2662. TABFAC(JGFAC0 + 2)='DY'
  2663. TABFAC(JGFAC0 + 3)='DZ'
  2664. ELSEIF (IFOUR.GE.3 .AND. IFOUR.LE.15) THEN
  2665. IF (IFOUR.LE.6) THEN
  2666. JGOBL = JGOBL + 1
  2667. TABOBL(JGOBL0 + 1)='VITX'
  2668.  
  2669. JGFAC = JGFAC + 1
  2670. TABFAC(JGFAC0 + 1)='DX'
  2671.  
  2672. ELSEIF (IFOUR.EQ.7 .OR. IFOUR.EQ.8) THEN
  2673. JGOBL = JGOBL + 2
  2674. TABOBL(JGOBL0 + 1)='VITX'
  2675. TABOBL(JGOBL0 + 2)='VITY'
  2676.  
  2677. JGFAC = JGFAC + 2
  2678. TABFAC(JGFAC0 + 1)='DX'
  2679. TABFAC(JGFAC0 + 2)='DY'
  2680.  
  2681. ELSEIF (IFOUR.EQ.9 .OR. IFOUR.EQ.10) THEN
  2682. JGOBL = JGOBL + 2
  2683. TABOBL(JGOBL0 + 1)='VITX'
  2684. TABOBL(JGOBL0 + 2)='VITZ'
  2685.  
  2686. JGFAC = JGFAC + 2
  2687. TABFAC(JGFAC0 + 1)='DX'
  2688. TABFAC(JGFAC0 + 2)='DZ'
  2689.  
  2690. ELSEIF (IFOUR.EQ.11) THEN
  2691. JGOBL = JGOBL + 3
  2692. TABOBL(JGOBL0 + 1)='VITX'
  2693. TABOBL(JGOBL0 + 2)='VITY'
  2694. TABOBL(JGOBL0 + 3)='VITZ'
  2695.  
  2696. JGFAC = JGFAC + 3
  2697. TABFAC(JGFAC0 + 1)='DX'
  2698. TABFAC(JGFAC0 + 2)='DY'
  2699. TABFAC(JGFAC0 + 3)='DZ'
  2700.  
  2701. ELSEIF (IFOUR.EQ.12.OR.IFOUR.EQ.13.OR.IFOUR.EQ.15) THEN
  2702. JGOBL = JGOBL + 1
  2703. TABOBL(JGOBL0 + 1)='VITR'
  2704.  
  2705. JGFAC = JGFAC + 1
  2706. TABFAC(JGFAC0 + 1)='DR'
  2707.  
  2708. ELSEIF (IFOUR.EQ.14) THEN
  2709. JGOBL = JGOBL + 2
  2710. TABOBL(JGOBL0 + 1)='VITR'
  2711. TABOBL(JGOBL0 + 2)='VITZ'
  2712.  
  2713. JGFAC = JGFAC + 2
  2714. TABFAC(JGFAC0 + 1)='DR'
  2715. TABFAC(JGFAC0 + 2)='DZ'
  2716. ENDIF
  2717. ENDIF
  2718. ENDIF
  2719. ENDIF
  2720. C =================================================================
  2721. C FORMULATION CHARGEMENT
  2722. C =================================================================
  2723. ELSE IF (MFR2.EQ.72) THEN
  2724. C
  2725. IF (IMATEE.EQ.1) THEN
  2726. C RAJOUTER DIFFERENTIATION EN FONCIONS DE LA FORMULATION MASSIF -> P
  2727. C COQUE PINF PSUP
  2728. JGOBL=1
  2729. TABOBL(1)='PR '
  2730. ELSE
  2731. IRET = 0
  2732. CALL ERREUR(5)
  2733. ENDIF
  2734. C =================================================================
  2735. C FORMULATION CHANGEMENT_PHASE
  2736. C =================================================================
  2737. ELSE IF (MFR2.EQ.30) THEN
  2738. C
  2739. IF (IMODEL.CMATEE.EQ.'CHPH_PAR') THEN
  2740. JGOBL=2
  2741. TABOBL(1)='PRIM'
  2742. TABOBL(2)='DUAL'
  2743.  
  2744. JGFAC=0
  2745. ELSEIF (IMODEL.CMATEE.EQ.'CHPH_SOL') THEN
  2746. JGOBL=1
  2747. TABOBL(1)='SOLU'
  2748.  
  2749. JGFAC=0
  2750. ENDIF
  2751. C =================================================================
  2752. ENDIF
  2753. *--------------------------------------------------------------------
  2754. * CREATION DU NOMID A PARTIR DE TABOBL ET TABFAC
  2755. *--------------------------------------------------------------------
  2756. 9999 CONTINUE
  2757.  
  2758. IF((MFR2.EQ.2) .OR. (MFR2.EQ.33)) THEN
  2759. C CB215821 : Ajout de TREF et TALP à la fin des compostantes facultatives
  2760. C pour les FORMULATION MECANIQUE, POREUX
  2761. C Pour ne pas casser l'ordre dans COMP (com2/coml6/comval/comara/...)
  2762. JGFAC=JGFAC+2
  2763. TABFAC(JGFAC-1) ='TREF'
  2764. TABFAC(JGFAC) ='TALP'
  2765. ENDIF
  2766.  
  2767. C Erreur si JGOBL ou JGFAC sont superieurs a ITA
  2768. C (Passage en FORTRAN 77 car la compilation depasse la memoire sur
  2769. C Windows-32bits)
  2770. IF ((JGOBL .GT. ITA) .OR. (JGFAC .GT. ITA)) THEN
  2771. IRET = 0
  2772. CALL ERREUR(5)
  2773. RETURN
  2774. ENDIF
  2775. C
  2776. C SI PROBLEME (IRET = 0), ON SORT AVEC IPNOMC A 0
  2777. C
  2778. IF (IRET.NE.0) THEN
  2779. NBROBL = JGOBL
  2780. NBRFAC = JGFAC
  2781. SEGINI,NOMID
  2782. IPNOMC=NOMID
  2783. C
  2784. DO 100 IO = 1,NBROBL
  2785. NOMID.LESOBL(IO) = TABOBL(IO)
  2786. 100 CONTINUE
  2787. C
  2788. DO 110 IO=1,NBRFAC
  2789. NOMID.LESFAC(IO) = TABFAC(IO)
  2790. 110 CONTINUE
  2791. C
  2792. SEGACT,NOMID*NOMOD
  2793. ENDIF
  2794. END
  2795.  
  2796.  
  2797.  

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