Télécharger capac1.eso

Retour à la liste

Numérotation des lignes :

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

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