53 subroutine calwxt_bourg_post(im,jm,jsta_2l,jend_2u,jsta,jend,lm,lp1, &
55 & t,q,pmid,pint,lmh,prec,zint,ptype,me)
59 integer,
intent(in):: im,jm,jsta_2l,jend_2u,jsta,jend,lm,lp1,iseed,me
60 real,
intent(in):: g,pthresh
61 real,
intent(in),
dimension(im,jsta_2l:jend_2u,lm) :: t, q, pmid
62 real,
intent(in),
dimension(im,jsta_2l:jend_2u,lp1) :: pint, zint
63 real,
intent(in),
dimension(im,jsta_2l:jend_2u) :: lmh, prec
67 integer,
intent(out) :: ptype(im,jsta:jend)
69 integer i,j,ifrzl,iwrml,l,lhiwrm,lmhk,jlen
70 real pintk1,areane,tlmhk,areape,pintk2,surfw,area1,dzkl,psfck,r1,r2
72 integer :: rn_seed_size
73 integer,
allocatable,
dimension(:) :: rn_seed
74 logical,
parameter :: debugprint = .false.
80 print *,
'in calwxtbg, jsta,jend=',jsta,jend,
' im=',im
81 print *,
'in calwxtbg,me=',me,
'iseed=',iseed
91 jlen = jend - jsta + 1
93 call random_seed(
size = rn_seed_size)
94 allocate(rn_seed(rn_seed_size))
96 call random_seed(put = rn_seed)
97 call random_number(rn)
107 lmhk = min(nint(lmh(i,j)),lm)
108 psfck = pint(i,j,lmhk+1)
110 if (prec(i,j) <= pthresh) cycle
118 if (tlmhk >= 273.15)
then
120 if (t(i,j,l) >= 273.15 .and. t(i,j,l-1) < 273.15 .and. &
121 & iwrml == lmhk+1) iwrml = l
131 if (t(i,j,l) >= 273.15 .and. pmid(i,j,l) > 25000.) lhiwrm = l
154 if (ifrzl == 0.and.t(i,j,l) <= 273.15) ifrzl = 1
156 dzkl = zint(i,j,l)-zint(i,j,l+1)
157 area1 = log(t(i,j,l)/273.15) * g * dzkl
158 if (t(i,j,l) >= 273.15.and. pmid(i,j,l) > 25000.)
then
159 if (l < iwrml) areape = areape + area1
160 if (l >= iwrml) surfw = surfw + area1
162 if (l > lhiwrm) areane = areane + abs(area1)
169 if (areape < 2.0)
then
172 if (surfw < 5.6)
then
176 else if (surfw > 13.2)
then
194 if (areane > 66.0+0.66*areape)
then
198 if (surfw < 5.6)
then
201 else if (surfw > 13.2)
then
214 else if (areane < 46.0+0.66*areape)
then
217 if (tlmhk < 273.15)
then
229 if (surfw < 5.6)
then
231 else if (surfw > 13.2)
then
236 r2 = rn(i+im*(j-1)+im*jm)
246 if (tlmhk < 273.15)
then