forked from ESCOMP/CLUBB_CESM
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsigma_sqd_w_module.F90
66 lines (52 loc) · 2.22 KB
/
sigma_sqd_w_module.F90
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
!-------------------------------------------------------------------------
! $Id$
!===============================================================================
module sigma_sqd_w_module
implicit none
public :: compute_sigma_sqd_w
private ! Default scope
contains
!---------------------------------------------------------------------------------------------------
elemental function compute_sigma_sqd_w( gamma_Skw_fnc, wp2, thlp2, rtp2, wpthlp, wprtp ) &
result( sigma_sqd_w )
! Description:
! Compute the variable sigma_sqd_w (PDF width parameter)
!
! References:
! Eqn 22 in ``Equations for CLUBB''
!---------------------------------------------------------------------------------------------------
use constants_clubb, only: &
w_tol, & ! Constant(s)
rt_tol, &
thl_tol
use clubb_precision, only: &
core_rknd ! Variable(s)
implicit none
! External
intrinsic :: min, max, sqrt
! Input Variables
real( kind = core_rknd ), intent(in) :: &
gamma_Skw_fnc, & ! Gamma as a function of skewness [-]
wp2, & ! Variance of vertical velocity [m^2/s^2]
thlp2, & ! Variance of liquid pot. temp. [K^2]
rtp2, & ! Variance of total water [kg^2/kg^2]
wpthlp, & ! Flux of liquid pot. temp. [m/s K]
wprtp ! Flux of total water [m/s kg/kg]
! Output Variable
real( kind = core_rknd ) :: sigma_sqd_w ! PDF width parameter [-]
! ---- Begin Code ----
!----------------------------------------------------------------
! Compute sigma_sqd_w with new formula from Vince
!----------------------------------------------------------------
sigma_sqd_w = gamma_Skw_fnc * &
( 1.0_core_rknd - min( &
max( ( wpthlp / ( sqrt( wp2 * thlp2 ) &
+ 0.01_core_rknd * w_tol * thl_tol ) )**2, &
( wprtp / ( sqrt( wp2 * rtp2 ) &
+ 0.01_core_rknd * w_tol * rt_tol ) )**2 &
), & ! max
1.0_core_rknd ) & ! min - Known magic number (eq. 22 from "Equations for CLUBB")
)
return
end function compute_sigma_sqd_w
end module sigma_sqd_w_module