diff --git a/components/elm/src/biogeochem/CNPBudgetMod.F90 b/components/elm/src/biogeochem/CNPBudgetMod.F90 index aeb033a1c257..0a8117ecc45a 100644 --- a/components/elm/src/biogeochem/CNPBudgetMod.F90 +++ b/components/elm/src/biogeochem/CNPBudgetMod.F90 @@ -376,7 +376,7 @@ subroutine Reset(mode, budg_fluxL, budg_fluxG, budg_fluxN, budg_stateL, budg_sta ! integer :: year, mon, day, sec integer :: ip - character(*),parameter :: subName = '(WaterBudget_Reset) ' + character(*),parameter :: subName = '(Reset) ' if (.not.present(mode)) then call get_curr_date(year, mon, day, sec) @@ -470,7 +470,7 @@ subroutine CNPBudget_Restart(bounds, ncid, flag) type(file_desc_t), intent(inout) :: ncid ! netcdf id character(len=*) , intent(in) :: flag ! 'read' or 'write' ! - character(len=*),parameter :: subname = 'WaterBudget_Restart' + character(len=*),parameter :: subname = 'CNPBudget_Restart' select case (trim(flag)) case ('define') @@ -718,8 +718,8 @@ subroutine Sum0(f_size, s_size, budg_fluxL, budg_fluxG, budg_stateL, budg_stateG budg_fluxGtmp = 0._r8 budg_stateGtmp = 0._r8 - call shr_mpi_sum(budg_fluxL, budg_fluxGtmp, mpicom, subName) - call shr_mpi_sum(budg_stateL, budg_stateGtmp, mpicom, subName) + call shr_mpi_sum(budg_fluxL, budg_fluxGtmp, mpicom, subName, all=.true.) + call shr_mpi_sum(budg_stateL, budg_stateGtmp, mpicom, subName, all=.true.) budg_fluxG = budg_fluxG + budg_fluxGtmp @@ -946,7 +946,8 @@ subroutine Restart_Define(bounds, ncid, name) call ncd_defvar(varname=trim(name)//'_budg_fluxG', xtype=ncd_double, & dim1name=trim(name)//'_budg_flux', & - long_name=trim(name)//'_budg_fluxG', units='mm', ncid=ncid) + long_name=trim(name)//'_budg_fluxG', & + units='g'//trim(name)//'/m2/s', ncid=ncid) call ncd_defvar(varname=trim(name)//'_budg_fluxN', xtype=ncd_double, & dim1name=trim(name)//'_budg_flux', & @@ -954,7 +955,8 @@ subroutine Restart_Define(bounds, ncid, name) call ncd_defvar(varname=trim(name)//'_budg_stateG', xtype=ncd_double, & dim1name=trim(name)//'_budg_state', & - long_name=trim(name)//'_budg_stateG', units='-', ncid=ncid) + long_name=trim(name)//'_budg_stateG', & + units='g'//trim(name)//'/m2', ncid=ncid) end subroutine Restart_Define @@ -990,8 +992,8 @@ subroutine Restart_Write(bounds, ncid, flag, name, f_size, s_size, & budg_fluxGtmp = 0._r8 budg_stateGtmp = 0._r8 - call shr_mpi_sum(budg_fluxL, budg_fluxGtmp, mpicom, subName) - call shr_mpi_sum(budg_stateL, budg_stateGtmp, mpicom, subName) + call shr_mpi_sum(budg_fluxL, budg_fluxGtmp, mpicom, subName, all=.true.) + call shr_mpi_sum(budg_stateL, budg_stateGtmp, mpicom, subName, all=.true.) ! Copy data from 2D into 1D array count = 0 diff --git a/components/elm/src/biogeophys/WaterBudgetMod.F90 b/components/elm/src/biogeophys/WaterBudgetMod.F90 index a1e70e6cd8e4..cf42f1e63085 100644 --- a/components/elm/src/biogeophys/WaterBudgetMod.F90 +++ b/components/elm/src/biogeophys/WaterBudgetMod.F90 @@ -374,8 +374,8 @@ subroutine WaterBudget_Sum0() budg_fluxGtmp = 0._r8 budg_stateGtmp = 0._r8 - call shr_mpi_sum(budg_fluxL, budg_fluxGtmp, mpicom, subName) - call shr_mpi_sum(budg_stateL, budg_stateGtmp, mpicom, subName) + call shr_mpi_sum(budg_fluxL, budg_fluxGtmp, mpicom, subName, all=.true. ) + call shr_mpi_sum(budg_stateL, budg_stateGtmp, mpicom, subName, all=.true. ) budg_fluxG = budg_fluxG + budg_fluxGtmp budg_stateG = budg_stateGtmp @@ -563,7 +563,7 @@ subroutine WaterBudget_Restart_Define(bounds, ncid) call ncd_defvar(varname='budg_fluxG', xtype=ncd_double, & dim1name='budg_flux', & - long_name='budg_fluxG', units='mm', ncid=ncid) + long_name='budg_fluxG', units='kg/m2/s', ncid=ncid) call ncd_defvar(varname='budg_fluxN', xtype=ncd_double, & dim1name='budg_flux', & @@ -571,7 +571,7 @@ subroutine WaterBudget_Restart_Define(bounds, ncid) call ncd_defvar(varname='budg_stateG', xtype=ncd_double, & dim1name='budg_state', & - long_name='budg_stateG', units='mm', ncid=ncid) + long_name='budg_stateG', units='kg/m2', ncid=ncid) end subroutine WaterBudget_Restart_Define @@ -601,8 +601,8 @@ subroutine WaterBudget_Restart_Write(bounds, ncid, flag) budg_fluxGtmp = 0._r8 budg_stateGtmp = 0._r8 - call shr_mpi_sum(budg_fluxL, budg_fluxGtmp, mpicom, subName) - call shr_mpi_sum(budg_stateL, budg_stateGtmp, mpicom, subName) + call shr_mpi_sum(budg_fluxL, budg_fluxGtmp, mpicom, subName, all=.true.) + call shr_mpi_sum(budg_stateL, budg_stateGtmp, mpicom, subName, all=.true. ) ! Copy data from 2D into 1D array count = 0 diff --git a/components/elm/src/data_types/ColumnDataType.F90 b/components/elm/src/data_types/ColumnDataType.F90 index 32ebf37af051..bc6c935efa5c 100644 --- a/components/elm/src/data_types/ColumnDataType.F90 +++ b/components/elm/src/data_types/ColumnDataType.F90 @@ -2513,6 +2513,8 @@ subroutine col_cs_restart ( this, bounds, ncid, flag, carbon_type, c12_carbonst ! !DESCRIPTION: ! Read/Write column carbon state information to/from restart file. ! + use elm_varctl, only : do_budgets + ! ! !ARGUMENTS: class(column_carbon_state) :: this type(bounds_type), intent(in) :: bounds @@ -2544,6 +2546,13 @@ subroutine col_cs_restart ( this, bounds, ncid, flag, carbon_type, c12_carbonst integer :: decomp_cascade_state, restart_file_decomp_cascade_state !----------------------------------------------------------------------- + if (do_budgets) then + call restartvar(ncid=ncid, flag=flag, varname='ENDCB', xtype=ncd_double, & + dim1name='column', & + long_name='carbon balance at end of timestep', units='gC/m2', & + interpinic_flag='interp', readvar=readvar, data=this%endcb) + endif + if (carbon_type == 'c13' .or. carbon_type == 'c14') then if (.not. present(c12_carbonstate_vars)) then call endrun(msg=' ERROR: for C14 must pass in c12_carbonstate_vars as argument' //& @@ -7755,6 +7764,9 @@ subroutine col_cf_setvalues ( this, num_column, filter_column, value_column) this%prod1c_loss(i) = value_column this%prod10c_loss(i) = value_column this%prod100c_loss(i) = value_column + this%er(i) = value_column + this%som_c_leached(i) = value_column + this%somc_yield(i) = value_column this%somhr(i) = value_column ! REVISIT this%lithr(i) = value_column ! REVISIT this%hr(i) = value_column diff --git a/components/elm/src/data_types/GridcellDataType.F90 b/components/elm/src/data_types/GridcellDataType.F90 index 5c312cdd035d..092cbd4e1378 100644 --- a/components/elm/src/data_types/GridcellDataType.F90 +++ b/components/elm/src/data_types/GridcellDataType.F90 @@ -443,7 +443,7 @@ subroutine grc_ws_restart(this, bounds, ncid, flag) !----------------------------------------------------------------------- call restartvar(ncid=ncid, flag=flag, varname='TWS_MONTH_BEGIN', xtype=ncd_double, & dim1name='gridcell', & - long_name='surface watertotal water storage at the beginning of a month', units='mm', & + long_name='total water storage at the beginning of a month', units='mm', & interpinic_flag='interp', readvar=readvar, data=this%tws_month_beg) end subroutine grc_ws_restart @@ -603,12 +603,12 @@ subroutine grc_cs_init(this, begg, endg,carbon_type) end if this%tcs_month_beg(begg:endg) = spval - call hist_addfld1d (fname='TCS_MONTH_BEGIN', units='mm', & + call hist_addfld1d (fname='TCS_MONTH_BEGIN', units='gC/m^2', & avgflag='I', long_name='total carbon storage at the beginning of a month', & ptr_lnd=this%tcs_month_beg) this%tcs_month_end(begg:endg) = spval - call hist_addfld1d (fname='TCS_MONTH_END', units='mm', & + call hist_addfld1d (fname='TCS_MONTH_END', units='gC/m^2', & avgflag='I', long_name='total carbon storage at the end of a month', & ptr_lnd=this%tcs_month_end) @@ -644,7 +644,7 @@ subroutine grc_cs_restart(this, bounds, ncid, flag) !----------------------------------------------------------------------- call restartvar(ncid=ncid, flag=flag, varname='TCS_MONTH_BEGIN', xtype=ncd_double, & dim1name='gridcell', & - long_name='surface watertotal carbon storage at the beginning of a month', units='mm', & + long_name='total carbon storage at the beginning of a month', units='gC/m^2', & interpinic_flag='interp', readvar=readvar, data=this%tcs_month_beg) end subroutine grc_cs_restart