79 itf,ktf,its,ite, kts,kte &
80 ,dicycle & ! diurnal cycle flag
81 ,ichoice & ! choice of closure, use "0" for ensemble average
82 ,ipr & ! this flag can be used for debugging prints
83 ,ccn & ! not well tested yet
85 ,dtime & ! dt over which forcing is applied
86 ,imid & ! flag to turn on mid level convection
87 ,kpbl & ! level of boundary layer height
88 ,dhdt & ! boundary layer forcing (one closure for shallow)
133 ,do_smoke_transport &
144 ,do_capsuppress,cap_suppress_j &
152 nranflag,itf,ktf,its,ite, kts,kte,ipr,imid,kdt
153 integer,
intent (in ) :: &
155 real(kind=kind_phys),
dimension (its:ite,4) &
156 ,
intent (in ) :: rand_clos
157 real(kind=kind_phys),
dimension (its:ite) &
158 ,
intent (in ) :: rand_mom,rand_vmas
161 integer,
intent(in) :: do_capsuppress
162 real(kind=kind_phys),
intent(in),
dimension(:),
optional :: cap_suppress_j
167 real(kind=kind_phys),
dimension (its:ite,1:maxens3) :: xf_ens,pr_ens
173 real(kind=kind_phys),
dimension (its:ite,kts:kte) &
174 ,
intent (inout ) :: &
175 cnvwt,outu,outv,outt,outq,outqc,cupclw
176 real(kind=kind_phys),
dimension (its:ite) &
179 real(kind=kind_phys),
dimension (its:ite) &
180 ,
intent (inout ) :: &
183 real(kind=kind_phys),
dimension (its:ite) &
185 mc_thresh,hfx,qfx,xmbm_in,xmbs_in
187 integer,
dimension (its:ite) &
188 ,
intent (inout ) :: &
191 integer,
dimension (its:ite) &
200 real(kind=kind_phys),
dimension (its:ite,kts:kte) &
202 dhdt,rho,t,po,us,vs,tn
204 real(kind=kind_phys),
dimension (its:ite,kts:kte) &
205 ,
intent (inout ) :: &
208 real(kind=kind_phys),
dimension (its:ite,kts:kte) &
212 real(kind=kind_phys),
dimension (its:ite) &
216 real(kind=kind_phys),
dimension (its:ite) &
217 ,
intent (inout ) :: &
220 real(kind=kind_phys),
dimension (:,:,:) &
221 ,
intent (inout),
optional :: &
223 logical,
intent (in) :: do_smoke_transport
224 real(kind=kind_phys),
dimension (:,:) &
225 ,
intent (out),
optional :: wetdpc_deep
226 real(kind=kind_phys),
intent (in) :: fscav(:)
229 real(kind=kind_phys) &
237 real(kind=kind_phys),
dimension (its:ite,1) :: &
239 real(kind=kind_phys),
dimension (its:ite,1) :: &
241 real(kind=kind_phys),
dimension (its:ite,kts:kte,1) :: &
242 dellat_ens,dellaqc_ens,dellaq_ens,pwo_ens
309 real(kind=kind_phys),
dimension (its:ite,kts:kte,nchem) :: &
311 real(kind=kind_phys),
dimension (its:ite,kts:kte,nchem) :: &
312 chem_cup,chem_up,chem_down,dellac,dellac2,chem_c,chem_pw,chem_pwd
313 real(kind=kind_phys),
dimension (its:ite,nchem) :: &
315 real(kind=kind_phys):: dtime_max,sum1,sum2
316 real(kind=kind_phys),
dimension (kts:kte) :: trac,trcflx_in,trcflx_out,trc,trco
317 real(kind=kind_phys),
dimension (its:ite,kts:kte) :: pwdper, massflx
322 real(kind=kind_phys),
dimension (its:ite,kts:kte) :: &
323 entr_rate_2d,mentrd_rate_2d,he,hes,qes,z, heo,heso,qeso,zo, &
324 xhe,xhes,xqes,xz,xt,xq,qes_cup,q_cup,he_cup,hes_cup,z_cup, &
325 p_cup,gamma_cup,t_cup, qeso_cup,qo_cup,heo_cup,heso_cup, &
326 zo_cup,po_cup,gammao_cup,tn_cup, &
327 xqes_cup,xq_cup,xhe_cup,xhes_cup,xz_cup, &
328 xt_cup, dby,hc,zu,clw_all, &
329 dbyo,qco,qrcdo,pwdo,pwo,hcdo,qcdo,dbydo,hco,qrco, &
338 cd,cdd,dellah,dellaq,dellat,dellaqc, &
339 u_cup,v_cup,uc,vc,ucd,vcd,dellu,dellv
359 real(kind=kind_phys),
dimension (its:ite) :: &
360 edt,edto,edtm,aa1,aa0,xaa0,hkb, &
363 pwevo,bu,bud,cap_max, &
364 cap_max_increment,closure_n,psum,psumh,sig,sigd
365 real(kind=kind_phys),
dimension (its:ite) :: &
366 axx,edtmax,edtmin,entr_rate
367 integer,
dimension (its:ite) :: &
368 kzdown,kdet,k22,jmin,kstabi,kstabm,k22x,xland1, &
369 ktopdby,kbconx,ierr2,ierr3,kbmax
379 integer,
dimension (its:ite),
intent(inout) :: ierr
380 integer,
dimension (its:ite),
intent(in),
optional :: csum
383 iloop,nens3,ki,kk,i,k
384 real(kind=kind_phys) :: &
385 dz,dzo,mbdt,radius, &
386 zcutdown,depth_min,zkbmax,z_detr,zktop, &
387 dh,cap_maxs,trash,trash2,frh,sig_thresh
388 real(kind=kind_phys),
dimension (its:ite) :: pefc
389 real(kind=kind_phys) entdo,dp,subin,detdo,entup, &
390 detup,subdown,entdoj,entupk,detupk,totmas
392 real(kind=kind_phys),
dimension (its:ite) :: lambau,flux_tun,zws,ztexec,zqexec
395 integer :: jprnt,jmini,start_k22
396 logical :: keep_going,flg(its:ite)
399 character*50 :: ierrc(its:ite)
400 character*4 :: cumulus
401 real(kind=kind_phys),
dimension (its:ite,kts:kte) :: &
402 up_massentr,up_massdetr,c1d &
403 ,up_massentro,up_massdetro,dd_massentro,dd_massdetro
404 real(kind=kind_phys),
dimension (its:ite,kts:kte) :: &
405 up_massentru,up_massdetru,dd_massentru,dd_massdetru
408 real(kind=kind_phys) c1_max,buo_flux,pgcon,pgc,blqe
410 real(kind=kind_phys) :: xff_mid(its:ite,2)
412 integer :: iversion=1
413 real(kind=kind_phys) :: denom,h_entr,umean,t_star,dq
414 integer,
intent(in) :: dicycle
415 real(kind=kind_phys),
dimension (its:ite) :: aa1_bl,hkbo_bl,tau_bl,tau_ecmwf,wmean
416 real(kind=kind_phys),
dimension (its:ite,kts:kte) :: tn_bl, qo_bl, qeso_bl, heo_bl, heso_bl &
417 ,qeso_cup_bl,qo_cup_bl, heo_cup_bl,heso_cup_bl &
418 ,gammao_cup_bl,tn_cup_bl,hco_bl,dbyo_bl
419 real(kind=kind_phys),
dimension(its:ite) :: xf_dicycle
424 real(kind=kind_phys),
intent(inout),
dimension(its:ite,10) :: forcing
426 integer :: turn,pmin_lev(its:ite),start_level(its:ite),ktopkeep(its:ite)
427 real(kind=kind_phys),
dimension (its:ite,kts:kte) :: dtempdz
428 integer,
dimension (its:ite,kts:kte) :: k_inv_layers
429 real(kind=kind_phys),
dimension (its:ite) :: c0, rrfs_factor
430 real(kind=kind_phys),
dimension (its:ite,kts:kte) :: c0t3d
434 real(kind=kind_phys) zuh2(40)
435 real(kind=kind_phys),
dimension (its:ite) :: rntot,delqev,delq2,qevap,rn,qcond
437 real(kind=kind_phys) :: rain,t1,q1,elocp,evef,el2orc,evfact,evfactl,g_rain,e_dn,c_up
438 real(kind=kind_phys) :: pgeoh,dts,fp,fpi,pmin,x_add,beta,beta_u
439 real(kind=kind_phys) :: cbeg,cmid,cend,const_a,const_b,const_c
442 real(kind=kind_phys),
dimension (its:ite,kts:kte) :: p_liq_ice,melting_layer,melting
449 melting_layer(:,:)=0.
455 if(imid.eq.1)cumulus=
'mid'
457 if(imid.eq.1)pmin=75.
463 el2orc=xlv*xlv/(r_v*cp)
476 if(imid.eq.1)lambau(:)=2.0
478 if(nranflag == 1)
then
479 lambau(:)=1.5+rand_mom(:)
492 xland1(i)=int(xland(i)+.0001)
493 if(xland(i).gt.1.5 .or. xland(i).lt.0.5)
then
496 if(xland1(i).eq.1)c0(i)=0.002
512 buo_flux= (hfx(i)/cp+0.608*t(i,1)*qfx(i)/xlv)/rho(i,1)
515 zws(i) = max(0.,flux_tun(i)*0.41*buo_flux*zo(i,2)*g/t(i,1))
516 if(zws(i) > tiny(pgeoh))
then
518 zws(i) = 1.2*zws(i)**.3333
520 ztexec(i) = max(flux_tun(i)*hfx(i)/(rho(i,1)*zws(i)*cp),0.0)
522 zqexec(i) = max(flux_tun(i)*qfx(i)/xlv/(rho(i,1)*zws(i)),0.)
526 zws(i) = max(0.,.001-flux_tun(i)*0.41*buo_flux*zo(i,kpbl(i))*g/t(i,kpbl(i)))
527 zws(i) = 1.2*zws(i)**.3333
528 zws(i) = zws(i)*rho(i,kpbl(i))
538 cap_max_increment(i)=20.
542 if (xland1(i)==0)
then
543 cap_max_increment(i)=20.
545 if(ztexec(i).gt.0.)cap_max(i)=cap_max(i)+25.
546 if(ztexec(i).lt.0.)cap_max(i)=cap_max(i)-25.
553 if(use_excess == 0 )
then
559 if(do_capsuppress == 1)
then
563 if (abs(cap_suppress_j(i) - 1.0 ) < 0.1 )
then
564 cap_max(i)=cap_maxs+75.
565 elseif (abs(cap_suppress_j(i) - 0.0 ) < 0.1 )
then
586 if(imid.eq.1)entr_rate(i)=3.e-4
587 radius=.2/entr_rate(i)
588 frh=min(1.,3.14*radius*radius/dx(i)/dx(i))
589 if(frh > frh_thresh)
then
591 radius=sqrt(frh*dx(i)*dx(i)/3.14)
592 entr_rate(i)=.2/radius
596 if(forcing(i,7).eq.0.)sig(i)=1.
600 sig_thresh = (1.-frh_thresh)**2
618 cd(i,k)=.1*entr_rate(i)
619 if(imid.eq.1)cd(i,k)=.5*entr_rate(i)
643 if(imid.eq.1)depth_min=2500.
664 if(imid.eq.1)zkbmax=2000.
689 call cup_env(z,qes,he,hes,t,q,po,z1, &
690 psur,ierr,tcrit,-1, &
693 call cup_env(zo,qeso,heo,heso,tn,qo,po,z1, &
694 psur,ierr,tcrit,-1, &
701 call cup_env_clev(t,qes,q,he,hes,z,po,qes_cup,q_cup,he_cup, &
702 hes_cup,z_cup,p_cup,gamma_cup,t_cup,psur, &
706 call cup_env_clev(tn,qeso,qo,heo,heso,zo,po,qeso_cup,qo_cup, &
707 heo_cup,heso_cup,zo_cup,po_cup,gammao_cup,tn_cup,psur, &
714 itf,ktf,its,ite,kts,kte,cumulus)
719 if(kpbl(i).gt.5 .and. imid.eq.1)cap_max(i)=po_cup(i,kpbl(i))
720 u_cup(i,kts)=us(i,kts)
721 v_cup(i,kts)=vs(i,kts)
723 u_cup(i,k)=.5*(us(i,k-1)+us(i,k))
724 v_cup(i,k)=.5*(vs(i,k-1)+vs(i,k))
731 if(zo_cup(i,k).gt.zkbmax+z1(i))
then
741 if(zo_cup(i,k).gt.z_detr+z1(i))
then
761 k22(i)=maxloc(heo_cup(i,start_k22:kbmax(i)+2),1)+start_k22-1
762 if(k22(i).ge.kbmax(i))
then
765 ierrc(i)=
"could not find k22"
782 x_add = xlv*zqexec(i)+cp*ztexec(i)
783 call get_cloud_bc(kte,he_cup(i,1:kte),hkb(i),k22(i),x_add)
784 call get_cloud_bc(kte,heo_cup(i,1:kte),hkbo(i),k22(i),x_add)
792 call cup_kbcon(ierrc,cap_max_increment,iloop,k22,kbcon,heo_cup,heso_cup, &
793 hkbo,ierr,kbmax,po_cup,cap_max, &
797 z_cup,entr_rate,heo,imid)
801 call cup_minimi(heso_cup,kbcon,kstabm,kstabi,ierr, &
807 frh = min(qo_cup(i,kbcon(i))/qeso_cup(i,kbcon(i)),1.)
808 if(frh >= rh_thresh .and. sig(i) <= sig_thresh )
then
818 if(po(i,kbcon(i))-po(i,k) > pmin+x_add)
then
826 start_level(i)=k22(i)
827 x_add = xlv*zqexec(i)+cp*ztexec(i)
828 call get_cloud_bc(kte,he_cup(i,1:kte),hkb(i),k22(i),x_add)
838 kbcon,kstabi,dtempdz,itf,ktf,its,ite, kts,kte)
842 if(kstabi(i).lt.kbcon(i))
then
847 entr_rate_2d(i,k)=entr_rate(i)
850 kbcon(i)=max(2,kbcon(i))
852 frh = min(qo_cup(i,k)/qeso_cup(i,k),1.)
853 entr_rate_2d(i,k)=entr_rate(i) *(1.3-frh)
856 if(k_inv_layers(i,2).gt.0 .and. &
857 (po_cup(i,k22(i))-po_cup(i,k_inv_layers(i,2))).lt.500.)
then
859 ktop(i)=min(kstabi(i),k_inv_layers(i,2))
864 if((po_cup(i,k22(i))-po_cup(i,k)).gt.500.)
then
884 call rates_up_pdf(rand_vmas,ipr,
'mid',ktop,ierr,po_cup,entr_rate_2d,hkbo,heo,heso_cup,zo_cup, &
885 xland1,kstabi,k22,kbcon,its,ite,itf,kts,kte,ktf,zuo,kpbl,ktopdby,csum,pmin_lev)
887 call rates_up_pdf(rand_vmas,ipr,
'deep',ktop,ierr,po_cup,entr_rate_2d,hkbo,heo,heso_cup,zo_cup, &
888 xland1,kstabi,k22,kbcon,its,ite,itf,kts,kte,ktf,zuo,kbcon,ktopdby,csum,pmin_lev)
924 ,ierr,ktop,zo_cup,zuo,cd,entr_rate_2d &
925 ,up_massentro, up_massdetro ,up_massentr, up_massdetr &
926 ,3,kbcon,k22,up_massentru,up_massdetru,lambau)
929 ,ierr,ktop,zo_cup,zuo,cd,entr_rate_2d &
930 ,up_massentro, up_massdetro ,up_massentr, up_massdetr &
931 ,1,kbcon,k22,up_massentru,up_massdetru,lambau)
952 do k=1,start_level(i)
956 do k=1,start_level(i)-1
958 hco(i,k)=heo_cup(i,k)
975 if(ierr(i) /= 0) cycle
978 do k=start_level(i) +1,ktop(i)
980 denom=zuo(i,k-1)-.5*up_massdetro(i,k-1)+up_massentro(i,k-1)
981 if(denom.lt.1.e-8)
then
985 hco(i,k)=(hco(i,k-1)*zuo(i,k-1)-.5*up_massdetro(i,k-1)*hco(i,k-1)+ &
986 up_massentro(i,k-1)*heo(i,k-1)) / &
987 (zuo(i,k-1)-.5*up_massdetro(i,k-1)+up_massentro(i,k-1))
988 dbyo(i,k)=hco(i,k)-heso_cup(i,k)
992 do k=ktop(i)-1,kbcon(i),-1
993 if(dbyo(i,k).gt.0.)
then
1004 if(ierr(i).eq.0)
then
1005 zktop=(zo_cup(i,ktop(i))-z1(i))*.6
1006 if(imid.eq.1)zktop=(zo_cup(i,ktop(i))-z1(i))*.4
1007 zktop=min(zktop+z1(i),zcutdown+z1(i))
1010 if(zo_cup(i,k).gt.zktop)
then
1012 kzdown(i)=min(kzdown(i),kstabi(i)-1)
1023 call cup_minimi(heso_cup,k22,kzdown,jmin,ierr, &
1028 if(ierr(i).eq.0)
then
1039 do while ( keep_going )
1040 keep_going = .false.
1041 if ( jmini - 1 .lt. kdet(i) ) kdet(i) = jmini-1
1042 if ( jmini .ge. ktop(i)-1 ) jmini = ktop(i) - 2
1044 hcdo(i,ki)=heso_cup(i,ki)
1045 dz=zo_cup(i,ki+1)-zo_cup(i,ki)
1049 hcdo(i,k)=heso_cup(i,jmini)
1050 dz=zo_cup(i,k+1)-zo_cup(i,k)
1051 dh=dh+dz*(hcdo(i,k)-heso_cup(i,k))
1054 if ( jmini .gt. 5 )
then
1059 ierrc(i) =
"could not find jmini9"
1067 if ( jmini .le. 5 )
then
1070 ierrc(i) =
"could not find jmini4"
1076 if(ierr(i) /= 0) cycle
1079 hco(i,k)=heso_cup(i,k)
1089 p_cup,kbcon,ktop,dbyo,clw_all,xland1, &
1090 qo,gammao_cup,zuo,qeso_cup,k22,qo_cup,c0,c0t3d, &
1091 zqexec,ccn,ccnclean,rho,c1d,tn_cup,autoconv,up_massentr,up_massdetr,psum,psumh, &
1096 p_cup,kbcon,ktop,dbyo,clw_all,xland1, &
1097 qo,gammao_cup,zuo,qeso_cup,k22,qo_cup,c0,c0t3d, &
1098 zqexec,ccn,ccnclean,rho,c1d,tn_cup,autoconv,up_massentr,up_massdetr,psum,psumh, &
1109 if(ierr(i) /= 0) cycle
1112 do k=start_level(i) +1,ktop(i)
1114 denom=zuo(i,k-1)-.5*up_massdetro(i,k-1)+up_massentro(i,k-1)
1115 if(denom.lt.1.e-8)
then
1120 hc(i,k)=(hc(i,k-1)*zu(i,k-1)-.5*up_massdetr(i,k-1)*hc(i,k-1)+ &
1121 up_massentr(i,k-1)*he(i,k-1)) / &
1122 (zu(i,k-1)-.5*up_massdetr(i,k-1)+up_massentr(i,k-1))
1123 uc(i,k)=(uc(i,k-1)*zu(i,k-1)-.5*up_massdetru(i,k-1)*uc(i,k-1)+ &
1124 up_massentru(i,k-1)*us(i,k-1) &
1125 -pgcon*.5*(zu(i,k)+zu(i,k-1))*(u_cup(i,k)-u_cup(i,k-1))) / &
1126 (zu(i,k-1)-.5*up_massdetru(i,k-1)+up_massentru(i,k-1))
1127 vc(i,k)=(vc(i,k-1)*zu(i,k-1)-.5*up_massdetru(i,k-1)*vc(i,k-1)+ &
1128 up_massentru(i,k-1)*vs(i,k-1) &
1129 -pgcon*.5*(zu(i,k)+zu(i,k-1))*(v_cup(i,k)-v_cup(i,k-1))) / &
1130 (zu(i,k-1)-.5*up_massdetru(i,k-1)+up_massentru(i,k-1))
1131 dby(i,k)=hc(i,k)-hes_cup(i,k)
1132 hco(i,k)=(hco(i,k-1)*zuo(i,k-1)-.5*up_massdetro(i,k-1)*hco(i,k-1)+ &
1133 up_massentro(i,k-1)*heo(i,k-1)) / &
1134 (zuo(i,k-1)-.5*up_massdetro(i,k-1)+up_massentro(i,k-1))
1139 hc(i,k)= hc(i,k)+(1.-p_liq_ice(i,k))*qrco(i,k)*xlf
1140 hco(i,k)= hco(i,k)+(1.-p_liq_ice(i,k))*qrco(i,k)*xlf
1142 dby(i,k)=hc(i,k)-hes_cup(i,k)
1144 dbyo(i,k)=hco(i,k)-heso_cup(i,k)
1145 dz=zo_cup(i,k+1)-zo_cup(i,k)
1146 dbyt(i,k)=dbyt(i,k-1)+dbyo(i,k)*dz
1150 kk=maxloc(dbyt(i,:),1)
1151 ki=maxloc(zuo(i,:),1)
1154 do k=ktop(i)-1,kbcon(i),-1
1155 if(dbyo(i,k).gt.0.)
then
1166 if(ierr(i) /= 0) cycle
1168 hc(i,k)=hes_cup(i,k)
1171 hco(i,k)=heso_cup(i,k)
1177 entr_rate_2d(i,k)=0.
1180 up_massentro(i,k)=0.
1181 up_massdetro(i,k)=0.
1187 if(ktop(i).lt.kbcon(i)+2)
then
1190 ierrc(i)=
'ktop too small deep'
1202 if(ierr(i).eq.0)
then
1203 if ( jmin(i) - 1 .lt. kdet(i) ) kdet(i) = jmin(i)-1
1204 if(-zo_cup(i,kbcon(i))+zo_cup(i,ktop(i)).lt.depth_min)
then
1207 ierrc(i)=
"cloud depth very shallow"
1223 dd_massentro(i,k)=0.
1224 dd_massdetro(i,k)=0.
1225 dd_massentru(i,k)=0.
1226 dd_massdetru(i,k)=0.
1227 hcdo(i,k)=heso_cup(i,k)
1231 mentrd_rate_2d(i,k)=entr_rate(i)
1239 beta=max(.025,.055-float(csum(i))*.0015)
1240 if(imid.eq.1)beta=.025
1242 cdd(i,1:jmin(i))=.1*entr_rate(i)
1244 dd_massdetro(i,:)=0.
1245 dd_massentro(i,:)=0.
1246 call get_zu_zd_pdf_fim(0,po_cup(i,:),rand_vmas(i),0.0_kind_phys,ipr,xland1(i),zuh2,4, &
1247 ierr(i),kdet(i),jmin(i)+1,zdo(i,:),kts,kte,ktf,beta,kpbl(i),csum(i),pmin_lev(i))
1248 if(zdo(i,jmin(i)) .lt.1.e-8)
then
1251 cdd(i,jmin(i):ktf)=0.
1252 zdo(i,jmin(i)+1:ktf)=0.
1253 if(zdo(i,jmin(i)) .lt.1.e-8)
then
1259 itemp = maxloc(zdo(i,:),1)
1260 do ki=jmin(i) , itemp,-1
1262 dzo=zo_cup(i,ki+1)-zo_cup(i,ki)
1263 dd_massdetro(i,ki)=cdd(i,ki)*dzo*zdo(i,ki+1)
1264 dd_massentro(i,ki)=zdo(i,ki)-zdo(i,ki+1)+dd_massdetro(i,ki)
1265 if(dd_massentro(i,ki).lt.0.)
then
1266 dd_massentro(i,ki)=0.
1267 dd_massdetro(i,ki)=zdo(i,ki+1)-zdo(i,ki)
1268 if(zdo(i,ki+1).gt.0.)cdd(i,ki)=dd_massdetro(i,ki)/(dzo*zdo(i,ki+1))
1270 if(zdo(i,ki+1).gt.0.)mentrd_rate_2d(i,ki)=dd_massentro(i,ki)/(dzo*zdo(i,ki+1))
1272 mentrd_rate_2d(i,1)=0.
1275 dzo=zo_cup(i,ki+1)-zo_cup(i,ki)
1276 dd_massentro(i,ki)=mentrd_rate_2d(i,ki)*dzo*zdo(i,ki+1)
1277 dd_massdetro(i,ki) = zdo(i,ki+1)+dd_massentro(i,ki)-zdo(i,ki)
1278 if(dd_massdetro(i,ki).lt.0.)
then
1279 dd_massdetro(i,ki)=0.
1280 dd_massentro(i,ki)=zdo(i,ki)-zdo(i,ki+1)
1281 if(zdo(i,ki+1).gt.0.)mentrd_rate_2d(i,ki)=dd_massentro(i,ki)/(dzo*zdo(i,ki+1))
1283 if(zdo(i,ki+1).gt.0.)cdd(i,ki)= dd_massdetro(i,ki)/(dzo*zdo(i,ki+1))
1288 dd_massentru(i,k-1)=dd_massentro(i,k-1)+lambau(i)*dd_massdetro(i,k-1)
1289 dd_massdetru(i,k-1)=dd_massdetro(i,k-1)+lambau(i)*dd_massdetro(i,k-1)
1291 dbydo(i,jmin(i))=hcdo(i,jmin(i))-heso_cup(i,jmin(i))
1292 bud(i)=dbydo(i,jmin(i))*(zo_cup(i,jmin(i)+1)-zo_cup(i,jmin(i)))
1293 ucd(i,jmin(i)+1)=.5*(uc(i,jmin(i)+1)+u_cup(i,jmin(i)+1))
1296 dzo=zo_cup(i,ki+1)-zo_cup(i,ki)
1297 h_entr=.5*(heo(i,ki)+.5*(hco(i,ki)+hco(i,ki+1)))
1298 ucd(i,ki)=(ucd(i,ki+1)*zdo(i,ki+1) &
1299 -.5*dd_massdetru(i,ki)*ucd(i,ki+1)+ &
1300 dd_massentru(i,ki)*us(i,ki) &
1301 -pgcon*zdo(i,ki+1)*(us(i,ki+1)-us(i,ki))) / &
1302 (zdo(i,ki+1)-.5*dd_massdetru(i,ki)+dd_massentru(i,ki))
1303 vcd(i,ki)=(vcd(i,ki+1)*zdo(i,ki+1) &
1304 -.5*dd_massdetru(i,ki)*vcd(i,ki+1)+ &
1305 dd_massentru(i,ki)*vs(i,ki) &
1306 -pgcon*zdo(i,ki+1)*(vs(i,ki+1)-vs(i,ki))) / &
1307 (zdo(i,ki+1)-.5*dd_massdetru(i,ki)+dd_massentru(i,ki))
1308 hcdo(i,ki)=(hcdo(i,ki+1)*zdo(i,ki+1) &
1309 -.5*dd_massdetro(i,ki)*hcdo(i,ki+1)+ &
1310 dd_massentro(i,ki)*h_entr) / &
1311 (zdo(i,ki+1)-.5*dd_massdetro(i,ki)+dd_massentro(i,ki))
1312 dbydo(i,ki)=hcdo(i,ki)-heso_cup(i,ki)
1313 bud(i)=bud(i)+dbydo(i,ki)*dzo
1319 ierrc(i)=
'downdraft is not negatively buoyant '
1329 pwdo,qo_cup,zo_cup,dd_massentro,dd_massdetro,jmin,ierr,gammao_cup, &
1330 pwevo,bu,qrcdo,po_cup,qo,heo,1, &
1338 dp=100.*(po_cup(i,1)-po_cup(i,2))
1339 cupclw(i,k)=qrco(i,k)
1340 cnvwt(i,k)=zuo(i,k)*cupclw(i,k)*g/dp
1347 call cup_up_aa0(aa0,z,zu,dby,gamma_cup,t_cup, &
1351 call cup_up_aa0(aa1,zo,zuo,dbyo,gammao_cup,tn_cup, &
1359 if(aa1(i).eq.0.)
then
1362 ierrc(i)=
"cloud work function zero"
1388 if(ierr(i).eq.0)
then
1391 if(imid.eq.1)wmean(i) = 3.0
1393 tau_ecmwf(i)=( zo_cup(i,ktop(i))- zo_cup(i,kbcon(i)) ) / wmean(i)
1394 tau_ecmwf(i)=max(tau_ecmwf(i),720.)
1395 tau_ecmwf(i)= tau_ecmwf(i) * (1.0061 + 1.23e-2 * (dx(i)/1000.))
1402 if(dicycle == 1)
then
1406 if(ierr(i).eq.0)
then
1407 if(xland1(i) == 0 )
then
1409 umean= 2.0+sqrt(0.5*(us(i,1)**2+vs(i,1)**2+us(i,kbcon(i))**2+vs(i,kbcon(i))**2))
1410 tau_bl(i) = (zo_cup(i,kbcon(i))- z1(i)) /umean
1413 tau_bl(i) =( zo_cup(i,ktopdby(i))- zo_cup(i,kbcon(i)) ) / wmean(i)
1422 tn_bl(i,:)=0.;qo_bl(i,:)=0.
1423 if ( ierr(i) == 0 )
then
1425 tn_bl(i,1:kbcon(i)) = tn(i,1:kbcon(i))
1426 qo_bl(i,1:kbcon(i)) = qo(i,1:kbcon(i))
1428 tn_bl(i,kbcon(i)+1:ktf) = t(i,kbcon(i)+1:ktf)
1429 qo_bl(i,kbcon(i)+1:ktf) = q(i,kbcon(i)+1:ktf)
1434 call cup_env(zo,qeso_bl,heo_bl,heso_bl,tn_bl,qo_bl,po,z1, &
1435 psur,ierr,tcrit,-1, &
1436 itf,ktf, its,ite, kts,kte)
1438 call cup_env_clev(tn_bl,qeso_bl,qo_bl,heo_bl,heso_bl,zo,po,qeso_cup_bl,qo_cup_bl, &
1439 heo_cup_bl,heso_cup_bl,zo_cup,po_cup,gammao_cup_bl,tn_cup_bl,psur, &
1441 itf,ktf,its,ite, kts,kte)
1443 if(iversion == 1)
then
1450 zo_cup,zuo,dbyo_bl,gammao_cup_bl,tn_cup_bl, &
1452 itf,ktf,its,ite, kts,kte)
1456 if(ierr(i).eq.0)
then
1464 aa1_bl(i) = ( aa1_bl(i)/t_star)* tau_bl(i)
1476 if(ierr(i).eq.0)
then
1477 hkbo_bl(i)=heo_cup_bl(i,k22(i))
1487 if(ierr(i).eq.0)
then
1489 hco_bl(i,k)=hkbo_bl(i)
1492 hco_bl(i,k)=hkbo_bl(i)
1493 dbyo_bl(i,k)=hkbo_bl(i) - heso_cup_bl(i,k)
1499 if(ierr(i).eq.0)
then
1500 do k=kbcon(i)+1,ktop(i)
1501 hco_bl(i,k)=(hco_bl(i,k-1)*zuo(i,k-1)-.5*up_massdetro(i,k-1)*hco_bl(i,k-1)+ &
1502 up_massentro(i,k-1)*heo_bl(i,k-1)) / &
1503 (zuo(i,k-1)-.5*up_massdetro(i,k-1)+up_massentro(i,k-1))
1504 dbyo_bl(i,k)=hco_bl(i,k)-heso_cup_bl(i,k)
1507 hco_bl(i,k)=heso_cup_bl(i,k)
1514 call cup_up_aa0(aa1_bl,zo,zuo,dbyo_bl,gammao_cup_bl,tn_cup_bl, &
1516 itf,ktf,its,ite, kts,kte)
1520 if(ierr(i).eq.0)
then
1522 aa1_bl(i) = aa1_bl(i) - aa0(i)
1528 aa1_bl(i) = aa1_bl(i)* tau_bl(i)/ dtime
1546 call cup_dd_edt(ierr,us,vs,zo,ktop,kbcon,edt,po,pwavo, &
1547 pwo,ccn,ccnclean,pwevo,edtmax,edtmin,edtc,psum,psumh, &
1548 rho,aeroevap,pefc,xland1,itf,ktf, &
1557 ,pwo,edto,pwdo,melting &
1558 ,itf,ktf,its,ite, kts,kte, cumulus )
1562 dellat_ens(i,k,1)=0.
1563 dellaq_ens(i,k,1)=0.
1564 dellaqc_ens(i,k,1)=0.
1626 dp=100.*(po_cup(i,1)-po_cup(i,2))
1627 dellu(i,1)=pgcd*(edto(i)*zdo(i,2)*ucd(i,2) &
1628 -edto(i)*zdo(i,2)*u_cup(i,2))*g/dp &
1629 -zuo(i,2)*(uc(i,2)-u_cup(i,2)) *g/dp
1630 dellv(i,1)=pgcd*(edto(i)*zdo(i,2)*vcd(i,2) &
1631 -edto(i)*zdo(i,2)*v_cup(i,2))*g/dp &
1632 -zuo(i,2)*(vc(i,2)-v_cup(i,2)) *g/dp
1638 if(k == k22(i)-1) entupk=zuo(i,k+1)
1642 detdo=edto(i)*dd_massdetro(i,k)
1643 entdo=edto(i)*dd_massentro(i,k)
1645 entup=up_massentro(i,k)
1646 detup=up_massdetro(i,k)
1648 subin=-zdo(i,k+1)*edto(i)
1649 subdown=-zdo(i,k)*edto(i)
1651 if(k.eq.ktop(i))
then
1652 detupk=zuo(i,ktop(i))
1660 totmas=subin-subdown+detup-entup-entdo+ &
1661 detdo-entupk-entdoj+detupk+zuo(i,k+1)-zuo(i,k)
1662 if(abs(totmas).gt.1.e-6)
then
1664 write(0,123)
'totmas=',k22(i),kbcon(i),k,entup,detup,edto(i),zdo(i,k+1),dd_massdetro(i,k),dd_massentro(i,k)
1665123
format(a7,1x,3i3,2e12.4,1(1x,f5.2),3e12.4)
1668 dp=100.*(po_cup(i,k)-po_cup(i,k+1))
1670 if(k.ge.ktop(i))pgc=0.
1672 dellu(i,k) =-(zuo(i,k+1)*(uc(i,k+1)-u_cup(i,k+1) ) - &
1673 zuo(i,k )*(uc(i,k )-u_cup(i,k ) ) )*g/dp &
1674 +(zdo(i,k+1)*(ucd(i,k+1)-u_cup(i,k+1) ) - &
1675 zdo(i,k )*(ucd(i,k )-u_cup(i,k ) ) )*g/dp*edto(i)*pgcd
1676 dellv(i,k) =-(zuo(i,k+1)*(vc(i,k+1)-v_cup(i,k+1) ) - &
1677 zuo(i,k )*(vc(i,k )-v_cup(i,k ) ) )*g/dp &
1678 +(zdo(i,k+1)*(vcd(i,k+1)-v_cup(i,k+1) ) - &
1679 zdo(i,k )*(vcd(i,k )-v_cup(i,k ) ) )*g/dp*edto(i)*pgcd
1689 if(ierr(i).eq.0)
then
1691 dp=100.*(po_cup(i,1)-po_cup(i,2))
1693 dellah(i,1)=(edto(i)*zdo(i,2)*hcdo(i,2) &
1694 -edto(i)*zdo(i,2)*heo_cup(i,2))*g/dp &
1695 -zuo(i,2)*(hco(i,2)-heo_cup(i,2))*g/dp
1697 dellaq(i,1)=(edto(i)*zdo(i,2)*qcdo(i,2) &
1698 -edto(i)*zdo(i,2)*qo_cup(i,2))*g/dp &
1699 -zuo(i,2)*(qco(i,2)-qo_cup(i,2))*g/dp
1701 g_rain= 0.5*(pwo(i,1)+pwo(i,2))*g/dp
1702 e_dn = -0.5*(pwdo(i,1)+pwdo(i,2))*g/dp*edto(i)
1703 dellaq(i,1) = dellaq(i,1)+ e_dn-g_rain
1713 dp=100.*(po_cup(i,k)-po_cup(i,k+1))
1716 dellah(i,k) =-(zuo(i,k+1)*(hco(i,k+1)-heo_cup(i,k+1) ) - &
1717 zuo(i,k )*(hco(i,k )-heo_cup(i,k ) ) )*g/dp &
1718 +(zdo(i,k+1)*(hcdo(i,k+1)-heo_cup(i,k+1) ) - &
1719 zdo(i,k )*(hcdo(i,k )-heo_cup(i,k ) ) )*g/dp*edto(i)
1723 dellah(i,k) = dellah(i,k) + xlf*((1.-p_liq_ice(i,k))*0.5*(qrco(i,k+1)+qrco(i,k)) &
1724 - melting(i,k))*g/dp
1733 detup=up_massdetro(i,k)
1734 dz=zo_cup(i,k)-zo_cup(i,k-1)
1735 if(k.lt.ktop(i))
then
1736 dellaqc(i,k) = zuo(i,k)*c1d(i,k)*qrco(i,k)*dz/dp*g
1738 dellaqc(i,k)= detup*0.5*(qrco(i,k+1)+qrco(i,k)) *g/dp
1741 g_rain= 0.5*(pwo(i,k)+pwo(i,k+1))*g/dp
1742 e_dn = -0.5*(pwdo(i,k)+pwdo(i,k+1))*g/dp*edto(i)
1746 c_up = dellaqc(i,k)+(zuo(i,k+1)* qrco(i,k+1) - &
1747 zuo(i,k )* qrco(i,k ) )*g/dp + g_rain
1752 dellaq(i,k) =-(zuo(i,k+1)*(qco(i,k+1)-qo_cup(i,k+1) ) - &
1753 zuo(i,k )*(qco(i,k )-qo_cup(i,k ) ) )*g/dp &
1754 +(zdo(i,k+1)*(qcdo(i,k+1)-qo_cup(i,k+1) ) - &
1755 zdo(i,k )*(qcdo(i,k )-qo_cup(i,k ) ) )*g/dp*edto(i) &
1766444
format(1x,i2,1x,7e12.4)
1777 if(ierr(i).eq.0)
then
1779 xhe(i,k)=dellah(i,k)*mbdt+heo(i,k)
1781 xq(i,k)=max(1.e-16,dellaq(i,k)*mbdt+qo(i,k))
1782 dellat(i,k)=(1./cp)*(dellah(i,k)-xlv*dellaq(i,k))
1784 xt(i,k)= dellat(i,k)*mbdt+tn(i,k)
1785 xt(i,k)=max(190.,xt(i,k))
1790 xt(i,k)=tn(i,k)+0.25*(dellat(i,k-1) + 2.*dellat(i,k) + dellat(i,k+1)) * mbdt
1791 xt(i,k)=max(190.,xt(i,k))
1792 xq(i,k)=max(1.e-16, qo(i,k)+0.25*(dellaq(i,k-1) + 2.*dellaq(i,k) + dellaq(i,k+1)) * mbdt)
1793 xhe(i,k)=heo(i,k)+0.25*(dellah(i,k-1) + 2.*dellah(i,k) + dellah(i,k+1)) * mbdt
1798 if(ierr(i).eq.0)
then
1799 xhe(i,ktf)=heo(i,ktf)
1808 call cup_env(xz,xqes,xhe,xhes,xt,xq,po,z1, &
1809 psur,ierr,tcrit,-1, &
1815 call cup_env_clev(xt,xqes,xq,xhe,xhes,xz,po,xqes_cup,xq_cup, &
1816 xhe_cup,xhes_cup,xz_cup,po_cup,gamma_cup,xt_cup,psur, &
1836 if(ierr(i).eq.0)
then
1837 x_add = xlv*zqexec(i)+cp*ztexec(i)
1838 call get_cloud_bc(kte,xhe_cup(i,1:kte),xhkb(i),k22(i),x_add)
1839 do k=1,start_level(i)-1
1840 xhc(i,k)=xhe_cup(i,k)
1851 if(ierr(i).eq.0)
then
1853 do k=start_level(i) +1,ktop(i)
1854 xhc(i,k)=(xhc(i,k-1)*xzu(i,k-1)-.5*up_massdetro(i,k-1)*xhc(i,k-1) + &
1855 up_massentro(i,k-1)*xhe(i,k-1)) / &
1856 (xzu(i,k-1)-.5*up_massdetro(i,k-1)+up_massentro(i,k-1))
1863 xhc(i,k)= xhc(i,k)+ xlf*(1.-p_liq_ice(i,k))*qrco(i,k)
1866 xdby(i,k)=xhc(i,k)-xhes_cup(i,k)
1870 xhc(i,k)=xhes_cup(i,k)
1879 call cup_up_aa0(xaa0,xz,xzu,xdby,gamma_cup,xt_cup, &
1885 if(ierr(i).eq.0)
then
1886 xaa0_ens(i,1)=xaa0(i)
1893 pr_ens(i,nens3)=pr_ens(i,nens3) &
1894 +pwo(i,k)+edto(i)*pwdo(i,k)
1896 else if(nens3.eq.8)
then
1897 pr_ens(i,nens3)=pr_ens(i,nens3)+ &
1898 pwo(i,k)+edto(i)*pwdo(i,k)
1900 else if(nens3.eq.9)
then
1901 pr_ens(i,nens3)=pr_ens(i,nens3) &
1902 + pwo(i,k)+edto(i)*pwdo(i,k)
1904 pr_ens(i,nens3)=pr_ens(i,nens3)+ &
1905 pwo(i,k) +edto(i)*pwdo(i,k)
1909 if(pr_ens(i,7).lt.1.e-6)
then
1912 ierrc(i)=
"total normalized condensate too small"
1919 if(pr_ens(i,nens3).lt.1.e-5)
then
1946 call cup_kbcon(ierrc,cap_max_increment,iloop,k22x,kbconx,heo_cup, &
1947 heso_cup,hkbo,ierr2,kbmax,po_cup,cap_max, &
1951 z_cup,entr_rate,heo,imid)
1953 call cup_kbcon(ierrc,cap_max_increment,iloop,k22x,kbconx,heo_cup, &
1954 heso_cup,hkbo,ierr3,kbmax,po_cup,cap_max, &
1958 z_cup,entr_rate,heo,imid)
1968 dq=(qo_cup(i,k+1)-qo_cup(i,k))
1970 mconv(i)=mconv(i)+omeg(i,k)*dq/g
1972 if ( mconv(i) < mc_thresh(i)) ierr(i)=2242
1976 ierr,ierr2,ierr3,xf_ens,axx,forcing, &
1977 maxens3,mconv,rand_clos, &
1978 po_cup,ktop,omeg,zdo,zdm,k22,zuo,pr_ens,edto,edtm,kbcon, &
1982 dicycle,tau_ecmwf,aa1_bl,xf_dicycle)
1987 if(ierr(i).eq.0)
then
1988 dellat_ens(i,k,1)=dellat(i,k)
1989 dellaq_ens(i,k,1)=dellaq(i,k)
1990 dellaqc_ens(i,k,1)=dellaqc(i,k)
1991 pwo_ens(i,k,1)=pwo(i,k) +edto(i)*pwdo(i,k)
1993 dellat_ens(i,k,1)=0.
1994 dellaq_ens(i,k,1)=0.
1995 dellaqc_ens(i,k,1)=0.
2006 if(imid.eq.1 .and. ichoice .le.2)
then
2012 if(ierr(i).eq.0)
then
2015 if(k22(i).lt.kpbl(i)+1)
then
2017 blqe=blqe+100.*dhdt(i,k)*(po_cup(i,k)-po_cup(i,k+1))/g
2019 trash=max((hco(i,kbcon(i))-heo_cup(i,kbcon(i))),1.e1)
2020 xff_mid(i,1)=max(0.,blqe/trash)
2021 xff_mid(i,1)=min(0.1,xff_mid(i,1))
2023 xff_mid(i,2)=min(0.1,.03*zws(i))
2024 forcing(i,1)=xff_mid(i,1)
2025 forcing(i,2)=xff_mid(i,2)
2031 dellaqc_ens,outt,outq,outqc,dx, &
2032 zuo,pre,pwo_ens,xmb,ktop, &
2033 edto,pwdo,
'deep',ierr2,ierr3, &
2034 po_cup,pr_ens,maxens3, &
2035 sig,closure_n,xland1,xmbm_in,xmbs_in,rrfs_factor, &
2036 ichoice,imid,ipr,itf,ktf, &
2038 dicycle,xf_dicycle )
2043 kts,kte,ierr,kbcon,xmb,psur,xland,qo_cup, &
2044 po_cup,qes_cup,pwavo,edto,pwevo,pre,outt,outq)
2051 if (do_smoke_transport .and. nchem > 0)
then
2060 chem(i,k,nv) = max(qamin, chem3d(i,k,nv))
2070 chem_pwd(:,:,:) = 0.
2072 chem_down(:,:,:) = 0.
2075 chem_cup(:,:,:) = 0.
2078 if(ierr(i).eq.0)
then
2080 if(pwavo(i).ne.0.) pwdper(i,k)=-edtc(i,1)*pwdo(i,k)/pwavo(i)
2085 chem_cup(i,k,nv)=.5*(chem(i,k-1,nv)+chem(i,k,nv))
2087 chem_cup(i,kts,nv)=chem(i,kts,nv)
2092 chem_up(i,k,nv)=chem_cup(i,k,nv)
2094 do k=k22(i)+1,ktop(i)
2095 chem_up(i,k,nv)=(chem_up(i,k-1,nv)*zuo(i,k-1) &
2096 -.5*up_massdetr(i,k-1)*chem_up(i,k-1,nv)+ &
2097 up_massentr(i,k-1)*chem(i,k-1,nv)) / &
2098 (zuo(i,k-1)-.5*up_massdetr(i,k-1)+up_massentr(i,k-1))
2099 chem_c(i,k,nv)=fscav(nv)*chem_up(i,k,nv)
2100 dz=zo_cup(i,k)-zo_cup(i,k-1)
2101 trash2=chem_up(i,k,nv)-chem_c(i,k,nv)
2102 trash=chem_c(i,k,nv)/(1.+c0t3d(i,k)*dz)
2103 chem_pw=c0t3d(i,k)*dz*trash*zuo(i,k)
2104 chem_up(i,k,nv)=trash2+trash
2105 chem_pwav(i,nv)=chem_pwav(i,nv)+chem_pw(i,k,nv)
2108 chem_up(i,k,nv)=chem_cup(i,k,nv)
2113 chem_down(i,jmin(i)+1,nv)=chem_cup(i,jmin(i)+1,nv)
2116 dp=100.*(po_cup(i,ki)-po_cup(i,ki+1))
2117 chem_down(i,ki,nv)=(chem_down(i,ki+1,nv)*zdo(i,ki+1) &
2118 -.5_kind_phys*dd_massdetro(i,ki)*chem_down(i,ki+1,nv)+ &
2119 dd_massentro(i,ki)*chem(i,ki,nv)) / &
2120 (zdo(i,ki+1)-.5_kind_phys*dd_massdetro(i,ki)+dd_massentro(i,ki))
2121 chem_down(i,ki,nv)=chem_down(i,ki,nv)+pwdper(i,ki)*chem_pwav(i,nv)
2122 chem_pwd(i,ki,nv)=max(0._kind_phys,pwdper(i,ki)*chem_pwav(i,nv))
2126 dp=100.*(po_cup(i,k)-po_cup(i,k+1))
2127 chem_psum(i,nv)=chem_psum(i,nv)+chem_pw(i,k,nv)*g
2129 chem_psum(i,nv)=chem_psum(i,nv)*xmb(i)*dtime
2139 if(ierr(i).eq.0)
then
2140 dp=100.*(po_cup(i,1)-po_cup(i,2))
2141 dellac(i,1,nv)=dellac(i,1,nv)+(edto(i)*zdo(i,2)*chem_down(i,2,nv))*g/dp*xmb(i)
2144 dellac(i,1,nv)=dellac(i,1,nv)-entupk*chem_cup(i,2,nv)*g/dp*xmb(i)
2146 do k=kts+1,ktop(i)-1
2152 dp=100.*(po_cup(i,k)-po_cup(i,k+1))
2154 entdo=edto(i)*dd_massentro(i,k)*chem(i,k,nv)
2155 detdo=edto(i)*dd_massdetro(i,k)*.5*(chem_down(i,k+1,nv)+chem_down(i,k,nv))
2156 entup=up_massentro(i,k)*chem(i,k,nv)
2157 detup=up_massdetro(i,k)*.5*(chem_up(i,k+1,nv)+chem_up(i,k,nv))
2159 if(k == k22(i)-1)
then
2160 entup=zuo(i,k+1)*chem_cup(i,k+1,nv)
2163 if(k.eq.jmin(i))entdoj=edto(i)*zdo(i,k)*chem_cup(i,k,nv)
2165 dellac(i,k,nv) =dellac(i,k,nv) + (detup+detdo-entdo-entup-entdoj)*g/dp*xmb(i)
2167 dellac(i,ktop(i),nv)=zuo(i,ktop(i))*chem_up(i,ktop(i),nv)*g/dp*xmb(i)
2178 if(ierr(i).eq.0)
then
2184 dp=100._kind_phys*(po_cup(i,k)-po_cup(i,k+1))
2185 dtime_max=min(dtime_max,.5_kind_phys*dp)
2186 massflx(i,k)=-xmb(i)*(zuo(i,k)-edto(i)*zdo(i,k))
2187 trcflx_in(k)=massflx(i,k)*chem_cup(i,k,nv)
2191 call fct1d3(ktop(i),kte,dtime_max,po_cup(i,:),chem(i,:,nv),massflx(i,:), &
2192 trcflx_in,dellac2(i,:,nv),g)
2195 chem(i,k,nv)=chem(i,k,nv) + (dellac(i,k,nv)+dellac2(i,k,nv))*dtime
2196 if(chem(i,k,nv).lt.qamin)
then
2197 dp=100.*(po_cup(i,k)-po_cup(i,k+1))
2198 wetdpc_deep(i,nv)=wetdpc_deep(i,nv)+(qamin-chem(i,k,nv))*dp/g/dtime
2211 if(ierr(i).eq.0)
then
2212 if (k <= ktop(i))
then
2213 dp=100.*(po_cup(i,k)-po_cup(i,k+1))
2214 wetdpc_deep(i,nv)=wetdpc_deep(i,nv) + ((chem3d(i,k,nv)-chem(i,k,nv))*dp/(g*dtime))
2215 chem3d(i,k,nv) = chem(i,k,nv)
2219 wetdpc_deep(i,nv)=max(wetdpc_deep(i,nv),qamin)
2229 if(ierr(i).eq.0 .and.pre(i).gt.0.)
then
2231 pre(i)=max(pre(i),0.)
2233 outu(i,1)=dellu(i,1)*xmb(i)
2234 outv(i,1)=dellv(i,1)*xmb(i)
2236 outu(i,k)=.25*(dellu(i,k-1)+2.*dellu(i,k)+dellu(i,k+1))*xmb(i)
2237 outv(i,k)=.25*(dellv(i,k-1)+2.*dellv(i,k)+dellv(i,k+1))*xmb(i)
2239 elseif(ierr(i).ne.0 .or. pre(i).eq.0.)
then
2253 if(irainevap.eq.1)
then
2262 if(ierr(i).eq.0)
then
2264 do k = ktop(i), 1, -1
2265 rain = pwo(i,k) + edto(i) * pwdo(i,k)
2267 rntot(i) = rntot(i) + rain * xmb(i)* .001 * dtime
2274 if(ierr(i).eq.0)
then
2275 evef = edt(i) * evfact * sig(i)**2
2276 if(xland(i).gt.0.5 .and. xland(i).lt.1.5) evef = edt(i) * evfactl * sig(i)**2
2278 do k = ktop(i), 1, -1
2279 rain = pwo(i,k) + edto(i) * pwdo(i,k)
2280 rn(i) = rn(i) + rain * xmb(i) * .001 * dtime
2283 q1=qo(i,k)+(outq(i,k))*dtime
2284 t1=tn(i,k)+(outt(i,k))*dtime
2285 qcond(i) = evef * (q1 - qeso(i,k)) &
2286 & / (1. + el2orc * qeso(i,k) / t1**2)
2287 dp = -100.*(p_cup(i,k+1)-p_cup(i,k))
2288 if(rn(i).gt.0. .and. qcond(i).lt.0.)
then
2289 qevap(i) = -qcond(i) * (1.-exp(-.32*sqrt(dtime*rn(i))))
2290 qevap(i) = min(qevap(i), rn(i)*1000.*g/dp)
2291 delq2(i) = delqev(i) + .001 * qevap(i) * dp / g
2293 if(rn(i).gt.0..and.qcond(i).lt.0..and. &
2294 & delq2(i).gt.rntot(i))
then
2295 qevap(i) = 1000.* g * (rntot(i) - delqev(i)) / dp
2298 if(rn(i).gt.0..and.qevap(i).gt.0.)
then
2299 outq(i,k) = outq(i,k) + qevap(i)/dtime
2300 outt(i,k) = outt(i,k) - elocp * qevap(i)/dtime
2301 rn(i) = max(0.,rn(i) - .001 * qevap(i) * dp / g)
2302 pre(i) = pre(i) - qevap(i) * dp /g/dtime
2303 pre(i)=max(pre(i),0.)
2304 delqev(i) = delqev(i) + .001*dp*qevap(i)/g
2317 if(ierr(i).eq.0)
then
2318 if(aeroevap.gt.1)
then
2320 ccnloss(i)=ccn(i)*pefc(i)*xmb(i)
2321 ccn(i) = ccn(i) - ccnloss(i)*scav_factor
2332 if(ierr(i).eq.0)
then
2336 dp=(po_cup(i,k)-po_cup(i,k+1))*100.
2338 dts= dts -(outu(i,k)*us(i,k)+outv(i,k)*vs(i,k))*dp/g
2340 fpi = fpi +sqrt(outu(i,k)*outu(i,k) + outv(i,k)*outv(i,k))*dp
2344 fp= sqrt((outu(i,k)*outu(i,k)+outv(i,k)*outv(i,k)))/fpi
2345 outt(i,k)=outt(i,k)+fp*dts*g/cp