hru_urban.f90 Source File


This file depends on

sourcefile~~hru_urban.f90~~EfferentGraph sourcefile~hru_urban.f90 hru_urban.f90 sourcefile~climate_module.f90 climate_module.f90 sourcefile~hru_urban.f90->sourcefile~climate_module.f90 sourcefile~hru_module.f90 hru_module.f90 sourcefile~hru_urban.f90->sourcefile~hru_module.f90 sourcefile~hydrograph_module.f90 hydrograph_module.f90 sourcefile~hru_urban.f90->sourcefile~hydrograph_module.f90 sourcefile~urban_data_module.f90 urban_data_module.f90 sourcefile~hru_urban.f90->sourcefile~urban_data_module.f90 sourcefile~basin_module.f90 basin_module.f90 sourcefile~hydrograph_module.f90->sourcefile~basin_module.f90 sourcefile~time_module.f90 time_module.f90 sourcefile~hydrograph_module.f90->sourcefile~time_module.f90

Source Code

      subroutine hru_urban
      
!!    ~ ~ ~ PURPOSE ~ ~ ~
!!    this subroutine computes loadings from urban areas using the
!!    USGS regression equations or a build-up/wash-off algorithm

!!    ~ ~ ~ INCOMING VARIABLES ~ ~ ~
!!    name         |units          |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    dirtmx(:)    |kg/curb km     |maximum amount of solids allowed to
!!                                 |build up on impervious surfaces
!!    hru_km(:)    |km^2           |area of HRU in square kilometers
!!    ihru         |none           |HRU number
!!    nsweep(:)    |none           |sequence number of street sweeping operation
!!                                 |within the year
!!    qp_cms       |m^3/s          |peak runoff rate
!!    sedyld(:)    |metric tons    |daily soil loss caused by water erosio
!!    surfq(:)     |mm H2O         |surface runoff for the day in HRU
!!    tconc(:)     |hr             |time of concentration
!!    thalf(:)     |days           |time for the amount of solids on
!!                                 |impervious areas to build up to 1/2
!!                                 |the maximum level
!!    tnconc(:)    |mg N/kg sed    |concentration of total nitrogen in
!!                                 |suspended solid load from impervious
!!                                 |areas
!!    tno3conc(:)  |mg NO3-N/kg sed|concentration of NO3-N in suspended
!!                                 |solid load from impervious areas
!!    tpconc(:)    |mg P/kg sed    |concentration of total phosphorus in
!!                                 |suspended solid load from impervious
!!                                 |areas
!!    twash(:)     |days           |time that solids have built-up on streets
!!    urbcoef(:)   |1/mm           |wash-off coefficient for removal of
!!                                 |constituents from an impervious surface
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

!!    ~ ~ ~ OUTGOING VARIABLES ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    twash(:)    |
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~

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

