Télécharger cli22r.eso

Retour à la liste

Numérotation des lignes :

cli22r
  1. C CLI22R SOURCE OF166741 24/12/13 21:15:34 12097
  2. SUBROUTINE CLI22R(NSP,MELEMF,MELEMC,MELECB,MELEFC,INORM,ICHPVO,
  3. & ICHPSU,LRECP,LRECV,IPC,ICHLIM,ICHRES,ICHRLI)
  4. C************************************************************************
  5. C
  6. C PROJET : CASTEM 2000
  7. C
  8. C NOM : CLI22R
  9. C
  10. C DESCRIPTION : Subroutine appellée par CLIM22
  11. C calcul de RESIDU et CLIM at the board
  12. C OPTION: 'RESE' 2D, 3D
  13. C
  14. C LANGAGE : FORTRAN 77 + ESOPE 2000 (avec estensions CISI)
  15. C
  16. C AUTEUR : A. Beccantini, DEN/DM2S/SFME/LTMF
  17. C
  18. C************************************************************************
  19. C
  20. C APPELES (Calcul) :
  21. C
  22. C************************************************************************
  23. C
  24. C HISTORIQUE (Anomalies et modifications éventuelles)
  25. C
  26. C HISTORIQUE :
  27. C
  28. C************************************************************************
  29. C
  30. C We know everything outside
  31. C
  32. C 1) PC < PF
  33. C Condition de type reservoir
  34. C
  35. C 2) PC > PF
  36. C We stop the mass flux
  37. C We put zero velocity on the wall
  38. C We put P = PF at the wall
  39. C
  40. IMPLICIT INTEGER(I-N)
  41.  
  42. -INC PPARAM
  43. -INC CCOPTIO
  44. -INC SMLMOTS
  45. -INC SMELEME
  46. POINTEUR MELEFC.MELEME
  47. -INC SMLENTI
  48. POINTEUR MLEMC.MLENTI, MLEMCB.MLENTI,MLEMF.MLENTI
  49. -INC SMCHPOI
  50. POINTEUR MPNORM.MPOVAL, MPVOL.MPOVAL, MPSURF.MPOVAL,
  51. & MPPC.MPOVAL, MPLIM.MPOVAL,
  52. & MPRES.MPOVAL, MPRLI.MPOVAL
  53. C----------------------------------------
  54. INTEGER MELEMF,MELEMC,MELECB,INORM,ICHPVO,ICHPSU,IPC
  55. & ,ICHLIM,ICHRES,ICHRLI,ICEL,NFAC,IFAC
  56. & ,NGF,NGC,NLF,NLC,NLCB,LRECP,LRECV,I,NSP
  57. REAL*8 VOLU,SURF,PC,CNX,CNY,CNZ
  58. & ,RF,PF,PCR,TOP,BOT
  59. & ,GAMF
  60. & ,UN,RHO,P,UX,UY,UZ
  61. CHARACTER*(8) TYPE
  62. C------------------------------------------------------------
  63. -INC SMLREEL
  64. POINTEUR MLRECP.MLREEL, MLRECV.MLREEL
  65. C
  66. C-------------------------------------------------------------
  67. C******* Les fractionines massiques **************************
  68. C-------------------------------------------------------------
  69. SEGMENT FRAMAS
  70. REAL*8 YET(NSP)
  71. ENDSEGMENT
  72. POINTEUR YF.FRAMAS
  73. C------------------------------------------------------
  74. C**** KRIPAD pour la correspondance global/local
  75. C------------------------------------------------------
  76. CALL KRIPAD(MELEMC,MLEMC)
  77. CALL KRIPAD(MELECB,MLEMCB)
  78. CALL KRIPAD(MELEMF,MLEMF)
  79. C------------------------------------------------------
  80. C**** CHPOINTs de la table DOMAINE
  81. C------------------------------------------------------
  82. CALL LICHT(INORM,MPNORM,TYPE,ICEL)
  83. CALL LICHT(ICHPVO,MPVOL,TYPE,ICEL)
  84. CALL LICHT(ICHPSU,MPSURF,TYPE,ICEL)
  85. C------------------------------------------------------
  86. C**** CHPOINTs des variables
  87. C------------------------------------------------------
  88. CALL LICHT(IPC,MPPC,TYPE,ICEL)
  89. CALL LICHT(ICHLIM,MPLIM,TYPE,ICEL)
  90. CALL LICHT(ICHRES,MPRES,TYPE,ICEL)
  91. CALL LICHT(ICHRLI,MPRLI,TYPE,ICEL)
  92.  
  93. C---------------------------------------------------------
  94. C**** Boucle sur le face pour le calcul du flux
  95. C---------------------------------------------------------
  96.  
  97. MLRECV = LRECV
  98. MLRECP = LRECP
  99.  
  100. SEGACT MLRECV
  101. SEGACT MLRECP
  102. SEGACT MELEFC
  103. SEGINI YF
  104.  
  105. NFAC=MELEFC.NUM(/2)
  106. CNZ=0.0D0
  107. DO 1 IFAC=1,NFAC,1
  108. NGF=MELEFC.NUM(1,IFAC)
  109. NGC=MELEFC.NUM(2,IFAC)
  110. NLF=MLEMF.LECT(NGF)
  111. NLC=MLEMC.LECT(NGC)
  112. NLCB=MLEMCB.LECT(NGF)
  113. VOLU=MPVOL.VPOCHA(NLC,1)
  114. SURF=MPSURF.VPOCHA(NLF,1)
  115. C----------------------------------------------
  116. C In CASTEM les normales sont sortantes
  117. C----------------------------------------------
  118. CNX=-1*MPNORM.VPOCHA(NLF,1)
  119. CNY=-1*MPNORM.VPOCHA(NLF,2)
  120. IF(IDIM.EQ.3)THEN
  121. CNZ=-1*MPNORM.VPOCHA(NLF,3)
  122. ENDIF
  123. C----------------------------
  124. C Variables au centre
  125. C----------------------------
  126. PC=MPPC.VPOCHA(NLC,1)
  127. C----------------------------
  128. C Variables à la face
  129. C----------------------------
  130. RF=MPLIM.VPOCHA(NLCB,1)
  131. PF=MPLIM.VPOCHA(NLCB,2)
  132. DO 101 I=1,(NSP-1)
  133. YF.YET(I)=MPLIM.VPOCHA(NLCB,2+I)
  134. 101 CONTINUE
  135. c-------------------------------------------------------------
  136. c Computing GAMMA at the face-center
  137. c-------------------------------------------------------------
  138. top=0.0D0
  139. bot=0.0D0
  140. do 103 i=1,(nsp-1)
  141. top=top+yf.yet(i)*(MLRECP.PROG(i)-MLRECP.PROG(nsp))
  142. bot=bot+yf.yet(i)*(MLRECV.PROG(i)-MLRECV.PROG(nsp))
  143. 103 continue
  144. top=MLRECP.PROG(nsp)+top
  145. bot=MLRECV.PROG(nsp)+bot
  146. GAMF=top/bot
  147. C----------------------------------------
  148. C******* PCR, P, RHO and UN on the border
  149. C----------------------------------------
  150. IF(PF .LT. PC)THEN
  151. C
  152. C P_{interface}=PF
  153. C \rho_{interface}=RF
  154. C U_{interface}=0.0D0
  155. C Y_{interface}=YF
  156. C
  157. MPRLI.VPOCHA(NLCB,1)=RF
  158. MPRLI.VPOCHA(NLCB,2)=0.0D0
  159. MPRLI.VPOCHA(NLCB,3)=0.0D0
  160. IF(IDIM.EQ.3) MPRLI.VPOCHA(NLCB,4)=0.0D0
  161. MPRLI.VPOCHA(NLCB,IDIM+2)=PF
  162. do 104 i=1,(nsp-1),1
  163. MPRLI.VPOCHA(NLCB,IDIM+2+I)=YF.YET(I)
  164. 104 continue
  165. MPRES.VPOCHA(IFAC,1)=0.0D0
  166. MPRES.VPOCHA(IFAC,2)=(PC*CNX)*SURF/VOLU
  167. MPRES.VPOCHA(IFAC,3)=(PC*CNY)*SURF/VOLU
  168. IF(IDIM.EQ.3)
  169. & MPRES.VPOCHA(IFAC,4)=(PC*CNZ)*SURF/VOLU
  170. MPRES.VPOCHA(IFAC,IDIM+2)=0.0D0
  171. do 105 i=1,(nsp-1),1
  172. MPRES.VPOCHA(IFAC,IDIM+2+I)=0.0D0
  173. 105 continue
  174. ELSE
  175. PCR=PF*((2.0D0/(GAMF+1.0D0))**((GAMF/(GAMF-1.0D0))))
  176. P=MAX(PCR,PC)
  177. RHO=(P/PF)**(1.0D0/GAMF)
  178. RHO=RHO*RF
  179. C
  180. UN=(2*GAMF)/(GAMF-1.0D0)
  181. UN=UN*((PF/RF)-(P/RHO))
  182. UN=MAX(UN,1.0D-16*((P/RHO)*0.5D0))
  183. UN=UN**0.5D0
  184. C
  185. UX=UN*CNX
  186. UY=UN*CNY
  187. UZ=UN*CNZ
  188. C
  189. MPRLI.VPOCHA(NLCB,1)=RHO
  190. MPRLI.VPOCHA(NLCB,2)=UX
  191. MPRLI.VPOCHA(NLCB,3)=UY
  192. IF(IDIM.EQ.3) MPRLI.VPOCHA(NLCB,4)=UZ
  193. MPRLI.VPOCHA(NLCB,IDIM+2)=P
  194. do 106 i=1,(nsp-1),1
  195. MPRLI.VPOCHA(NLCB,IDIM+2+I)=YF.YET(I)
  196. 106 continue
  197. C-------------------------------------------------------
  198. C******* Residuum (son SPG a le meme ordre que MELEFC)
  199. C-------------------------------------------------------
  200. MPRES.VPOCHA(IFAC,1)=RHO*UN*SURF/VOLU
  201. MPRES.VPOCHA(IFAC,2)=(RHO*UN*UX+(P*CNX))*SURF/VOLU
  202. MPRES.VPOCHA(IFAC,3)=(RHO*UN*UY+(P*CNY))*SURF/VOLU
  203. IF(IDIM.EQ.3)
  204. & MPRES.VPOCHA(IFAC,4)=(RHO*UN*UZ+(P*CNZ))*SURF/VOLU
  205. MPRES.VPOCHA(IFAC,IDIM+2)=((UN*GAMF*P/(GAMF-1.0D0)) +
  206. & (0.5D0*RHO*UN*UN*UN))*SURF/VOLU
  207. do 107 i=1,(nsp-1)
  208. MPRES.VPOCHA(IFAC,IDIM+2+I)=RHO*YF.YET(I)*UN*SURF/VOLU
  209. 107 continue
  210. ENDIF
  211. 1 CONTINUE
  212. C
  213. SEGDES MELEFC
  214. C
  215. SEGSUP MLEMC
  216. SEGSUP MLEMCB
  217. SEGSUP MLEMF
  218. SEGSUP YF
  219. C
  220. C
  221. SEGDES MPNORM
  222. SEGDES MPVOL
  223. SEGDES MPSURF
  224. SEGDES MPPC
  225. SEGDES MPLIM
  226. SEGDES MPRES
  227. SEGDES MPRLI
  228. SEGDES MLRECP
  229. SEGDES MLRECV
  230. C
  231. 9999 CONTINUE
  232. RETURN
  233. END
  234.  
  235.  
  236.  
  237.  
  238.  
  239.  

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