Télécharger raccor.eso

Retour à la liste

Numérotation des lignes :

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

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