Skip to content

Commit

Permalink
Revert "Include calving in Runge-Kutta loop"
Browse files Browse the repository at this point in the history
This reverts commit 813ee05. After
testing and discussion, it is apparent that including calving within
the Runge-Kutta loop is not desirable because it changes the domain
between stages of the Runge-Kutta integration.
  • Loading branch information
trhille committed Nov 6, 2023
1 parent 7073b89 commit fb0315f
Showing 1 changed file with 32 additions and 20 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
groundedSfcMassBalApplied, &
groundedBasalMassBalApplied, &
floatingBasalMassBalApplied, &
calvingThickness, &
fluxAcrossGroundingLine, &
fluxAcrossGroundingLineOnCells, &
groundedToFloatingThickness
Expand All @@ -136,7 +135,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
groundedSfcMassBalAccum, &
groundedBasalMassBalAccum, &
floatingBasalMassBalAccum, &
calvingThicknessAccum, &
fluxAcrossGroundingLineAccum
real (kind=RKIND), dimension(:), pointer :: layerCenterSigma, layerThicknessFractions
integer, dimension(:), pointer :: cellMaskPrev ! cell mask before advection
Expand Down Expand Up @@ -203,7 +201,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
allocate(groundedSfcMassBalAccum(nCells+1))
allocate(groundedBasalMassBalAccum(nCells+1))
allocate(floatingBasalMassBalAccum(nCells+1))
allocate(calvingThicknessAccum(nCells+1))
allocate(fluxAcrossGroundingLineAccum(nEdges+1))

temperaturePrev(:,:) = 0.0_RKIND
Expand All @@ -221,7 +218,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
groundedSfcMassBalAccum(:) = 0.0_RKIND
groundedBasalMassBalAccum(:) = 0.0_RKIND
floatingBasalMassBalAccum(:) = 0.0_RKIND
calvingThicknessAccum(:) = 0.0_RKIND
fluxAcrossGroundingLineAccum(:) = 0.0_RKIND

! === Prepare for advection (including CFL checks) ===========
Expand Down Expand Up @@ -379,18 +375,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
err = ior(err, err_tmp)
call mpas_timer_stop("advect thickness and tracers")
! ==== Apply iceberg calving ====
call mpas_timer_start("calve_ice")
call li_calve_ice(domain, err_tmp)
err = ior(err, err_tmp)
if (config_restore_calving_front) then
! restore the calving front to its initial position before velocity solve.
call li_restore_calving_front(domain, err_tmp)
err = ior(err, err_tmp)
endif
call mpas_timer_stop("calve_ice")
! If using SSP RK, then update thickness and tracers incrementally.
! For first RK stage, thickness and tracer updates above are sufficient.
! Likewise, for the 4-stage SSP RK3 the last stage is just a forward euler update.
Expand Down Expand Up @@ -469,7 +453,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
call mpas_pool_get_array(geometryPool, 'basalMassBalApplied', basalMassBalApplied)
call mpas_pool_get_array(geometryPool, 'floatingBasalMassBalApplied', floatingBasalMassBalApplied)
call mpas_pool_get_array(geometryPool, 'groundedBasalMassBalApplied', groundedBasalMassBalApplied)
call mpas_pool_get_array(geometryPool, 'calvingThickness', calvingThickness)
call mpas_pooL_get_array(velocityPool, 'fluxAcrossGroundingLine', fluxAcrossGroundingLine)
call mpas_pool_get_array(geometryPool, 'thickness', thickness)
Expand All @@ -479,7 +462,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
basalMassBalAccum = basalMassBalAccum + rkTendWeights(rkStage) * basalMassBalApplied
groundedBasalMassBalAccum = groundedBasalMassBalAccum + rkTendWeights(rkStage) * groundedBasalMassBalApplied
floatingBasalMassBalAccum = floatingBasalMassBalAccum + rkTendWeights(rkStage) * floatingBasalMassBalApplied
calvingThicknessAccum = calvingThicknessAccum + rkTendWeights(rkStage) * calvingThickness
fluxAcrossGroundingLineAccum = fluxAcrossGroundingLineAccum + rkTendWeights(rkStage) * fluxAcrossGroundingLine
! Halo updates
Expand All @@ -493,6 +475,12 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
call mpas_timer_stop("halo updates")
if (config_restore_calving_front) then
! restore the calving front to its initial position before velocity solve.
call li_restore_calving_front(domain, err_tmp)
err = ior(err, err_tmp)
endif
! Update velocity for each RK step
! === Solve Velocity =====================
call li_velocity_solve(domain, solveVelo=.true., err=err_tmp)
Expand All @@ -518,7 +506,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
basalMassBalApplied(:) = basalMassBalAccum(:)
groundedBasalMassBalApplied(:) = groundedBasalMassBalAccum(:)
floatingBasalMassBalApplied(:) = floatingBasalMassBalAccum(:)
calvingThickness(:) = calvingThicknessAccum(:)
fluxAcrossGroundingLine(:) = fluxAcrossGroundingLineAccum(:)
fluxAcrossGroundingLineOnCells(:) = 0.0_RKIND
Expand All @@ -542,6 +529,32 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
! Reset time step to full length after RK loop
deltat = deltatFull
! === Calve ice ========================
call mpas_timer_start("calve_ice")
! ice calving
call li_calve_ice(domain, err_tmp)
err = ior(err, err_tmp)
if (config_restore_calving_front .and. config_restore_calving_front_prevent_retreat) then
! restore the calving front to its initial position before velocity solve.
call li_restore_calving_front(domain, err_tmp)
err = ior(err, err_tmp)
endif
call mpas_timer_stop("calve_ice")
call mpas_timer_start("halo updates")
call mpas_dmpar_field_halo_exch(domain, 'cellMask')
call mpas_dmpar_field_halo_exch(domain, 'edgeMask')
call mpas_dmpar_field_halo_exch(domain, 'vertexMask')
call mpas_timer_stop("halo updates")
! Update stresses etc
! === Solve Velocity =====================
call li_velocity_solve(domain, solveVelo=.false., err=err_tmp)
err = ior(err, err_tmp)
! === Update bed topo =====================
! It's not clear when the best time to do this is.
! Seems cleaner to do it either before or after all of the time evolution of the ice
Expand Down Expand Up @@ -576,7 +589,6 @@ subroutine li_time_integrator_forwardeuler_rungekutta(domain, err)
deallocate(groundedSfcMassBalAccum)
deallocate(groundedBasalMassBalAccum)
deallocate(floatingBasalMassBalAccum)
deallocate(calvingThicknessAccum)
deallocate(fluxAcrossGroundingLineAccum)
!--------------------------------------------------------------------
end subroutine li_time_integrator_forwardeuler_rungekutta
Expand Down

0 comments on commit fb0315f

Please sign in to comment.