unit_hyd.f90 Source File


This file depends on

sourcefile~~unit_hyd.f90~~EfferentGraph sourcefile~unit_hyd.f90 unit_hyd.f90 sourcefile~basin_module.f90 basin_module.f90 sourcefile~unit_hyd.f90->sourcefile~basin_module.f90 sourcefile~time_module.f90 time_module.f90 sourcefile~unit_hyd.f90->sourcefile~time_module.f90

Source Code

      subroutine unit_hyd (tc, uh)

!!    ~ ~ ~ PURPOSE ~ ~ ~
!!    This subroutine computes variables related to the watershed hydrology:
!!    the time of concentration for the subbasins, lagged surface runoff,
!!    the coefficient for the peak runoff rate equation, and lateral flow travel
!!    time.

!!    ~ ~ ~ INCOMING VARIABLES ~ ~ ~1
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ 
!!    ch_n(1,:)   |none          |Manning"s "n" value for the tributary channels
!!    ch_s(1,:)   |m/m           |average slope of tributary channels
!!    gdrain(:)   |hrs           |drain tile lag time: the amount of time
!!                               |between the transfer of water from the soil
!!                               |to the drain tile and the release of the
!!                               |water from the drain tile to the reach.
!!    hru_km(:)   |km2           |area of HRU in square kilometers
!!    lat_ttime(:)|days          |lateral flow travel time
!!    slsoil(:)   |m             |slope length for lateral subsurface flow
!!    slsubbsn(:) |m             |average slope length for subbasin
!!    tconc(:)     |hr           |time of concentration
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ 


!!    ~ ~ ~ OUTGOING VARIABLES ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ 
!!    lat_ttime(:)|none          |Exponential of the lateral flow travel time
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ 

!!    ~ ~ ~ LOCAL DEFINITIONS ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ 
!!    l           |none          |counter
!!    scmx        |mm/hr         |maximum soil hydraulic conductivity
!!    t_ch        |hr            |time for flow entering the farthest upstream 
!!                               |channel to reach the subbasin outlet
!!    xx          |none          |variable to hold calculation result
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ 

!!    ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~  
!!    SWAT: Ttcoef

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

      !use hru_module, only : itb
      use basin_module
      use time_module
      
      implicit none
      
      real :: ql = 0.           !           | 
      real :: sumq = 0.         !           |
      real :: tb = 0.           !           |
      real :: tp = 0.           !           |
      integer :: i = 0          !none       |counter
      real :: xi = 0.           !           |
      real :: q = 0.            !           |
      integer :: max            !           |
      integer :: itb = 0        !           |
      integer :: istep = 0      !none       |time step that corresponds to time%step for routing
      integer :: iday = 0       !none       |current day in the unit hydrograph
      integer :: t_inc = 0      !none       |time increments within the time step to sum the unit hyd
      integer :: ts_base = 0    !none       |number of time steps in base of hydrograph
      real :: t_inc_hr = 0.     !hr         |time increment
      real :: t_tot = 0.        !hr         |total time in the hydrograph
      
      real, intent (in)  :: tc
      real, intent (out), dimension(bsn_prm%day_lag_mx,time%step) :: uh

      !! compute unit hydrograph for computing hydrograph from direct runoff
      ql = 0.
      sumq = 0.
      uh = 0.
      tb = .5 + .6 * tc + bsn_prm%tb_adj    !baseflow time, hr
      if (tb > 48.) tb = 48.                !maximum 48hrs
      tp = .375 * tb                        ! time to peak flow

      !! sum 20 points on the unit hydrograph to get sum for the time%step
      t_inc = tb / 20.
      t_tot = 0.
      
      !!
      ts_base = int(tb / (time%dtm / 60.))
      ts_base = max (1, ts_base)
      t_inc = 20 / ts_base + 2
      t_inc_hr = time%dtm / float(t_inc) / 60.
       
      do iday = 1, 2
        do istep = 1, time%step
          !! increment within the time step to get accurate estimates near peak
          do i = 1, t_inc
            t_tot = t_tot + t_inc_hr
            
            !! Triangular Unit Hydrograph
            if (bsn_cc%uhyd == 0) then
              if (t_tot < tp) then
                !! rising limb of hydrograph
                q = t_tot / tp
              else
                !! falling limb of hydrograph
                q = (tb - t_tot) / (tb - tp)
              end if
            end if
            
            !! Gamma Function Unit Hydrograph
            if (bsn_cc%uhyd == 1) then
              q = (t_tot / tp) ** bsn_prm%uhalpha * exp((1. - t_tot / tp) * bsn_prm%uhalpha)
            end if
            
            q = Max(0.,q)
            uh(iday,istep) = uh(iday,istep) + (q + ql) / 2.
            sumq = sumq + (q + ql) / 2.
            ql = q
          end do
          if (q < 1.e-4) exit
        end do
      end do
      
      do i = 1, 2
        do istep = 1, time%step
          uh(i,istep) = uh(i, istep) / sumq
        end do
      end do
        
      return
      end subroutine unit_hyd