diff --git a/biogeochem/EDCohortDynamicsMod.F90 b/biogeochem/EDCohortDynamicsMod.F90 index cc20f45f88..91e322c242 100644 --- a/biogeochem/EDCohortDynamicsMod.F90 +++ b/biogeochem/EDCohortDynamicsMod.F90 @@ -436,7 +436,7 @@ subroutine nan_cohort(cc_p) currentCohort%root_md = nan ! root maintenance demand: kgC/indiv/year currentCohort%carbon_balance = nan ! carbon remaining for growth and storage: kg/indiv/year currentCohort%dmort = nan ! proportional mortality rate. (year-1) - currentCohort%lmort_logging = nan + currentCohort%lmort_direct = nan currentCohort%lmort_infra = nan currentCohort%lmort_collateral = nan @@ -514,7 +514,7 @@ subroutine zero_cohort(cc_p) currentcohort%dmort = 0._r8 currentcohort%gscan = 0._r8 currentcohort%treesai = 0._r8 - currentCohort%lmort_logging = 0._r8 + currentCohort%lmort_direct = 0._r8 currentCohort%lmort_infra = 0._r8 currentCohort%lmort_collateral = 0._r8 ! currentCohort%npp_leaf = 0._r8 @@ -866,8 +866,8 @@ subroutine fuse_cohorts(patchptr, bc_in) currentCohort%dmort = (currentCohort%n*currentCohort%dmort + & nextc%n*nextc%dmort)/newn - currentCohort%lmort_logging = (currentCohort%n*currentCohort%lmort_logging + & - nextc%n*nextc%lmort_logging)/newn + currentCohort%lmort_direct = (currentCohort%n*currentCohort%lmort_direct + & + nextc%n*nextc%lmort_direct)/newn currentCohort%lmort_infra = (currentCohort%n*currentCohort%lmort_infra + & nextc%n*nextc%lmort_infra)/newn currentCohort%lmort_collateral = (currentCohort%n*currentCohort%lmort_collateral + & @@ -885,8 +885,8 @@ subroutine fuse_cohorts(patchptr, bc_in) currentCohort%fmort = (currentCohort%n*currentCohort%fmort + nextc%n*nextc%fmort)/newn ! logging mortality, Yi Xu - currentCohort%lmort_logging = (currentCohort%n*currentCohort%lmort_logging + & - nextc%n*nextc%lmort_logging)/newn + currentCohort%lmort_direct = (currentCohort%n*currentCohort%lmort_direct + & + nextc%n*nextc%lmort_direct)/newn currentCohort%lmort_collateral = (currentCohort%n*currentCohort%lmort_collateral + & nextc%n*nextc%lmort_collateral)/newn currentCohort%lmort_infra = (currentCohort%n*currentCohort%lmort_infra + & @@ -1259,7 +1259,7 @@ subroutine copy_cohort( currentCohort,copyc ) n%root_md = o%root_md n%carbon_balance = o%carbon_balance n%dmort = o%dmort - n%lmort_logging = o%lmort_logging + n%lmort_direct = o%lmort_direct n%lmort_infra = o%lmort_infra n%lmort_collateral= o%lmort_collateral n%seed_prod = o%seed_prod @@ -1276,7 +1276,7 @@ subroutine copy_cohort( currentCohort,copyc ) n%hmort = o%hmort ! logging mortalities, Yi Xu - n%lmort_logging=o%lmort_logging + n%lmort_direct=o%lmort_direct n%lmort_collateral =o%lmort_collateral n%lmort_infra =o%lmort_infra diff --git a/biogeochem/EDLoggingMortalityMod.F90 b/biogeochem/EDLoggingMortalityMod.F90 index d3fe5d6b1e..f620290cb0 100644 --- a/biogeochem/EDLoggingMortalityMod.F90 +++ b/biogeochem/EDLoggingMortalityMod.F90 @@ -3,15 +3,16 @@ module EDLoggingMortalityMod ! ==================================================================================== ! Purpose: 1. create logging mortalities: - ! (a)logging mortality (cohort level) - ! (b)collateral mortality (cohort level) - ! (c)infrastructure mortality (cohort level) + ! (a) direct logging mortality (cohort level) + ! (b) collateral mortality (cohort level) + ! (c) infrastructure mortality (cohort level) ! 2. move the logged trunk fluxes from live into product pool ! 3. move logging-associated mortality fluxes from live to CWD ! 4. keep carbon balance (in ed_total_balance_check) ! - ! Yi Xu - ! Date: 2017 + ! Yi Xu & M.Huang + ! Date: 09/2017 + ! Last updated: 10/2017 ! ==================================================================================== use FatesConstantsMod , only : r8 => fates_r8 @@ -29,7 +30,7 @@ module EDLoggingMortalityMod use EDParamsMod , only : logging_collateral_frac use EDParamsMod , only : logging_direct_frac use EDParamsMod , only : logging_mechanical_frac - use EDParamsMod , only : ED_val_understorey_death + use EDParamsMod , only : logging_coll_under_frac use FatesInterfaceMod , only : hlm_current_year use FatesInterfaceMod , only : hlm_current_month use FatesInterfaceMod , only : hlm_current_day @@ -142,44 +143,49 @@ end subroutine IsItLoggingTime ! ====================================================================================== - subroutine LoggingMortality_frac( pft_i, dbh, lmort_logging,lmort_collateral,lmort_infra ) + subroutine LoggingMortality_frac( pft_i, dbh, lmort_direct,lmort_collateral,lmort_infra ) ! Arguments integer, intent(in) :: pft_i ! pft index real(r8), intent(in) :: dbh ! diameter at breast height (cm) - real(r8), intent(out) :: lmort_logging ! direct (harvestable) mortality fraction + real(r8), intent(out) :: lmort_direct ! direct (harvestable) mortality fraction real(r8), intent(out) :: lmort_collateral ! collateral damage mortality fraction real(r8), intent(out) :: lmort_infra ! infrastructure mortality fraction ! Parameters real(r8), parameter :: adjustment = 1.0 ! adjustment for mortality rates - + real(r8), parameter :: logging_dbhmax_infra = 35 !(cm), based on Feldpaush et al. (2005) and Ferry et al. (2010) + if (logging_time) then if(EDPftvarcon_inst%woody(pft_i) == 1)then ! only set logging rates for trees ! Pass logging rates to cohort level if (dbh >= logging_dbhmin ) then - lmort_logging = logging_direct_frac * adjustment + lmort_direct = logging_direct_frac * adjustment lmort_collateral = logging_collateral_frac * adjustment else - lmort_logging = 0.0_r8 + lmort_direct = 0.0_r8 lmort_collateral = 0.0_r8 end if - lmort_infra = logging_mechanical_frac * adjustment + if (dbh >= logging_dbhmax_infra) then + lmort_infra = 0.0_r8 + else + lmort_infra = logging_mechanical_frac * adjustment + end if !damage rates for size class < & > threshold_size need to be specified seperately ! Collateral damage to smaller plants below the direct logging size threshold ! will be applied via "understory_death" via the disturbance algorithm else - lmort_logging = 0.0_r8 + lmort_direct = 0.0_r8 lmort_collateral = 0.0_r8 lmort_infra = 0.0_r8 end if else - lmort_logging = 0.0_r8 + lmort_direct = 0.0_r8 lmort_collateral = 0.0_r8 lmort_infra = 0.0_r8 end if @@ -269,14 +275,14 @@ subroutine logging_litter_fluxes(currentSite, currentPatch, newPatch, patch_site if(currentCohort%canopy_layer == 1)then - direct_dead = currentCohort%n * currentCohort%lmort_logging + direct_dead = currentCohort%n * currentCohort%lmort_direct indirect_dead = currentCohort%n * & (currentCohort%lmort_collateral + currentCohort%lmort_infra) else if(EDPftvarcon_inst%woody(currentCohort%pft) == 1)then direct_dead = 0.0_r8 - indirect_dead = ED_val_understorey_death * currentCohort%n * & + indirect_dead = logging_coll_under_frac * currentCohort%n * & (patch_site_areadis/currentPatch%area) !kgC/site/day else ! If the cohort of interest is grass, it will not experience diff --git a/biogeochem/EDPatchDynamicsMod.F90 b/biogeochem/EDPatchDynamicsMod.F90 index 051baf689a..10d84a221b 100644 --- a/biogeochem/EDPatchDynamicsMod.F90 +++ b/biogeochem/EDPatchDynamicsMod.F90 @@ -75,9 +75,9 @@ subroutine disturbance_rates( site_in) ! be one disturbance type for each timestep. ! all disturbance rates here are per daily timestep. - ! 2016-2017 - ! Modify to add logging disturbance - + ! 2016-2017 + ! Modify to add logging disturbance + ! !USES: use EDMortalityFunctionsMod , only : mortality_rates ! loging flux @@ -95,7 +95,7 @@ subroutine disturbance_rates( site_in) real(r8) :: bmort real(r8) :: hmort - real(r8) :: lmort_logging + real(r8) :: lmort_direct real(r8) :: lmort_collateral real(r8) :: lmort_infra @@ -126,9 +126,9 @@ subroutine disturbance_rates( site_in) currentCohort%fmort = 0.0_r8 ! Fire mortality is initialized as zero, but may be changed call LoggingMortality_frac(currentCohort%pft, currentCohort%dbh, & - lmort_logging,lmort_collateral,lmort_infra ) + lmort_direct,lmort_collateral,lmort_infra ) - currentCohort%lmort_logging = lmort_logging + currentCohort%lmort_direct = lmort_direct currentCohort%lmort_collateral = lmort_collateral currentCohort%lmort_infra = lmort_infra @@ -160,7 +160,7 @@ subroutine disturbance_rates( site_in) ! Logging Disturbance Rate currentPatch%disturbance_rates(dtype_ilog) = currentPatch%disturbance_rates(dtype_ilog) + & - min(1.0_r8, currentCohort%lmort_logging + & + min(1.0_r8, currentCohort%lmort_direct + & currentCohort%lmort_collateral + & currentCohort%lmort_infra ) * & currentCohort%c_area/currentPatch%area @@ -222,7 +222,7 @@ subroutine disturbance_rates( site_in) currentCohort%hmort = currentCohort%hmort*(1.0_r8 - fates_mortality_disturbance_fraction) currentCohort%bmort = currentCohort%bmort*(1.0_r8 - fates_mortality_disturbance_fraction) currentCohort%dmort = currentCohort%dmort*(1.0_r8 - fates_mortality_disturbance_fraction) - currentCohort%lmort_logging = 0.0_r8 + currentCohort%lmort_direct = 0.0_r8 currentCohort%lmort_collateral = 0.0_r8 currentCohort%lmort_infra = 0.0_r8 end if @@ -245,7 +245,7 @@ subroutine disturbance_rates( site_in) currentCohort => currentPatch%shortest do while(associated(currentCohort)) if(currentCohort%canopy_layer == 1)then - currentCohort%lmort_logging = 0.0_r8 + currentCohort%lmort_direct = 0.0_r8 currentCohort%lmort_collateral = 0.0_r8 currentCohort%lmort_infra = 0.0_r8 currentCohort%fmort = 0.0_r8 @@ -280,7 +280,7 @@ subroutine spawn_patches( currentSite, bc_in) ! ! !USES: - use EDParamsMod , only : ED_val_understorey_death + use EDParamsMod , only : ED_val_understorey_death, logging_coll_under_frac use EDCohortDynamicsMod , only : zero_cohort, copy_cohort, terminate_cohorts ! @@ -403,7 +403,7 @@ subroutine spawn_patches( currentSite, bc_in) nc%hmort = nan nc%bmort = nan nc%fmort = nan - nc%lmort_logging = nan + nc%lmort_direct = nan nc%lmort_collateral = nan nc%lmort_infra = nan @@ -446,7 +446,7 @@ subroutine spawn_patches( currentSite, bc_in) nc%hmort = currentCohort%hmort nc%bmort = currentCohort%bmort nc%dmort = currentCohort%dmort - nc%lmort_logging = currentCohort%lmort_logging + nc%lmort_direct = currentCohort%lmort_direct nc%lmort_collateral = currentCohort%lmort_collateral nc%lmort_infra = currentCohort%lmort_infra @@ -470,7 +470,7 @@ subroutine spawn_patches( currentSite, bc_in) nc%hmort = currentCohort%hmort nc%bmort = currentCohort%bmort nc%dmort = currentCohort%dmort - nc%lmort_logging = currentCohort%lmort_logging + nc%lmort_direct = currentCohort%lmort_direct nc%lmort_collateral = currentCohort%lmort_collateral nc%lmort_infra = currentCohort%lmort_infra @@ -496,7 +496,7 @@ subroutine spawn_patches( currentSite, bc_in) nc%hmort = currentCohort%hmort nc%bmort = currentCohort%bmort nc%dmort = currentCohort%dmort - nc%lmort_logging = currentCohort%lmort_logging + nc%lmort_direct = currentCohort%lmort_direct nc%lmort_collateral = currentCohort%lmort_collateral nc%lmort_infra = currentCohort%lmort_infra @@ -511,7 +511,7 @@ subroutine spawn_patches( currentSite, bc_in) nc%n = 0.0_r8 ! Reduce counts in the existing/donor patch according to the logging rate - currentCohort%n = currentCohort%n * (1.0_r8 - min(1.0_r8,(currentCohort%lmort_logging + & + currentCohort%n = currentCohort%n * (1.0_r8 - min(1.0_r8,(currentCohort%lmort_direct + & currentCohort%lmort_collateral + & currentCohort%lmort_infra))) @@ -520,7 +520,7 @@ subroutine spawn_patches( currentSite, bc_in) nc%hmort = nan nc%bmort = nan nc%fmort = nan - nc%lmort_logging = nan + nc%lmort_direct = nan nc%lmort_collateral = nan nc%lmort_infra = nan @@ -544,29 +544,28 @@ subroutine spawn_patches( currentSite, bc_in) ! the number density. currentSite%imort_rate(currentCohort%size_class, currentCohort%pft) = & currentSite%imort_rate(currentCohort%size_class, currentCohort%pft) + & - nc%n * ED_val_understorey_death / hlm_freq_day + nc%n * logging_coll_under_frac / hlm_freq_day currentSite%imort_carbonflux = currentSite%imort_carbonflux + & - (nc%n * ED_val_understorey_death / hlm_freq_day ) * & + (nc%n * logging_coll_under_frac/ hlm_freq_day ) * & currentCohort%b * g_per_kg * days_per_sec * years_per_day * ha_per_m2 ! Step 2: Apply survivor ship function based on the understory death fraction ! remaining of understory plants of those that are knocked over by the overstorey trees dying... - ! CURRENTLY ASSUMING THAT LOGGING SURVIVORSHIP OF UNDERSTORY PLANTS IS SAME AS NATURAL - ! TREEFALL (STILL BEING DISCUSSED) - nc%n = nc%n * (1.0_r8 - ED_val_understorey_death) + ! LOGGING SURVIVORSHIP OF UNDERSTORY PLANTS IS SET AS A NEW PARAMETER in the fatesparameter files + nc%n = nc%n * (1.0_r8 - logging_coll_under_frac) ! Step 3: Reduce the number count of cohorts in the original/donor/non-disturbed patch ! to reflect the area change currentCohort%n = currentCohort%n * (1._r8 - patch_site_areadis/currentPatch%area) - nc%fmort = 0.0_r8 + nc%fmort = 0.0_r8 nc%cmort = currentCohort%cmort nc%hmort = currentCohort%hmort nc%bmort = currentCohort%bmort nc%dmort = currentCohort%dmort - nc%lmort_logging = currentCohort%lmort_logging + nc%lmort_direct = currentCohort%lmort_direct nc%lmort_collateral = currentCohort%lmort_collateral nc%lmort_infra = currentCohort%lmort_infra @@ -585,7 +584,7 @@ subroutine spawn_patches( currentSite, bc_in) nc%hmort = currentCohort%hmort nc%bmort = currentCohort%bmort nc%dmort = currentCohort%dmort - nc%lmort_logging = currentCohort%lmort_logging + nc%lmort_direct = currentCohort%lmort_direct nc%lmort_collateral = currentCohort%lmort_collateral nc%lmort_infra = currentCohort%lmort_infra diff --git a/biogeochem/EDPhysiologyMod.F90 b/biogeochem/EDPhysiologyMod.F90 index 5b998bed4e..77bf10ff57 100644 --- a/biogeochem/EDPhysiologyMod.F90 +++ b/biogeochem/EDPhysiologyMod.F90 @@ -814,7 +814,7 @@ subroutine Growth_Derivatives( currentSite, currentCohort, bc_in) real(r8) :: bmort ! background mortality rate (fraction per year) real(r8) :: hmort ! hydraulic failure mortality rate (fraction per year) - real(r8) :: lmort_logging ! Mortality fraction associated with direct logging + real(r8) :: lmort_direct ! Mortality fraction associated with direct logging real(r8) :: lmort_collateral ! Mortality fraction associated with logging collateral damage real(r8) :: lmort_infra ! Mortality fraction associated with logging infrastructure real(r8) :: dndt_logging ! Mortality rate (per day) associated with the a logging event @@ -847,15 +847,16 @@ subroutine Growth_Derivatives( currentSite, currentCohort, bc_in) ! Mortality for trees in the understorey. !if trees are in the canopy, then their death is 'disturbance'. This probably needs a different terminology call mortality_rates(currentCohort,cmort,hmort,bmort) + call LoggingMortality_frac(ipft, currentCohort%dbh, & - currentCohort%lmort_logging, & - currentCohort%lmort_collateral, & + currentCohort%lmort_direct, & + currentCohort%lmort_collateral, & currentCohort%lmort_infra ) if (currentCohort%canopy_layer > 1)then ! Include understory logging mortality rates not associated with disturbance - dndt_logging = (currentCohort%lmort_logging + & + dndt_logging = (currentCohort%lmort_direct + & currentCohort%lmort_collateral + & currentCohort%lmort_infra)/hlm_freq_day @@ -1306,7 +1307,7 @@ subroutine CWD_Input( currentSite, currentPatch) ! Total number of dead understory from direct logging ! (it is possible that large harvestable trees are in the understory) - dead_n_dlogging = ( currentCohort%lmort_logging) * & + dead_n_dlogging = ( currentCohort%lmort_direct) * & currentCohort%n/hlm_freq_day/currentPatch%area ! Total number of dead understory from indirect logging diff --git a/main/EDParamsMod.F90 b/main/EDParamsMod.F90 index b6da0529e7..f9cc8a54a3 100644 --- a/main/EDParamsMod.F90 +++ b/main/EDParamsMod.F90 @@ -444,6 +444,7 @@ subroutine FatesReportParams(is_master) write(fates_log(),fmt0) 'hydr_psicap = ',hydr_psicap write(fates_log(),fmt0) 'logging_dbhmin = ',logging_dbhmin write(fates_log(),fmt0) 'logging_collateral_frac = ',logging_collateral_frac + write(fates_log(),fmt0) 'logging_coll_under_frac = ',logging_coll_under_frac write(fates_log(),fmt0) 'logging_direct_frac = ',logging_direct_frac write(fates_log(),fmt0) 'logging_mechanical_frac = ',logging_mechanical_frac write(fates_log(),fmt0) 'logging_event_code = ',logging_event_code diff --git a/main/EDTypesMod.F90 b/main/EDTypesMod.F90 index 05e0775205..dcb7b7c2d9 100644 --- a/main/EDTypesMod.F90 +++ b/main/EDTypesMod.F90 @@ -229,11 +229,10 @@ module EDTypesMod real(r8) :: fmort ! fire mortality n/year ! Logging Mortality Rate - ! Yi Xu - real(r8) :: lmort_logging ! directly logging rate %/per logging activity + ! Yi Xu & M. Huang + real(r8) :: lmort_direct ! directly logging rate %/per logging activity real(r8) :: lmort_collateral ! collaterally damaged rate %/per logging activity real(r8) :: lmort_infra ! mechanically damaged rate %/per logging activity - ! NITROGEN POOLS ! ---------------------------------------------------------------------------------- diff --git a/main/FatesHistoryInterfaceMod.F90 b/main/FatesHistoryInterfaceMod.F90 index 8287713fe6..d8b662a98d 100644 --- a/main/FatesHistoryInterfaceMod.F90 +++ b/main/FatesHistoryInterfaceMod.F90 @@ -1486,16 +1486,16 @@ subroutine update_history_dyn(this,nc,nsites,sites) hio_m2_si_scpf(io_si,scpf) = hio_m2_si_scpf(io_si,scpf) + ccohort%hmort*ccohort%n hio_m3_si_scpf(io_si,scpf) = hio_m3_si_scpf(io_si,scpf) + ccohort%cmort*ccohort%n hio_m5_si_scpf(io_si,scpf) = hio_m5_si_scpf(io_si,scpf) + ccohort%fmort*ccohort%n - hio_m7_si_scpf(io_si,scpf) = hio_m7_si_scpf(io_si,scpf) + & - (ccohort%lmort_logging+ccohort%lmort_collateral+ccohort%lmort_infra) * ccohort%n + hio_m7_si_scpf(io_si,scpf) = hio_m7_si_scpf(io_si,scpf) + & + (ccohort%lmort_direct+ccohort%lmort_collateral+ccohort%lmort_infra) * ccohort%n hio_m1_si_scls(io_si,scls) = hio_m1_si_scls(io_si,scls) + ccohort%bmort*ccohort%n hio_m2_si_scls(io_si,scls) = hio_m2_si_scls(io_si,scls) + ccohort%hmort*ccohort%n hio_m3_si_scls(io_si,scls) = hio_m3_si_scls(io_si,scls) + ccohort%cmort*ccohort%n hio_m5_si_scls(io_si,scls) = hio_m5_si_scls(io_si,scls) + ccohort%fmort*ccohort%n hio_m7_si_scls(io_si,scls) = hio_m7_si_scls(io_si,scls) + & - (ccohort%lmort_logging+ccohort%lmort_collateral+ccohort%lmort_infra) * ccohort%n - + (ccohort%lmort_direct+ccohort%lmort_collateral+ccohort%lmort_infra) * ccohort%n + ! basal area [m2/ha] hio_ba_si_scpf(io_si,scpf) = hio_ba_si_scpf(io_si,scpf) + & @@ -1544,9 +1544,8 @@ subroutine update_history_dyn(this,nc,nsites,sites) hio_mortality_canopy_si_scpf(io_si,scpf) = hio_mortality_canopy_si_scpf(io_si,scpf)+ & (ccohort%bmort + ccohort%hmort + ccohort%cmort + ccohort%fmort) * ccohort%n + & - (ccohort%lmort_logging + ccohort%lmort_collateral + ccohort%lmort_infra) * & + (ccohort%lmort_direct + ccohort%lmort_collateral + ccohort%lmort_infra) * & ccohort%n * sec_per_day * days_per_year - hio_nplant_canopy_si_scpf(io_si,scpf) = hio_nplant_canopy_si_scpf(io_si,scpf) + ccohort%n hio_nplant_canopy_si_scls(io_si,scls) = hio_nplant_canopy_si_scls(io_si,scls) + ccohort%n @@ -1567,13 +1566,13 @@ subroutine update_history_dyn(this,nc,nsites,sites) ! sum of all mortality hio_mortality_canopy_si_scls(io_si,scls) = hio_mortality_canopy_si_scls(io_si,scls) + & (ccohort%bmort + ccohort%hmort + ccohort%cmort + ccohort%fmort ) * ccohort%n + & - (ccohort%lmort_logging + ccohort%lmort_collateral + ccohort%lmort_infra) * & + (ccohort%lmort_direct + ccohort%lmort_collateral + ccohort%lmort_infra) * & ccohort%n * sec_per_day * days_per_year hio_canopy_mortality_carbonflux_si(io_si) = hio_canopy_mortality_carbonflux_si(io_si) + & (ccohort%bmort + ccohort%hmort + ccohort%cmort + ccohort%fmort) * & ccohort%b * ccohort%n * g_per_kg * days_per_sec * years_per_day * ha_per_m2 + & - (ccohort%lmort_logging + ccohort%lmort_collateral + ccohort%lmort_infra)* ccohort%b * & + (ccohort%lmort_direct + ccohort%lmort_collateral + ccohort%lmort_infra)* ccohort%b * & ccohort%n * g_per_kg * ha_per_m2 hio_leaf_md_canopy_si_scls(io_si,scls) = hio_leaf_md_canopy_si_scls(io_si,scls) + & @@ -1624,7 +1623,7 @@ subroutine update_history_dyn(this,nc,nsites,sites) hio_mortality_understory_si_scpf(io_si,scpf) = hio_mortality_understory_si_scpf(io_si,scpf)+ & (ccohort%bmort + ccohort%hmort + ccohort%cmort + ccohort%fmort ) * ccohort%n + & - (ccohort%lmort_logging + ccohort%lmort_collateral + ccohort%lmort_infra) * & + (ccohort%lmort_direct + ccohort%lmort_collateral + ccohort%lmort_infra) * & ccohort%n * sec_per_day * days_per_year hio_nplant_understory_si_scpf(io_si,scpf) = hio_nplant_understory_si_scpf(io_si,scpf) + ccohort%n @@ -1647,13 +1646,13 @@ subroutine update_history_dyn(this,nc,nsites,sites) ! sum of all mortality hio_mortality_understory_si_scls(io_si,scls) = hio_mortality_understory_si_scls(io_si,scls) + & (ccohort%bmort + ccohort%hmort + ccohort%cmort + ccohort%fmort ) * ccohort%n + & - (ccohort%lmort_logging + ccohort%lmort_collateral + ccohort%lmort_infra) * & + (ccohort%lmort_direct + ccohort%lmort_collateral + ccohort%lmort_infra) * & ccohort%n * sec_per_day * days_per_year hio_understory_mortality_carbonflux_si(io_si) = hio_understory_mortality_carbonflux_si(io_si) + & (ccohort%bmort + ccohort%hmort + ccohort%cmort + ccohort%fmort) * & ccohort%b * ccohort%n * g_per_kg * days_per_sec * years_per_day * ha_per_m2 + & - (ccohort%lmort_logging + ccohort%lmort_collateral + ccohort%lmort_infra) * ccohort%b * & + (ccohort%lmort_direct + ccohort%lmort_collateral + ccohort%lmort_infra) * ccohort%b * & ccohort%n * g_per_kg * ha_per_m2 ! hio_leaf_md_understory_si_scls(io_si,scls) = hio_leaf_md_understory_si_scls(io_si,scls) + & @@ -1860,7 +1859,7 @@ subroutine update_history_dyn(this,nc,nsites,sites) hio_m4_si_scpf(io_si,i_scpf) + & hio_m5_si_scpf(io_si,i_scpf) + & hio_m6_si_scpf(io_si,i_scpf) + & - hio_m7_si_scpf(io_si,i_scpf) + hio_m7_si_scpf(io_si,i_scpf) diff --git a/main/FatesRestartInterfaceMod.F90 b/main/FatesRestartInterfaceMod.F90 index 7ccbe0bdab..773bc8ca93 100644 --- a/main/FatesRestartInterfaceMod.F90 +++ b/main/FatesRestartInterfaceMod.F90 @@ -101,7 +101,7 @@ module FatesRestartInterfaceMod integer, private :: ir_fmort_co !Logging - integer, private :: ir_lmort_logging_co + integer, private :: ir_lmort_direct_co integer, private :: ir_lmort_collateral_co integer, private :: ir_lmort_infra_co @@ -744,10 +744,10 @@ subroutine define_restart_vars(this, initialize_variables) hlms='CLM:ALM', initialize=initialize_variables, ivar=ivar, index = ir_fmort_co ) - call this%set_restart_var(vname='fates_lmort_logging', vtype=cohort_r8, & + call this%set_restart_var(vname='fates_lmort_direct', vtype=cohort_r8, & long_name='ed cohort - directly logging mortality rate', & units='%/event', flushval = flushzero, & - hlms='CLM:ALM', initialize=initialize_variables, ivar=ivar, index = ir_lmort_logging_co ) + hlms='CLM:ALM', initialize=initialize_variables, ivar=ivar, index = ir_lmort_direct_co ) call this%set_restart_var(vname='fates_lmort_collateral', vtype=cohort_r8, & long_name='ed cohort - collateral mortality rate', & @@ -1055,14 +1055,9 @@ subroutine set_restart_vectors(this,nc,nsites,sites) rio_hmort_co => this%rvars(ir_hmort_co)%r81d, & rio_cmort_co => this%rvars(ir_cmort_co)%r81d, & rio_fmort_co => this%rvars(ir_fmort_co)%r81d, & - - - - rio_lmort_logging_co => this%rvars(ir_lmort_logging_co)%r81d, & - rio_lmort_collateral_co => this%rvars(ir_lmort_collateral_co)%r81d, & - rio_lmort_infra_co => this%rvars(ir_lmort_infra_co)%r81d, & - - + rio_lmort_direct_co => this%rvars(ir_lmort_direct_co)%r81d, & + rio_lmort_collateral_co => this%rvars(ir_lmort_collateral_co)%r81d, & + rio_lmort_infra_co => this%rvars(ir_lmort_infra_co)%r81d, & rio_ddbhdt_co => this%rvars(ir_ddbhdt_co)%r81d, & rio_dbalivedt_co => this%rvars(ir_dbalivedt_co)%r81d, & rio_dbdeaddt_co => this%rvars(ir_dbdeaddt_co)%r81d, & @@ -1178,11 +1173,9 @@ subroutine set_restart_vectors(this,nc,nsites,sites) rio_fmort_co(io_idx_co) = ccohort%fmort !Logging - rio_lmort_logging_co(io_idx_co) = ccohort%lmort_logging - rio_lmort_collateral_co(io_idx_co) = ccohort%lmort_collateral - rio_lmort_infra_co(io_idx_co) = ccohort%lmort_infra - - + rio_lmort_direct_co(io_idx_co) = ccohort%lmort_direct + rio_lmort_collateral_co(io_idx_co) = ccohort%lmort_collateral + rio_lmort_infra_co(io_idx_co) = ccohort%lmort_infra rio_ddbhdt_co(io_idx_co) = ccohort%ddbhdt rio_dbalivedt_co(io_idx_co) = ccohort%dbalivedt @@ -1637,11 +1630,9 @@ subroutine get_restart_vectors(this, nc, nsites, sites) rio_cmort_co => this%rvars(ir_cmort_co)%r81d, & rio_fmort_co => this%rvars(ir_fmort_co)%r81d, & - rio_lmort_logging_co => this%rvars(ir_lmort_logging_co)%r81d, & - rio_lmort_collateral_co => this%rvars(ir_lmort_collateral_co)%r81d, & - rio_lmort_infra_co => this%rvars(ir_lmort_infra_co)%r81d, & - - + rio_lmort_direct_co => this%rvars(ir_lmort_direct_co)%r81d, & + rio_lmort_collateral_co => this%rvars(ir_lmort_collateral_co)%r81d, & + rio_lmort_infra_co => this%rvars(ir_lmort_infra_co)%r81d, & rio_ddbhdt_co => this%rvars(ir_ddbhdt_co)%r81d, & rio_dbalivedt_co => this%rvars(ir_dbalivedt_co)%r81d, & @@ -1741,12 +1732,10 @@ subroutine get_restart_vectors(this, nc, nsites, sites) ccohort%cmort = rio_cmort_co(io_idx_co) ccohort%fmort = rio_fmort_co(io_idx_co) - !Logging - ccohort%lmort_logging = rio_lmort_logging_co(io_idx_co) - ccohort%lmort_collateral = rio_lmort_collateral_co(io_idx_co) - ccohort%lmort_infra = rio_lmort_infra_co(io_idx_co) - - + !Logging + ccohort%lmort_direct = rio_lmort_direct_co(io_idx_co) + ccohort%lmort_collateral = rio_lmort_collateral_co(io_idx_co) + ccohort%lmort_infra = rio_lmort_infra_co(io_idx_co) ccohort%ddbhdt = rio_ddbhdt_co(io_idx_co) ccohort%dbalivedt = rio_dbalivedt_co(io_idx_co)