Télécharger liapor.eso

Retour à la liste

Numérotation des lignes :

liapor
  1. C LIAPOR SOURCE BP208322 16/11/18 21:18:44 9177
  2. C
  3. C FABRIQUE LES ELEMENTS LIAISON POUR LES ELEMENTS JOINT POREUX (BALD).
  4. C CES ELEMENTS JOINTS SONT COMPOSES PAR TROIS SURFACES: LES SURFACES TOP
  5. C ET BOT SONT MAILLEES AVEC DES ELEMENTS QUA8 (TRI6), LA SURFACE AU
  6. C MILIEU AVEC DES QUA4 (TRI3). L'ELEMENT LIAISON CREE A 20 (15) NOEUDS.
  7. C
  8. SUBROUTINE LIAPOR(IPT1,IPT2,IPT3,MELEME,PREC)
  9. IMPLICIT INTEGER(I-N)
  10. IMPLICIT REAL*8 (a-h,o-z)
  11.  
  12. -INC PPARAM
  13. -INC CCOPTIO
  14. -INC CCGEOME
  15. -INC CCREEL
  16.  
  17. -INC SMELEME
  18. -INC SMCOORD
  19. SEGMENT MTRAV
  20. REAL*8 TA(NBELEM)
  21. INTEGER NP1(NBELE1),NP2(NBELE1)
  22. ENDSEGMENT
  23. C* DIMENSION ITEST(0:NBCOUL-1) - NBCOUL stocke dans CCGEOME
  24. DIMENSION ITEST(0:15)
  25.  
  26. IDIMP1 = IDIM+1
  27. SEGACT MCOORD
  28. PREC3=3.*PREC
  29. TMAX=-XGRAND
  30. TMIN= XGRAND
  31. NB1=IPT1.NUM(/2)
  32. NB2=IPT2.NUM(/2)
  33. NB3=IPT3.NUM(/2)
  34. NBMAX=MIN(NB1,NB2,NB3)
  35. NBNN=IPT1.NUM(/1)
  36. NBNM=IPT3.NUM(/1)
  37. IF ((NBNN.NE.IPT2.NUM(/1)).OR.(NBNN.EQ.NBNM).OR.
  38. . (NBSOM(IPT1.ITYPEL).NE.NBSOM(IPT3.ITYPEL))) THEN
  39. CALL ERREUR(16)
  40. RETURN
  41. ENDIF
  42.  
  43. DO 40 I=0,(NBCOUL-1)
  44. ITEST(I)=0
  45. 40 CONTINUE
  46. DO 41 I=1,NB1
  47. ITEST(IPT1.ICOLOR(I))=1
  48. 41 CONTINUE
  49. DO 42 I=1,NB2
  50. ITEST(IPT2.ICOLOR(I))=1
  51. 42 CONTINUE
  52. DO 43 I=1,NB3
  53. ITEST(IPT3.ICOLOR(I))=1
  54. 43 CONTINUE
  55. ICHCOL=-1
  56. DO 44 I=0,(NBCOUL-1)
  57. IF (ITEST(I).EQ.1) THEN
  58. IF (ICHCOL.EQ.-1) THEN
  59. ICHCOL=I
  60. ELSE
  61. ICHCOL=ITABM(ICHCOL,I)
  62. ENDIF
  63. ENDIF
  64. 44 CONTINUE
  65.  
  66. NBELEM=NB2
  67. NBELE1=NBELEM+1
  68. SEGINI,MTRAV
  69. DO 11 I=1,NB2
  70. Z=0.
  71. DO 12 J=1,NBNN
  72. IREF=IPT2.NUM(J,I)*IDIMP1-IDIM
  73. Z=Z+XCOOR(IREF)+XCOOR(IREF+1)
  74. IF (IDIM.NE.2) Z=Z+XCOOR(IREF+2)
  75. 12 CONTINUE
  76. Z=Z/NBNN
  77. TA(I)=Z
  78. IF(Z.GT.TMAX) TMAX=Z
  79. IF(Z.LT.TMIN) TMIN=Z
  80. 11 CONTINUE
  81. C
  82. C CLASSEMENT APPROXIMATIF PAR ' DISTANCE '
  83. C
  84. IF ((TMAX-TMIN)/TMAX.GE.1E-6) GOTO 6
  85. TMAX=TMAX+1.
  86. TMIN=TMIN-1.
  87. 6 CONTINUE
  88. TDEC=(TMAX-TMIN)/NBELEM*1.0001
  89. N = PREC/TDEC + 1.
  90. C* Boucle 3 redondante avec SEGINI,MTRAV
  91. C* DO 3 I=1,NBELE1
  92. C* 3 NP1(I)=0
  93. DO 4 I=1,NBELEM
  94. IPLA=(TA(I)-TMIN)/TDEC+1.
  95. 4 NP1(IPLA)=NP1(IPLA)+1
  96. DO 400 I=2,NBELE1
  97. 400 NP1(I)=NP1(I-1)+NP1(I)
  98. DO 5 I=1,NBELEM
  99. IPLA=(TA(I)-TMIN)/TDEC+1.
  100. IPLB=NP1(IPLA)
  101. NP1(IPLA)=NP1(IPLA)-1
  102. NP2(IPLB)=I
  103. 5 CONTINUE
  104. C
  105. C DANS NP1 ADDRESSE DU DEBUT DE ZONE
  106. C DANS NP2 NUMERO DES ELEMENTS EN NUMEROTATION LOCALE
  107. C DANS TA DISTANCE DES ELEMENTS
  108. C
  109. C IL FAUT PREPARER LE SEGMENT TAMPON OU METTRE LES ELEMS CREES.
  110. NBREF=0
  111. NBSOUS=0
  112. NBNNOR=NBNN
  113. NBNN=2*NBNN+NBNM
  114. NBELEM=NB1+NB2
  115. SEGINI MELEME
  116. IPT4=MELEME
  117. NBELEM=NB2
  118. NUMELG=0
  119. C
  120. C BOUCLE SUR TOUS LES ELEMENTS POUR CONNAITRE LEUR FACES ET REGARDER SI
  121. C LE CENTRE DE GRAVITE EST CONFONDU A PREC PRES DE CELUI D'UN ELEMENT
  122. C COQUE
  123. C
  124. DO 20 I=1,NB1
  125. ZAA=0.
  126. DO 21 J=1,NBNNOR
  127. IREF=IPT1.NUM(J,I)*IDIMP1-IDIM
  128. ZAA=ZAA+XCOOR(IREF)+XCOOR(IREF+1)
  129. IF (IDIM.NE.2) ZAA=ZAA+XCOOR(IREF+2)
  130. 21 CONTINUE
  131. ZAA=ZAA/NBNNOR
  132. IZO=(ZAA-TMIN)/TDEC+1.
  133. IZO1=IZO-N
  134. IZO2=IZO+N
  135. IF(IZO1.LT.1) IZO1=1
  136. IF(IZO2.GT.NBELEM) IZO2=NBELEM
  137. IF (IZO.LT.0.OR.IZO.GT.NBELE1) GOTO 20
  138. DO 28 IZO=IZO1,IZO2
  139. IDEP=NP1(IZO)+1
  140. IFIN=NP1(IZO+1)
  141. IF(IFIN.LT.IDEP) GO TO 28
  142. DO 23 JFA=IDEP,IFIN
  143. IB=NP2(JFA)
  144. IF(ABS(TA(IB)-ZAA).GT.PREC3) GO TO 23
  145. IREFA=IPT1.NUM(1,I)*IDIMP1-IDIM
  146. DO 24 IK=1,NBNNOR
  147. IREFB=IPT2.NUM(IK,IB)*IDIMP1-IDIM
  148. IF (ABS(XCOOR(IREFA)-XCOOR(IREFB)).GT.PREC) GOTO 24
  149. IF (ABS(XCOOR(1+IREFA)-XCOOR(1+IREFB)).GT.PREC) GOTO 24
  150. IF (ABS(XCOOR(2+IREFA)-XCOOR(2+IREFB)).GT.PREC.AND.IDIM.NE.2)
  151. # GOTO 24
  152. ISTA=IK
  153. GO TO 26
  154. 24 CONTINUE
  155. GO TO 23
  156. 26 CONTINUE
  157. ISENS=1
  158. ISTA1=ISTA+1
  159. ISTAA=ISTA
  160. IF (ISTA1.GT.NBNNOR) ISTA1=1
  161. IREFA=IPT1.NUM(2,I)*IDIMP1-IDIM
  162. IREFB=IPT2.NUM(ISTA1,IB)*IDIMP1-IDIM
  163. Z=XCOOR(IREFA)-XCOOR(IREFB)
  164. IF(ABS(Z).GT.PREC) ISENS=-1
  165. Z=XCOOR(IREFA+1)-XCOOR(IREFB+1)
  166. IF(ABS(Z).GT.PREC) ISENS=-1
  167. IF (IDIM.NE.2) THEN
  168. Z=XCOOR(IREFA+2)-XCOOR(IREFB+2)
  169. IF (ABS(Z).GT.PREC) ISENS=-1
  170. ENDIF
  171. DO 30 IJ=2,NBNNOR
  172. IREFA=IPT1.NUM(IJ,I)*IDIMP1-IDIM
  173. ISTAA=ISTAA+ISENS
  174. IF (ISTAA.EQ.0) ISTAA=NBNNOR
  175. IF (ISTAA.GT.NBNNOR) ISTAA=1
  176. IREFB=IPT2.NUM(ISTAA,IB)*IDIMP1-IDIM
  177. DO 32 KLP=1,IDIM
  178. Z=XCOOR(IREFA+KLP-1)-XCOOR(IREFB+KLP-1)
  179. IF(ABS(Z).GT.PREC) GO TO 23
  180. 32 CONTINUE
  181. 30 CONTINUE
  182. C
  183. IZC=(ZAA-TMIN)/TDEC+1.
  184. DO 33 IC=1,NB3
  185. Z=0.
  186. DO 31 J=1,NBNM
  187. IREF=IPT3.NUM(J,IC)*IDIMP1-IDIM
  188. Z=Z+XCOOR(IREF)+XCOOR(IREF+1)
  189. IF (IDIM.NE.2) Z=Z+XCOOR(IREF+2)
  190. 31 CONTINUE
  191. Z=Z/NBNM
  192. IF(ABS(ZAA-Z).GT.PREC3) GO TO 33
  193. C ON VIENT D'IDENTIFIER UN ELEMENT DE RACCOR ON VA LE CREER
  194. IREFA=IPT1.NUM(1,I)*IDIMP1-IDIM
  195. DO 34 IK=1,NBNM
  196. IREFB=IPT3.NUM(IK,IC)*IDIMP1-IDIM
  197. IF (ABS(XCOOR(IREFA)-XCOOR(IREFB)).GT.PREC) GOTO 34
  198. IF (ABS(XCOOR(1+IREFA)-XCOOR(1+IREFB)).GT.PREC) GOTO 34
  199. IF (ABS(XCOOR(2+IREFA)-XCOOR(2+IREFB)).GT.PREC.AND.IDIM.NE.2)
  200. # GOTO 34
  201. ISTC=IK
  202. GO TO 36
  203. 34 CONTINUE
  204. GO TO 33
  205. 36 CONTINUE
  206. ISENT=1
  207. ISTC1=ISTC+1
  208. ISTCC=ISTC
  209. IF (ISTC1.GT.NBNM) ISTC1=1
  210. IREFA=IPT1.NUM(3,I)*IDIMP1-IDIM
  211. IREFB=IPT3.NUM(ISTC1,IC)*IDIMP1-IDIM
  212. Z=XCOOR(IREFA)-XCOOR(IREFB)
  213. IF(ABS(Z).GT.PREC) ISENT=-1
  214. Z=XCOOR(IREFA+1)-XCOOR(IREFB+1)
  215. IF(ABS(Z).GT.PREC) ISENT=-1
  216. IF (IDIM.NE.2) THEN
  217. Z=XCOOR(IREFA+2)-XCOOR(IREFB+2)
  218. IF (ABS(Z).GT.PREC) ISENT=-1
  219. ENDIF
  220. DO 50 IJ=3,NBNNOR,2
  221. IREFA=IPT1.NUM(IJ,I)*IDIMP1-IDIM
  222. ISTCC=ISTCC+ISENT
  223. IF (ISTCC.EQ.0) ISTCC=NBNM
  224. IF (ISTCC.GT.NBNM) ISTCC=1
  225. IREFB=IPT3.NUM(ISTCC,IC)*IDIMP1-IDIM
  226. DO 52 KLP=1,IDIM
  227. Z=XCOOR(IREFA+KLP-1)-XCOOR(IREFB+KLP-1)
  228. IF(ABS(Z).GT.PREC) GO TO 33
  229. 52 CONTINUE
  230. 50 CONTINUE
  231. C CREATION D'UN ELEM RACCORD
  232. NUMELG=NUMELG+1
  233. IF (NUMELG.GT.NBMAX) THEN
  234. CALL ERREUR(31)
  235. GOTO 101
  236. ENDIF
  237. IM=0
  238. DO 27 IK=1,NBNNOR
  239. IP1=IPT1.NUM(IK,I)
  240. IP2=IPT2.NUM(ISTA,IB)
  241. NUM(IK,NUMELG)=IP1
  242. NUM(NBNNOR+IK,NUMELG)=IP2
  243. ISTA=ISTA+ISENS
  244. IF (ISTA.EQ.0) ISTA=NBNNOR
  245. IF (ISTA.GT.NBNNOR) ISTA=1
  246. IF (IK.EQ.IBSOM(NSPOS(IPT1.ITYPEL)+IM)) THEN
  247. IM=IM+1
  248. IP3=IPT3.NUM(ISTC,IC)
  249. NUM(2*NBNNOR+IM,NUMELG)=IP3
  250. ISTC=ISTC+ISENT
  251. IF (ISTC.EQ.0) ISTC=NBNM
  252. IF (ISTC.GT.NBNM) ISTC=1
  253. IF ((IP1.NE.IP2).AND.(IP1.NE.IP3).AND.(IP2.NE.IP3)) GO TO 27
  254. INTERR(1)=NUMELG
  255. CALL ERREUR(101)
  256. ENDIF
  257. IF (IP1.NE.IP2) GO TO 27
  258. INTERR(1)=NUMELG
  259. CALL ERREUR(101)
  260. 27 CONTINUE
  261. 33 CONTINUE
  262. C
  263. 23 CONTINUE
  264. 28 CONTINUE
  265. 20 CONTINUE
  266. C WRITE(IOIMP,29) NUMELG
  267. C 29 FORMAT(//,' NOMBRE D''ELEMENTS DE LIAISON CREES : ',I5)
  268. NBELEM=NUMELG
  269. MELEME=0
  270. IF (NBELEM.EQ.0) GOTO 101
  271. SEGINI MELEME
  272. IF (NBNN.EQ.15) ITYPEL=30
  273. IF (NBNN.EQ.20) ITYPEL=31
  274. DO 100 J=1,NBELEM
  275. ICOLOR(J)=ICHCOL
  276. DO 100 I=1,NBNN
  277. NUM(I,J)=IPT4.NUM(I,J)
  278. 100 CONTINUE
  279. 101 SEGSUP IPT4
  280. SEGSUP MTRAV
  281. RETURN
  282. END
  283.  
  284.  
  285.  
  286.  
  287.  

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