From 75c8f98f006eba0ffa8c4dc1c63349023aec9fd8 Mon Sep 17 00:00:00 2001 From: Dom Heinzeller Date: Wed, 27 Dec 2017 10:35:27 -0700 Subject: [PATCH] Update of various GFS physics routines for CCPP-compliancy: missing arguments in argument tables, missing 'end subroutine XYZ' statements, case-sensitivity of subroutine names --- physics/GFS_calpreciptype.f90 | 18 +- physics/GFS_radsw_post.f90 | 1 + physics/calpreciptype.f90 | 1468 --------------------------------- physics/radlw_main.f | 6 +- physics/radsw_main.f | 6 +- physics/sfc_nst.f | 30 +- physics/sfc_sice.f | 118 +-- 7 files changed, 87 insertions(+), 1560 deletions(-) delete mode 100644 physics/calpreciptype.f90 diff --git a/physics/GFS_calpreciptype.f90 b/physics/GFS_calpreciptype.f90 index ea2560c78..9a70e4601 100644 --- a/physics/GFS_calpreciptype.f90 +++ b/physics/GFS_calpreciptype.f90 @@ -41,7 +41,7 @@ end subroutine GFS_calpreciptype_init !!| srflag | flag_for_precipitation_type | snow(1)/rain(0) flag for precipitation | 1 | 1 | real | kind_phys | out | F | !!| tprcp | precipitation_amount_in_one_dynamics_time_step | precipitation amount in one dynamics time step | m | 1 | real | kind_phys | out | F | !! - subroutine GFS_calpreciptype_run (kdt,nrcm,im,ix,lm,lp1,randomno, & + subroutine GFS_calpreciptype_run(kdt,nrcm,im,ix,lm,lp1,randomno, & cal_pre, & gt0,gq0,prsl,prsi, rainc,frain,rain1, & phii,n3dfercld,tskin,sr,phy_f3d, & !input @@ -307,7 +307,7 @@ subroutine GFS_calpreciptype_run (kdt,nrcm,im,ix,lm,lp1,randomno, & endif return - end subroutine GFS_CALPRECIPTYPE_RUN + end subroutine GFS_calpreciptype_run ! !&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& ! @@ -548,7 +548,7 @@ subroutine calwxt(lm,lp1,t,q,pmid,pint, & ! deallocate (twet) return - end + end subroutine calwxt ! ! !ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc @@ -836,7 +836,7 @@ subroutine calwxt_ramer(lm,lp1,t,q,pmid,rh,td,pint,ptyp) return ! - end + end subroutine calwxt_ramer ! ! !-------------------------------------------------------------------------- @@ -894,7 +894,7 @@ real function xmytw(t,td,p) end if ! return - end + end function xmytw ! ! !$$$ subprogram documentation block @@ -1124,7 +1124,7 @@ subroutine calwxt_bourg(lm,lp1,rn,g,t,q,pmid,pint,zint,ptype) end if ! return - end + end subroutine calwxt_bourg ! ! subroutine calwxt_revised(lm,lp1,t,q,pmid,pint, & @@ -1380,7 +1380,7 @@ subroutine calwxt_revised(lm,lp1,t,q,pmid,pint, & endif return - end + end subroutine calwxt_revised ! ! subroutine calwxt_explicit(lm,tskin,sr,f_rimef,iwx) @@ -1440,7 +1440,7 @@ subroutine calwxt_explicit(lm,tskin,sr,f_rimef,iwx) iwx = iwx + 1 endif endif - end + end subroutine calwxt_explicit ! ! subroutine calwxt_dominant(nalg,rain,freezr,sleet,snow, & @@ -1511,7 +1511,7 @@ subroutine calwxt_dominant(nalg,rain,freezr,sleet,snow, & endif ! return - end + end subroutine calwxt_dominant !> \section arg_table_GFS_calpreciptype_finalize Argument table !! diff --git a/physics/GFS_radsw_post.f90 b/physics/GFS_radsw_post.f90 index 5c256a6af..d4a9fbe31 100644 --- a/physics/GFS_radsw_post.f90 +++ b/physics/GFS_radsw_post.f90 @@ -19,6 +19,7 @@ end subroutine GFS_radsw_post_init !!| Radtend | FV3-GFS_Radtend_type | Fortran DDT containing FV3-GFS fields targetted for diagnostic output | DDT | 0 | GFS_typedefs%GFS_radtend_type | | inout | F | !!| Coupling | FV3-GFS_Coupling_type | Fortran DDT containing FV3-GFS fields to/from coupling with other components | DDT | 0 | GFS_typedefs%GFS_coupling_type| | inout | F | !!| ltp | extra_top_layer | extra top layers | none | 0 | integer | | in | F | +!!| nday | daytime_points_dimension | daytime points dimension | index | 0 | integer | | in | F | !!| lm | vertical_layer_dimension_for_radiation | number of vertical layers for radiation calculation | index | 0 | integer | | in | F | !!| kd | vertical_index_difference_between_in-out_and_local | vertical index difference between in/out and local | index | 0 | integer | | in | F | !!| htswc | tendency_of_air_temperature_due_to_shortwave_heating | total sky heating rate due to shortwave radiation | K s-1 | 2 | real | kind_phys | in | F | diff --git a/physics/calpreciptype.f90 b/physics/calpreciptype.f90 deleted file mode 100644 index e0f038bc5..000000000 --- a/physics/calpreciptype.f90 +++ /dev/null @@ -1,1468 +0,0 @@ -!> \file calpreciptype.f90 -!! This file contains the subroutine that calculates dominant precipitation type. It is -!! adopted from post but was made into a column to used by GFS model. - - module calpreciptype - contains - -!>\section arg_table_calpreciptype_init Argument Table - subroutine calpreciptype_init - end subroutine calpreciptype_init - -!!\section arg_table_calpreciptype_run Argument Table -!!| local var name | longname |description | units | rank | type | kind | intent | optional | -!!|----------------|------------------------------------------------|----------------------------------------------------------|---------|------|---------|-----------|--------|----------| -!!| kdt | index_of_time_step | current time step index | index | 0 | integer | | in | F | -!!| nrcm | array_dimension | second dimension of random number array | index | 0 | integer | | in | F | -!!| im | horizontal_loop_extent | horizontal loop extent, start at 1 | index | 0 | integer | | in | F | -!!| ix | horizontal_dimension | horizontal dimension | index | 0 | integer | | in | F | -!!| lm | vertical_dimension | vertical layer dimension | index | 0 | integer | | in | F | -!!| lp1 | vertical_interface_dimension | vertical interface dimension | index | 0 | integer | | in | F | -!!| randomno | random_number_array | random number array | none | 2 | real | | in | F | -!!| xlat | latitude | latitude | 1 | 1 | real | | in | F | -!!| xlon | longitude | longitude | 1 | 1 | real | | in | F | -!!| gt0 | air_temperature | layer mean air temperature | K | 2 | real | kind_phys | in | F | -!!| gq0 | water_vapor_specific_humidity | water vapor specific humidity | kg kg-1 | 2 | real | kind_phys | in | F | -!!| prsl | air_pressure | layer mean pressure | Pa | 2 | real | kind_phys | in | F | -!!| prsi | air_pressure_at_interface | pressure at layer interface | Pa | 2 | real | kind_phys | in | F | -!!| prec | total_rainfall_amount | instantaneous total precipitation at surface | m | 1 | real | kind_phys | in | F | -!!| phii | geopotential_at_interface | geopotential at model layer interfaces | m2 s-2 | 2 | real | kind_phys | in | F | -!!| n3dfercld | num_p3d=4 ?? | number of 3D arrays needed for microphysics | count | 0 | integer | | in | F | -!!| tskin | surface_skin_temperature | surface skin temperature | K | 1 | real | kind_phys | in | F | -!!| sr | ratio_of_snowfall_to_rainfall | ratio of snowfall to rainfall | frac | 1 | real | kind_phys | in | F | -!!| phy_f3d | air_temperature_at_previous_time_step | air temperature at previous time step | K | 2 | real | kind_phys | in | F | -!!| domr | dominant_rain_type | dominant rain type | none | 1 | real | kind_phys | out | F | -!!| domzr | dominant_freezing_rain_type | dominant freezing rain type | none | 1 | real | kind_phys | out | F | -!!| domip | dominant_sleet_type | dominant sleet type | none | 1 | real | kind_phys | out | F | -!!| doms | dominant_snow_type | dominant snow type | none | 1 | real | kind_phys | out | F | -! subroutine calpreciptype(kdt,nrcm,im,ix,lm,lp1,randomno, & - subroutine calpreciptype_run(kdt,nrcm,im,ix,lm,lp1,randomno, & - xlat,xlon, & - gt0,gq0,prsl,prsi,prec, & !input - phii,n3dfercld,tskin,sr,phy_f3d, & !input - domr,domzr,domip,doms) !output - -!$$$ subprogram documentation block -! . . . -! subprogram: calpreciptype compute dominant precip type -! prgrmmr: chuang org: w/np2 date: 2008-05-28 -! -! -! abstract: -! this routine computes precipitation type. -! . it is adopted from post but was made into a column to used by gfs model -! -! -------------------------------------------------------------------- - use funcphys, only : fpvs,ftdp,fpkap,ftlcl,stma,fthe - use physcons -!- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - implicit none -! - real, parameter :: pthresh = 0.0, oneog = 1.0/con_g - integer,parameter :: nalg = 5 -! -! declare variables. -! - integer,intent(in) :: kdt,nrcm,im,ix,lm,lp1,n3dfercld - real,intent(in) :: xlat(im),xlon(im) - real,intent(in) :: randomno(ix,nrcm) - real(kind=kind_phys),dimension(im), intent(in) :: prec,sr,tskin - real(kind=kind_phys),dimension(ix,lm), intent(in) :: gt0,gq0,prsl,phy_f3d - real(kind=kind_phys),dimension(ix,lp1),intent(in) :: prsi,phii - real(kind=kind_phys),dimension(im), intent(out) :: domr,domzr,domip,doms - - integer, dimension(nalg) :: sleet,rain,freezr,snow - real(kind=kind_phys),dimension(lm) :: t,q,pmid,f_rimef - real(kind=kind_phys),dimension(lp1) :: pint,zint - real(kind=kind_phys), allocatable :: twet(:),rh(:),td(:) -! - integer i,iwx,isno,iip,izr,irain,k,k1 - real(kind=kind_phys) es,qc,pv,tdpd,pr,tr,pk,tlcl,thelcl,qwet, & - time_vert,time_ncep,time_ramer,time_bourg,time_revised,& - time_dominant,btim,timef,ranl(2) - -! -! computes wet bulb here since two algorithms use it -! lp1=lm+1 -! convert geopotential to height -! do l=1,lp1 -! zint(l)=zint(l)/con_g -! end do -! don't forget to flip 3d arrays around because gfs counts from bottom up - - allocate ( twet(lm),rh(lm),td(lm) ) - -! print*,'debug calpreciptype: ', im,lm,lp1,nrcm - -! time_vert = 0. -! time_ncep = 0. -! time_ramer = 0. -! time_bourg = 0. -! time_revised = 0. - - do i=1,im - if (prec(i) > pthresh) then - do k=1,lm - k1 = lm-k+1 - t(k1) = gt0(i,k) - q(k1) = gq0(i,k) - pmid(k1) = prsl(i,k) ! pressure in pascals - f_rimef(k1) = phy_f3d(i,k) -! -! compute wet bulb temperature -! - pv = pmid(k1)*q(k1)/(con_eps-con_epsm1*q(k1)) - td(k1) = ftdp(pv) - tdpd = t(k1)-td(k1) -! if (pmid(k1) >= 50000.) then ! only compute twet below 500mb to save time - if (tdpd > 0.) then - pr = pmid(k1) - tr = t(k1) - pk = fpkap(pr) - tlcl = ftlcl(tr,tdpd) - thelcl = fthe(tlcl,pk*tlcl/tr) - call stma(thelcl,pk,twet(k1),qwet) - else - twet(k1) = t(k1) - endif -! endif - es = min(fpvs(t(k1)), pmid(k1)) - qc = con_eps*es / (pmid(k1)+con_epsm1*es) - rh(k1) = max(con_epsq,q(k1)) / qc - - k1 = lp1-k+1 - pint(k1) = prsi(i,k) - zint(k1) = phii(i,k) * oneog - - enddo - pint(1) = prsi(i,lp1) - zint(1) = phii(i,lp1) * oneog - -!------------------------------------------------------------------------------- -! if(kdt>15.and.kdt<20) time_vert = time_vert + (timef() - btim) -! debug print statement -! if (abs(xlon(i)*57.29578-114.0) .lt. 0.2 .and. & -! abs(xlat(i)*57.29578-40.0) .lt. 0.2)then -! print*,'debug in calpreciptype: i,im,lm,lp1,xlon,xlat,prec,tskin,sr,nrcm,randomno,n3dfercld ', & -! i,im,lm,lp1,xlon(i)*57.29578,xlat(i)*57.29578,prec(i),tskin(i),sr(i), & -! nrcm,randomno(i,1:nrcm),n3dfercld -! do l=1,lm -! print*,'debug in calpreciptype: l,t,q,p,pint,z,twet', & -! l,t(l),q(l), & -! pmid(l),pint(l),zint(l),twet(l) -! end do -! print*,'debug in calpreciptype: lp1,pint,z ', lp1,pint(lp1),zint(lp1) -! end if -! end debug print statement -! call wetbulb(lm,con_rocp,con_epsq,t,q,pmid,twet) -! if(kdt>10.and.kdt<20)btim = timef() -!------------------------------------------------------------------------------- -! -! instantaneous precipitation type. -!> -# Call calwxt(), to compute precipitation type using a decision tree approach -!! that uses variables such as integrated wet bulb temperature below freezing and -!! lowest layer temperature. See Baldwin and Contorno preprint from 13th weather -!! analysis and forcasting conference for more details (or Baldwin et al, 10th NWP -!! conference preprint) - call calwxt(lm,lp1,t,q,pmid,pint,con_fvirt,con_rog,con_epsq,zint,iwx,twet) - snow(1) = mod(iwx,2) - sleet(1) = mod(iwx,4)/2 - freezr(1) = mod(iwx,8)/4 - rain(1) = iwx/8 - -! dominant precipitation type - -!gsm if dominant precip type is requested, 4 more algorithms -!gsm will be called. the tallies are then summed in calwxt_dominant - -! ramer algorithm -! allocate ( rh(lm),td(lm) ) -! do l=1,lm -!hc: use rh and td consistent with gfs ice physics -! es=fpvs(t(l)) -! es=min(es,pmid(l)) -! qc=con_eps*es/(pmid(l)+con_epsm1*es) -! rh(l)=max(con_epsq,q(l))/qc -! pv = pmid(l)*q(l)/(con_eps-con_epsm1*q(l)) -! td(l)=ftdp(pv) -! end do -! if(kdt>10.and.kdt<20)btim = timef() - -! write(0,*)' i=',i,' lm=',lm,' lp1=',lp1,' t=',t(1),q(1),pmid(1) & -! &,' pint=',pint(1),' prec=',prec(i),' pthresh=',pthresh - - call calwxt_ramer(lm,lp1,t,q,pmid,rh,td,pint,iwx) - -! - snow(2) = mod(iwx,2) - sleet(2) = mod(iwx,4)/2 - freezr(2) = mod(iwx,8)/4 - rain(2) = iwx/8 - -! bourgouin algorithm -! iseed=44641*(int(sdat(1)-1)*24*31+int(sdat(2))*24+ihrst)+ & -! & mod(ifhr*60+ifmin,44641)+4357 - - ranl = randomno(i,1:2) -!> -# Call calwxt_bourg() using Bourgouin algorithm - call calwxt_bourg(lm,lp1,ranl,con_g,t,q,pmid,pint,zint(1),iwx) - -! - snow(3) = mod(iwx,2) - sleet(3) = mod(iwx,4)/2 - freezr(3) = mod(iwx,8)/4 - rain(3) = iwx/8 -! -! revised ncep algorithm -! -!> -# Call calwxt_revised(), revised NCEP algorithm - call calwxt_revised(lm,lp1,t,q,pmid,pint, & - con_fvirt,con_rog,con_epsq,zint,twet,iwx) -! - snow(4) = mod(iwx,2) - sleet(4) = mod(iwx,4)/2 - freezr(4) = mod(iwx,8)/4 - rain(4) = iwx/8 -! -! explicit algorithm (under 18 not admitted without parent or guardian) - - if(n3dfercld == 3) then ! ferrier's scheme - call calwxt_explicit(lm,tskin(i),sr(i),f_rimef,iwx) - snow(5) = mod(iwx,2) - sleet(5) = mod(iwx,4)/2 - freezr(5) = mod(iwx,8)/4 - rain(5) = iwx/8 - else - snow(5) = 0 - sleet(5) = 0 - freezr(5) = 0 - rain(5) = 0 - endif -! -! -# Call calwxt_dominant(),which takes the precip type solution from different -!! algorithms and sums them up to give a dominant type. - call calwxt_dominant(nalg,rain(1),freezr(1),sleet(1), & - snow(1),domr(i),domzr(i),domip(i),doms(i)) - - else ! prec < pthresh - domr(i) = 0. - domzr(i) = 0. - domip(i) = 0. - doms(i) = 0. - end if - enddo ! end loop for i - - deallocate (twet,rh,td) - return - end -! -!&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& -! - subroutine calwxt(lm,lp1,t,q,pmid,pint, & - d608,rog,epsq,zint,iwx,twet) -! -! file: calwxt.f -! written: 11 november 1993, michael baldwin -! revisions: -! 30 sept 1994-setup new decision tree (m baldwin) -! 12 june 1998-conversion to 2-d (t black) -! 01-10-25 h chuang - modified to process hybrid model output -! 02-01-15 mike baldwin - wrf version -! -! -! routine to compute precipitation type using a decision tree -! approach that uses variables such as integrated wet bulb temp -! below freezing and lowest layer temperature -! -! see baldwin and contorno preprint from 13th weather analysis -! and forecasting conference for more details -! (or baldwin et al, 10th nwp conference preprint) -! -!- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - implicit none -! -! input: -! t,q,pmid,htm,lmh,zint -! - integer,intent(in) :: lm,lp1 - real,dimension(lm),intent(in) :: t,q,pmid,twet - real,dimension(lp1),intent(in) :: zint,pint - integer,intent(out) :: iwx - real,intent(in) :: d608,rog,epsq - - -! output: -! iwx - instantaneous weather type. -! acts like a 4 bit binary -! 1111 = rain/freezing rain/ice pellets/snow -! where the one's digit is for snow -! the two's digit is for ice pellets -! the four's digit is for freezing rain -! and the eight's digit is for rain -! -! internal: -! -! real, allocatable :: twet(:) - real, parameter :: d00=0.0 - integer karr,licee - real tcold,twarm - -! subroutines called: -! wetbulb -! -! -! initialize weather type array to zero (ie, off). -! we do this since we want iwx to represent the -! instantaneous weather type on return. -! -! -! allocate local storage -! - - integer l,lice,iwrml,ifrzl - real psfck,tdchk,a,tdkl,tdpre,tlmhk,twrmk,areas8,areap4, & - surfw,surfc,dzkl,area1,pintk1,pintk2,pm150,pkl,tkl,qkl - -! allocate ( twet(lm) ) -! - iwx = 0 -! -! find coldest and warmest temps in saturated layer between -! 70 mb above ground and 500 mb -! also find highest saturated layer in that range -! -!meb - psfck = pint(lm+1) -!meb - tdchk = 2.0 - 760 tcold = t(lm) - twarm = t(lm) - licee = lm -! - do l=1,lm - qkl = q(l) - qkl = max(epsq,qkl) - tkl = t(l) - pkl = pmid(l) -! -! skip past this if the layer is not between 70 mb above ground and 500 mb -! - if (pkl < 50000.0 .or. pkl > psfck-7000.0) cycle - a = log(qkl*pkl/(6.1078*(0.378*qkl+0.622))) - tdkl = (237.3*a) / (17.269-a) + 273.15 - tdpre = tkl - tdkl - if (tdpre < tdchk .and. tkl < tcold) tcold = tkl - if (tdpre < tdchk .and. tkl > twarm) twarm = tkl - if (tdpre < tdchk .and. l < licee) licee = l - enddo -! -! if no sat layer at dew point dep=tdchk, increase tdchk -! and start again (but don't make tdchk > 6) -! - if (tcold == t(lm) .and. tdchk < 6.0) then - tdchk = tdchk + 2.0 - goto 760 - endif -! -! lowest layer t -! - karr = 0 - tlmhk = t(lm) -! -! decision tree time -! - if (tcold > 269.15) then - if (tlmhk <= 273.15) then - -! turn on the flag for freezing rain = 4 if its not on already -! izr=mod(iwx(i,j),8)/4 -! if (izr.lt.1) iwx(i,j)=iwx(i,j)+4 - - iwx = iwx + 4 - goto 850 - else -! turn on the flag for rain = 8 -! if its not on already -! irain=iwx(i,j)/8 -! if (irain.lt.1) iwx(i,j)=iwx(i,j)+8 - - iwx = iwx + 8 - goto 850 - endif - endif - karr = 1 - 850 continue -! -! compute wet bulb only at points that need it -! -! call wetbulb(lm,t,q,pmid,karr,twet) -! call wetfrzlvl(twet,zwet) -! - if (karr > 0) then - lice=licee -!meb - psfck = pint(lm+1) -!meb - tlmhk = t(lm) - twrmk = twarm -! -! twet area variables calculate only what is needed -! from ground to 150 mb above surface from ground to tcold layer -! and from ground to 1st layer where wet bulb t < 0.0 -! -! pintk1 is the pressure at the bottom of the layer -! pintk2 is the pressure at the top of the layer -! -! areap4 is the area of twet above -4 c below highest sat lyr -! - areas8 = d00 - areap4 = d00 - surfw = d00 - surfc = d00 -! - do l=lm,lice,-1 - area1 = (twet(l)-269.15) * (zint(l)-zint(l+1)) - if (twet(l) >= 269.15) areap4 = areap4 + area1 - enddo -! - if (areap4 < 3000.0) then -! turn on the flag for snow = 1 -! if its not on already -! isno=mod(iwx(i,j),2) -! if (isno.lt.1) iwx(i,j)=iwx(i,j)+1 - - iwx = iwx + 1 - return - endif -! -! areas8 is the net area of twet w.r.t. freezing in lowest 150mb -! - pintk1 = psfck - pm150 = psfck - 15000. -! - do l=lm,1,-1 - pintk2 = pint(l) - if (pintk1 >= pm150) then - dzkl = zint(l)-zint(l+1) -! sum partial layer if in 150 mb agl layer - if (pintk2 < pm150) & - dzkl = t(l)*(q(l)*d608+1.0)*rog*log(pintk1/pm150) - area1 = (twet(l)-273.15)*dzkl - areas8 = areas8 + area1 - endif - pintk1 = pintk2 - enddo -! -! surfw is the area of twet above freezing between the ground -! and the first layer above ground below freezing -! surfc is the area of twet below freezing between the ground -! and the warmest sat layer -! - ifrzl = 0 - iwrml = 0 -! - do l=lm,1,-1 - if (ifrzl == 0 .and. t(l) < 273.15) ifrzl = 1 - if (iwrml == 0 .and. t(l) >= twrmk) iwrml = 1 -! - if (iwrml == 0 .or. ifrzl == 0) then -! if(pmid(l) < 50000.)print*,'need twet above 500mb' - dzkl = zint(l)-zint(l+1) - area1 = (twet(l)-273.15)*dzkl - if(ifrzl == 0 .and. twet(l) >= 273.15) surfw = surfw + area1 - if(iwrml == 0 .and. twet(l) <= 273.15) surfc = surfc + area1 - endif - enddo - if(surfc < -3000.0 .or. (areas8 < -3000.0 .and. surfw < 50.0)) then -! turn on the flag for ice pellets = 2 if its not on already -! iip=mod(iwx(i,j),4)/2 -! if (iip.lt.1) iwx(i,j)=iwx(i,j)+2 - iwx = iwx + 2 -! - elseif(tlmhk < 273.15) then -! turn on the flag for freezing rain = 4 if its not on already -! izr=mod(iwx(k),8)/4 -! if (izr.lt.1) iwx(k)=iwx(k)+4 - iwx = iwx + 4 - else -! turn on the flag for rain = 8 if its not on already -! irain=iwx(k)/8 -! if (irain.lt.1) iwx(k)=iwx(k)+8 - iwx = iwx + 8 - endif - endif -!--------------------------------------------------------- -! deallocate (twet) - - return - end -! -! -!ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc -! -! dophase is a subroutine written and provided by jim ramer at noaa/fsl -! -! ramer, j, 1993: an empirical technique for diagnosing precipitation -! type from model output. preprints, 5th conf. on aviation -! weather systems, vienna, va, amer. meteor. soc., 227-230. -! -! code adapted for wrf post 24 august 2005 g manikin -!ccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccccc -! - subroutine calwxt_ramer(lm,lp1,t,q,pmid,rh,td,pint,ptyp) - -! subroutine dophase(pq, ! input pressure sounding mb -! + t, ! input temperature sounding k -! + pmid, ! input pressure -! + pint, ! input interface pressure -! + q, ! input spec humidityfraction -! + lmh, ! input number of levels in sounding -! + ptyp) ! output(2) phase 2=rain, 3=frzg, 4=solid, -! 6=ip jc 9/16/99 -! use params_mod -! use ctlblk_mod -!- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - implicit none -! - real,parameter :: twice=266.55,rhprcp=0.80,deltag=1.02, & - & emelt=0.045,rlim=0.04,slim=0.85 - real,parameter :: twmelt=273.15,tz=273.15,efac=1.0 ! specify in params now -! - integer*4 i, k1, lll, k2, toodry -! - real xxx ,mye, icefrac - integer, intent(in) :: lm,lp1 - real,dimension(lm), intent(in) :: t,q,pmid,rh,td - real,dimension(lp1),intent(in) :: pint - integer, intent(out) :: ptyp -! - real,dimension(lm) :: tq,pq,rhq,twq -! - integer j,l,lev,ii - real rhmax,twmax,ptop,dpdrh,twtop,rhtop,wgt1,wgt2, & - rhavg,dtavg,dpk,ptw,pbot -! real b,qtmp,rate,qc -!zhang real,external :: xmytw -! -! initialize. - icefrac = -9999. -! - - ptyp = 0 - do l = 1,lm - lev = lp1 - l -! p(l)=pmid(l) -! qc=pq0/p(l) * exp(a2*(t(l)-a3)/(t(l)-a4)) -!gsm forcing q (qtmp) to be positive to deal with negative q values -! causing problems later in this subroutine -! qtmp=max(h1m12,q(l)) -! rhqtmp(lev)=qtmp/qc - rhq(lev) = rh(l) - pq(lev) = pmid(l) * 0.01 - tq(lev) = t(l) - enddo - - -! -!cc rate restriction removed by john cortinas 3/16/99 -! -! construct wet-bulb sounding, locate generating level. - twmax = -999.0 - rhmax = 0.0 - k1 = 0 ! top of precip generating layer - k2 = 0 ! layer of maximum rh -! - if (rhq(1) < rhprcp) then - toodry = 1 - else - toodry = 0 - end if -! - pbot = pq(1) -! nq=lm - do l = 1, lm -! xxx = tdofesat(esat(tq(l))*rhq(l)) -! xxx = td(l) !hc: use td consistent with gfs ice physics - xxx = td(lp1-l) !hc: use td consistent with gfs ice physics - if (xxx < -500.) return - twq(l) = xmytw(tq(l),xxx,pq(l)) - twmax = max(twq(l),twmax) - if (pq(l) >= 400.0) then - if (rhq(l) > rhmax) then - rhmax = rhq(l) - k2 = l - end if -! - if (l /= 1) then - if (rhq(l) >= rhprcp .or. toodry == 0) then - if (toodry /= 0) then - dpdrh = log(pq(l)/pq(l-1)) / (rhq(l)-rhq(l-1)) - pbot = exp(log(pq(l))+(rhprcp-rhq(l))*dpdrh) -! - ptw = pq(l) - toodry = 0 - else if (rhq(l)>= rhprcp) then - ptw = pq(l) - else - toodry = 1 - dpdrh = log(pq(l)/pq(l-1)) / (rhq(l)-rhq(l-1)) - ptw = exp(log(pq(l))+(rhprcp-rhq(l))*dpdrh) - -!lin dpdrh = (pq(i)-pq(i-1))/(rhq(i)-rhq(i-1)) -!lin ptw = pq(i)+(rhprcp-rhq(i))*dpdrh -! - end if -! - if (pbot/ptw >= deltag) then -!lin if (pbot-ptw.lt.deltag) goto 2003 - k1 = l - ptop = ptw - end if - end if - end if - end if - enddo -! -! gross checks for liquid and solid precip which dont require generating level. -! - if (twq(1) >= 273.15+2.0) then - ptyp = 8 ! liquid - icefrac = 0.0 - return - end if -! - if (twmax <= twice) then - icefrac = 1.0 - ptyp = 1 ! solid - return - end if -! -! check to see if we had no success with locating a generating level. -! - if (k1 == 0) return -! - if (ptop == pq(k1)) then - twtop = twq(k1) - rhtop = rhq(k1) - k2 = k1 - k1 = k1 - 1 - else - k2 = k1 - k1 = k1 - 1 - wgt1 = log(ptop/pq(k2)) / log(pq(k1)/pq(k2)) - wgt2 = 1.0 - wgt1 - twtop = twq(k1) * wgt1 + twq(k2) * wgt2 - rhtop = rhq(k1) * wgt1 + rhq(k2) * wgt2 - end if -! -! calculate temp and wet-bulb ranges below precip generating level. - do l = 1, k1 - twmax = max(twq(l),twmax) - enddo -! -! gross check for solid precip, initialize ice fraction. -! if (i.eq.1.and.j.eq.1) write (*,*) 'twmax=',twmax,twice,'twtop=',twtop - - if (twtop <= twice) then - icefrac = 1.0 - if (twmax <= twmelt) then ! gross check for solid precip. - ptyp = 1 ! solid precip - return - end if - lll = 0 - else - icefrac = 0.0 - lll = 1 - end if -! -! loop downward through sounding from highest precip generating level. - 30 continue -! - if (icefrac >= 1.0) then ! starting as all ice - if (twq(k1) < twmelt) go to 40 ! cannot commence melting - if (twq(k1) == twtop) go to 40 ! both equal twmelt, nothing h - wgt1 = (twmelt-twq(k1)) / (twtop-twq(k1)) - rhavg = rhq(k1) + wgt1 * (rhtop-rhq(k1)) * 0.5 - dtavg = (twmelt-twq(k1)) * 0.5 - dpk = wgt1 * log(pq(k1)/ptop) !lin dpk=wgt1*(pq(k1)-ptop) -! mye=emelt*(1.0-(1.0-rhavg)*efac) - mye = emelt * rhavg ** efac - icefrac = icefrac + dpk * dtavg / mye - else if (icefrac <= 0.0) then ! starting as all liquid - lll = 1 -! goto 1020 - if (twq(k1) > twice) go to 40 ! cannot commence freezing - if (twq(k1) == twtop) then - wgt1 = 0.5 - else - wgt1 = (twice-twq(k1)) / (twtop-twq(k1)) - end if - rhavg = rhq(k1) + wgt1 * (rhtop-rhq(k1)) * 0.5 - dtavg = twmelt - (twq(k1)+twice) * 0.5 - dpk = wgt1 * log(pq(k1)/ptop) !lin dpk=wgt1*(pq(k1)-ptop) -! mye = emelt*(1.0-(1.0-rhavg)*efac) - mye = emelt * rhavg ** efac - icefrac = icefrac + dpk * dtavg / mye - else if ((twq(k1) <= twmelt).and.(twq(k1) < twmelt)) then ! mix - rhavg = (rhq(k1)+rhtop) * 0.5 - dtavg = twmelt - (twq(k1)+twtop) * 0.5 - dpk = log(pq(k1)/ptop) !lin dpk=pq(k1)-ptop -! mye = emelt*(1.0-(1.0-rhavg)*efac) - mye = emelt * rhavg ** efac - icefrac = icefrac + dpk * dtavg / mye - else ! mix where tw curve crosses twmelt in layer - if (twq(k1) == twtop) go to 40 ! both equal twmelt, nothing h - wgt1 = (twmelt-twq(k1)) / (twtop-twq(k1)) - wgt2 = 1.0 - wgt1 - rhavg = rhtop + wgt2 * (rhq(k1)-rhtop) * 0.5 - dtavg = (twmelt-twtop) * 0.5 - dpk = wgt2 * log(pq(k1)/ptop) !lin dpk=wgt2*(pq(k1)-ptop) -! mye = emelt*(1.0-(1.0-rhavg)*efac) - mye = emelt * rhavg ** efac - icefrac = icefrac + dpk * dtavg / mye - icefrac = min(1.0,max(icefrac,0.0)) - if (icefrac <= 0.0) then -! goto 1020 - if (twq(k1) > twice) go to 40 ! cannot commence freezin - wgt1 = (twice-twq(k1)) / (twtop-twq(k1)) - dtavg = twmelt - (twq(k1)+twice) * 0.5 - else - dtavg = (twmelt-twq(k1)) * 0.5 - end if - rhavg = rhq(k1) + wgt1 * (rhtop-rhq(k1)) * 0.5 - dpk = wgt1 * log(pq(k1)/ptop) !lin dpk=wgt1*(pq(k1)-ptop) -! mye = emelt*(1.0-(1.0-rhavg)*efac) - mye = emelt * rhavg ** efac - icefrac = icefrac + dpk * dtavg / mye - end if -! - icefrac = min(1.0,max(icefrac,0.0)) - -! if (i.eq.1.and.j.eq.1) write (*,*) 'new icefrac:', icefrac, icefrac -! -! get next level down if there is one, loop back. - 40 continue - if (k1 > 1) then - twtop = twq(k1) - ptop = pq(k1) - rhtop = rhq(k1) - k1 = k1 - 1 - go to 30 - end if -! -! determine precip type based on snow fraction and surface wet-bulb. -! - if (icefrac >= slim) then - if (lll /= 0) then - ptyp = 2 ! ice pellets jc 9/16/99 - else - ptyp = 1 ! snow - end if - else if (icefrac <= rlim) then - if (twq(1).lt.tz) then - ptyp = 4 ! freezing precip - else - ptyp = 8 ! rain - end if - else - if (twq(1) < tz) then -!gsm not sure what to do when 'mix' is predicted; in previous -!gsm versions of this code for which i had to have an answer, -!gsm i chose sleet. here, though, since we have 4 other -!gsm algorithms to provide an answer, i will not declare a -!gsm type from the ramer in this situation and allow the -!gsm other algorithms to make the call. - - ptyp = 0 ! don't know -! ptyp = 5 ! mix - else -! ptyp = 5 ! mix - ptyp = 0 ! don't know - end if - end if - - return -! - end -! -! -!-------------------------------------------------------------------------- -!zhang - real function xmytw(t,td,p) -! function xmytw(t,td,p) -! - implicit none -! - integer*4 cflag, l - real f, c0, c1, c2, k, kd, kw, ew, t, td, p, ed, fp, s, & - & de -! & de, xmytw - data f, c0, c1, c2 /0.0006355, 26.66082, 0.0091379024, 6106.3960/ -! - xmytw = (t+td) / 2 - if (td >= t) return -! - if (t < 100.0) then - k = t + 273.15 - kd = td + 273.15 - if (kd >= k) return - cflag = 1 - else - k = t - kd = td - cflag = 0 - end if -! - ed = c0 - c1 * kd - c2 / kd - if (ed < -14.0 .or. ed > 7.0) return - ed = exp(ed) - ew = c0 - c1 * k - c2 / k - if (ew < -14.0 .or. ew > 7.0) return - ew = exp(ew) - fp = p * f - s = (ew-ed) / (k-kd) - kw = (k*fp+kd*s) / (fp+s) -! - do l = 1, 5 - ew = c0 - c1 * kw - c2 / kw - if (ew < -14.0 .or. ew > 7.0) return - ew = exp(ew) - de = fp * (k-kw) + ed - ew - if (abs(de/ew) < 1e-5) exit - s = ew * (c1-c2/(kw*kw)) - fp - kw = kw - de / s - enddo -! -! print *, 'kw ', kw - if (cflag /= 0) then - xmytw = kw - 273.15 - else - xmytw = kw - end if -! - return - end -! -! -!$$$ subprogram documentation block -! -! subprogram: calwxt_bourg calculate precipitation type (bourgouin) -! prgmmr: baldwin org: np22 date: 1999-07-06 -! -! abstract: this routine computes precipitation type -! using a decision tree approach that uses the so-called -! "energy method" of bourgouin of aes (canada) 1992 -! -! program history log: -! 1999-07-06 m baldwin -! 1999-09-20 m baldwin make more consistent with bourgouin (1992) -! 2005-08-24 g manikin added to wrf post -! 2007-06-19 m iredell mersenne twister, best practices -! 2008-03-03 g manikin added checks to prevent stratospheric warming -! episodes from being seen as "warm" layers -! impacting precip type -! -! usage: call calwxt_bourg(im,jm,jsta_2l,jend_2u,jsta,jend,lm,lp1, & -! & iseed,g, & -! & t,q,pmid,pint,lmh,zint,ptype) -! input argument list: -! im integer i dimension -! jm integer j dimension -! jsta_2l integer j dimension start point (including haloes) -! jend_2u integer j dimension end point (including haloes) -! jsta integer j dimension start point (excluding haloes) -! jend integer j dimension end point (excluding haloes) -! lm integer k dimension -! lp1 integer k dimension plus 1 -! iseed integer random number seed -! g real gravity (m/s**2) -! pthresh real precipitation threshold (m) -! t real(im,jsta_2l:jend_2u,lm) mid layer temp (k) -! q real(im,jsta_2l:jend_2u,lm) specific humidity (kg/kg) -! pmid real(im,jsta_2l:jend_2u,lm) mid layer pressure (pa) -! pint real(im,jsta_2l:jend_2u,lp1) interface pressure (pa) -! lmh real(im,jsta_2l:jend_2u) max number of layers -! zint real(im,jsta_2l:jend_2u,lp1) interface height (m) -! output argument list: -! ptype real(im,jm) instantaneous weather type () -! acts like a 4 bit binary -! 1111 = rain/freezing rain/ice pellets/snow -! where the one's digit is for snow -! the two's digit is for ice pellets -! the four's digit is for freezing rain -! and the eight's digit is for rain -! in other words... -! ptype=1 snow -! ptype=2 ice pellets/mix with ice pellets -! ptype=4 freezing rain/mix with freezing rain -! ptype=8 rain -! -! modules used: -! mersenne_twister pseudo-random number generator -! -! subprograms called: -! random_number pseudo-random number generator -! -! attributes: -! language: fortran 90 -! -! remarks: vertical order of arrays must be layer 1 = top -! and layer lmh = bottom -! -!$$$ - subroutine calwxt_bourg(lm,lp1,rn,g,t,q,pmid,pint,zint,ptype) - implicit none -! -! input: - integer,intent(in) :: lm,lp1 - real,intent(in) :: g,rn(2) - real,intent(in), dimension(lm) :: t, q, pmid - real,intent(in), dimension(lp1) :: pint, zint -! -! output: - integer, intent(out) :: ptype -! - integer ifrzl,iwrml,l,lhiwrm - real pintk1,areane,tlmhk,areape,pintk2,surfw,area1,dzkl,psfck,r1,r2 -! -! initialize weather type array to zero (ie, off). -! we do this since we want ptype to represent the -! instantaneous weather type on return. -! - ptype = 0 - psfck = pint(lm+1) - -! find the depth of the warm layer based at the surface -! this will be the cut off point between computing -! the surface based warm air and the warm air aloft -! -! lowest layer t -! - tlmhk = t(lm) - iwrml = lm + 1 - if (tlmhk >= 273.15) then - do l = lm, 2, -1 - if (t(l) >= 273.15 .and. t(l-1) < 273.15 .and. & - & iwrml == lm+1) iwrml = l - end do - end if -! -! now find the highest above freezing level -! - lhiwrm = lm + 1 - do l = lm, 1, -1 -! gsm added 250 mb check to prevent stratospheric warming situations -! from counting as warm layers aloft - if (t(l) >= 273.15 .and. pmid(l) > 25000.) lhiwrm = l - end do - -! energy variables -! surfw is the positive energy between the ground -! and the first sub-freezing layer above ground -! areane is the negative energy between the ground -! and the highest layer above ground -! that is above freezing -! areape is the positive energy "aloft" -! which is the warm energy not based at the ground -! (the total warm energy = surfw + areape) -! -! pintk1 is the pressure at the bottom of the layer -! pintk2 is the pressure at the top of the layer -! dzkl is the thickness of the layer -! ifrzl is a flag that tells us if we have hit -! a below freezing layer -! - pintk1 = psfck - ifrzl = 0 - areane = 0.0 - areape = 0.0 - surfw = 0.0 - - do l = lm, 1, -1 - if (ifrzl == 0 .and. t(l) <= 273.15) ifrzl = 1 - pintk2 = pint(l) - dzkl = zint(l)-zint(l+1) - if (t(l) >= 273.15 .and. pmid(l) > 25000.) then - area1 = log(t(l)/273.15) * g * dzkl - if (l < iwrml) then - areape = areape + area1 - else - surfw = surfw + area1 - endif - elseif (l > lhiwrm) then - area1 = log(t(l)/273.15) * g * dzkl - areane = areane + abs(area1) - endif - pintk1 = pintk2 - enddo - -! -! decision tree time -! - if (areape < 2.0) then ! very little or no positive energy aloft, check for - ! positive energy just above the surface to determine rain vs. snow - if (surfw < 5.6) then ! not enough positive energy just above the surface snow = 1 - ptype = 1 - else if (surfw > 13.2) then ! enough positive energy just above the surface rain = 8 - ptype = 8 - else ! transition zone, assume equally likely rain/snow - ! picking a random number, if <=0.5 snow - r1 = rn(1) - if (r1 <= 0.5) then ! snow = 1 - ptype = 1 - else ! rain = 8 - ptype = 8 - end if - end if -! - else ! some positive energy aloft, check for enough negative energy - ! to freeze and make ice pellets to determine ip vs. zr - - if (areane > 66.0+0.66*areape) then -! enough negative area to make ip, -! now need to check if there is enough positive energy -! just above the surface to melt ip to make rain - if (surfw < 5.6) then ! not enough energy at the surface to melt ip ice pellets = 2 - ptype = 2 - elseif (surfw > 13.2) then ! enough energy at the surface to melt ip rain = 8 - ptype = 8 - else ! transition zone, assume equally likely ip/rain picking a random number, if <=0.5 ip - r1 = rn(1) - if (r1 <= 0.5) then ! ice pellets = 2 - ptype = 2 - else ! rain = 8 - ptype = 8 - end if - end if - elseif (areane < 46.0+0.66*areape) then -! not enough negative energy to refreeze, check surface temp to determine rain vs. zr - if (tlmhk < 273.15) then ! freezing rain = 4 - ptype = 4 - else ! rain = 8 - ptype = 8 - end if - else -! transition zone, assume equally likely ip/zr picking a random number, if <=0.5 ip - r1 = rn(1) - if (r1 <= 0.5) then -! still need to check positive energy just above the surface to melt ip vs. rain - if (surfw < 5.6) then ! ice pellets = 2 - ptype = 2 - else if (surfw > 13.2) then ! rain = 8 - ptype = 8 - else -! transition zone, assume equally likely ip/rain picking a random number, if <=0.5 ip - r2 = rn(2) - if (r2 <= 0.5) then ! ice pellets = 2 - ptype = 2 - else ! rain = 8 - ptype = 8 - end if - end if - else -! not enough negative energy to refreeze, check surface temp to determine rain vs. zr - if (tlmhk < 273.15) then ! freezing rain = 4 - ptype = 4 - else ! rain = 8 - ptype = 8 - end if - end if - end if - end if -! - return - end -! -! - subroutine calwxt_revised(lm,lp1,t,q,pmid,pint, & - d608,rog,epsq,zint,twet,iwx) -! -! file: calwxt.f -! written: 11 november 1993, michael baldwin -! revisions: -! 30 sept 1994-setup new decision tree (m baldwin) -! 12 june 1998-conversion to 2-d (t black) -! 01-10-25 h chuang - modified to process hybrid model output -! 02-01-15 mike baldwin - wrf version -! 05-07-07 binbin zhou - add prec for rsm -! 05-08-24 geoff manikin - modified the area requirements -! to make an alternate algorithm -! -! -! routine to compute precipitation type using a decision tree -! approach that uses variables such as integrated wet bulb temp -! below freezing and lowest layer temperature -! -! see baldwin and contorno preprint from 13th weather analysis -! and forecasting conference for more details -! (or baldwin et al, 10th nwp conference preprint) -! -! since the original version of the algorithm has a high bias -! for freezing rain and sleet, the goal is to balance that bias -! with a version more likely to predict snow -! -! use params_mod -! use ctlblk_mod -!- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - implicit none -! -! list of variables needed -! parameters: -! d608,rog,h1,d00 -!hc parameter(d608=0.608,rog=287.04/9.8,h1=1.0,d00=0.0) -! -! input: -! t,q,pmid,htm,lmh,zint - - integer,intent(in) :: lm,lp1 - real,dimension(lm),intent(in) :: t,q,pmid,twet - real,dimension(lp1),intent(in) :: pint,zint - real,intent(in) :: d608,rog,epsq -! output: -! iwx - instantaneous weather type. -! acts like a 4 bit binary -! 1111 = rain/freezing rain/ice pellets/snow -! where the one's digit is for snow -! the two's digit is for ice pellets -! the four's digit is for freezing rain -! and the eight's digit is for rain - integer, intent(out) :: iwx -! internal: -! - real, parameter :: d00=0.0 - integer karr,licee - real tcold,twarm -! - integer l,lmhk,lice,iwrml,ifrzl - real psfck,tdchk,a,tdkl,tdpre,tlmhk,twrmk,areas8,areap4,area1, & - surfw,surfc,dzkl,pintk1,pintk2,pm150,qkl,tkl,pkl,area0,areap0 - -! subroutines called: -! wetbulb -! -! -! initialize weather type array to zero (ie, off). -! we do this since we want iwx to represent the -! instantaneous weather type on return. -! -! -! allocate local storage -! -! - iwx = 0 - lmhk=lm -! -! find coldest and warmest temps in saturated layer between -! 70 mb above ground and 500 mb -! also find highest saturated layer in that range -! -!meb - psfck = pint(lp1) -!meb - tdchk = 2.0 - 760 tcold = t(lmhk) - twarm = t(lmhk) - licee = lmhk -! - do l=1,lmhk - qkl = q(l) - qkl = max(epsq,qkl) - tkl = t(l) - pkl = pmid(l) -! -! skip past this if the layer is not between 70 mb above ground -! and 500 mb -! - if (pkl < 50000.0 .or. pkl > psfck-7000.0) cycle - a = log(qkl*pkl/(6.1078*(0.378*qkl+0.622))) - tdkl = (237.3*a)/(17.269-a)+273.15 - tdpre = tkl-tdkl - if (tdpre < tdchk .and. tkl < tcold) tcold = tkl - if (tdpre < tdchk .and. tkl > twarm) twarm = tkl - if (tdpre < tdchk .and. l < licee) licee = l - enddo -! -! if no sat layer at dew point dep=tdchk, increase tdchk -! and start again (but don't make tdchk > 6) -! - if (tcold == t(lmhk) .and. tdchk < 6.0) then - tdchk = tdchk + 2.0 - goto 760 - endif -! -! lowest layer t -! - karr = 0 - lmhk = lm - tlmhk = t(lmhk) -! -! decision tree time -! - if (tcold > 269.15) then - if (tlmhk <= 273.15) then -! turn on the flag for freezing rain = 4 if its not on already -! izr=mod(iwx,8)/4 -! if (izr.lt.1) iwx=iwx+4 - iwx = iwx + 4 - goto 850 - else -! turn on the flag for rain = 8 if its not on already -! irain=iwx/8 -! if (irain.lt.1) iwx=iwx+8 - iwx = iwx + 8 - goto 850 - endif - endif - karr = 1 - 850 continue -! - if (karr > 0)then - lmhk = lm - lice = licee -!meb - psfck = pint(lp1) -!meb - tlmhk = t(lmhk) - twrmk = twarm -! -! twet area variables -! calculate only what is needed -! from ground to 150 mb above surface -! from ground to tcold layer -! and from ground to 1st layer where wet bulb t < 0.0 -! -! pintk1 is the pressure at the bottom of the layer -! pintk2 is the pressure at the top of the layer -! -! areap4 is the area of twet above -4 c below highest sat lyr -! areap0 is the area of twet above 0 c below highest sat lyr -! - areas8 = d00 - areap4 = d00 - areap0 = d00 - surfw = d00 - surfc = d00 - -! - do l=lmhk,lice,-1 - dzkl = zint(l)-zint(l+1) - area1 = (twet(l)-269.15)*dzkl - area0 = (twet(l)-273.15)*dzkl - if (twet(l) >= 269.15) areap4 = areap4 + area1 - if (twet(l) >= 273.15) areap0 = areap0 + area0 - enddo -! -! if (areap4.lt.3000.0) then turn on the flag for snow = 1 if its not on already -! isno=mod(iwx,2) -! if (isno.lt.1) iwx=iwx+1 -! iwx=iwx+1 -! go to 1900 -! endif - if (areap0 < 350.0) then ! turn on the flag for snow = 1 - iwx = iwx + 1 - return - endif -! -! areas8 is the net area of twet w.r.t. freezing in lowest 150mb -! - pintk1 = psfck - pm150 = psfck - 15000. -! - do l=lmhk,1,-1 - pintk2 = pint(l) - if(pintk1 >= pm150) then - dzkl = zint(l)-zint(l+1) -! -! sum partial layer if in 150 mb agl layer -! - if(pintk2 < pm150) dzkl = t(l)*(q(l)*d608+1.0)*rog* & - log(pintk1/pm150) - area1 = (twet(l)-273.15)*dzkl - areas8 = areas8 + area1 - endif - pintk1=pintk2 - enddo -! -! surfw is the area of twet above freezing between the ground -! and the first layer above ground below freezing -! surfc is the area of twet below freezing between the ground -! and the warmest sat layer -! - ifrzl = 0 - iwrml = 0 -! - do l=lmhk,1,-1 - if (ifrzl == 0 .and. t(l) < 273.15) ifrzl = 1 - if (iwrml == 0 .and. t(l) >= twrmk) iwrml = 1 -! - if (iwrml == 0 .or. ifrzl == 0) then -! if(pmid(l) .lt. 50000.)print*,'twet needed above 500mb' - dzkl = zint(l)-zint(l+1) - area1 = (twet(l)-273.15)*dzkl - if(ifrzl == 0 .and. twet(l) >= 273.15) surfw = surfw + area1 - if(iwrml == 0 .and. twet(l) <= 273.15) surfc = surfc + area1 - endif - enddo - if (surfc < -3000.0 .or. & - & (areas8 < -3000.0 .and. surfw < 50.0)) then -! turn on the flag for ice pellets = 2 if its not on already -! iip=mod(iwx,4)/2 -! if (iip.lt.1) iwx=iwx+2 - iwx = iwx + 2 - return - endif -! - if (tlmhk < 273.15) then -! turn on the flag for freezing rain = 4 if its not on already -! izr=mod(iwx(k),8)/4 -! if (izr.lt.1) iwx(k)=iwx(k)+4 - iwx = iwx + 4 - else -! turn on the flag for rain = 8 if its not on already -! irain=iwx(k)/8 -! if (irain.lt.1) iwx(k)=iwx(k)+8 - iwx = iwx + 8 - endif -! print *, 'revised check ', iwx(500,800) - endif - - return - end -! -! - subroutine calwxt_explicit(lm,tskin,sr,f_rimef,iwx) -! -! file: calwxt.f -! written: 24 august 2005, g manikin and b ferrier -! -! routine to compute precipitation type using explicit fields -! from the model microphysics - -!- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - implicit none -! -! list of variables needed -! parameters: -! -! input: - integer, intent(in) :: lm - real,intent(in) :: tskin, sr - real,intent(in) :: f_rimef(lm) - integer,intent(out) :: iwx - real snow -! real psfc -! -! allocate local storage -! - iwx = 0 - -!gsm the rsm is currently incompatible with this routine -!gsm according to b ferrier, there may be a way to write -!gsm a version of this algorithm to work with the rsm -!gsm microphysics, but it doesn't exist at this time - -! a snow ratio less than 0.5 eliminates snow and sleet -! use the skin temperature to distinguish rain from freezing rain -! note that 2-m temperature may be a better choice if the model -! has a cold bias for skin temperature -! - if (sr < 0.5) then -! surface (skin) potential temperature and temperature. -! psfc=pmid(lm) -! tskin=ths*(psfc/p1000)**capa - - if (tskin < 273.15) then ! freezing rain = 4 - iwx = iwx + 4 - else ! rain = 8 - iwx = iwx + 8 - endif - else -! -! distinguish snow from sleet with the rime factor -! - if(f_rimef(lm) >= 10) then ! sleet = 2 - iwx = iwx + 2 - else - snow = 1 - iwx = iwx + 1 - endif - endif - end -! -! - subroutine calwxt_dominant(nalg,rain,freezr,sleet,snow, & - & domr,domzr,domip,doms) -! -! written: 24 august 2005, g manikin -! -! this routine takes the precip type solutions from different -! algorithms and sums them up to give a dominant type -! -!- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - implicit none -! -! input: - integer,intent(in) :: nalg - real,intent(out) :: doms,domr,domzr,domip - integer,dimension(nalg),intent(in) :: rain,snow,sleet,freezr - integer l - real totsn,totip,totr,totzr -!-------------------------------------------------------------------------- -! print* , 'into dominant' - domr = 0. - doms = 0. - domzr = 0. - domip = 0. -! - totsn = 0 - totip = 0 - totr = 0 - totzr = 0 -! loop over the number of different algorithms that are used - do l = 1, nalg - if (rain(l) > 0) then - totr = totr + 1 - elseif (snow(l) > 0) then - totsn = totsn + 1 - elseif (sleet(l) > 0) then - totip = totip + 1 - elseif (freezr(l) > 0) then - totzr = totzr + 1 - endif - enddo - -! ties are broken to favor the most dangerous form of precip -! freezing rain > snow > sleet > rain - if (totsn > totip) then - if (totsn > totzr) then - if (totsn >= totr) then - doms = 1 - else - domr = 1 - endif - elseif (totzr >= totr) then - domzr = 1 - else - domr = 1 - endif - else if (totip > totzr) then - if (totip >= totr) then - domip = 1 - else - domr = 1 - endif - else if (totzr >= totr) then - domzr = 1 - else - domr = 1 - endif -! - return - end - -!> \section arg_table_calpreciptype_finalize Argument table -!! - subroutine calpreciptype_finalize - end subroutine calpreciptype_finalize - - end module calpreciptype diff --git a/physics/radlw_main.f b/physics/radlw_main.f index 61c30630f..a15d1c2c1 100644 --- a/physics/radlw_main.f +++ b/physics/radlw_main.f @@ -454,8 +454,8 @@ end subroutine lwrad_init !! \section arg_table_lwrad_run Argument Table !! | local var name | longname | description | units | rank | type | kind | intent | optional | !! |-----------------|-----------------------------------------|--------------------------------------------------------|---------|------|-------------|-----------|--------|----------| -!! | plyr | air_pressure | air pressure layer | hPa | 2 | real | kind_phys | in | F | -!! | plvl | air_pressure_level | air pressure level | hPa | 2 | real | kind_phys | in | F | +!! | plyr | air_pressure_in_hPa | air pressure layer | hPa | 2 | real | kind_phys | in | F | +!! | plvl | air_pressure_level_in_hPa | air pressure level | hPa | 2 | real | kind_phys | in | F | !! | tlyr | air_temperature | air temperature layer | K | 2 | real | kind_phys | in | F | !! | tlvl | air_temperature_level | air temperature level | K | 2 | real | kind_phys | in | F | !! | qlyr | specific_humidity | specific humidity layer | gm gm-1 | 2 | real | kind_phys | in | F | @@ -472,7 +472,7 @@ end subroutine lwrad_init !! | icseed | seed_random_numbers | seed for random number generation | | 2 | integer | | in | F | !! | aeraod | aerosol_optical_depth | aerosol optical depth | | 3 | real | kind_phys | in | F | !! | aerssa | aerosol_single_scattering_albedo | aerosol sngle scattering albedo | | 3 | real | kind_phys | in | F | -!! | sfemis | surface_longwave_emissivity | surface emissivity | | 1 | real | kind_phys | in | F | +!! | sfemis | surface_longwave_emissivity | surface emissivity | frac | 1 | real | kind_phys | in | F | !! | sfgtmp | surface_groud_temperature | surface ground temperature | K | 1 | real | kind_phys | in | F | !! | npts | horizontal_loop_extent | horizontal dimension | index | 0 | integer | | in | F | !! | nlay | vertical_layer_dimension | vertical layer dimension | index | 0 | integer | | in | F | diff --git a/physics/radsw_main.f b/physics/radsw_main.f index 802646764..30dae805e 100644 --- a/physics/radsw_main.f +++ b/physics/radsw_main.f @@ -587,8 +587,8 @@ end subroutine swrad_init !! \section arg_table_swrad_run Argument Table !! | local var name | longname | description | units | rank | type | kind | intent | optional | !! |-----------------|-----------------------------------------|--------------------------------------------------------|---------|------|-------------|-----------|--------|----------| -!! | plyr | air_pressure | air pressure layer | hPa | 2 | real | kind_phys | in | F | -!! | plvl | air_pressure_level | air pressure level | hPa | 2 | real | kind_phys | in | F | +!! | plyr | air_pressure_in_hPa | air pressure layer | hPa | 2 | real | kind_phys | in | F | +!! | plvl | air_pressure_level_in_hPa | air pressure level | hPa | 2 | real | kind_phys | in | F | !! | tlyr | air_temperature | air temperature layer | K | 2 | real | kind_phys | in | F | !! | tlvl | air_temperature_level | air temperature level | K | 2 | real | kind_phys | in | F | !! | qlyr | specific_humidity | specific humidity layer | gm gm-1 | 2 | real | kind_phys | in | F | @@ -605,7 +605,7 @@ end subroutine swrad_init !! | sfcalb_nir_dif | albedo_sfc_nir_dif | near infrared sw albedo for surface diffuse irradiance | | 1 | real | kind_phys | in | F | !! | sfcalb_uvis_dir | albedo_sfc_uvis_dir | uv - visible sw albedo for surface direct irradiance | | 1 | real | kind_phys | in | F | !! | sfcalb_uvis_dif | albedo_sfc_uvis_dif | uv - visible sw albedo for surface diffuse irradiance | | 1 | real | kind_phys | in | F | -!! | cosz | cosine_of_zenith_angle | cosine of the solar zenit angle | | 1 | real | kind_phys | in | F | +!! | cosz | cosine_of_zenith_angle | cosine of the solar zenit angle | none | 1 | real | kind_phys | in | F | !! | solcon | solar_constant | solar constant | W m-2 | 0 | real | kind_phys | in | F | !! | nday | daytime_points_dimension | daytime points dimension | index | 0 | integer | | in | F | !! | idxday | daytime_points | daytime points | | 1 | integer | | in | F | diff --git a/physics/sfc_nst.f b/physics/sfc_nst.f index 526de4263..a934f907f 100644 --- a/physics/sfc_nst.f +++ b/physics/sfc_nst.f @@ -39,8 +39,7 @@ module sfc_nst !! \section arg_table_sfc_nst_init Argument Table !! subroutine sfc_nst_init - - end + end subroutine sfc_nst_init !> \brief This subroutine is empty since there are no procedures that need to be done to finalize the GFS NSST code. !! @@ -49,8 +48,7 @@ subroutine sfc_nst_init !! \section arg_table_sfc_nst_finalize Argument Table !! subroutine sfc_nst_finalize - - end + end subroutine sfc_nst_finalize !> \brief This subroutine calls the Thermal Skin-layer and Diurnal Thermocline models to update the NSST profile. !! @@ -689,10 +687,10 @@ subroutine sfc_nst_run & ! if (lprnt) print *,' tskin=',tskin(ipr) return - end + end subroutine sfc_nst_run !> @} !! @} - end module + end module sfc_nst @@ -723,8 +721,7 @@ module sfc_nst_pre !! \section arg_table_sfc_nst_init Argument Table !! subroutine sfc_nst_pre_init - - end + end subroutine sfc_nst_pre_init !> \brief Brief description of the subroutine !! @@ -733,8 +730,7 @@ subroutine sfc_nst_pre_init !! \section arg_table_sfc_nst_finalize Argument Table !! subroutine sfc_nst_pre_finalize - - end + end subroutine sfc_nst_pre_finalize !> \brief Brief description of the subroutine !! @@ -790,11 +786,11 @@ subroutine sfc_nst_pre_run & enddo return - end + end subroutine sfc_nst_pre_run !> @} !! @} - end module + end module sfc_nst_pre @@ -824,8 +820,7 @@ module sfc_nst_post !! \section arg_table_sfc_nst_init Argument Table !! subroutine sfc_nst_post_init - - end + end subroutine sfc_nst_post_init !> \brief Brief description of the subroutine !! @@ -834,8 +829,7 @@ subroutine sfc_nst_post_init !! \section arg_table_sfc_nst_finalize Argument Table !! subroutine sfc_nst_post_finalize - - end + end subroutine sfc_nst_post_finalize !> \brief Brief description of the subroutine !! @@ -930,8 +924,8 @@ subroutine sfc_nst_post_run & ! & ' dt_cool=',dt_cool(ipr),' dt_warm=',dt_warm(ipr),' kdt=',kdt return - end + end subroutine sfc_nst_post_run !> @} !! @} - end module + end module sfc_nst_post diff --git a/physics/sfc_sice.f b/physics/sfc_sice.f index 01160cd02..0ab1a7e06 100644 --- a/physics/sfc_sice.f +++ b/physics/sfc_sice.f @@ -23,49 +23,49 @@ end subroutine sfc_sice_init subroutine sfc_sice_finalize end subroutine sfc_sice_finalize !! -!! \section arg_table_sice_run Arguments -!! | local var name | longname | description | units | rank | type | kind | intent | optional | -!! |----------------|-------------------------------------------------------|---------------------------------------------|---------------|------|---------|-----------|--------|----------| -!! | im | horizontal_loop_extent | horizontal loop extent, start at 1 | index | 0 | integer | | in | F | -!! | km | vertical_loop_extent | vertical loop extent, start at 1 | index | 0 | integer | | in | F | -!! | ps | surface_air_pressure | surface pressure | Pa | 1 | real | kind_phys | in | F | -!! | u1 | x_wind_at_lowest_layer | u component of surface layer wind | m s-1 | 1 | real | kind_phys | in | F | -!! | v1 | y_wind_at_lowest_layer | v component of surface layer wind | m s-1 | 1 | real | kind_phys | in | F | -!! | t1 | air_temperature_at_lowest_layer | surface layer mean temperature | K | 1 | real | kind_phys | in | F | -!! | q1 | specific_humidity_at_lowest_layer | surface layer mean specific humidity | kg kg-1 | 1 | real | kind_phys | in | F | -!! | delt | time_step_for_dynamics | time step | s | 0 | real | kind_phys | in | F | -!! | sfcemis | surface_longwave_emissivity | sfc lw emissivity | frac | 1 | real | kind_phys | in | F | -!! | dlwflx | surface_downwelling_longwave_flux | total sky sfc downward lw flux | W m-2 | 1 | real | kind_phys | in | F | -!! | sfcnsw | surface_net_downward_shortwave_flux | total sky sfc netsw flx into ground | W m-2 | 1 | real | kind_phys | in | F | -!! | sfcdsw | surface_downwelling_shortwave_flux | total sky sfc downward sw flux | W m-2 | 1 | real | kind_phys | in | F | -!! | srflag | flag_for_precipitation_type | snow/rain flag for precipitation | flag | 1 | real | kind_phys | in | F | -!! | cm | surface_drag_coefficient_for_momentum_in_air | surface exchange coeff for momentum | none | 1 | real | kind_phys | in | F | -!! | ch | surface_drag_coefficient_for_heat_and_moisture_in_air | surface exchange coeff heat & moisture | none | 1 | real | kind_phys | in | F | -!! | prsl1 | air_pressure_at_lowest_model_layer | surface layer mean pressure | Pa | 1 | real | kind_phys | in | F | -!! | prslki | ratio_of_exner_function_between_midlayer_and_interface_at_lowest_model_layer | Exner function at 1st layer | ratio | 1 | real | kind_phys | in | F | -!! | islimsk | sea_land_ice_mask | sea/land/ice mask (=0/1/2) | flag | 1 | integer | | in | F | -!! | ddvel | surface_wind_enhancement_due_to_convection | wind enhancement due to convection | m s-1 | 1 | real | kind_phys | in | F | -!! | flag_iter | flag_for_iteration | flag for iteration | flag | 1 | logical | | in | F | -!! | mom4ice | flag_for_mom4_coupling | flag for Mom4 coupling | flag | 0 | logical | | in | F | -!! | lsm | flag_for_land_surface_scheme | flag for land sfc scheme =0: osu; =1: noah | flag | 0 | integer | | in | F | -!! | lprnt | flag_print | switch for printing sample column to stdout | flag | 0 | logical | | in | F | -!! | ipr | horizontal_index_of_printed_column | horizontal index of printed column | flag | 0 | integer | | in | F | -!! | hice | sea_ice_thickness | sea-ice thickness | m | 1 | real | kind_phys | inout | F | -!! | fice | sea_ice_concentration | sea-ice concentration [0,1] | frac | 1 | real | kind_phys | inout | F | -!! | tice | sea_ice_temperature | sea-ice surface temperature | K | 1 | real | kind_phys | inout | F | -!! | weasd | water_equivalent_accumulated_snow_depth | water equivalent accumulated snow depth | mm | 1 | real | kind_phys | inout | F | -!! | tskin | surface_skin_temperature | ground surface skin temperature | K | 1 | real | kind_phys | inout | F | -!! | tprcp | precipitation_amount_in_one_dynamics_time_step | total precipitation | kg m-2 s-1 | 1 | real | kind_phys | inout | F | -!! | stc | soil_temperature | soil temp | K | 2 | real | kind_phys | inout | F | -!! | ep | surface_upward_potential_latent_heat_flux | potential evaporation | W m-2 | 1 | real | kind_phys | inout | F | -!! | snwdph | surface_snow_thickness_water_equivalent | water equivalent snow depth | mm | 1 | real | kind_phys | out | F | -!! | qsurf | surface_specific_humidity | sfc air saturation specific humidity | kg kg-1 | 1 | real | kind_phys | out | F | -!! | snowmt | surface_snow_melt | snow melt during timestep | m | 1 | real | kind_phys | out | F | -!! | gflux | upward_heat_flux_in_soil | soil heat flux | W m-2 | 1 | real | kind_phys | out | F | -!! | cmm | surface_drag_wind_speed_for_momentum_in_air | surf mom exch coef time mean surf wind | m s-1 | 1 | real | kind_phys | out | F | -!! | chh | surface_drag_mass_flux_for_heat_and_moisture_in_air | surf h&m exch coef time surf wind & density | kg m-2 s-1 | 1 | real | kind_phys | out | F | -!! | evap | kinematic_surface_upward_latent_heat_flux | evaperative latent heat flux | kg kg-1 m s-1 | 1 | real | kind_phys | out | F | -!! | hflx | kinematic_surface_upward_sensible_heat_flux | kinematic sensible heat flux | K m s-1 | 1 | real | kind_phys | out | F | +!! \section arg_table_sfc_sice_run Arguments +!! | local var name | longname | description | units | rank | type | kind | intent | optional | +!! |----------------|-------------------------------------------------------|----------------------------------------------------------|---------------|------|---------|-----------|--------|----------| +!! | im | horizontal_loop_extent | horizontal loop extent, start at 1 | index | 0 | integer | | in | F | +!! | km | vertical_loop_extent | vertical loop extent, start at 1 | index | 0 | integer | | in | F | +!! | ps | surface_air_pressure | surface pressure | Pa | 1 | real | kind_phys | in | F | +!! | u1 | x_wind_at_lowest_layer | u component of surface layer wind | m s-1 | 1 | real | kind_phys | in | F | +!! | v1 | y_wind_at_lowest_layer | v component of surface layer wind | m s-1 | 1 | real | kind_phys | in | F | +!! | t1 | air_temperature_at_lowest_layer | surface layer mean temperature | K | 1 | real | kind_phys | in | F | +!! | q1 | specific_humidity_at_lowest_layer | surface layer mean specific humidity | kg kg-1 | 1 | real | kind_phys | in | F | +!! | delt | time_step_for_dynamics | time step | s | 0 | real | kind_phys | in | F | +!! | sfcemis | surface_longwave_emissivity | sfc lw emissivity | frac | 1 | real | kind_phys | in | F | +!! | dlwflx | surface_downwelling_longwave_flux | total sky sfc downward lw flux | W m-2 | 1 | real | kind_phys | in | F | +!! | sfcnsw | surface_net_downward_shortwave_flux | total sky sfc netsw flx into ground | W m-2 | 1 | real | kind_phys | in | F | +!! | sfcdsw | surface_downwelling_shortwave_flux | total sky sfc downward sw flux | W m-2 | 1 | real | kind_phys | in | F | +!! | srflag | flag_for_precipitation_type | snow/rain flag for precipitation | flag | 1 | real | kind_phys | in | F | +!! | cm | surface_drag_coefficient_for_momentum_in_air | surface exchange coeff for momentum | none | 1 | real | kind_phys | in | F | +!! | ch | surface_drag_coefficient_for_heat_and_moisture_in_air | surface exchange coeff heat & moisture | none | 1 | real | kind_phys | in | F | +!! | prsl1 | air_pressure_at_lowest_model_layer | surface layer mean pressure | Pa | 1 | real | kind_phys | in | F | +!! | prslki | ratio_of_exner_function_between_midlayer_and_interface_at_lowest_model_layer | Exner function ratio at 1st layer | ratio | 1 | real | kind_phys | in | F | +!! | islimsk | sea_land_ice_mask | sea/land/ice mask (=0/1/2) | flag | 1 | integer | | in | F | +!! | ddvel | surface_wind_enhancement_due_to_convection | wind enhancement due to convection | m s-1 | 1 | real | kind_phys | in | F | +!! | flag_iter | flag_for_iteration | flag for iteration | flag | 1 | logical | | in | F | +!! | mom4ice | flag_for_mom4_coupling | flag for Mom4 coupling | flag | 0 | logical | | in | F | +!! | lsm | flag_for_land_surface_scheme | flag for land sfc scheme =0: osu; =1: noah | flag | 0 | integer | | in | F | +!! | lprnt | flag_print | switch for printing sample column to stdout | flag | 0 | logical | | in | F | +!! | ipr | horizontal_index_of_printed_column | horizontal index of printed column | index | 0 | integer | | in | F | +!! | hice | sea_ice_thickness | sea-ice thickness | m | 1 | real | kind_phys | inout | F | +!! | fice | sea_ice_concentration | sea-ice concentration [0,1] | frac | 1 | real | kind_phys | inout | F | +!! | tice | sea_ice_temperature | sea-ice surface temperature | K | 1 | real | kind_phys | inout | F | +!! | weasd | water_equivalent_accumulated_snow_depth | water equivalent accumulated snow depth | mm | 1 | real | kind_phys | inout | F | +!! | tskin | surface_skin_temperature | ground surface skin temperature | K | 1 | real | kind_phys | inout | F | +!! | tprcp | precipitation_amount_in_one_dynamics_time_step | total precipitation | kg m-2 | 1 | real | kind_phys | inout | F | +!! | stc | soil_temperature | soil temp | K | 2 | real | kind_phys | inout | F | +!! | ep | surface_upward_potential_latent_heat_flux | potential evaporation | W m-2 | 1 | real | kind_phys | inout | F | +!! | snwdph | surface_snow_thickness_water_equivalent | water equivalent snow depth | mm | 1 | real | kind_phys | out | F | +!! | qsurf | surface_specific_humidity | sfc air saturation specific humidity | kg kg-1 | 1 | real | kind_phys | out | F | +!! | snowmt | surface_snow_melt | snow melt during timestep | m | 1 | real | kind_phys | out | F | +!! | gflux | upward_heat_flux_in_soil | soil heat flux | W m-2 | 1 | real | kind_phys | out | F | +!! | cmm | surface_drag_wind_speed_for_momentum_in_air | surf mom exch coef time mean surf wind | m s-1 | 1 | real | kind_phys | out | F | +!! | chh | surface_drag_mass_flux_for_heat_and_moisture_in_air | surf h&m exch coef time surf wind & density | kg m-2 s-1 | 1 | real | kind_phys | out | F | +!! | evap | kinematic_surface_upward_latent_heat_flux | evaperative latent heat flux | kg kg-1 m s-1 | 1 | real | kind_phys | out | F | +!! | hflx | kinematic_surface_upward_sensible_heat_flux | kinematic sensible heat flux | K m s-1 | 1 | real | kind_phys | out | F | !! !! \section general General Algorithm !! \section detailed Detailed Algorithm @@ -74,7 +74,7 @@ subroutine sfc_sice_run & & ( im, km, ps, u1, v1, t1, q1, delt, & & sfcemis, dlwflx, sfcnsw, sfcdsw, srflag, & & cm, ch, prsl1, prslki, islimsk, ddvel, & - & flag_iter, mom4ice, lsm, lprnt,ipr, & ! -- inputs from here and above + & flag_iter, mom4ice, lsm, lprnt, ipr, & ! -- inputs from here and above & hice, fice, tice, weasd, tskin, tprcp, stc, ep, & ! -- in/outs & snwdph, qsurf, snowmt, gflux, cmm, chh, evap, hflx & ! -- outputs & ) @@ -743,19 +743,19 @@ end subroutine sfc_sice_pre_finalize !! -!! \section arg_table_sice_pre Argument Table -!! | local var name | longname | description | units | rank | type | kind | intent | optional | -!! |----------------|-------------------------------------------------------|---------------------------------------------|---------------|------|---------|-----------|--------|----------| -!! | im | horizontal_loop_extent | horizontal loop extent, start at 1 | index | 0 | integer | | in | F | -!! | fice | sea_ice_concentration | sea-ice concentration [0,1] | frac | 1 | real | kind_phys | in | F | -!! | hice | sea_ice_thickness | sea-ice thickness | m | 1 | real | kind_phys | in | F | -!! | tisfc | sea_ice_temperature | sea-ice surface temperature | K | 1 | real | kind_phys | in | F | -!! | prsik | exter_function_at_lowest_model_interface | external function at lowest model interface | none | 1 | real | kind_phys | in | F | -!! | prslk | dimensionless_exner_function | dimensionless_exner_function | none | 1 | real | kind_phys | in | F | -!! | cice | sea_ice_concentration | sea-ice concentration [0,1] | frac | 1 | real | kind_phys | out | F | -!! | zice | sea_ice_thickness | sea-ice thickness | m | 1 | real | kind_phys | out | F | -!! | tice | sea_ice_temperature | sea-ice surface temperature | K | 1 | real | kind_phys | out | F | -!! | work3 | ratio_of_exner_function_between_midlayer_and_interface_at_lowest_model_layer | Exner function at 1st layer | ratio | 1 | real | kind_phys | out | F | +!! \section arg_table_sfc_sice_pre_run Argument Table +!! | local var name | longname | description | units | rank | type | kind | intent | optional | +!! |----------------|-------------------------------------------------------|----------------------------------------------------------|---------------|------|---------|-----------|--------|----------| +!! | im | horizontal_loop_extent | horizontal loop extent, start at 1 | index | 0 | integer | | in | F | +!! | fice | sea_ice_concentration | sea-ice concentration [0,1] | frac | 1 | real | kind_phys | in | F | +!! | hice | sea_ice_thickness | sea-ice thickness | m | 1 | real | kind_phys | in | F | +!! | tisfc | sea_ice_temperature | sea-ice surface temperature | K | 1 | real | kind_phys | in | F | +!! | prsik | exter_function_at_lowest_model_interface | external function at lowest model interface | none | 1 | real | kind_phys | in | F | +!! | prslk | dimensionless_exner_function_at_lowest_model_level | dimensionless exner function at lowest model level | none | 1 | real | kind_phys | in | F | +!! | cice | sea_ice_concentration | sea-ice concentration [0,1] | frac | 1 | real | kind_phys | out | F | +!! | zice | sea_ice_thickness | sea-ice thickness | m | 1 | real | kind_phys | out | F | +!! | tice | sea_ice_temperature | sea-ice surface temperature | K | 1 | real | kind_phys | out | F | +!! | work3 | ratio_of_exner_function_between_midlayer_and_interface_at_lowest_model_layer | Exner function ratio at 1st layer | ratio | 1 | real | kind_phys | out | F | !! !! @{ subroutine sfc_sice_pre_run(im, fice, hice, tisfc , prsik, prslk, & @@ -786,7 +786,7 @@ subroutine sfc_sice_pre_run(im, fice, hice, tisfc , prsik, prslk, & enddo return - end + end subroutine sfc_sice_pre_run end module sfc_sice_pre @@ -810,7 +810,7 @@ end subroutine sfc_sice_post_finalize !! -!! \section arg_table_sice_post Argument Table +!! \section arg_table_sfc_sice_post_run Argument Table !! | local var name | longname | description | units | rank | type | kind | intent | optional | !! |----------------|-------------------------------------------------------|---------------------------------------------|---------------|------|---------|-----------|--------|----------| !! | im | horizontal_loop_extent | horizontal loop extent, start at 1 | index | 0 | integer | | in | F |