Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add capability to use RAP/HRRR MASSDEN as smoke IC/LBCs #923

Merged
merged 18 commits into from
Nov 12, 2024
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
28 changes: 28 additions & 0 deletions parm/varmap_tables/GSDphys_smoke_var_map.txt
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
dzdt dzdt set_to_fill 0 D
delta_p delp skip 0 D
sphum sphum intrp 1E-7 T
liq_wat liq_wat intrp 0 T
o3mr o3mr intrp 1E-7 T
rainwat rainwat intrp 0 T
ice_wat ice_wat intrp 0 T
snowwat snowwat intrp 0 T
graupel graupel intrp 0 T
ice_nc ice_nc intrp -1.0 T
rain_nc rain_nc intrp -1.0 T
water_nc water_nc intrp -1.0 T
liq_aero liq_aero intrp 0 T
ice_aero ice_aero intrp 0 T
sgs_tke sgs_tke intrp 0 T
vtype vtype skip 0 S
sotype stype skip 0 S
vfrac vfrac skip 0 S
fricv uustar skip 0 S
sfcr zorl set_to_fill 0.01 S
soilw smc stop 0 S
soilt stc stop 0 S
cnwat cnwat set_to_fill 0.0 S
icetk icetk set_to_fill 265.0 S
weasd weasd set_to_fill 0.0 S
snod snod set_to_fill 0.0 S
tprcp tprcp set_to_fill 0.0 S
massden smoke set_to_fill 1E-12 T
2 changes: 1 addition & 1 deletion parm/varmap_tables/GSDphys_var_map.txt
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,4 @@ cnwat cnwat set_to_fill 0.0 S
icetk icetk set_to_fill 265.0 S
weasd weasd set_to_fill 0.0 S
snod snod set_to_fill 0.0 S
tprcp tprcp set_to_fill 0.0 S
tprcp tprcp set_to_fill 0.0 S
84 changes: 77 additions & 7 deletions sorc/chgres_cube.fd/atm_input_data.F90
Original file line number Diff line number Diff line change
Expand Up @@ -1990,7 +1990,7 @@ subroutine read_input_atm_grib2_file(localpet)

integer, intent(in) :: localpet

integer, parameter :: ntrac_max=14
integer, parameter :: ntrac_max=15
integer, parameter :: max_levs=1000

character(len=300) :: the_file
Expand Down Expand Up @@ -2027,7 +2027,8 @@ subroutine read_input_atm_grib2_file(localpet)
real(esmf_kind_r8), allocatable :: rlevs(:)
real(esmf_kind_r4), allocatable :: dummy2d(:,:)
real(esmf_kind_r8), allocatable :: dummy3d(:,:,:), dummy2d_8(:,:),&
u_tmp_3d(:,:,:), v_tmp_3d(:,:,:)
u_tmp_3d(:,:,:), v_tmp_3d(:,:,:),&
dummy3d_pres(:,:,:)
real(esmf_kind_r8), pointer :: presptr(:,:,:), psptr(:,:),tptr(:,:,:), &
qptr(:,:,:), wptr(:,:,:), &
uptr(:,:,:), vptr(:,:,:)
Expand All @@ -2042,18 +2043,19 @@ subroutine read_input_atm_grib2_file(localpet)

tracers(:) = "NULL"

trac_names_oct10 = (/1, 1, 14, 1, 1, 1, 1, 6, 6, 1, 6, 13, 13, 2 /)
trac_names_oct11 = (/0, 22, 192, 23, 24, 25, 32, 1, 29, 100, 28, 193, 192, 2 /)
trac_names_oct10 = (/1, 1, 14, 1, 1, 1, 1, 6, 6, 1, 6, 13, 13, 2, 20 /)
trac_names_oct11 = (/0, 22, 192, 23, 24, 25, 32, 1, 29, 100, 28, 193, 192, 2, 0 /)


trac_names_vmap = (/"sphum ", "liq_wat ", "o3mr ", "ice_wat ", &
"rainwat ", "snowwat ", "graupel ", "cld_amt ", "ice_nc ", &
"rain_nc ", "water_nc", "liq_aero", "ice_aero", &
"sgs_tke "/)
"sgs_tke ", "massden "/)

tracers_default = (/"sphum ", "liq_wat ", "o3mr ", "ice_wat ", &
"rainwat ", "snowwat ", "graupel ", "cld_amt ", "ice_nc ", &
"rain_nc ", "water_nc", "liq_aero", "ice_aero", &
"sgs_tke "/)
"sgs_tke ", "smoke "/)

the_file = trim(data_dir_input_grid) // "/" // trim(grib2_file_input_grid)

