smp_grass_wway.f90 Source File


This file depends on

sourcefile~~smp_grass_wway.f90~~EfferentGraph sourcefile~smp_grass_wway.f90 smp_grass_wway.f90 sourcefile~channel_velocity_module.f90 channel_velocity_module.f90 sourcefile~smp_grass_wway.f90->sourcefile~channel_velocity_module.f90 sourcefile~constituent_mass_module.f90 constituent_mass_module.f90 sourcefile~smp_grass_wway.f90->sourcefile~constituent_mass_module.f90 sourcefile~hru_module.f90 hru_module.f90 sourcefile~smp_grass_wway.f90->sourcefile~hru_module.f90 sourcefile~output_ls_pesticide_module.f90 output_ls_pesticide_module.f90 sourcefile~smp_grass_wway.f90->sourcefile~output_ls_pesticide_module.f90

Source Code

      subroutine smp_grass_wway
      
!!    ~ ~ ~ PURPOSE ~ ~ ~
!!    this subroutine controls the grass waterways                      
!!    ~ ~ ~ INCOMING VARIABLES ~ ~ ~
!!    name          |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ihru            |none          |HRU number
!!    surfq(:)      |mm H2O        |amount of water in surface runoff generated
!!   grwat_l(:)      |km               |Length of Grass Waterway
!!  grwat_w(:)      |none          |Width of grass waterway
!!  grwat_s(:)      |m/m           |Slope of grass waterway
!!  grwat_spcon(:)  |none          |sediment transport coefficant defined by user
!!  tc_gwat(:)      |none          |Time of concentration for Grassed waterway and its drainage area
!!    surfq(:)        |mm H2O        |surface runoff generated on day in HRU
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ~ ~ ~ OUTGOING VARIABLES ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ~ ~ ~ LOCAL DEFINITIONS ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    qp_cms      |m^3/s         |peak runoff rate for the day 
!!    rcharea     |m^2           |cross-sectional area of flow
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~

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

      use hru_module, only : hru, surfq, sedyld, ihru, clayld, sanyld, silyld, sagyld, lagyld,  &
        sedminpa, sedminps, sedorgp, surqsolp, sedorgn, surqno3, tc_gwat, qp_cms, sdti
      use constituent_mass_module
      use channel_velocity_module
      use output_ls_pesticide_module
      
      implicit none

      real :: chflow_m3 = 0.         !m^3/s         |Runoff in CMS
      real :: sf_area = 0.           !m^2           |area of waterway sides in sheetflow
      real :: surq_remove = 0.       !%             |percent of surface runoff capture in VFS
      real :: sed_remove = 0.        !%             |percent of sediment capture in VFS
      real :: sf_sed = 0.            !kg/m^2        |sediment loads on sides of waterway
      real :: vc = 0.                !m/s           |flow velocity in reach
      real :: chflow_day = 0.        !m^3/day       |Runoff
      integer :: j = 0               !none          |HRU number
      real :: rchdep = 0.            !m             |depth of flow on day
      real :: p = 0.                 !              |
      real :: rh = 0.                !m             |hydraulic radius
      real :: qman                   !m^3/s or m/s  |flow rate or flow velocity 
      real :: sedin = 0.             !mg            |Sediment in waterway 
      real :: sf_depth = 0.          !              |
      real :: sedint = 0.            !mg            |Sediment into waterway channel
      real :: cyin = 0.              !              |
      real :: cych = 0.              !              |
      real :: rcharea = 0.
      real :: depnet = 0.            !metric tons   |
      real :: deg = 0.               !metric tons   |sediment reentrained in water by channel
                                     !              |degradation
      real :: dep = 0.               !              |
      real :: sedout = 0.            !mg            | Sediment out of waterway channel
      real :: sed_frac = 0.          !              |
      real :: surq_frac = 0.         !              |
      real :: sedtrap = 0.           !              | 
      real :: xrem = 0.              !              | 
      integer :: k = 0               !m^3/s         |Total number of HRUs plus this HRU number
      
!!  set variables
      j = ihru

                                
!!  do this only if there is surface runoff this day
      if (surfq(j) > 0.001) then

!!        compute channel peak rate using SCS triangular unit hydrograph
!!      Calculate average flow based on 3 hours of runoff
        chflow_day = 1000. * surfq(j) * hru(ihru)%km
          chflow_m3 = chflow_day/10800
          qp_cms = 2. * chflow_m3 / (1.5 * tc_gwat(j))

!! if peak rate is greater than bankfull discharge
          if (qp_cms > grwway_vel(j)%vel_bf) then
            rcharea = grwway_vel(j)%area
            rchdep = hru(j)%lumv%grwat_d
          else
!!          find the crossectional area and depth for todays flow
!!          by iteration method at 1cm interval depth
!!          find the depth until the discharge rate is equal to volrt
            sdti = 0.
            rchdep = 0.

            Do While (sdti < qp_cms)
              rchdep = rchdep + 0.01
              rcharea = (grwway_vel(j)%wid_btm + 8 * rchdep) * rchdep
              p = grwway_vel(j)%wid_btm + 2. * rchdep * Sqrt(1. + 8 * 8)
              rh = rcharea / p
              sdti = Qman(rcharea, rh, hru(j)%lumv%grwat_n, hru(j)%lumv%grwat_s)
            end do
          end if

