pl_nup.f90 Source File


This file depends on

sourcefile~~pl_nup.f90~~EfferentGraph sourcefile~pl_nup.f90 pl_nup.f90 sourcefile~basin_module.f90 basin_module.f90 sourcefile~pl_nup.f90->sourcefile~basin_module.f90 sourcefile~hru_module.f90 hru_module.f90 sourcefile~pl_nup.f90->sourcefile~hru_module.f90 sourcefile~organic_mineral_mass_module.f90 organic_mineral_mass_module.f90 sourcefile~pl_nup.f90->sourcefile~organic_mineral_mass_module.f90 sourcefile~output_landscape_module.f90 output_landscape_module.f90 sourcefile~pl_nup.f90->sourcefile~output_landscape_module.f90 sourcefile~plant_data_module.f90 plant_data_module.f90 sourcefile~pl_nup.f90->sourcefile~plant_data_module.f90 sourcefile~plant_module.f90 plant_module.f90 sourcefile~pl_nup.f90->sourcefile~plant_module.f90 sourcefile~soil_module.f90 soil_module.f90 sourcefile~pl_nup.f90->sourcefile~soil_module.f90

Source Code

      subroutine pl_nup
      
!!    ~ ~ ~ PURPOSE ~ ~ ~
!!    This subroutine calculates plant nitrogen uptake

!!    ~ ~ ~ INCOMING VARIABLES ~ ~ ~
!!    name        |units          |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    nup1(:)   |none           |1st shape parameter for plant N uptake
!!                                |equation
!!    nup2(:)   |none           |2nd shape parameter for plant N uptake
!!                                |equation
!!    ihru        |none           |HRU number
!!    pltnfr(1,:) |kg N/kg biomass|nitrogen uptake parameter #1: normal fraction
!!                                |of N in crop biomass at emergence
!!    pltnfr(3,:) |kg N/kg biomass|nitrogen uptake parameter #3: normal fraction
!!                                |of N in crop biomass at maturity
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ OUTGOING VARIABLES ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    uno3d       |kg N/ha       |plant nitrogen deficiency for day in HRU
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ LOCAL DEFINITIONS ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    un2         |kg N/ha       |ideal plant nitrogen content
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~
!!    Intrinsic: Exp, Min
!!    SWAT: nfix, nuts

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

      use plant_data_module
      use basin_module
      use organic_mineral_mass_module
      use hru_module, only : uno3d, un2, nplnt, fixn, ihru, ipl, rto_no3, uptake
      use soil_module
      use plant_module
      use output_landscape_module

      implicit none

      integer :: j = 0       !none      |hru number
      integer :: l = 0       !none      |counter (soil layer)
      real :: uno3l = 0.     !kg N/ha   |plant nitrogen demand
      integer :: idp = 0     !          |       
      real :: root_depth = 0.  !mm        |root depth
      real :: unmx = 0.      !kg N/ha   |maximum amount of nitrogen that can be removed from soil layer
      real :: soil_depth = 0.  !mm        |lowest depth in layer from which nitrogen may be removed
      real :: xx = 0.        !          |  
      integer :: max         !          |
  
      j = ihru

      idp = pcom(j)%plcur(ipl)%idplt
      pcom(j)%plstr(ipl)%strsn = 1.
      hnb_d(j)%nuptake = 0.
      if (uno3d(ipl) < 1.e-6) return
      
      !! find depth of soil layer the roots are into
      root_depth = max (10.1, pcom(j)%plg(ipl)%root_dep)
      soil_depth = 0.
      do l = 1, soil(j)%nly
        soil_depth = soil(j)%phys(l)%d
        if (root_depth < soil_depth) then
          root_depth = soil(j)%phys(l)%d
          exit
        end if
      end do
        
      do l = 1, soil(j)%nly
        soil_depth = soil(j)%phys(l)%d
        if (root_depth < soil_depth) exit
        unmx = uno3d(ipl) * rto_no3 * (1. - Exp(-bsn_prm%n_updis * soil_depth / root_depth)) / uptake%n_norm
        uno3l = Min(unmx - nplnt(j), soil1(j)%mn(l)%no3)
        !uno3l = Min(unmx, soil1(j)%mn(l)%no3)
        nplnt(j) = nplnt(j) + uno3l 
        soil1(j)%mn(l)%no3 = soil1(j)%mn(l)%no3 - uno3l
      end do
      if (nplnt(j) < 0.) nplnt(j) = 0.

      !! if crop is a legume, call nitrogen fixation routine
      if (pldb(idp)%nfix_co > 1.e-6) then
        call pl_nfix
      end if

      nplnt(j) = nplnt(j) + fixn
      pl_mass(j)%tot(ipl)%n = pl_mass(j)%tot(ipl)%n + nplnt(j)
      pl_mass(j)%ab_gr(ipl)%n = pl_mass(j)%ab_gr(ipl)%n + nplnt(j) * (1. - pcom(j)%plg(ipl)%root_frac)
      pl_mass(j)%root(ipl)%n = pl_mass(j)%root(ipl)%n + nplnt(j) * pcom(j)%plg(ipl)%root_frac
      pl_mass_up%n = nplnt(j)
      hnb_d(j)%nuptake = hnb_d(j)%nuptake + nplnt(j)
 
      !! compute nitrogen stress

      if (pldb(idp)%nfix_co > 1.e-6) then
        pcom(j)%plstr(ipl)%strsn = 1.
      else
        call nuts (pl_mass(j)%tot(ipl)%n, un2(ipl), pcom(j)%plstr(ipl)%strsn)
        if (uno3d(ipl) > 1.e-5) then
          xx = nplnt(j) / uno3d(ipl)
        else
          xx = 1.
        end if
        pcom(j)%plstr(ipl)%strsn = Max(pcom(j)%plstr(ipl)%strsn, xx)
        pcom(j)%plstr(ipl)%strsn = amin1(pcom(j)%plstr(ipl)%strsn, 1.)
      end if

      return
      end subroutine pl_nup