source: trunk/LMDZ.GENERIC/libf/phystd/watercommon_h.F90 @ 937

Last change on this file since 937 was 875, checked in by jleconte, 12 years ago

11/02/2013 == JL

  • Updated moist convection scheme to handle situations with a large water vapor content
  • Added a keyword to enable ocean runoff in callphys.def (activerunoff)


File size: 5.6 KB
RevLine 
[728]1module watercommon_h
[135]2
3      implicit none
4
5      real, parameter :: T_coup = 234.0
[650]6      real, parameter :: T_h2O_ice_liq = 273.16
7      real, parameter :: T_h2O_ice_clouds = T_h2O_ice_liq-15.
[135]8      real, parameter :: mH2O = 18.01528   
9
[253]10      ! benjamin additions
[650]11      real, parameter :: RLVTT = 2.257E+6 ! Latent heat of vaporization (J kg-1)
[253]12      real, parameter :: RLSTT = 2.257E+6 ! 2.591E+6 in reality ! Latent heat of sublimation (J kg-1)
13
[650]14      real, parameter :: RLFTT = 3.334E+5 ! Latent heat of fusion (J kg-1) ! entails an energy sink but better description of albedo
[253]15      real, parameter :: rhowater = 1.0E+3 ! mass of water (kg/m^3)
[728]16      real, parameter :: rhowaterice = 9.2E+2 ! mass of water (kg/m^3)
[650]17      real, parameter :: capcal_h2o_liq = 4181.3 ! specific heat capacity of liquid water J/kg/K
[253]18      real, parameter :: mx_eau_sol = 150 ! mass of water (kg/m^2)
19
[650]20      real, save :: epsi, RCPD, RCPV, RV, RVTMP2
[728]21     
22      contains
[135]23
[728]24     
25!==================================================================
26      subroutine Psat_water(T,p,psat,qsat)
27
28         implicit none
29
30!==================================================================
31!     Purpose
32!     -------
33!     Compute the saturation vapor pressure and mass mixing ratio at saturation (kg/kg)
34!     for a given pressure (Pa) and temperature (K)
35!     Based on the Tetens formula from L.Li physical parametrization manual
36!
37!     Authors
38!     -------
39!     Jeremy Leconte (2012)
40!
41!==================================================================
42
43!        input
44         real, intent(in) :: T, p
45 
46!        output
47         real psat,qsat
48
49! JL12 variables for tetens formula
50         real,parameter :: Pref_solid_liquid=611.14
51         real,parameter :: Trefvaporization=35.86
52         real,parameter :: Trefsublimation=7.66
[786]53         real,parameter :: Tmin=8.
[728]54         real,parameter :: r3vaporization=17.269
55         real,parameter :: r3sublimation=21.875
56
57! checked vs. old watersat data 14/05/2012 by JL.
58
[786]59         if (T.gt.T_h2O_ice_liq) then
60            psat = Pref_solid_liquid*Exp(r3vaporization*(T-T_h2O_ice_liq)/(T-Trefvaporization)) ! liquid / vapour
61         else if (T.lt.Tmin) then
62            print*, "careful, T<Tmin in psat water"
63            psat = Pref_solid_liquid*Exp(r3sublimation*(Tmin-T_h2O_ice_liq)/(Tmin-Trefsublimation)) ! min psat 
64         else                 
65            psat = Pref_solid_liquid*Exp(r3sublimation*(T-T_h2O_ice_liq)/(T-Trefsublimation)) ! solid / vapour
[728]66         endif
67         if(psat.gt.p) then
68            qsat=1.
69         else
70            qsat=epsi*psat/(p-(1.-epsi)*psat)
71         endif
72         return
73      end subroutine Psat_water
74
75
76
77
78!==================================================================
[875]79      subroutine Lcpdqsat_water(T,p,psat,qsat,dqsat,dlnpsat)
[728]80
81         implicit none
82
83!==================================================================
84!     Purpose
85!     -------
[875]86!     Compute dqsat=L/cp*d (q_sat)/d T and dlnpsat=L/cp d(ln Psat)/d T
[728]87!     for a given temperature (K)!
88!     Based on the Tetens formula from L.Li physical parametrization manual
89!
90!     Authors
91!     -------
92!     Jeremy Leconte (2012)
93!
94!==================================================================
95
96!        input
97         real T, p, psat, qsat
98 
99!        output
[875]100         real dqsat,dlnpsat
[728]101
102! JL12 variables for tetens formula
103         real,parameter :: Pref_solid_liquid=611.14
104         real,parameter :: Trefvaporization=35.86
[786]105         real,parameter :: Tmin=8.
[728]106         real,parameter :: Trefsublimation=7.66
107         real,parameter :: r3vaporization=17.269
108         real,parameter :: r3sublimation=21.875
109
110         real :: dummy
111
112         if (psat.gt.p) then
113            dqsat=0.
114            return
115         endif
116
[786]117         if (T.gt.T_h2O_ice_liq) then
118            dummy = r3vaporization*(T_h2O_ice_liq-Trefvaporization)/(T-Trefvaporization)**2  ! liquid / vapour
119         else if (T.lt.Tmin) then
120            print*, "careful, T<Tmin in Lcp psat water"
121            dummy = r3sublimation*(T_h2O_ice_liq-Trefsublimation)/(Tmin-Trefsublimation)**2  ! solid / vapour
122         else               
123            dummy = r3sublimation*(T_h2O_ice_liq-Trefsublimation)/(T-Trefsublimation)**2  ! solid / vapour
[728]124         endif
125
[786]126         dqsat=RLVTT/RCPD*qsat*(p/(p-(1.-epsi)*psat))*dummy
[875]127         dlnpsat=RLVTT/RCPD*dummy
[728]128         return
129      end subroutine Lcpdqsat_water
130
131
132
133
134!==================================================================
135      subroutine Tsat_water(p,Tsat)
136
137         implicit none
138
139!==================================================================
140!     Purpose
141!     -------
142!     Compute the saturation temperature
143!     for a given pressure (Pa)
144!     Based on the Tetens formula from L.Li physical parametrization manual
145!
146!     Authors
147!     -------
148!     Jeremy Leconte (2012)
149!
150!==================================================================
151
152!        input
153         real p
154 
155!        output
156         real Tsat
157
158! JL12 variables for tetens formula
159         real,parameter :: Pref_solid_liquid=611.14
160         real,parameter :: Trefvaporization=35.86
161         real,parameter :: Trefsublimation=7.66
162         real,parameter :: r3vaporization=17.269
163         real,parameter :: r3sublimation=21.875
164
165         if (p.lt.Pref_solid_liquid) then ! solid / vapour
166            Tsat =(T_h2O_ice_liq*r3sublimation- Trefsublimation*Log(p/Pref_solid_liquid))/(r3sublimation-Log(p/Pref_solid_liquid))
167         else                 ! liquid / vapour
168            Tsat =(T_h2O_ice_liq*r3vaporization- Trefvaporization*Log(p/Pref_solid_liquid))/(r3vaporization-Log(p/Pref_solid_liquid))
169         endif
170
171         return
172      end subroutine Tsat_water
173
174
175end module watercommon_h
Note: See TracBrowser for help on using the repository browser.