!!    ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~
!!    Intrinsic: Exp, Max, Log
!!    SWAT: Regres, sweep

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

      use hru_module, only : hru, ihru, sedyld, surfq, ulu, sanyld, silyld, clayld, sagyld, lagyld, sedorgn, sedorgp,  &
        surqno3, surqsolp, twash, tconc, qp_cms
      use urban_data_module
      use hydrograph_module
      use climate_module
      
      implicit none

      real :: cod = 0.     !kg            |carbonaceous biological oxygen demand of 
                           !              |surface runoff from urban area
      real :: sus_sol = 0. !kg/ha         |suspended solid loading in surface runoff
                           !              |from urban area
      real :: tn = 0.      !kg            |total nitrogen in surface runoff from
                           !              |urban area
      real :: tp = 0.      !kg            |total phosphorus in surface runoff from 
                           !              |urban area
      real :: urbk = 0.    !1/hr          |
      real :: turo = 0.    !              |
      real :: dirto = 0.   !kg/ha         |amount of solids built up on impervious
                           !              |surfaces at beginning of day
      real :: durf = 0.    !hr            |duration of rainfall
      real :: rp1 = 0.     !none          |variable to hold intermediate calculation
                           !              |value 
      real :: dirt = 0.    !kg/curb km    |amount of solids built up on impervious
                           !              |surfaces 
      integer :: j = 0     !none          |HRU number
      integer :: iob = 0   !              |
      real :: regres       !              |
      real :: xx = 0.      !              |
      real :: exp          !              |
      real :: tno3 = 0.    !              |

      j = ihru
      ulu = hru(j)%luse%urb_lu
      iob = hru(j)%obj_no
      iwst = ob(iob)%wst

      select case (hru(j)%luse%urb_ro)

        case ("usgs_reg")                         !! USGS regression equations
        if (w%precip > .1 .and. surfq(j) > .1) then
          cod = Regres(1)
          sus_sol = Regres(2)
          tn = Regres(3)
          tp = Regres(4)
  
          sedyld(j) = (.001 * sus_sol) * urbdb(ulu)%fimp + sedyld(j)    & 
                                             * (1. - urbdb(ulu)%fimp)

          !! The sediment loading from urban imprevious area is assumed 
          !! to be all sitly particles
          silyld(j) = (.001 * sus_sol) * urbdb(ulu)%fimp                &
                                  + silyld(j) * (1. - urbdb(ulu)%fimp)
          sanyld(j) = sanyld(j) * (1. - urbdb(ulu)%fimp)
          clayld(j) = clayld(j) * (1. - urbdb(ulu)%fimp)
          sagyld(j) = sagyld(j) * (1. - urbdb(ulu)%fimp)
          lagyld(j) = lagyld(j) * (1. - urbdb(ulu)%fimp)

          sedorgn(j)=(.7 * tn / (hru(j)%km *100.))*urbdb(ulu)%fimp         &
                               + sedorgn(j) * (1. - urbdb(ulu)%fimp)
          surqno3(j)=(.3 * tn / (hru(j)%km *100.))*urbdb(ulu)%fimp         &
                               + surqno3(j) * (1. - urbdb(ulu)%fimp)
          sedorgp(j)=(.75 * tp / (hru(j)%km*100.))*urbdb(ulu)%fimp         &
                              +  sedorgp(j) * (1. - urbdb(ulu)%fimp)
          surqsolp(j)=.25 * tp / (hru(j)%km *100.)*urbdb(ulu)%fimp         &
                              + surqsolp(j) * (1. - urbdb(ulu)%fimp)
        endif

        case ("buildup_washoff")                         !! build-up/wash-off algorithm

        if (surfq(j) > 0.1) then
          !! rainy day: no build-up, street cleaning allowed

          !! calculate amount of dirt on streets prior to wash-off 
          dirt = urbdb(ulu)%dirtmx * twash(j) / (urbdb(ulu)%thalf + twash(j))
          dirto = dirt

          !! calculate wash-off of solids 
          urbk = urbdb(ulu)%urbcoef * (qp_cms * 3.6 / hru(j)%km)
                                     !! expression in () qp_cms in mm/hr 
          rp1 = -2. * Log(1.- wst(iwst)%weat%precip_half_hr)
          durf = 4.605 / rp1         
          turo = durf + tconc(j)
          if (turo > 24.) turo = 24.
          xx = urbk * turo
          if (xx > 24.) xx = 24.
          dirt = dirt * Exp (-xx)
          if (dirt < 1.e-6) dirt = 0.0

          !! set time to correspond to lower amount of dirt 
          twash(j) = urbdb(ulu)%thalf * dirt / (urbdb(ulu)%dirtmx -dirt)
 
          !! amounts are kg/ha
          sus_sol = Max(0., (dirto - dirt) * urbdb(ulu)%curbden)
          tn = urbdb(ulu)%tnconc * sus_sol / 1.e6
          tp = urbdb(ulu)%tpconc * sus_sol / 1.e6
          tno3 = urbdb(ulu)%tno3conc * sus_sol / 1.e6

          !! sus_sol * .001 = t/ha
          sedyld(j) = (.001 * sus_sol) * urbdb(ulu)%fimp +            &
                                   sedyld(j) * (1. - urbdb(ulu)%fimp)

          !! The sediment loading from urban imprevious area is assumed 
          !! to be all sitly particles
          silyld(j) = (.001 * sus_sol * hru(j)%area_ha) *                         &
                     urbdb(ulu)%fimp + silyld(j) * (1. - urbdb(ulu)%fimp)
          sanyld(j) = sanyld(j) * (1. - urbdb(ulu)%fimp)
          clayld(j) = clayld(j) * (1. - urbdb(ulu)%fimp)
          sagyld(j) = sagyld(j) * (1. - urbdb(ulu)%fimp)
          lagyld(j) = lagyld(j) * (1. - urbdb(ulu)%fimp)

          surqno3(j) = tno3 * urbdb(ulu)%fimp + surqno3(j) *           &
                                             (1. - urbdb(ulu)%fimp)
          sedorgn(j) = (tn - tno3) * urbdb(ulu)%fimp + sedorgn(j) *    &
                                             (1. - urbdb(ulu)%fimp)
          sedorgp(j) = .75 * tp * urbdb(ulu)%fimp + sedorgp(j)         &
                                           * (1. - urbdb(ulu)%fimp)
          surqsolp(j) = .25 * tp * urbdb(ulu)%fimp + surqsolp(j) *     &
                                             (1. - urbdb(ulu)%fimp)
        else
          !! dry day
          twash(j) = twash(j) + 1.

        end if

      end select

      return
      end subroutine hru_urban