Expand Down Expand Up @@ -2405,11 +2407,19 @@ subroutine read_input_atm_grib2_file(localpet)
allocate(dummy2d(i_input,j_input))
allocate(dummy2d_8(i_input,j_input))
allocate(dummy3d(i_input,j_input,lev_input))
if (trim(external_model) .eq. 'RAP' .or. & ! for smoke conversion
trim(external_model) .eq. 'HRRR' ) then
allocate(dummy3d_pres(i_input,j_input,lev_input))
endif
allocate(dum2d_1(i_input,j_input))
else
allocate(dummy2d(0,0))
allocate(dummy2d_8(0,0))
allocate(dummy3d(0,0,0))
if (trim(external_model) .eq. 'RAP' .or. & ! for smoke conversion
trim(external_model) .eq. 'HRRR' ) then
allocate(dummy3d_pres(0,0,0))
endif
allocate(dum2d_1(0,0))
endif

Expand Down Expand Up @@ -2469,12 +2479,61 @@ subroutine read_input_atm_grib2_file(localpet)
call get_var_cond(vname,this_miss_var_method=method, this_miss_var_value=value, &
this_field_var_name=tmpstr,loc=varnum)

if (n==1 .and. .not. hasspfh) then
if (n==1 .and. .not. hasspfh .or. &
( (trim(external_model) .eq. 'RAP' .or. & ! for smoke conversion
trim(external_model) .eq. 'HRRR' ) .and. &
tracers_input_vmap(n) == trac_names_vmap(15) )) then
print*,"- CALL FieldGather TEMPERATURE."
call ESMF_FieldGather(temp_input_grid,dummy3d,rootPet=0, tile=1, rc=rc)
if(ESMF_logFoundError(rcToCheck=rc,msg=ESMF_LOGERR_PASSTHRU,line=__LINE__,file=__FILE__)) &
call error_handler("IN FieldGet", rc)
endif

if ( (trim(external_model) .eq. 'RAP' .or. & ! for smoke conversion
trim(external_model) .eq. 'HRRR' ) .and. &
tracers_input_vmap(n) == trac_names_vmap(15)) then

if (localpet == 0) then

print*,"- READ PRESSURE FOR SMOKE CONVERSION."

jdisc = 0 ! search for discipline - meteorological products
j = 0 ! search at beginning of file.
jpdt = -9999 ! array of values in product definition template, set towildcard
jids = -9999 ! array of values in identification section, set towildcard
jgdt = -9999 ! array of values in grid definition template, set towildcard
jgdtn = -1 ! search for any grid definition number.
jpdtn = pdt_num ! Search for the product definition template number.
jpdt(1) = 3 ! Sect4/oct 10 - parameter category - mass
jpdt(2) = 0 ! Sect4/oct 11 - parameter number - pressure
jpdt(10) = octet_23 ! Sect4/oct 23 - type of level.
unpack=.true.

do vlev = 1, lev_input

jpdt(12) = nint(rlevs(vlev))
call getgb2(lugb, lugi, j, jdisc, jids, jpdtn, jpdt, jgdtn, jgdt, &
unpack, k, gfld, iret)
if (iret /= 0) then
call error_handler("READING IN PRESSURE AT LEVEL"//trim(slevs(vlev)),iret)
endif

dum2d_1 = reshape(gfld%fld, (/i_input,j_input/) )

dummy3d_pres(:,:,vlev) = dum2d_1

enddo

endif ! localpet == 0

endif ! read pressure for smoke conversion

if (tracers_input_vmap(n) == trac_names_vmap(15) .and. &
(trim(external_model) .ne. 'RAP' .and. & ! for smoke conversion
trim(external_model) .ne. 'HRRR' ) ) then
cycle ! Do not process smoke for non RAP/HRRR
endif


if (localpet == 0) then

Expand Down Expand Up @@ -2569,6 +2628,16 @@ subroutine read_input_atm_grib2_file(localpet)
end if
endif

! Convert smoke from mass density (RAP/HRRR = kg/m^3) to mixing ratio (ug/kg)
if ( tracers_input_vmap(n) == trac_names_vmap(15) ) then
do i = 1, i_input
do j = 1, j_input
dummy2d(i,j) = dummy2d(i,j) * 1.0d9 * &
(287.05 * dummy3d(i,j,vlev) / dummy3d_pres(i,j,vlev))
enddo
enddo
endif

dummy3d(:,:,vlev) = real(dummy2d,esmf_kind_r8)

enddo !vlev
Expand Down Expand Up @@ -2881,6 +2950,7 @@ subroutine read_input_atm_grib2_file(localpet)
endif

deallocate(dummy3d, dum2d_1)
if (allocated(dummy3d_pres)) deallocate(dummy3d_pres)

!---------------------------------------------------------------------------
! Convert from 2-d to 3-d component winds.
Expand Down
Loading