Skip to content

Commit

Permalink
Merge pull request #324 from huangmy/logging-experiments
Browse files Browse the repository at this point in the history
Updating the logging module so that it could follow the GMD manuscript
  • Loading branch information
rgknox authored Feb 13, 2018
2 parents 865431c + b4d0b92 commit 34e7722
Show file tree
Hide file tree
Showing 8 changed files with 89 additions and 95 deletions.
16 changes: 8 additions & 8 deletions biogeochem/EDCohortDynamicsMod.F90
Original file line number Diff line number Diff line change
Expand Up @@ -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

Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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 + &
Expand All @@ -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 + &
Expand Down Expand Up @@ -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
Expand All @@ -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

Expand Down
38 changes: 22 additions & 16 deletions biogeochem/EDLoggingMortalityMod.F90
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand All @@ -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
Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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
Expand Down
47 changes: 23 additions & 24 deletions biogeochem/EDPatchDynamicsMod.F90
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand All @@ -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

Expand Down Expand Up @@ -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

Expand Down Expand Up @@ -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
Expand Down Expand Up @@ -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
Expand All @@ -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
Expand Down Expand Up @@ -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

!
Expand Down Expand Up @@ -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

Expand Down Expand Up @@ -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

Expand All @@ -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

Expand All @@ -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

Expand All @@ -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)))

Expand All @@ -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

Expand All @@ -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

Expand All @@ -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

Expand Down
11 changes: 6 additions & 5 deletions biogeochem/EDPhysiologyMod.F90
Original file line number Diff line number Diff line change
Expand Up @@ -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
Expand Down Expand Up @@ -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

Expand Down Expand Up @@ -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
Expand Down
Loading

0 comments on commit 34e7722

Please sign in to comment.