From c95417e6b12a8f5a25e0e47c7c388a0d0bf725ab Mon Sep 17 00:00:00 2001 From: Mariana Vertenstein Date: Fri, 7 Jun 2024 05:59:42 -0600 Subject: [PATCH] addressed issue https://github.com/ESCOMP/MOSART/issues/95 --- src/riverroute/mosart_budget_type.F90 | 32 ++++++++++++++++----------- src/riverroute/mosart_timemanager.F90 | 2 +- 2 files changed, 20 insertions(+), 14 deletions(-) diff --git a/src/riverroute/mosart_budget_type.F90 b/src/riverroute/mosart_budget_type.F90 index b15571f..3df5c8a 100644 --- a/src/riverroute/mosart_budget_type.F90 +++ b/src/riverroute/mosart_budget_type.F90 @@ -9,7 +9,6 @@ module mosart_budget_type use mosart_vars, only: re, spval, barrier_timers, iulog, mainproc, npes, iam, mpicom_rof use mosart_data, only: ctl, Tctl, Tunit, TRunoff, Tpara use mosart_timemanager, only: get_nstep, get_curr_date - use mpi implicit none private @@ -46,6 +45,13 @@ module mosart_budget_type end type budget_type public :: budget_type + integer, parameter :: index_beg_vol_grc = 1 + integer, parameter :: index_end_vol_grc = 2 + integer, parameter :: index_in_grc = 3 + integer, parameter :: index_out_grc = 4 + integer, parameter :: index_net_grc = 5 + integer, parameter :: index_lag_grc = 6 + character(*), parameter :: u_FILE_u = & __FILE__ @@ -201,12 +207,12 @@ subroutine check_budget(this, begr, endr, ntracers, dt) end do do nt = 1, ntracers - tmp_in(1, nt) = sum(this%beg_vol_grc(:, nt)) - tmp_in(2, nt) = sum(this%end_vol_grc(:, nt)) - tmp_in(3, nt) = sum(this%in_grc(:, nt)) - tmp_in(4, nt) = sum(this%out_grc(:, nt)) - tmp_in(5, nt) = sum(this%net_grc(:, nt)) - tmp_in(6, nt) = sum(this%lag_grc(:, nt)) + tmp_in(index_beg_vol_grc, nt) = sum(this%beg_vol_grc(:, nt)) + tmp_in(index_end_vol_grc, nt) = sum(this%end_vol_grc(:, nt)) + tmp_in(index_in_grc, nt) = sum(this%in_grc(:, nt)) + tmp_in(index_out_grc, nt) = sum(this%out_grc(:, nt)) + tmp_in(index_net_grc, nt) = sum(this%net_grc(:, nt)) + tmp_in(index_lag_grc, nt) = sum(this%lag_grc(:, nt)) end do tmp_in = tmp_in*1e-6_r8 !convert to million m3 @@ -216,12 +222,12 @@ subroutine check_budget(this, begr, endr, ntracers, dt) error_budget = .false. abserr = 0.0_r8 relerr = 0.0_r8 - this%beg_vol_glob(nt) = tmp_glob(1, nt) - this%end_vol_glob(nt) = tmp_glob(2, nt) - this%in_glob(nt) = tmp_glob(3, nt) - this%out_glob(nt) = tmp_glob(4, nt) - this%net_glob(nt) = tmp_glob(5, nt) - this%lag_glob(nt) = tmp_glob(6, nt) + this%beg_vol_glob(nt) = tmp_glob(index_beg_vol_grc, nt) + this%end_vol_glob(nt) = tmp_glob(index_end_vol_grc, nt) + this%in_glob(nt) = tmp_glob(index_in_grc, nt) + this%out_glob(nt) = tmp_glob(index_out_grc, nt) + this%net_glob(nt) = tmp_glob(index_net_grc, nt) + this%lag_glob(nt) = tmp_glob(index_lag_grc, nt) if (this%do_budget(nt)) then if (abs(this%net_glob(nt) - this%lag_glob(nt)*dt) > this%tolerance) then error_budget = .true. diff --git a/src/riverroute/mosart_timemanager.F90 b/src/riverroute/mosart_timemanager.F90 index 1d35ae7..df53ba5 100644 --- a/src/riverroute/mosart_timemanager.F90 +++ b/src/riverroute/mosart_timemanager.F90 @@ -3,7 +3,7 @@ module mosart_timemanager use shr_kind_mod , only: r8 => shr_kind_r8, CS => shr_kind_CS use shr_sys_mod , only: shr_sys_abort use shr_string_mod , only: shr_string_toUpper - use mosart_vars , only: isecspday, iulog, nsrest, nsrContinue, mpicom_rof, mainproc + use mosart_vars , only: isecspday, iulog, nsrest, nsrContinue, mainproc use ESMF , only: ESMF_MAXSTR, ESMF_Calendar, ESMF_Clock, ESMF_Time, ESMF_TimeInterval, & ESMF_TimeIntervalSet, ESMF_TimeIntervalGet, ESMF_TimeSet, ESMF_TimeGet, & ESMF_ClockCreate, ESMF_ClockGet, ESMF_ClockAdvance, &