cbn_rsd_decomp.f90 Source File


This file depends on

sourcefile~~cbn_rsd_decomp.f90~~EfferentGraph sourcefile~cbn_rsd_decomp.f90 cbn_rsd_decomp.f90 sourcefile~basin_module.f90 basin_module.f90 sourcefile~cbn_rsd_decomp.f90->sourcefile~basin_module.f90 sourcefile~hru_module.f90 hru_module.f90 sourcefile~cbn_rsd_decomp.f90->sourcefile~hru_module.f90 sourcefile~organic_mineral_mass_module.f90 organic_mineral_mass_module.f90 sourcefile~cbn_rsd_decomp.f90->sourcefile~organic_mineral_mass_module.f90 sourcefile~output_landscape_module.f90 output_landscape_module.f90 sourcefile~cbn_rsd_decomp.f90->sourcefile~output_landscape_module.f90 sourcefile~plant_module.f90 plant_module.f90 sourcefile~cbn_rsd_decomp.f90->sourcefile~plant_module.f90 sourcefile~septic_data_module.f90 septic_data_module.f90 sourcefile~cbn_rsd_decomp.f90->sourcefile~septic_data_module.f90 sourcefile~soil_module.f90 soil_module.f90 sourcefile~cbn_rsd_decomp.f90->sourcefile~soil_module.f90 sourcefile~carbon_module.f90 carbon_module.f90 sourcefile~organic_mineral_mass_module.f90->sourcefile~carbon_module.f90 sourcefile~soil_module.f90->sourcefile~carbon_module.f90

Source Code

      subroutine cbn_rsd_decomp

!!    ~ ~ ~ PURPOSE ~ ~ ~
!!    this subroutine estimates daily nitrogen and phosphorus
!!    mineralization and immobilization considering fresh organic
!!    material (plant residue) and active and stable humus material

!!    ~ ~ ~ INCOMING VARIABLES ~ ~ ~
!!    name          |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ihru          |none          |HRU number
!!    rsdco_pl(:)   |none          |plant residue decomposition coefficient. The
!!                                 |fraction of residue which will decompose in
!!                                 |a day assuming optimal moisture,
!!                                 |temperature, C:N ratio, and C:P ratio
!!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ OUTGOING VARIABLES ~ ~ ~
!!    name          |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ LOCAL DEFINITIONS ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~
!!    Intrinsic: Max, Exp, Sqrt, Min, Abs