!!        Sediment yield (kg) from fraction of area drained by waterway

          sedin = sedyld(ihru) * hru(ihru)%km 
!! Calculate sediment losses in sheetflow at waterway sides

!! calculate area of sheeflow in m^2 assumne *:1 side slope 8.06 = (8^2+1^2)^.5
    sf_area = (hru(j)%lumv%grwat_d - rchdep) * 8.06 * hru(j)%lumv%grwat_l * 1000
!! Adjust Area to account for flow nonuniformities White and Arnold 2009 found half of flow in VFS
!!handled by 10% of VFS area. Waterways likely even more concentrated Assume only 20% of sideslope acts as filters
      if (sf_area > 1.e-6) then
      sf_area = sf_area * 0.20 
!! calculate runoff depth over sheetflow area in mm
      sf_depth=surfq(j)  * hru(ihru)%km * 1000000/sf_area
!! Calculate sediment load on sheetflow area kg/ha
      sf_sed = sedin * 1000 / sf_area
!! Calculate runoff and sediment losses taken from mostly from filter.f
      end if

    if (sf_area > 0.) then 
!!      surq_remove = 75.8 - 10.8 * Log(sf_depth) + 25.9 
!!     &    * Log(sol_k(1,j))
    !! Simpler form derived from vfsmod simulations. r2 = 0.57 Publication pending white and arnold 2008

        surq_remove = 95.6 - 10.79 * Log(sf_depth) 
        if (surq_remove > 100.) surq_remove = 100.
        if (surq_remove < 0.) surq_remove = 0.

        sed_remove = 79.0 - 1.04 * sf_sed + 0.213 * surq_remove 
        if (sed_remove > 100.) sed_remove = 100.
        if (sed_remove < 0.) sed_remove = 0.

    Else
        sed_remove = 0 
        surq_remove = 0
    endif
    sedint = sedin * (1. - sed_remove / 100.)

!!        calculate flow velocity
          vc = 0.001
          if (rcharea > 1.e-4) then
            vc = qp_cms / rcharea
            if (vc > grwway_vel(j)%celerity_bf) vc = grwway_vel(j)%celerity_bf
          end if

!!        compute deposition in the waterway
          cyin = 0.
          cych = 0.
          depnet = 0.
          deg = 0.
          dep = 0.
!! if there is significant flow calculate 
          if (chflow_m3 > 1.e-4) then
!! Calculate sediment concentration in inflow mg/m^3
            cyin = sedint / chflow_day
!! Calculate sediment transport capacity mg/m^3
            cych = hru(j)%lumv%grwat_spcon * vc ** 1.5
!! Calculate deposition in mg
            depnet = chflow_day * (cyin - cych)
            if (depnet < 0.) depnet = 0
          if (depnet > sedint) depnet = sedint
          endif
!! Calculate sediment out of waterway channel
    sedout = sedint - depnet

!! Calculate total fraction of sediment and surface runoff transported
      if (sedyld(j) < .0001) sedyld(j) = .0001
    sed_frac =  sedout/sedyld(j)


    surq_frac = 1 - surq_remove/100

!! Subtract reductions from sediment, nutrients, bacteria, and pesticides NOT SURFACE RUNOFF to protect water balance
      sedtrap = sedyld(j) * (1. - sed_frac)
    sedyld(j) = sedyld(j) * sed_frac 
    sedminpa(j) = sedminpa(j) * sed_frac
    sedminps(j) = sedminps(j) * sed_frac
    sedorgp(j) = sedorgp(j) * sed_frac
    surqsolp(j) = surqsolp(j) * surq_frac
    sedorgn(j) = sedorgn(j) * sed_frac
    surqno3(j) = surqno3(j) * surq_frac

        xrem = 0.
      if (sedtrap <= lagyld(j)) then
        lagyld(j) = lagyld(j) - sedtrap
      else
        xrem = sedtrap - lagyld(j)
        lagyld(j) = 0.
        if (xrem <= sanyld(j)) then
          sanyld(j) = sanyld(j) - xrem
        else
          xrem = xrem - sanyld(j)
          sanyld(j) = 0.
          if (xrem <= sagyld(j)) then
            sagyld(j) = sagyld(j) - xrem
          else
            xrem = xrem - sagyld(j)
            sagyld(j) = 0.
            if (xrem <= silyld(j)) then
              silyld(j) = silyld(j) - xrem
            else
              xrem = xrem - silyld(j)
              silyld(j) = 0.
              if (xrem <= clayld(j)) then
                clayld(j) = clayld(j) - xrem
              else
                xrem = xrem - clayld(j)
                clayld(j) = 0.
              end if
            end if
          end if
        end if
      end if
        sanyld(j) = Max(0., sanyld(j))
        silyld(j) = Max(0., silyld(j))
        clayld(j) = Max(0., clayld(j))
        sagyld(j) = Max(0., sagyld(j))
        lagyld(j) = Max(0., lagyld(j))

!! Calculate pesticide removal 
!! based on the sediment and runoff removal only
        do k = 1, cs_db%num_pests
          hpestb_d(j)%pest(k)%surq = hpestb_d(j)%pest(k)%surq * surq_frac
          hpestb_d(j)%pest(k)%sed = hpestb_d(j)%pest(k)%sed * (1. - sed_remove / 100.)
        end do

      end if
      return
      end subroutine smp_grass_wway