pl_waterup.f90 Source File


This file depends on

sourcefile~~pl_waterup.f90~~EfferentGraph sourcefile~pl_waterup.f90 pl_waterup.f90 sourcefile~basin_module.f90 basin_module.f90 sourcefile~pl_waterup.f90->sourcefile~basin_module.f90 sourcefile~constituent_mass_module.f90 constituent_mass_module.f90 sourcefile~pl_waterup.f90->sourcefile~constituent_mass_module.f90 sourcefile~hru_module.f90 hru_module.f90 sourcefile~pl_waterup.f90->sourcefile~hru_module.f90 sourcefile~plant_data_module.f90 plant_data_module.f90 sourcefile~pl_waterup.f90->sourcefile~plant_data_module.f90 sourcefile~plant_module.f90 plant_module.f90 sourcefile~pl_waterup.f90->sourcefile~plant_module.f90 sourcefile~salt_data_module.f90 salt_data_module.f90 sourcefile~pl_waterup.f90->sourcefile~salt_data_module.f90 sourcefile~soil_module.f90 soil_module.f90 sourcefile~pl_waterup.f90->sourcefile~soil_module.f90 sourcefile~urban_data_module.f90 urban_data_module.f90 sourcefile~pl_waterup.f90->sourcefile~urban_data_module.f90 sourcefile~carbon_module.f90 carbon_module.f90 sourcefile~soil_module.f90->sourcefile~carbon_module.f90

Source Code

      subroutine pl_waterup
      
!!    ~ ~ ~ PURPOSE ~ ~ ~
!!    this subroutine distributes potential plant evaporation through
!!    the root zone and calculates actual plant water use based on soil
!!    water availability. Also estimates water stress factor.     

!!    ~ ~ ~ INCOMING VARIABLES ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    epco(:)     |none          |plant water uptake compensation factor (0-1)
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ OUTGOING VARIABLES ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ep_day      |mm H2O        |actual amount of transpiration that occurs
!!                               |on day in HRU
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ LOCAL DEFINITIONS ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    gx          |
!!    ir          |
!!    j           |none          |HRU number
!!    k           |none          |counter (soil layer)
!!    reduc       |none          |fraction of water uptake by plants achieved
!!                               |where the reduction is caused by low water
!!                               |content
!!    sum         |
!!    sump        |
!!    wuse        |mm H2O        |water uptake by plants in each soil layer
!!    sum_wuse    |mm H2O        |water uptake by plants from all layers
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
    
