Télécharger assem5.eso

Retour à la liste

Numérotation des lignes :

assem5
  1. C ASSEM5 SOURCE PV 22/10/12 21:15:01 11474
  2. SUBROUTINE ASSEM5(ITRAV1,ITOPO1,INUIN1,MMMTRI,INCTR1
  3. &,IITOP1,NBNNMA,SNTT)
  4. c
  5. cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc
  6. c
  7. c **** subroutine pour faire l'assemblage de matrices symetriques
  8. c en vue d'une decomposition de crout modifiee.
  9. c
  10. c en entree:
  11. c **** itrav1 : pointeur objet mrigidite
  12. c **** itopo1 : pointeur segment de travail itopo ( voir assem1)
  13. c **** iitop1 : pointeur segment de travail iitop ( voir assem1)
  14. c **** inuin1 : pointeur segment de travail inuinv( voir assem1)
  15. c **** mmmtri : pointeur objet matrice triangularisee (non modifie)
  16. c (voir smmatri)
  17. c **** nbnnma : nombre d'inconnues maitresses
  18. c **** sntt : segment des noeuds non totalement maitres
  19. c
  20. cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc
  21. c
  22. IMPLICIT REAL*8 (A-H,O-Z)
  23. IMPLICIT INTEGER(I-N)
  24. -INC PPARAM
  25. -INC CCOPTIO
  26. -INC SMELEME
  27. -INC SMRIGID
  28. -INC SMMATRI
  29. -INC CCREEL
  30. SEGMENT,INUINV(NNGLOB)
  31. SEGMENT,ITOPO(IENNO)
  32. SEGMENT,IITOP(NNOE+1)
  33. SEGMENT,INCTRR(NIRI)
  34. SEGMENT,INCTRA(NLIGRE)
  35. SEGMENT,IPV(NNOE)
  36. SEGMENT,VMAX(INC)
  37. SEGMENT SNTT
  38. INTEGER NTTMAI(NN)
  39. ENDSEGMENT
  40. c
  41. c **** ces tableaux servent au reperage de la matrice pour l'assemblag
  42. c **** il seront tous supprimes en fin d'assemblage.
  43. c
  44. SEGMENT,IVAL(NNN)
  45. SEGMENT,ITRA(NNN,2)
  46. SEGMENT TRATRA
  47. REAL*8 XTRA(INCRED,INCDIF)
  48. INTEGER LTRA(INC,INCDIF)
  49. INTEGER NTRA(INCRED,INCDIF)
  50. INTEGER MTRA(INCDIF)
  51. ENDSEGMENT
  52. c
  53. cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc
  54. c
  55. c **** ival(i)=j : la i eme ligne d'une petite matrice s'assemble
  56. c dans la j eme de la grande.
  57. c **** itrav(i,1)=j : la ieme inconnue du noeud en cours d'assemblage
  58. c et qui se trouve dans la petite matrice se trouve
  59. c en j eme position de la petite matrice.
  60. c **** itrav(i,2) : la ieme inconnue du noeud en cours d'assemblage
  61. c present dans la petite matrice est en jeme
  62. c position dans la grande
  63. c
  64. cccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc
  65. c
  66. SEGMENT,RA(N1,N1)*D
  67. SEGMENT JNOMUL
  68. LOGICAL INOMUL(NNR)
  69. ENDSEGMENT
  70. REAL*8 DMAX,COER,DDDD,DMAXY
  71. LOGICAL NOMUL
  72. *
  73. * en cas de normalisation des variables.
  74. *
  75. INWUIT=0
  76. IF(NORINC.NE.0) CALL ASSEM0(ITRAV1,1,INWUIT)
  77. *
  78. * pv on active une fois pour toutes les meleme descr... de la rigidite
  79. * on en profite pour creer inomul
  80. c
  81. c **** recherche de la dimension max de ival,et segini de ival et itra
  82. c
  83. c
  84. INCTRR=INCTR1
  85. SEGACT,INCTRR
  86. c
  87. MRIGID=ITRAV1
  88.  
  89. SEGACT,MRIGID
  90. NNR=IRIGEL(/2)
  91. NNN=0
  92. SEGINI JNOMUL
  93. DO 1 IRI=1,NNR
  94. c
  95. INCTRA=INCTRR(IRI)
  96. SEGACT INCTRA
  97. c
  98. DESCR=IRIGEL(3,IRI)
  99. SEGACT, DESCR
  100. c
  101. IPT1=IRIGEL(1,IRI)
  102. SEGACT IPT1
  103. c
  104. XMATRI=IRIGEL(4,IRI)
  105. SEGACT XMATRI
  106. c
  107. c ... na = nb de variables primales ...
  108. NA=LISINC(/2)
  109. c ... nnn = max des nb de variables primales ...
  110. NNN=MAX(NA,NNN)
  111. c
  112. c ... inomul (non multiplicateurs ?) dit s'il ne s'agit pas des cl ...
  113. INOMUL(IRI)=.TRUE.
  114. IF(IPT1.ITYPEL.EQ.49) INOMUL(IRI)=.FALSE.
  115. c
  116. 1 CONTINUE
  117. c
  118. c ... ival a la taille nnn ...
  119. SEGINI,IVAL
  120. c ... itra a la taille (nnn,2) ...
  121. SEGINI,ITRA
  122. c
  123. c **** activation des segments de travails et de mmatri
  124. c
  125. c ... recherche du nombre d'inconnues impliquees
  126. c
  127. MMATRI=MMMTRI
  128. SEGACT,MMATRI*MOD
  129. c
  130. MINCPO=IINCPO
  131. SEGACT,MINCPO
  132. c
  133. c
  134. MAXIPO=0
  135. DO I=1,INCPO(/2)
  136. DO J=1,INCPO(/1)
  137. MAXIPO=MAX(INCPO(J,I),MAXIPO)
  138. ENDDO
  139. ENDDO
  140. c
  141. N1=MAXIPO
  142. c
  143. ITOPO=ITOPO1
  144. SEGACT,ITOPO
  145. c
  146. IITOP=IITOP1
  147. SEGACT,IITOP
  148. c
  149. INUINV=INUIN1
  150. SEGACT,INUINV
  151. c
  152. c ... nnoe = nombre de noeuds impliqués ...
  153. c
  154. SEGACT SNTT
  155. NNOE=INCPO(/2)+NTTMAI(/1)
  156. c
  157. c ... inc = dimension de la matrice ...
  158. INC=MAXIPO
  159. c
  160. SEGINI,MDIAG
  161. IDIAG=MDIAG
  162. c
  163. SEGINI,MILIGN
  164. IILIGN=MILIGN
  165. c
  166. c ... incdif = nb de variables primales différentes ...
  167. INCDIF=INCPO(/1)
  168. c
  169. MIMIK=IIMIK
  170. SEGACT,MIMIK
  171. c
  172. NNOE=INCPO(/2)
  173. c
  174. c ... ipv est de taille nnoe ...
  175. SEGINI IPV
  176. c
  177. INCRED=0
  178. DO 80 INO =1,NNOE
  179. ICOMPT=0
  180. c ... maxele = nb d'éléments qui contiennent le noeud no ino ...
  181. MAXELE = (IITOP(INO+1)-IITOP(INO))/2
  182. c ... boucle sur ces éléments ...
  183. DO 81 IELE=1,MAXELE
  184. c
  185. c ... iiu = pointeur dans iitop ...
  186. IIU=IITOP(INO) + IELE + IELE -2
  187. c
  188. c ... iel = numero de l'élément dans son maillage ...
  189. IEL=ITOPO(IIU)
  190. c
  191. c ... iri = numero du maillage (dans irigel) de cet élément ...
  192. IRI=ITOPO(IIU+1)
  193. c
  194. c ... on va chercher ce maillage dans irigel ...
  195. MELEME=IRIGEL(1,IRI)
  196. c
  197. c ... boucle sur les noeuds de cet élément ...
  198. DO 83 I=1,NUM(/1)
  199. c
  200. c ... ip = numéro local du i-ème noeud de l'élément ...
  201. IP=INUINV(NUM(I,IEL))
  202. c
  203. c ... la première condition = les "connections" sont symétriques ...
  204. **pv IF (IP.GT.INO) GOTO 83
  205. c ... le noeud ip a déjà vu ce noeud ...
  206. IF (IPV(IP).EQ.INO) GOTO 83
  207. c
  208. c ... ces deux opérations se font si (ip <= ino et ipv(ip) != ino) ...
  209. c ... ipv = n° max des noeuds "connectés" au noeud ip ...
  210. c
  211. IPV(IP)=INO
  212. c ... icompt = nombre de noeuds connectés (de numéro < ou =) au noeud ino ...
  213. ICOMPT=ICOMPT+1
  214. 83 CONTINUE
  215. 81 CONTINUE
  216. c ... incred = maximum des icompt sur tous les noeuds impliqués ...
  217. c
  218. INCRED=MAX(INCRED,ICOMPT)
  219. 80 CONTINUE
  220. c
  221. SEGSUP IPV
  222. c
  223. INCRED=INCRED*INCDIF
  224. c ... la taille de tratra dépend de inc, incred et incdif ...
  225. SEGINI TRATRA
  226. segini vmax
  227. c
  228. c ... coefficients de normalisation ...
  229. c -----------------------------
  230. c
  231. LLVNUL=0
  232. IJMAX=0
  233. NJTOT=0
  234. c
  235. c ... la taille de mdnor est inc (nombre d'équations) ...
  236. SEGINI MDNOR
  237. IDNORM=MDNOR
  238. DO 20 I=1,INC
  239. DNOR(I)=1.D0
  240. 20 CONTINUE
  241. c
  242. c ... si une normalisation est imposée, les valeurs dans mdnor seront modifiées
  243. c par assem3 ...
  244. IF(NORINC.NE.0) CALL ASSEM3(MDNOR,MIMIK,MINCPO)
  245. c
  246. c **** boucle *100* sur les numeros de noeuds que l'on assemble
  247. c -------------------------------------------------------------
  248. c
  249. c ... ipre = n° de la première ligne concernée par le noeud ino ...
  250. IPRE=1
  251. c
  252. DO 999 IJK=1,2
  253. c
  254. DO 100 INO=1,NNOE
  255. DO 101 IIT=1,INCDIF
  256. MTRA(IIT)=0
  257. 101 CONTINUE
  258. c ... ider = n° de la dernière ligne concernée par le noeud ino ...
  259. IDER=0
  260. c
  261. IF(IJK.EQ.2) IPRE=MAXIPO+1
  262. DO 998 II=1,INCDIF
  263. IF (IJK.EQ.1.AND.INCPO(II,INO).LE.NBNNMA)
  264. # IDER=MAX(INCPO(II,INO),IDER)
  265. IF (IJK.EQ.2.AND.INCPO(II,INO).GT.NBNNMA) THEN
  266. IDER=MAX(INCPO(II,INO),IDER)
  267. IPRE=MIN(INCPO(II,INO),IPRE)
  268. ENDIF
  269. 998 CONTINUE
  270. IF (IDER.EQ.0.OR.IPRE.EQ.(MAXIPO+1)) GOTO 100
  271. LLVVA=0
  272. c
  273. c **** boucle *99* sur les elements touchant le noeud ino
  274. c pour les elements multiplicateur on ne fait pas
  275. c l'assemblage
  276. c
  277. c ... maxele = nb d'éléments qui contiennent le noeud no ino ...
  278. MAXELE= (IITOP(INO+1) -IITOP(INO))/2
  279. c
  280.  
  281. DO 99 IELE=1,MAXELE
  282. IIU=IITOP(INO) + IELE + IELE - 2
  283. c ... iel = numero de l'élément dans son maillage ...
  284. IEL=ITOPO(IIU)
  285. c ... iri = numero du maillage (dans irigel) de cet élément ...
  286. IRI=ITOPO(IIU+1)
  287. c ... meleme = pointeur vers ce maillage ...
  288. MELEME=IRIGEL(1,IRI)
  289. c ... descr = pointeur vers le segment descr concerné ...
  290. DESCR=IRIGEL(3,IRI)
  291. c ... inctra contient les indices (dans imik et ihar) des descriptions
  292. c des ddl correspondants ...
  293. INCTRA=INCTRR(IRI)
  294. c ... xmatri = tableau de pointeurs vers les matrices élémentaires ...
  295. XMATRI=IRIGEL(4,IRI)
  296.  
  297. c ... coer = coefficient multiplicateur ...
  298. COER=COERIG(IRI)
  299. c
  300. c **** nomul =.false. il existe un multiplicateur
  301. c **** initialisation de ival. ival(i)=j veut dire que
  302. c **** la i eme ligne de la petite matrice s'assemble dans
  303. c **** la j eme de la grande matrice.
  304. c
  305. c ... nin = nombre de variables primales (dans descr) ...
  306. NIN=LISINC(/2)
  307. c ... non multiplicateur ? ...
  308. NOMUL=INOMUL(IRI)
  309. NA=0
  310. c ... boucle sur les variables primales de l'élément ...
  311. c
  312. DO 98 ICO=1,NIN
  313. c ... ija = numéro local du noeud-support du ddl ...
  314. IJA=INUINV(NUM(NOELEP(ICO),IEL))
  315. c ... ijb = indice du ddl ...
  316. IJB=INCTRA(ICO)
  317. c ... on met dans ival(ico) le n° de l'équation correspondant au noeud ija
  318. c et ddl no ijb ...
  319. IVAL(ICO)=INCPO(IJB,IJA)
  320. c ... si on a trouvé le bon noeud ...
  321. IF(IJA.EQ.INO) THEN
  322. c ... on incrémente na (le nombre de ddl connectés au noeud ino ?) ...
  323. NA=NA+1
  324. ITRA(NA,1)=ICO
  325. ITRA(NA,2)=IVAL(ICO)
  326. ENDIF
  327. 98 CONTINUE
  328. * XMATRI=IMATTT(IEL)
  329. * SEGACT,XMATRI
  330. c
  331. c **** boucle *95* sur les inconnues de la petite matrice
  332. c
  333. DO 90 INCC=1,NA
  334. c ... inco = le n° d'équation (ou de ligne) du ddl no incc du noeud ino ...
  335. INCO=ITRA(INCC,2)
  336. IF (IJK.EQ.1) then
  337. IF (INCO.GT.IDER) GOTO 90
  338. ENDIF
  339. c ... iloc = n° de ligne relatif / ipre du noeud ino ...
  340. c
  341. ILOC=INCO-IPRE+1
  342. IF (IJK.EQ.2) THEN
  343. IF (ILOC.LE.0) GOTO 90
  344. ENDIF
  345. c
  346. c ... jj = n° (dans l'élément) de la colonne (et de la ligne) correspondant au
  347. c ddl n° incc du noeud ino ...
  348. JJ=ITRA(INCC,1)
  349. DO 95 IK=1,NIN
  350. c ... io = n° de l'équation correspondant au ddl no ik de l'élément (n° de la colonne) ...
  351. IO=IVAL(IK)
  352. c ... s'il dépasse le dernier intéressant on ne fait rien ...
  353. IF(IO.GT.IDER) GO TO 95
  354. c ... boucle sur les ddl's du noeud ino ...
  355. c
  356. c
  357. c ... si io > inco on ne fait plus rien dans cette boucle ...
  358. c ... car c'est le cas symétrique !!! ...
  359. IF (IO.GT.INCO) GO TO 95
  360. c
  361. c ... ci-dessous on stockera les quelques lignes de la rigidité concernant le
  362. c noeud ino dans le segment tratra. les coefficients vont dans xtra, le deuxième
  363. c indice (iloc) est le numéro relatif de la ligne, le premier (imtt) n'a rien à voir avec le
  364. c numéro de la colonne. celui-ci est stocké dans ntra(imtt,iloc). l'information inverse
  365. c (imtt en fonction de io) se trouve dans ltra(io,iloc). on met dans mtra le nombre
  366. c de termes différents assemblés par ligne ...
  367. ILTT= LTRA(IO,ILOC)
  368. IF(ILTT.EQ.0) THEN
  369. c ... llvva est initialisé à 0 au début de la boucle 100 ...
  370. LLVVA=LLVVA+1
  371. c ... les mtra sont mis à 0 au début de la boucle 100 ...
  372. IMMTT=MTRA(ILOC)+1
  373. MTRA(ILOC)=IMMTT
  374. XTRA(IMMTT,ILOC)=0.D0
  375. NTRA(IMMTT,ILOC)=IO
  376. LTRA(IO,ILOC)=IMMTT
  377. ILTT=IMMTT
  378. ENDIF
  379. c
  380. c ... si ce n'est pas une condition aux limites, on assemble ...
  381. IF(NOMUL) THEN
  382. cfaux !!! xtra(iltt,iloc)=xtra(iltt,iloc)+re(ik,jj)*coer
  383. c ... cette ligne a été remplacée par ce qui suit car pour les termes
  384. c de couplage entre les ddl du même noeud, les termes au-dessus de
  385. c la diagonale étaient pris. Ça marchait car les matrices étaient
  386. c symétriques, comme maintenant on travaillera aussi sur des asymétriques ...
  387. *** IF(JJ.LT.IK) THEN
  388. *** IIILIG=IK
  389. *** IIICOL=JJ
  390. *** ELSE
  391. *** IIILIG=JJ
  392. *** IIICOL=IK
  393. *** ENDIF
  394. c ... attention ! dans xtra 1er indice est lié à la colonne, deuxième est le numéro
  395. c de la ligne, tandis que dans re c'est l'inverse ...
  396.  
  397. *** on exploite la symetrie de re - XTRA comprend COER
  398. XTRA(ILTT,ILOC)=XTRA(ILTT,ILOC)+RE(ik,jj,IEL)
  399. & *COER
  400. ENDIF
  401. 95 CONTINUE
  402. 90 CONTINUE
  403. * SEGDES,XMATRI
  404. 99 CONTINUE
  405. c
  406. c *** compactage des lignes, en meme temps calcul de ijmax qui sera
  407. c *** la dimension max d'un segment lign.
  408. c *** le segment associe a une ligne (segment llign) est de la forme :
  409. c *** immmm(na) permet de savoir si un mouvement d'ensemble sur la
  410. c *** ligne existe. ippo(na+1) donne la position dans xxva la 1ere
  411. c *** valeur de la ligne .xxva valeur de la matrice.
  412. c *** linc(i) donne le numero de la colonne du ieme elem de xxva
  413. c
  414. c ... na = nb de lignes concernant le noeud ino ...
  415. NA = IDER-IPRE+1
  416. c ... llvnul = somme cumulée des llvva ...
  417. LLVNUL=LLVNUL+LLVVA
  418. c
  419. SEGINI,LLIGN
  420. c
  421. NBINO=INO
  422. IF (IJK.EQ.2) THEN
  423. DO 116 JJ=1,NTTMAI(/1)
  424. IF (NTTMAI(JJ).EQ.INO) GOTO 117
  425. 116 CONTINUE
  426. GOTO 118
  427. 117 CONTINUE
  428. NBINO=NNOE+JJ
  429. ENDIF
  430. 118 CONTINUE
  431. ILIGN(NBINO)=LLIGN
  432. NBA=0
  433. c
  434. c ... boucle sur les ddl du noeud ino ...
  435. DO 120 JPA=1,NA
  436. c ... iiin = n° de ligne du ddl n° jpa ...
  437. IIIN=IPRE+JPA -1
  438. c
  439. c ... que l'on met au bon endroit dans immmm (faisant partie de llign) ...
  440. c
  441. IMMMM(JPA)=IIIN
  442. c
  443. c
  444. c ... ippo(i)+1 = adresse du début (dans xxva et linc) des données relatives au ddl n° i ...
  445. IPPO(JPA)=NBA
  446. c
  447. c ... boucle sur les termes dans la ligne ...
  448. DO 121 IPAK = 1,MTRA(JPA)
  449. c ... iunpak = n° de la colonne du terme n° ipak ...
  450. IUNPAK=NTRA(IPAK,JPA)
  451. c ... pour les termes mis dans llign on efface l'information sur la position dans xtra ...
  452. LTRA(IUNPAK,JPA)=0
  453. c ... compteur ++ ...
  454. NBA=NBA+1
  455. c ... le n° de la colonne va dans linc ...
  456. LINC(NBA)=IUNPAK
  457. c ... transfert du xtra (segment tratra) vers xxva (segment llign) ...
  458. XXVA(NBA)=XTRA(IPAK,JPA)
  459. vmax(iiin)=max(abs(xxva(nba)),vmax(iiin))
  460. c ... les termes diagonaux vont dans diag (segment mdiag) ...
  461. IF(IIIN.EQ.IUNPAK) DIAG(IIIN)=XXVA(NBA)
  462. 121 CONTINUE
  463. 120 CONTINUE
  464. c ... le pointeur vers la fin de la dernière ligne ...
  465. IPPO(NA+1)= NBA
  466. NJMAX= 0
  467. * recherche du mini globale sur toutes les inconnues
  468. LPA=IPRE
  469. c ... boucle sur les lignes relatives au noeud ino ...
  470. DO 126 JPA=IPRE,IDER
  471. c ... on met le n° du noeud dans ipno (segment milign) ...
  472. IPNO(JPA)=NBINO
  473. c ... ipde et ipdf : début et fin des données relatives au ddl n° jpa dans xxva et linc ...
  474. IPDE=IPPO(JPA-IPRE+1)+1
  475. IPDF=IPPO(JPA-IPRE+2)
  476. c ... lpa = n° mini de la colonne avec des termes non nuls dans la ligne n° jpa ...
  477. DO 155 JHT=IPDE,IPDF
  478. LPA=MIN(LPA,LINC(JHT))
  479. 155 CONTINUE
  480. 126 CONTINUE
  481. DO 127 JPA=IPRE,IDER
  482. c ... on le met dans ldeb (segment llign) ...
  483. LDEB(JPA-IPRE+1)=LPA
  484. c ... nna = longueur de la "skyline" ...
  485. NNA= JPA- LPA +1
  486. c ... njmax = profil cumulé sur un noeud ...
  487. NJMAX=NJMAX+NNA
  488. 127 continue
  489. c
  490. c ... njtot = profil total ...
  491. NJTOT=NJTOT+NJMAX
  492. c ... ijmax = (profil / noeud) maxi ...
  493. IF(IJMAX.LT.NJMAX) IJMAX=NJMAX
  494. SEGDES,LLIGN
  495. IPRE=IDER+1
  496. 100 CONTINUE
  497. c
  498. 999 CONTINUE
  499. c
  500. c ... fin de la boucle sur les noeuds ...
  501. SEGSUP TRATRA
  502. C
  503. C **** ON REPREND TOUTE LES MATRICES CONTENANT LES MULTIPLICATEURS
  504. C **** POUR MULTIPLIER TOUS LEURS TERMES PAR UNE NORME ATTACHEE
  505. C **** A CHAQUE MULTIPLICATEUR.PUIS ON LES ASSEMBLE.
  506. C
  507. * d'abord etablir une norme generale pour le cas ou on n'arrive pas
  508. * a calculer la norme particuliere
  509. DMAXGE=xpetit
  510. DO 378 I=1,INC
  511. ** write (6,*) ' assem5 diag vmav ',diag(i),vmax(i)
  512. DMAXGE=MAX(DMAXGE,abs(vmax(i)))
  513. 378 CONTINUE
  514. if (dmaxge.lt.xpetit/xzprec*10) dmaxge=1.d0
  515. if (iimpi.eq.1524)
  516. > write (6,*) ' nb inconnues facteur multiplicatif general ',
  517. > INC,DMAXGE
  518. IENMU=0
  519. c ... attention ! ici commence une boucle cachée (exécutée avec un goto 375) ...
  520. 375 IENMU1 = IENMU
  521. IENMU=0
  522. c ... boucle sur les rigidités qui calcule le nombre de matrices de blocages ...
  523. DO 376 I=1,NNR
  524. IF(.NOT.INOMUL(I)) IENMU=IENMU+1
  525. 376 CONTINUE
  526. c
  527. c ... s'il n'y en a pas on saute cette partie du code ...
  528. IF( IENMU.EQ.0) GO TO 3750
  529. c
  530. c ... mimik contient les noms des variables primales ...
  531. MIMIK=IIMIK
  532. SEGACT,MIMIK
  533. c ... boucle sur les rigidités ...
  534. DO 11 I=1,NNR
  535. c ... si celle si n'est pas une matrice de blocage on passe à la suivante ...
  536. IF(INOMUL(I)) GO TO 11
  537. c
  538. DESCR=IRIGEL(3,I)
  539. c ... n3 = nb de variables primales ...
  540. N3=LISINC(/2)
  541. COER=COERIG(I)
  542. MELEME=IRIGEL(1,I)
  543. INCTRA=INCTRR(I)
  544. XMATRI=IRIGEL(4,I)
  545. c ... n2 = nombre d'éléments dans le support géométrique ...
  546. N2=NUM(/2)
  547. c ... À quoi correspond ce cas ? (pas de matrices élémentaires) ...
  548. IF (RE(/3).EQ.0) THEN
  549. INOMUL(I)=.TRUE.
  550. GOTO 11
  551. ENDIF
  552. * XMATRI=IMATTT(1)
  553. * SEGACT,XMATRI
  554. c ... n1 = nombre de variables duales ...
  555. c ... pourquoi va-t-on chercher n3 dans descr et n1 dans re ? ...
  556. N1=RE(/1)
  557. SEGINI,RA
  558. c ... boucle sur les éléments ...
  559. DO 14 IEL=1,N2
  560. c ... boucle sur les inconnues ...
  561. DO 15 ICO=1,N3
  562. c ... ija = n° local du noeud-support de l'inconnue n° ico ...
  563. IJA=INUINV(NUM(NOELEP(ICO),IEL))
  564. c ... ijb = n° de l'inconnue ...
  565. IJB=INCTRA(ICO)
  566. c ... ival contient la correspondance entre le n° local du ddl
  567. c et le n° d'équation (de ligne) correspondant ...
  568. IVAL(ICO)=INCPO(IJB,IJA)
  569. 15 CONTINUE
  570.  
  571. DDDD= xpetit
  572. c ... dmax = max des valeurs absolues des termes diagonaux correspondants
  573. c au ddl de l'élément n° iel ...
  574. c COER a deja ete applique sur vmax
  575. DMAX=DDDD
  576. * la boucle suivante demarre 3 car les deux premiers sont les multiplicateurs de lagrange
  577. DO 19 ICO=3,N3
  578. DMAX=MAX(DMAX,vmax(IVAL(ICO)))
  579. 19 CONTINUE
  580. ** write (6,*) ' assem2 dmax dmaxge ',dmax,dmaxge
  581. C AUX FINS D'EVITER DES PROBLEMES DANS LA DECOMPOSITION
  582. IF( IIMPI. EQ.1524 ) WRITE(IOIMP,7391)DMAX,DDDD,IENMU,IENMU1
  583. 1,I,IEL
  584. 7391 FORMAT(' DMAX DDDD IENMU IENMU1 I IEL',2E12.5,4I3)
  585. ** write (6,*) ' assem2 dmax dmxge',dmax,dmaxge
  586. IF(DMAX.LE.xzprec*dmaxge.AND.IENMU.NE.IENMU1.AND.IEL.EQ.1)GOTO 377
  587. IF(DMAX.LE.xzprec*dmaxge) DMAX = DMAXGE
  588. * facteur de normalisation cf PV pour ne pas avoir de pivot nul
  589. DMAX=DMAX*1.5
  590. * on penalise la matrice en cas de resolution iterative
  591. **pv if (nucrou.eq.1) DMAX=DMAX*1D5
  592. ** write (6,*) ' assem2 i iel dmax ',i,iel,dmax
  593. * XMATRI=IMATTT(IEL)
  594. * SEGACT,XMATRI
  595. c ... dmaxy = maximum des termes dans la première colonne (les 2 premiers exclus) ...
  596. DMAXY=SQRT(XPETIT)*1D5
  597. * if (norinc.eq.0) dmaxy=1.d0
  598. * demarrage a 3 aussi. On a toujours 1 -1 sur les LX
  599. DO 821 ICO=3,N1
  600. DMAXY = MAX ( DMAXY, ABS( RE(ICO,1,iel)))
  601. 821 CONTINUE
  602. c
  603. IF( IIMPI. EQ.9022 ) WRITE(IOIMP,7398) DMAX
  604. 7398 FORMAT('FACTEUR MULTIPLICATIF DE NORME=',E12.5)
  605. ** coer est dans dmax, mais pas dans dmaxy
  606. DMAX = DMAX / DMAXY
  607.  
  608. c
  609. c ... copie de la matrice élémentaire fois dmax*coer dans ra ...
  610. DO 21 ICO=1,N1
  611. DO 2110 IKO=1,N1
  612. RA(ICO,IKO)=RE(ICO,IKO,iel)*coer*DMAX
  613. 2110 CONTINUE
  614. 21 CONTINUE
  615. c ... la sous-matrice de dimension 2 est multipliée par dmaxy ...
  616. * commenté car pose un problème dans excite et ne sert sans doute à rien
  617. ** write (6,*) ' dmaxy dans assem5 ', dmaxy
  618. if (norinc.eq.0.d0) dmaxy=dmaxy*2.d0
  619. RA(1,1)=RA(1,1)*DMAXY
  620. RA(2,1)=RA(2,1)*DMAXY
  621. RA(1,2)=RA(1,2)*DMAXY
  622. RA(2,2)=RA(2,2)*DMAXY
  623. c ... mise à dmax des dnor correspondant aux multiplicateurs ...
  624. DO 22 ICO=1,2
  625. dnor(ival(ico))=dmax
  626. 22 CONTINUE
  627. c
  628. c ... boucle sur les variables primales ...
  629. DO 24 ICO=1,N3
  630. c ... ino = n° local du noeud ...
  631. INO=INUINV(NUM(NOELEP(ICO),IEL))
  632. c ... io = n° de ligne du ddl n° ico ...
  633. IO=IVAL(ICO)
  634. if (ico.eq.1) io1=io
  635. if (ico.eq.2) io2=io
  636. c ... cas des noeuds non totalement maitres ...
  637. IF(IO.GT.NBNNMA) THEN
  638. DO 1161 JJ=1,NTTMAI(/1)
  639. IF (NTTMAI(JJ).EQ.INO) GOTO 1171
  640. 1161 CONTINUE
  641. GOTO 1181
  642. 1171 CONTINUE
  643. INO=NNOE+JJ
  644. 1181 CONTINUE
  645. ENDIF
  646. c ... llign contient les lignes liées aux noeud ino ...
  647. LLIGN=ILIGN(INO)
  648. SEGACT,LLIGN*MOD
  649. c ... on rajoute le terme diagonal au diag ...
  650. DIAG(IO)=DIAG(IO)+RA(ICO,ICO)
  651. c ... immmm contient les n°s des lignes des ddl ...
  652. DO 132 JLIJ=1,IMMMM(/1)
  653. JLIJ1=JLIJ
  654. c ... on est censé trouver le bon n° de ligne et aller au 133 ...
  655. IF( IMMMM(JLIJ).EQ.IO) GO TO 133
  656. 132 CONTINUE
  657. c
  658. IF(IIMPI.EQ.1524) WRITE(IOIMP,7354)
  659. 7354 FORMAT( ' PREMIERE ERREUR 5')
  660. CALL ERREUR(5)
  661. RETURN
  662. c
  663. 133 CONTINUE
  664. c
  665. c ... deuxième niveau de boucle sur les variables primales ...
  666. DO 26 IRO=1,N3
  667. c ... ia = n° de colonne du ddl n° iro ...
  668. IA=IVAL(IRO)
  669. c ... cas symétrique !!! ...
  670. IF(IA.GT.IO) GO TO 26
  671. c
  672. c ... jld et jlt sont égaux au début et à la fin (dans xxva et linc)
  673. c des données relatives au ddl n° iro ...
  674. JLT=IPPO(JLIJ1+1)
  675. JLD=IPPO(JLIJ1)+1
  676. c
  677. c ... on cherche le bon n° de colonne dans linc ...
  678. DO 134 JL=JLD,JLT
  679. JL1=JL
  680. IF(LINC(JL).EQ.IA) GO TO 135
  681. 134 CONTINUE
  682. c
  683. IF(IIMPI.EQ.1524) WRITE(IOIMP,7355)
  684. 7355 FORMAT( ' DEUXIEME ERREUR 5')
  685. CALL ERREUR(5)
  686. RETURN
  687. c
  688. 135 CONTINUE
  689. c ... on rajoute le coefficient dans ra au xxva correspondant ...
  690. XXVA(JL1)=XXVA(JL1)+RA(ICO,IRO)
  691. 26 CONTINUE
  692. SEGDES,LLIGN
  693. 24 CONTINUE
  694. * on stocke dans ittr les couples de LX
  695. ittr(io1)=io2
  696. ittr(io2)=io1
  697. * SEGDES,XMATRI
  698. 14 CONTINUE
  699. c ... après son assemblage, une matrice de blocage n'est plus stigmatisée comme telle ...
  700. INOMUL(I)=.TRUE.
  701. 377 CONTINUE
  702. SEGSUP,RA
  703. 11 CONTINUE
  704. c ... fin de la boucle sur les rigidités ...
  705. GO TO 375
  706. c ... fin de la boucle cachée ...
  707. 3750 CONTINUE
  708. c
  709. DO 18 IK=1,NNR
  710. INCTRA=INCTRR(IK)
  711. SEGSUP,INCTRA
  712. 18 CONTINUE
  713. * pv on desactive tout
  714. NNR=IRIGEL(/2)
  715. DO 2 IRI=1,NNR
  716. DESCR=IRIGEL(3,IRI)
  717. SEGDES DESCR
  718. IPT1=IRIGEL(1,IRI)
  719. SEGDES IPT1
  720. xMATRI=IRIGEL(4,IRI)
  721. SEGDES xMATRI
  722. 2 CONTINUE
  723. INTERR(1)=NJTOT
  724. c
  725. IF(IIMPI.GE.1) WRITE(IOIMP,4821) LLVNUL,NJTOT
  726. 4821 FORMAT('Nbre de valeurs non nulles à l assemblage ',I9,/
  727. & 'Nbre de valeurs à l assemblage ',I9)
  728. c
  729. c
  730. SEGDES,SNTT
  731. SEGSUP,INCTRR
  732. SEGDES,MDIAG
  733. SEGDES,MIMIK
  734. SEGDES,MDNOR
  735. SEGSUP,ITOPO
  736. SEGSUP,IITOP
  737. SEGDES,MILIGN
  738. SEGSUP,INUINV
  739. SEGDES,MMATRI
  740. MMMTRI=MMATRI
  741. SEGDES,MINCPO
  742. SEGSUP,IVAL,ITRA,JNOMUL,vmax
  743. IF(NORINC.NE.0) THEN
  744. CALL ASSEM0(MRIGID,2,INWUIT)
  745. SEGDES,MRIGID
  746. ELSE
  747. SEGDES,MRIGID
  748. ENDIF
  749. RETURN
  750. END
  751. c
  752. c
  753. c
  754. c
  755. c
  756.  
  757.  
  758.  
  759.  
  760.  
  761.  
  762.  
  763.  
  764.  
  765.  
  766.  
  767.  
  768.  
  769.  
  770.  
  771.  
  772.  
  773.  
  774.  
  775.  
  776.  
  777.  
  778.  
  779.  
  780.  
  781.  
  782.  
  783.  
  784.  
  785.  
  786.  
  787.  

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