!!    ~ ~ ~ ~ ~ ~ END SPECIFICATIONS ~ ~ ~ ~ ~ ~

      use septic_data_module
      use basin_module
      use organic_mineral_mass_module
      use hru_module, only : rsdco_plcom, i_sep, ihru, isep 
      use soil_module
      use plant_module
      use output_landscape_module, only : hnb_d
      
      implicit none 

      integer :: j = 0      !none          |HRU number
      integer :: k = 0      !none          |counter (soil layer)
      ! integer :: kk = 0     !none          |soil layer used to compute soil water and
      !                       !              |soil temperature factors
      !integer :: idp = 0
      real :: rmn1 = 0.     !kg N/ha       |amount of nitrogen moving from fresh organic
                            !              |to nitrate(80%) and active organic(20%)
                            !              |pools in layer
      real :: rmp = 0.      !              |to labile(80%) and organic(20%) pools in layer
      real :: xx = 0.       !varies        |variable to hold intermediate calculation result
      real :: csf = 0.      !none          |combined temperature/soil water factor
      real :: rwn = 0.      !kg N/ha       |amount of nitrogen moving from active organic
                            !              |to stable organic pool in layer
      real :: hmn = 0.      !kg N/ha       |amount of nitrogen moving from active organic
                            !              |nitrogen pool to nitrate pool in layer
      real :: hmp = 0.      !kg P/ha       |amount of phosphorus moving from the organic
                            !              |pool to the labile pool in layer
      real :: cnr = 0.      !              |carbon nitrogen ratio
      real :: cnrf = 0.     !              |carbon nitrogen ratio factor 
      real :: cpr = 0.      !              |carbon phosphorus ratio
      real :: cprf = 0.     !              |carbon phosphorus ratio factor
      real :: ca = 0.       !              |
      real :: decr = 0.     !              |
      !real :: rdc = 0.      !              |
      real :: wdn = 0.      !kg N/ha       |amount of nitrogen lost from nitrate pool in
                            !              |layer due to denitrification
      real :: cdg = 0.      !none          |soil temperature factor
      real :: sut = 0.      !none          |soil water factor
      real :: nactfr = 0.   !none          |nitrogen active pool fraction. The fraction
                            !              |of organic nitrogen in the active pool. 

      j = ihru
      nactfr = .02
      !zero transformations for summing layers
      hnb_d(j)%act_nit_n = 0.
      hnb_d(j)%org_lab_p = 0.
      hnb_d(j)%act_sta_n = 0.
      hnb_d(j)%denit = 0.
      hnb_d(j)%rsd_nitorg_n = 0.
      hnb_d(j)%rsd_laborg_p = 0.

      !! compute humus mineralization of organic soil pools 
      do k = 1, soil(j)%nly
        ! if (k == 1) then
        !   kk = 2
        ! else
        !   kk = k
        ! end if

        !! mineralization can occur only if temp above 0 deg
        if (soil(j)%phys(k)%tmp > 0.) then
          !! compute soil water factor
          sut = .1 + .9 * Sqrt(soil(j)%phys(k)%st / soil(j)%phys(k)%fc)
          sut = Max(.05, sut)

          !!compute soil temperature factor
          xx = soil(j)%phys(k)%tmp
          cdg = .9 * xx / (xx + Exp(9.93 - .312 * xx)) + .1
          cdg = Max(.1, cdg)

          !! compute combined factor
          xx = cdg * sut
          if (xx < 0.) xx = 0.
          if (xx > 1.e6) xx = 1.e6
          csf = Sqrt(xx)

          !! compute flow from active to stable pools- maintain fraction of active (nactfr)
          ! rwn = .1e-4 * ((soil1(j)%hact(k)%n * (1. / nactfr - 1.) - soil1(j)%hsta(k)%n))
          ! if (rwn > 0.) then
          !   rwn = Min(rwn, soil1(j)%hact(k)%n)
          ! else
          !   rwn = -(Min(Abs(rwn), soil1(j)%hsta(k)%n))
          ! endif
          ! soil1(j)%hsta(k)%n = Max(1.e-6, soil1(j)%hsta(k)%n + rwn)
          ! soil1(j)%hact(k)%n = Max(1.e-6, soil1(j)%hact(k)%n - rwn)
          ! hnb_d(j)%act_sta_n = hnb_d(j)%act_sta_n + rwn

          ! !! compute humus mineralization on active organic n
          ! hmn = bsn_prm%cmn * csf * soil1(j)%hact(k)%n
          ! hmn = Min(hmn, soil1(j)%hact(k)%n)
          ! !! compute humus mineralization on active organic p
          ! xx = soil1(j)%hsta(k)%n + soil1(j)%hact(k)%n
          ! if (xx > 1.e-6) then
          !   hmp = 1.4 * hmn * soil1(j)%hsta(k)%p / xx
          ! else
          !   hmp = 0.
          ! end if
          ! hmp = Min(hmp, soil1(j)%hsta(k)%p)
          ! !! move mineralized nutrients between pools
          ! soil1(j)%hact(k)%n = Max(1.e-6, soil1(j)%hact(k)%n - hmn)
          ! soil1(j)%mn(k)%no3 = soil1(j)%mn(k)%no3 + hmn
          ! soil1(j)%hsta(k)%p = soil1(j)%hsta(k)%p - hmp
          ! soil1(j)%mp(k)%lab = soil1(j)%mp(k)%lab + hmp
          
          ! hnb_d(j)%act_nit_n = hnb_d(j)%act_nit_n + hmn
          ! hnb_d(j)%org_lab_p = hnb_d(j)%org_lab_p + hmp

          !! compute residue decomp and mineralization of 
          !! fresh organic n and p (upper two layers only)
          rmn1 = 0.
          rmp = 0.
          if (soil1(j)%rsd(k)%n > 1.e-4) then
            cnr = soil1(j)%rsd(k)%c / soil1(j)%rsd(k)%n
            if (cnr > 500.) cnr = 500.
            cnrf = Exp(-.693 * (cnr - 25.) / 25.)
          else
            cnrf = 1.
          end if
            
          if (soil1(j)%rsd(k)%p > 1.e-4) then
            cpr = soil1(j)%rsd(k)%c / soil1(j)%rsd(k)%p
            if (cpr > 5000.) cpr = 5000.
            cprf = Exp(-.693 * (cpr - 200.) / 200.)
          else
            cprf = 1.
          end if

          ca = Min(cnrf, cprf, 1.)
            
          !! compute root and incorporated residue decomposition
          !! all plant residue in soil is mixed - don't track individual plant residue in soil
              
          if (pcom(j)%npl > 0) then
            decr = rsdco_plcom(j) / pcom(j)%npl * ca * csf
          else
            decr = 0.05
          end if
          decr = Max(bsn_prm%decr_min, decr)
          decr = Min(decr, 1.)
          decomp = decr * soil1(j)%rsd(k)
          soil1(j)%rsd(k) = soil1(j)%rsd(k) - decomp
          ! soil1(j)%mn(k)%no3 = soil1(j)%mn(k)%no3 + .8 * decomp%n
          ! soil1(j)%hact(k)%n = soil1(j)%hact(k)%n + .2 * decomp%n
          ! soil1(j)%mp(k)%lab = soil1(j)%mp(k)%lab + .8 * decomp%p
          ! soil1(j)%hsta(k)%p = soil1(j)%hsta(k)%p + .2 * decomp%p

          soil1(j)%meta(k) = soil1(j)%meta(k) + 0.85 * decomp
          soil1(j)%str(k) = soil1(j)%str(k) + 0.15 * decomp
          soil1(j)%lig(k) = soil1(j)%lig(k) + 0.12 * decomp

          ! hnb_d(j)%rsd_nitorg_n = hnb_d(j)%rsd_nitorg_n + .8 * decomp%n
          ! hnb_d(j)%rsd_laborg_p = hnb_d(j)%rsd_laborg_p + .8 * decomp%p
            
          ! !!  compute denitrification
          ! wdn = 0.   
          ! if (i_sep(j) /= k .or. sep(isep)%opt  /= 1) then
          !   if (sut >= bsn_prm%sdnco) then
          !     wdn = soil1(j)%mn(k)%no3 * (1.-Exp(-bsn_prm%cdn * cdg * soil1(j)%cbn(k) / 100.))
          !   else
          !     wdn = 0.
          !   endif
          !   soil1(j)%mn(k)%no3 = max(0.0001,soil1(j)%mn(k)%no3 - wdn)
          ! end if
          ! hnb_d(j)%denit = hnb_d(j)%denit + wdn

          !call nut_denit(k,j,cdg,wdn,0.05)

        end if
      end do        ! k = 1, soil(j)%nly

      return
      end subroutine