!!    ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~
!!    Intrinsic: Exp, Max

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

      use plant_data_module
      use basin_module
      use hru_module, only : hru, ihru, epmax, ipl, ep_day, uptake
      use soil_module
      use plant_module
      use urban_data_module
      use constituent_mass_module !rtb salt
      use salt_data_module !rtb salt
      
      implicit none
      
      integer :: j = 0       !none      |hru number
      integer :: k = 0       !none      |counter 
      integer :: ir = 0      !none      |flag to denote bottom of root zone reached
      integer :: idp = 0     !          | 
      integer :: ulu = 0     !          |urban land use from urban.urb
      integer :: isalt = 0   !          |salt ion counter (rtb salt)
      real :: sum = 0.       !          |
      real :: sum_wuse = 0.  !mm H2O    |water uptake by plants from all layers
      real :: sum_wusep = 0. !mm H2O    |previous water uptake by plants from all layers
      real :: reduc = 0.     !none      |fraction of water uptake by plants achieved
                             !          |where the reduction is caused by low water
                             !          |content

      real :: sump = 0.      !          |
      real :: gx = 0.        !mm        |lowest depth in layer from which nitrogen
                             !          |may be removed
      real :: wuse = 0.      !mm H2O    |water uptake by plants in each soil layer
      real :: satco = 0.     !          | 
      real :: scparm = 0.    !          |  
      real :: reduc_salt = 0.                                                !rtb salt
      real :: reduc_salt_min = 0.                                            !rtb salt
      real :: sw_decrease = 0.                                               !rtb salt
      real :: salt_decrease = 0.                                             !rtb salt
      real :: theta_w = 0.                                                   !rtb salt
      real :: soil_TDS = 0.                                                  !rtb salt
      real :: soil_TDS_sat = 0.                                              !rtb salt
      real :: soil_ECe = 0.                                                  !rtb salt
      real :: a_val = 0.                                                     !rtb salt
      real :: b_val = 0.                                                     !rtb salt
      real :: depth = 0.                                                     !rtb salt

      j = ihru
      idp = pcom(j)%plcur(ipl)%idplt
       
      !! compute aeration stress
      if (soil(j)%sw > soil(j)%sumfc) then
        satco = (soil(j)%sw - soil(j)%sumfc) / (soil(j)%sumul - soil(j)%sumfc)
        scparm = 100. * (satco - pldb(idp)%aeration) / (1.0001 - pldb(idp)%aeration)
        if (scparm > 0.) then
          pcom(j)%plstr(ipl)%strsa = 1. - (scparm / (scparm + Exp(2.9014 - .03867 * scparm)))
        else
          pcom(j)%plstr(ipl)%strsa = 1.
        end if
      end if

      !! compute limiting water stress
      if (epmax(ipl) <= 1.e-6) then
        pcom(j)%plstr(ipl)%strsw = 1.
      else
        !! initialize variables
        gx = 0.
        ir = 0
        sump = 0.
        wuse = 0.
        sum_wuse = 0.
        sum_wusep = 0.
        
        sw_decrease = 0.
        salt_decrease = 0.
        reduc_salt = 1.
        reduc_salt_min = 1.
        depth = 0.
        pcom(j)%plcur(ipl)%uptake(:) = 0.

        do k = 1, soil(j)%nly
          
          if (ir > 0) exit

          if (pcom(j)%plg(ipl)%root_dep <= soil(j)%phys(k)%d) then
            gx = pcom(j)%plg(ipl)%root_dep
            ir = k
          else
            gx = soil(j)%phys(k)%d
          end if

          if (pcom(j)%plg(ipl)%root_dep <= 0.01) then
            sum = epmax(ipl) / uptake%water_norm
          else
            sum = epmax(ipl) * (1. - Exp(-uptake%water_dis * gx / pcom(j)%plg(ipl)%root_dep)) / uptake%water_norm
          end if

          pcom(j)%plcur(ipl)%epco = 0.9
          !! let second layer compensate - 10 mm layer causes problems wehn root depth is shallow
          if (k == 2) then
            wuse = sum      !epco is always 1.0 for second layer
          else
            wuse = sum - sump * (1. - pcom(j)%plcur(ipl)%epco)
          end if
          
          ! adjust for impervious area
          ulu = hru(j)%luse%urb_lu
          !wuse = wuse * urbdb(ulu)%fcimp
          wuse = amin1 (wuse, soil(j)%phys(k)%st)
          
          sum_wuse = sum_wuse + wuse
          if (sum_wuse > epmax(ipl)) then
            wuse = epmax(ipl) - sum_wusep
            sum_wuse = epmax(ipl)
          end if
          sump = sum
          sum_wusep = sum_wuse

          if (soil(j)%phys(k)%st < wuse) then
            wuse = soil(j)%phys(k)%st
          end if

          !rtb salt
          !adjust uptake if soil salinity has reached threshold for crop 
          if(salt_tol_sim.eq.1) then
          depth = depth + soil(j)%phys(k)%thick !depth (mm) of soil layer below land surface
          !only proceed if salts are simulated and soil layer is within rooting depth
          if(cs_db%num_salts > 0 .and. depth < pcom(j)%plg(ipl)%root_dep) then
            reduc_salt = 1.
            
            !retrieve salt ion concentrations in soil water, based on additional salt mineral dissolution
            !(to mimic the procedure in the lab: saturated paste extract)
            !calculate salt ion concentration under saturated conditions (dilution)
            theta_w = soil(j)%phys(k)%st / soil(j)%phys(k)%ul !water content
            do isalt=1,cs_db%num_salts
              soil_salt_conc(isalt) = cs_soil(j)%ly(k)%saltc(isalt) * theta_w
            enddo
            
            !modify salt ion concentrations based on precipitation-dissolution reactions
            if(theta_w.gt.(1e-5)) then
              call salt_chem_soil_single(j,k,theta_w)
            endif
            
            !get TDS (mg/L) of the soil water, at saturation
            soil_TDS_sat = 0.
            do isalt=1,cs_db%num_salts
              soil_TDS_sat = soil_TDS_sat + soil_salt_conc(isalt)
            enddo
            
            !get the ECe value (dS/m)
            soil_ECe = soil_TDS_sat / salt_tds_ec
            
            !compute percent of potential soil water uptake, using yield-ECe relationship based on the
            !HRU crop type (idplt)
            a_val = salt_stress_a(idp) !threshold
            b_val = salt_stress_b(idp) !slope
            
            !only proceed if a and b values are provided (in "salt_plants" file)
            if(a_val.ne.0) then
              !if gypsiferous soil, increase a_val by 2 dS/m
              if(salt_soil_type.eq.1) then
                a_val = a_val + 2
              endif
              !calculate fraction of ET if soil_ECe is above the threshold value (a)
              if(soil_ECe.gt.a_val) then 
                reduc_salt = (100 - (b_val*(soil_ECe-a_val))) / 100
                if(reduc_salt.gt.1) reduc_salt = 1.
                if(reduc_salt.lt.0) reduc_salt = 0.
              endif
            endif

            !compute salinity stress on crop - take maximum from all soil layers
            if(reduc_salt .lt. reduc_salt_min) then
              reduc_salt_min = reduc_salt
            endif

          endif
          endif
          
          soil(j)%phys(k)%st = Max(1.e-6, soil(j)%phys(k)%st - wuse)
          pcom(j)%plcur(ipl)%uptake(k) = wuse
          
        end do      !! soil layer loop
        
        !! update total soil water in profile
        soil(j)%sw = 0.
        do k = 1, soil(j)%nly
          soil(j)%sw = soil(j)%sw + soil(j)%phys(k)%st
        end do

        !rtb salt - compute stress caused by high soil salinity
        pcom(j)%plstr(ipl)%strss = 1
        if(salt_tol_sim.eq.1) then
          if(cs_db%num_salts.gt.0) then
            pcom(j)%plstr(ipl)%strss = reduc_salt_min
          endif
        endif
        
        !new epco adjustment requires epmax adjustment of water stress is too high
        pcom(j)%plstr(ipl)%strsw = sum_wuse / epmax(ipl)
        
        ep_day = ep_day + sum_wuse
      end if

      return
      end subroutine pl_waterup