Télécharger capac3.eso

Retour à la liste

Numérotation des lignes :

capac3
  1. C CAPAC3 SOURCE OF166741 25/02/21 21:15:23 12166
  2.  
  3. C=======================================================================
  4. C= C A P A C 3 =
  5. C= ----------- =
  6. C= =
  7. C= Fonction : =
  8. C= ---------- =
  9. C= Calcul de la matrice de CAPACITE CALORIFIQUE pour des elements de =
  10. C= COQUE TRIANGLE (COQ3) a integration semi-analytique =
  11. C= =
  12. C= Parametres : (E)=Entree (S)=Sortie =
  13. C= ------------ =
  14. C= NEF (E) Numero de l'ELEMENT FINI dans NOMTP =
  15. C= IPMAIL (E) Numero du segment IMODEL dans le segment MMODEL =
  16. C= CLAT (E) Chaleur latente du changement de phase =
  17. C= IPRIGI (E/S) Matrice de CAPACITE (RIGIDITE) resultat (ACTIF) =
  18. C=======================================================================
  19.  
  20. SUBROUTINE CAPAC3 (NEF,IPMAIL,IPINTE,IVAMAT,NVAMAT,IVAPHA,NVAPHA,
  21. & IPMATR,NLIGR,INFOR)
  22.  
  23. IMPLICIT INTEGER(I-N)
  24. IMPLICIT REAL*8 (A-H,O-Z)
  25.  
  26. -INC PPARAM
  27. -INC CCOPTIO
  28. -INC CCREEL
  29. -INC CCHAMP
  30.  
  31. -INC SMCHAML
  32. -INC SMCOORD
  33. -INC SMELEME
  34. -INC SMINTE
  35. -INC SMRIGID
  36.  
  37. -INC TMPTVAL
  38.  
  39. SEGMENT MMAT1
  40. REAL*8 XE(3,NBNN),FORME(NBNN)
  41. REAL*8 CAPSS(NBNN,NBNN),CAPV(NLIGR,NLIGR)
  42. REAL*8 VACOMP(NVAMAT)
  43. ENDSEGMENT
  44.  
  45. CHARACTER*16 MOFOR
  46.  
  47. C= Quelques constantes numeriques
  48. PARAMETER (X1s15=0.066666666666666666666666666667D0)
  49. PARAMETER (X2s15=0.133333333333333333333333333333D0)
  50. PARAMETER (X8s15=0.533333333333333333333333333333D0)
  51. PARAMETER (X1s30=0.033333333333333333333333333333D0)
  52.  
  53. C 1 - INITIALISATIONS ET VERIFICATIONS
  54. C ======================================
  55. MELEME = IPMAIL
  56. c* SEGACT,MELEME
  57. NBNN = NUM(/1)
  58. NBELEM = NUM(/2)
  59. NBNN2 = 2*NBNN
  60. c* NBNN3 = 3*NBNN
  61. C =====
  62. MINTE = IPINTE
  63. c* SEGACT,MINTE
  64. NBPGAU = POIGAU(/1)
  65. C =====
  66. MPTVAL = IVAMAT
  67. c* SEGACT,MPTVAL
  68. C- Test sur la constance du champ d'epaisseur : supprime
  69. c* IPMELV = IVAL(3)
  70. c* CALL QUELCH(IPMELV,IOK)
  71. c* IF (IOK.NE.0) THEN
  72. c* CALL ERREUR(566)
  73. c* GOTO 9990
  74. c* ENDIF
  75. C =====
  76. c* IF (IVAPHA.NE.0) THEN
  77. c* MPTVAL = IVAPHA
  78. c* SEGACT,MPTVAL
  79. c* ENDIF
  80. C =====
  81. XMATRI = IPMATR
  82. c* SEGACT,XMATRI*MOD
  83. c* NLIGRP = NBNN3 = NLIGR
  84. c* NLIGRD = NBNN3 = NLIGR
  85. C =====
  86. SEGINI,MMAT1
  87.  
  88. C 2 - BOUCLE SUR LES ELEMENTS DU MAILLAGE ELEMENTAIRE IPMAIL
  89. C ============================================================
  90. DO iElt = 1, NBELEM
  91. C =====
  92. C 2.1 - Recuperation des coordonnees GLOABLES des noeuds de l'element
  93. C =====
  94. CALL ZERO(CAPV,NLIGR,NLIGR)
  95. C =====
  96. C 2.2 - Recuperation des coordonnees GLOABLES des noeuds de l'element
  97. C =====
  98. CALL DOXE(XCOOR,IDIM,NBNN,NUM,iElt,XE)
  99. C =====
  100. C 2.3 - Boucle sur les points de Gauss de l'element iElt
  101. C =====
  102. DO iGau = 1, NBPGAU
  103.  
  104. C- Calcul du volume associe a ce point de Gauss (jacobien)
  105. S1=XZero
  106. S2=XZero
  107. S3=XZero
  108. S4=XZero
  109. S5=XZero
  110. S6=XZero
  111. DO iNoe = 1, NBNN
  112. S1=S1+SHPTOT(2,iNoe,iGau)*XE(2,iNoe)
  113. S2=S2+SHPTOT(3,iNoe,iGau)*XE(3,iNoe)
  114. S3=S3+SHPTOT(3,iNoe,iGau)*XE(2,iNoe)
  115. S4=S4+SHPTOT(2,iNoe,iGau)*XE(3,iNoe)
  116. S5=S5+SHPTOT(3,iNoe,iGau)*XE(1,iNoe)
  117. S6=S6+SHPTOT(2,iNoe,iGau)*XE(1,iNoe)
  118. ENDDO
  119. SurfX=S1*S2-S3*S4
  120. SurfY=S4*S5-S2*S6
  121. SurfZ=S6*S3-S5*S1
  122. DJAC = ABS(SurfX*SurfX+SurfY*SurfY+SurfZ*SurfZ)
  123. C- Verification que le volume n'est pas nul en ce point de Gauss
  124. IF (DJAC.LT.XPETIT) THEN
  125. INTERR(1) = iElt
  126. CALL ERREUR(259)
  127. GOTO 9990
  128. ENDIF
  129. DJAC = SQRT(DJAC)
  130.  
  131. C MPTVAL = IVAMAT
  132. DO i = 1, NVAMAT
  133. MELVAL = IVAL(i)
  134. IGMN = MIN(iGau,VELCHE(/1))
  135. IEMN = MIN(iElt,VELCHE(/2))
  136. VACOMP(i) = VELCHE(IGMN,IEMN)
  137. ENDDO
  138. VALRHO = VACOMP(1)
  139.  
  140. C CAS THERMIQUE on fait RHO.CP
  141. IF (INFOR .EQ. 1) VACOMP(1) = VALRHO * VACOMP(2)
  142.  
  143. CAPA = DJAC * POIGAU(iGau) * VACOMP(1)
  144. C- Calcul de la contribution du point de Gauss a la matrice
  145. C- CAPACITE elementaire pour cet element fini
  146. CALL ZERO(CAPSS,NBNN,NBNN)
  147. do iou=1,nbnn
  148. forme(iou)=shptot(1,iou,igau)
  149. enddo
  150. CALL NTNST(FORME,CAPA,NBNN,1,CAPSS)
  151.  
  152. C- Ajout de termes specifiques dus a l'integration (analytique)
  153. C- suivant l'epaisseur de l'element de type COQUE
  154. C =======
  155. C- Erreur si l'epaisseur est est nulle
  156. EP = VACOMP(NVAMAT)
  157. c* IF (EP.LE.XPetit) THEN
  158. c* CALL ERREUR(517)
  159. c* GOTO 9990
  160. c* ENDIF
  161. C1 = X2s15*EP
  162. C2 = X1s15*EP
  163. C3 = -X1s30*EP
  164. C4 = X8s15*EP
  165. C5 = C2
  166. C6 = C1
  167. DO j=1,NBNN
  168. j1 = j + NBNN
  169. j2 = j + NBNN2
  170. DO i=1,NBNN
  171. i1 = i + NBNN
  172. i2 = i + NBNN2
  173. Cte = CAPSS(i,j)
  174. CAPV( i, j) = CAPV( i, j) + C1*Cte
  175. CAPV(i1, j) = CAPV(i1, j) + C2*Cte
  176. CAPV(i2, j) = CAPV(i2, j) + C3*Cte
  177. CAPV(i1,j1) = CAPV(i1,j1) + C4*Cte
  178. CAPV(i2,j1) = CAPV(i2,j1) + C5*Cte
  179. CAPV(i2,j2) = CAPV(i2,j2) + C6*Cte
  180. ENDDO
  181. ENDDO
  182. ENDDO
  183. C =====
  184. C 2.4 - Stockage de la matrice de CAPACITE pour cet element fini
  185. C (remplissage de XMATRI)
  186. C =====
  187. CALL REMPMT(CAPV,NLIGR,RE(1,1,iElt))
  188. ENDDO
  189.  
  190. C 3 - MENAGE : DESACTIVATION/DESTRUCTION DE SEGMENTS
  191. C ====================================================
  192. 9990 CONTINUE
  193. SEGSUP,MMAT1
  194. c* SEGDES,MELEME,MINTE,XMATRI
  195. c* MPTVAL = IVAMAT
  196. c* SEGDES,MPTVAL
  197. c* IF (IVAPHA.NE.0) THEN
  198. c* MPTVAL = IVAPHA
  199. c* SEGDES,MPTVAL
  200. c* ENDIF
  201.  
  202. RETURN
  203. END
  204.  
  205.  
  206.  

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