Télécharger liaiso.eso

Retour à la liste

Numérotation des lignes :

liaiso
  1. C LIAISO SOURCE BP208322 16/11/18 21:18:44 9177
  2. C FABRIQUE LES ELEMENTS LIAISON ENTRE DEUX SURFACES
  3. C D'APRES COCO
  4. C
  5. SUBROUTINE LIAISO(IPT1,IPT2,MELEME,PREC)
  6. IMPLICIT INTEGER(I-N)
  7. IMPLICIT REAL*8 (a-h,o-z)
  8.  
  9. -INC PPARAM
  10. -INC CCOPTIO
  11. -INC CCGEOME
  12. -INC CCREEL
  13. *-
  14. -INC SMELEME
  15. -INC SMCOORD
  16.  
  17. SEGMENT MTRAV
  18. REAL*8 TA(NBELEM)
  19. INTEGER NP1(NBELE1),NP2(NBELE1)
  20. ENDSEGMENT
  21.  
  22. C* DIMENSION ITEST(0:NBCOUL-1) - NBCOUL stocke dans CCGEOME
  23. DIMENSION ITEST(0:30)
  24.  
  25. IDIMP1 = IDIM+1
  26. SEGACT MCOORD
  27. PREC3=3.*PREC
  28. TMAX=-XGRAND
  29. TMIN=XGRAND
  30. NB1=IPT1.NUM(/2)
  31. NB2=IPT2.NUM(/2)
  32. NBPOS=MIN(NB1,NB2)
  33. NBNN=IPT1.NUM(/1)
  34. IF (NBNN.NE.IPT2.NUM(/1)) THEN
  35. CALL ERREUR(16)
  36. RETURN
  37. ENDIF
  38. DO 40 I=0,NBCOUL-1
  39. ITEST(I)=0
  40. 40 CONTINUE
  41. DO 41 I=1,NB1
  42. ITEST(min(22,IPT1.ICOLOR(I)))=1
  43. 41 CONTINUE
  44. DO 42 I=1,NB2
  45. ITEST(min(22,IPT2.ICOLOR(I)))=1
  46. 42 CONTINUE
  47. ICHCOL=-1
  48. DO 43 I=0,NBCOUL-1
  49. IF (ITEST(I).EQ.1) THEN
  50. IF (ICHCOL.EQ.-1) THEN
  51. ICHCOL=I
  52. ELSE
  53. ICHCOL=ITABM(ICHCOL,I)
  54. ENDIF
  55. ENDIF
  56. 43 CONTINUE
  57. ITYP=0
  58. IF(IPT1.ITYPEL.EQ.4) ITYP=18
  59. IF(IPT1.ITYPEL.EQ.8) ITYP=19
  60. IF(IPT1.ITYPEL.EQ.6) ITYP=20
  61. IF(IPT1.ITYPEL.EQ.10) ITYP=21
  62. IF (ITYP.EQ.0) RETURN
  63. NBELEM=NB2
  64. NBELE1=NBELEM+1
  65. SEGINI,MTRAV
  66. DO 11 I=1,NB2
  67. Z=0.D0
  68. DO 12 J=1,NBNN
  69. IREF=IPT2.NUM(J,I)*IDIMP1-IDIM
  70. Z=Z+ABS(XCOOR(IREF))+ABS(XCOOR(IREF+1))
  71. IF (IDIM.NE.2) Z=Z+ABS(XCOOR(IREF+2))
  72. 12 CONTINUE
  73. Z=Z/NBNN
  74. TA(I)=Z
  75. TMAX=MAX(Z,TMAX)
  76. TMIN=MIN(Z,TMIN)
  77. 11 CONTINUE
  78. C on recommence avec ipt1 pour avoir les vrais TMAX et TMIN
  79. DO 110 I=1,NB1
  80. Z=0.
  81. DO 120 J=1,NBNN
  82. IREF=IPT1.NUM(J,I)*IDIMP1-IDIM
  83. Z=Z+ABS(XCOOR(IREF))+ABS(XCOOR(IREF+1))
  84. IF (IDIM.NE.2) Z=Z+ABS(XCOOR(IREF+2))
  85. 120 CONTINUE
  86. Z=Z/NBNN
  87. TMAX=MAX(Z,TMAX)
  88. TMIN=MIN(Z,TMIN)
  89. 110 CONTINUE
  90. C
  91. C CLASSEMENT APPROXIMATIF PAR ' DISTANCE '
  92. C
  93. IF ((TMAX-TMIN)/TMAX.GE.1E-6) GOTO 6
  94. TMAX=TMAX+1.
  95. TMIN=TMIN-1.
  96. 6 CONTINUE
  97. TDEC=(TMAX-TMIN)/NBELEM*1.0001
  98. IF (TDEC.EQ.0.) TDEC=1.
  99. C* Boucle 3 redondante avec SEGINI,MTRAV
  100. C* DO 3 I=1,NBELE1
  101. C* 3 NP1(I)=0
  102. DO 4 I=1,NBELEM
  103. IPLA=INT((TA(I)-TMIN)/TDEC)+1
  104. 4 NP1(IPLA)=NP1(IPLA)+1
  105. DO 400 I=2,NBELE1
  106. 400 NP1(I)=NP1(I-1)+NP1(I)
  107. DO 5 I=1,NBELEM
  108. IPLA=INT((TA(I)-TMIN)/TDEC)+1
  109. IPLB=NP1(IPLA)
  110. NP1(IPLA)=NP1(IPLA)-1
  111. NP2(IPLB)=I
  112. 5 CONTINUE
  113. C
  114. C DANS NP1 ADDRESSE DU DEBUT DE ZONE
  115. C DANS NP2 NUMERO DES ELEMENTS EN NUMEROTATION LOCALE
  116. C DANS TA DISTANCE DES ELEMENTS
  117. C
  118. C IL FAUT PREPARER LE SEGMENT TAMPON OU METTRE LES ELEMS CREES.
  119. NBREF=0
  120. NBSOUS=0
  121. NBNNOR=NBNN
  122. NBNN=2*NBNN
  123. NBELEM=NB1+NB2
  124. SEGINI MELEME
  125. IPT4=MELEME
  126. NBT=NBELEM
  127. NBELEM=NB2
  128. NUMELG=0
  129. ittes=0
  130. C
  131. C BOUCLE SUR TOUS LES ELEMENTS POUR CONNAITRE LEUR FACES ET REGARDER SI
  132. C LE CENTRE DE GRAVITE EST CONFONDU A PREC PRES DE CELUI D'UN ELEMENT
  133. C COQUE
  134. DO 20 I=1,NB1
  135. ZAA=0.
  136. DO 21 J=1,NBNNOR
  137. IREF=IPT1.NUM(J,I)*IDIMP1-IDIM
  138. ZAA=ZAA+ABS(XCOOR(IREF))+ABS(XCOOR(IREF+1))
  139. IF (IDIM.NE.2) ZAA=ZAA+ABS(XCOOR(IREF+2))
  140. 21 CONTINUE
  141. ZAA=ZAA/NBNNOR
  142. zaami= zaa - idim*prec
  143. zaama= zaa + idim *prec
  144. IZO=(ZAA-TMIN)/TDEC+1.
  145. IZO1=IZO-1
  146. IZO2=IZO+1
  147. izo1= (ZAAmi-TMIN)/TDEC -1
  148. izo2= (ZAAma-TMIN)/TDEC+2
  149. IF(IZO1.LT.1) IZO1=1
  150. IF(IZO2.GT.NBELEM) IZO2=NBELEM
  151. DO 28 IZO=IZO1,IZO2
  152. IDEP=NP1(IZO)+1
  153. IFIN=NP1(IZO+1)
  154. IF(IFIN.LT.IDEP) GO TO 28
  155. DO 23 JFA=IDEP,IFIN
  156. IB=NP2(JFA)
  157. IF(ABS(TA(IB)-ZAA).GT.PREC3) GO TO 23
  158. C ON VIENT D'IDENTIFIER UN ELEMENT DE RACCORD ON VA LE CREER
  159. IREFA=IPT1.NUM(1,I)*IDIMP1-IDIM
  160. DO 24 IK=1,NBNNOR
  161. IREFB=IPT2.NUM(IK,IB)*IDIMP1-IDIM
  162. IF (ABS(XCOOR(IREFA)-XCOOR(IREFB)).GT.PREC) GOTO 24
  163. IF (ABS(XCOOR(1+IREFA)-XCOOR(1+IREFB)).GT.PREC) GOTO 24
  164. IF (ABS(XCOOR(2+IREFA)-XCOOR(2+IREFB)).GT.PREC.AND.IDIM.NE.2)
  165. # GOTO 24
  166. ISTA=IK
  167. GO TO 26
  168. 24 CONTINUE
  169. GO TO 23
  170. 26 CONTINUE
  171. ISENS=1
  172. ISTA1=ISTA+1
  173. ISTAA=ISTA
  174. IF (ISTA1.GT.NBNNOR) ISTA1=1
  175. IREFA=IPT1.NUM(2,I)*IDIMP1-IDIM
  176. IREFB=IPT2.NUM(ISTA1,IB)*IDIMP1-IDIM
  177. Z=XCOOR(IREFA)-XCOOR(IREFB)
  178. IF(ABS(Z).GT.PREC) ISENS=-1
  179. Z=XCOOR(IREFA+1)-XCOOR(IREFB+1)
  180. IF(ABS(Z).GT.PREC) ISENS=-1
  181. IF (IDIM.NE.2) THEN
  182. Z=XCOOR(IREFA+2)-XCOOR(IREFB+2)
  183. IF (ABS(Z).GT.PREC) ISENS=-1
  184. ENDIF
  185. DO 30 IJ=2,NBNNOR
  186. IREFA=IPT1.NUM(IJ,I)*IDIMP1-IDIM
  187. ISTAA=ISTAA+ISENS
  188. IF (ISTAA.EQ.0) ISTAA=NBNNOR
  189. IF (ISTAA.GT.NBNNOR) ISTAA=1
  190. IREFB=IPT2.NUM(ISTAA,IB)*IDIMP1-IDIM
  191. DO 32 KLP=1,IDIM
  192. Z=XCOOR(IREFA+KLP-1)-XCOOR(IREFB+KLP-1)
  193. IF(ABS(Z).GT.PREC) GO TO 23
  194. 32 CONTINUE
  195. 30 CONTINUE
  196. C CREATION D'UN ELEM RACCORD
  197. NUMELG=NUMELG+1
  198. IF (NUMELG.GT.NBPOS) THEN
  199. CALL ERREUR(31)
  200. GOTO 101
  201. ENDIF
  202. DO 27 IK=1,NBNNOR
  203. IP1=IPT1.NUM(IK,I)
  204. IP2=IPT2.NUM(ISTA,IB)
  205. NUM(IK,NUMELG)=IP1
  206. NUM(NBNNOR+IK,NUMELG)=IP2
  207. ISTA=ISTA+ISENS
  208. IF (ISTA.EQ.0) ISTA=NBNNOR
  209. IF (ISTA.GT.NBNNOR) ISTA=1
  210. IF (IP1.NE.IP2) GOTO 27
  211. INTERR(1)=NUMELG
  212. CALL ERREUR(101)
  213. 27 CONTINUE
  214. 23 CONTINUE
  215. 28 CONTINUE
  216. 20 CONTINUE
  217. IF (IIMPI.NE.0) WRITE(IOIMP,29) NUMELG
  218. 29 FORMAT(///,39H NOMBRE D'ELEMENTS DE LIAISON CREES : ,I5 )
  219. NBELEM=NUMELG
  220. MELEME=0
  221. IF (NBELEM.EQ.0) GOTO 101
  222. SEGINI MELEME
  223. ITYPEL=ITYP
  224. DO 100 J=1,NBELEM
  225. ICOLOR(J)=ICHCOL
  226. DO 100 I=1,NBNN
  227. NUM(I,J)=IPT4.NUM(I,J)
  228. 100 CONTINUE
  229. 101 SEGSUP IPT4
  230. SEGSUP,MTRAV
  231. RETURN
  232. END
  233.  
  234.  
  235.  
  236.  
  237.  
  238.  
  239.  

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