dhvdt
C DHVDT SOURCE CB215821 20/11/25 13:25:31 10792 SUBROUTINE DHVDT C C-------------------------------------------------------------------- C Enthalpie vapeur spécifique en fonction de P et de T: C dérivée partielle par rapport à la température C C Dans le cas ou seule la pression est fournie, on considère que la C pression P transmise est Psat et on calcule Tsat afin d'évaluer C la fonction derivée C-------------------------------------------------------------------- C Les données d'entrée sont des CHPOINT, des FLOTTANT ou des LISTREEL C Le résultat est du meme type que les input. C-------------------------------------------------------------------- C C--------------------------- C Phrase d'appel (GIBIANE) : C--------------------------- C C OBJ3 = VARI 'DHVDT' OBJ1 (OBJ2) ; C C------------------------ C Opérandes et résultat : C------------------------ C C OBJ1 : Pression partielle de vapeur (en Pa) C OBJ2 : Température (en K) C OBJ3 : Dérivée partielle de l'enthalpie spécifique de la vapeur C par rapport à la température (en J/kg/K) C C---------------------- C Variables principales C---------------------- C C ISAT : Flag valant 0 si 2 arguments, 1 sinon (T=Tsat(P)) C C----------------------------------------------------------------------- IMPLICIT INTEGER(I-N) IMPLICIT REAL*8 (A-H,O-Z) CHARACTER*8 TYPE CHARACTER*4 NOMTOT(1) C -INC SMCHPOI -INC SMLREEL C IFLAG = 0 ISAT = 0 C C- Lecture et controles des données d'entrée, C- Création de la structure chapeau pour la donnée de sortie C C- Gestion des ERREURS C 21 -> Données incompatibles C 19 -> Option indisponible C C CHPOINT C TYPE = 'CHPOINT ' IF (IRETOU.EQ.0) GOTO 10 IF (IRETOU.EQ.0) ISAT=1 C IF (ISAT.EQ.0) THEN SEGACT MCHPO1,MCHPO2 NSOUP1 = MCHPO1.IPCHP(/1) NSOUP2 = MCHPO2.IPCHP(/1) MSOUP1 = MCHPO1.IPCHP(1) MSOUP2 = MCHPO2.IPCHP(1) SEGACT MSOUP1,MSOUP2 NC1 = MSOUP1.NOHARM(/1) NC2 = MSOUP2.NOHARM(/1) IGEO1 = MSOUP1.IGEOC SEGACT MCHPO2,MSOUP2 MPOVA1 = MSOUP1.IPOVAL MPOVA2 = MSOUP2.IPOVAL SEGACT MPOVA1,MPOVA2 IF (NSOUP1.NE.NSOUP2) IFLAG=1 IF (NC1.NE.NC2) IFLAG=3 IF (NC1.NE.1) IFLAG=4 IF (IFLAG.NE.0) THEN RETURN ENDIF SEGINI, MCHPO3=MCHPO1 SEGINI, MSOUP3=MSOUP1 SEGINI, MPOVA3=MPOVA1 MCHPO3.IPCHP(1) = MSOUP3 MSOUP3.IPOVAL = MPOVA3 SEGDES MCHPO1,MCHPO2,MCHPO3,MSOUP1,MSOUP2,MSOUP3 SEGDES MPOVA1,MPOVA2,MPOVA3 ELSE SEGACT MCHPO1 NSOUP1 = MCHPO1.IPCHP(/1) MSOUP1 = MCHPO1.IPCHP(1) SEGACT MSOUP1 NC1 = MSOUP1.NOHARM(/1) MPOVA1 = MSOUP1.IPOVAL SEGACT MPOVA1 IF (NSOUP1.NE.1) IFLAG=2 IF (NC1.NE.1) IFLAG=4 IF (IFLAG.NE.0) THEN RETURN ENDIF SEGINI, MCHPO3=MCHPO1 SEGINI, MSOUP3=MSOUP1 SEGINI, MPOVA3=MPOVA1 MCHPO3.IPCHP(1) = MSOUP3 MSOUP3.IPOVAL = MPOVA3 SEGDES MCHPO1,MCHPO3,MSOUP1,MSOUP3 MPOVA2 = -1 SEGDES MPOVA1,MPOVA3 ENDIF RETURN C C FLOTTANT C 10 CONTINUE IF (IRETOU.EQ.0) GOTO 20 RETURN C C LISTREEL C 20 CONTINUE TYPE = 'LISTREEL' IF (IRETOU.EQ.0) GOTO 30 IF (IRETOU.EQ.0) ISAT=1 IF (ISAT.EQ.0) THEN SEGACT MLREE1,MLREE2 IF (JG1.NE.JG2) IFLAG=1 IF (IFLAG.NE.0) THEN RETURN ENDIF SEGINI, MLREE3=MLREE1 SEGDES MLREE1,MLREE2,MLREE3 ELSE SEGACT MLREE1 SEGINI, MLREE3=MLREE1 MLREE2 = -1 SEGDES MLREE1,MLREE3 ENDIF RETURN C C Autres C 30 CONTINUE RETURN END
© Cast3M 2003 - Tous droits réservés.
Mentions légales