92 use vrbls3d, only: zint, pint, t, q, zmid
93 use vrbls2d, only: slp, fis, z1000
95 use params_mod, only: rd, gi, g, h1, d608, gamma, d50, p1000
96 use ctlblk_mod
, only: jsta, jend, im, jm, spval
100 real,
PARAMETER :: zsl=0.0
101 real,
PARAMETER :: taucr=rd*gi*290.66,const=0.005*g/rd
102 real,
PARAMETER :: gord=g/rd,dp=60.e2
107 real zsfc,psfc,tvrt,tau,tvrsfc,tausfc,tvrsl,tausl,tauavg, &
108 alpavg,pavg,rhoavg,rrhog
121 llmh = nint(lmh(i,j))
123 if( pint(i,j,llmh+1)<spval)
then
125 zsfc = zint(i,j,llmh+1)
126 psfc = pint(i,j,llmh+1)
130 tvrt = t(i,j,llmh)*(h1+d608*q(i,j,llmh))
136 tvrsfc = tvrt + (zmid(i,j,llmh) - zsfc)*gamma
137 tausfc = tvrsfc*rd*gi
139 tvrsl = tvrt + (zmid(i,j,llmh) - zsl)*gamma
143 IF ((tausl>taucr).AND.(tausfc<=taucr))
THEN
145 ELSEIF ((tausl>taucr).AND.(tausfc>taucr))
THEN
146 tausl = taucr-const*(tausfc-taucr)**2
150 tauavg = d50*(tausl+tausfc)
153 IF (abs(fis(i,j))>1.0)slp(i,j) = psfc*exp(zsfc/tauavg)
156 alpavg = d50*(alog(psfc)+alog(slp(i,j)))
158 rhoavg = pavg*gi/tauavg
159 rrhog = h1/(rhoavg*g)
160 z1000(i,j) = (slp(i,j)-p1000)*rrhog