From 8c3f26a45c14896957529e0f2bd2644a03012973 Mon Sep 17 00:00:00 2001 From: "David A. Bailey" Date: Fri, 15 Nov 2024 15:03:32 -0700 Subject: [PATCH] Make dsnow and dsnown optional (#506) This is the icepack part of making both dsnow and dsnown optional. Later I can add some diagnostics for these in CICE. --- columnphysics/icepack_therm_vertical.F90 | 28 +++++++++++++++++++----- 1 file changed, 22 insertions(+), 6 deletions(-) diff --git a/columnphysics/icepack_therm_vertical.F90 b/columnphysics/icepack_therm_vertical.F90 index bf96096e..7ec9bf47 100644 --- a/columnphysics/icepack_therm_vertical.F90 +++ b/columnphysics/icepack_therm_vertical.F90 @@ -2361,12 +2361,14 @@ subroutine icepack_step_therm1(dt, & melttn , & ! top ice melt (m) meltbn , & ! bottom ice melt (m) congeln , & ! congelation ice growth (m) - snoicen , & ! snow-ice growth (m) - dsnown ! change in snow thickness (m/step-->cm/day) + snoicen ! snow-ice growth (m) real (kind=dbl_kind), dimension(:), intent(in) :: & fswthrun ! SW through ice to ocean (W/m^2) + real (kind=dbl_kind), dimension(:), intent(inout), optional :: & + dsnown ! change in snow thickness (m/step-->cm/day) + real (kind=dbl_kind), dimension(:), intent(in), optional :: & fswthrun_vdr , & ! vis dir SW through ice to ocean (W/m^2) fswthrun_vdf , & ! vis dif SW through ice to ocean (W/m^2) @@ -2442,6 +2444,8 @@ subroutine icepack_step_therm1(dt, & l_fswthrun_vdf, & ! vis dif SW local n ice to ocean (W/m^2) l_fswthrun_idr, & ! nir dir SW local n ice to ocean (W/m^2) l_fswthrun_idf, & ! nir dif SW local n ice to ocean (W/m^2) + l_dsnow, & ! local snow change + l_dsnown, & ! local snow change category l_meltsliq ! mass of snow melt local (kg/m^2) real (kind=dbl_kind) :: & @@ -2485,6 +2489,12 @@ subroutine icepack_step_therm1(dt, & call icepack_warnings_setabort(.true.,__FILE__,__LINE__) return endif + if ((present(dsnow) .and. .not.present(dsnown)) .or. & + (present(dsnown) .and. .not.present(dsnow))) then + call icepack_warnings_add(subname//' error in dsnow arguments') + call icepack_warnings_setabort(.true.,__FILE__,__LINE__) + return + endif if (tr_fsd) then if (.not.present(afsdn)) then call icepack_warnings_add(subname//' error missing afsdn argument, tr_fsd=T') @@ -2509,6 +2519,8 @@ subroutine icepack_step_therm1(dt, & l_meltsliq = c0 l_meltsliqn = c0 + l_dsnow = c0 + if (present(dsnow)) l_dsnow = dsnow ! solid and liquid components of snow mass massicen(:,:) = c0 @@ -2589,7 +2601,8 @@ subroutine icepack_step_therm1(dt, & meltbn (n) = c0 congeln(n) = c0 snoicen(n) = c0 - dsnown (n) = c0 + l_dsnown = c0 + if (present(dsnown)) dsnown(n) = c0 Trefn = c0 Qrefn = c0 @@ -2714,8 +2727,8 @@ subroutine icepack_step_therm1(dt, & smice=smice, massice=massicen (:,n), & smliq=smliq, massliq=massliqn (:,n), & congel=congeln (n), snoice=snoicen (n), & - mlt_onset=mlt_onset, frz_onset=frz_onset, & - yday=yday, dsnow=dsnown (n), & + mlt_onset=mlt_onset, frz_onset=frz_onset , & + yday=yday, dsnow=l_dsnown , & prescribed_ice=prescribed_ice) if (icepack_warnings_aborted(subname)) then @@ -2903,7 +2916,7 @@ subroutine icepack_step_therm1(dt, & meltbn=meltbn (n), congeln=congeln(n),& meltt=meltt, melts=melts, & meltb=meltb, snoicen=snoicen(n),& - dsnow=dsnow, dsnown=dsnown(n), & + dsnow=l_dsnow, dsnown=l_dsnown, & congel=congel, snoice=snoice, & meltsliq=l_meltsliq, & meltsliqn=l_meltsliqn(n), & @@ -2919,6 +2932,8 @@ subroutine icepack_step_therm1(dt, & endif + if (present(dsnown )) dsnown(n) = l_dsnown + enddo ! ncat !----------------------------------------------------------------- @@ -2944,6 +2959,7 @@ subroutine icepack_step_therm1(dt, & if (present(meltsliqn )) meltsliqn = l_meltsliqn if (present(meltsliq )) meltsliq = l_meltsliq + if (present(dsnow )) dsnow = l_dsnow !----------------------------------------------------------------- ! Calculate ponds from the topographic scheme