sq_daycn.f90 Source File


This file depends on

sourcefile~~sq_daycn.f90~~EfferentGraph sourcefile~sq_daycn.f90 sq_daycn.f90 sourcefile~hru_module.f90 hru_module.f90 sourcefile~sq_daycn.f90->sourcefile~hru_module.f90 sourcefile~urban_data_module.f90 urban_data_module.f90 sourcefile~sq_daycn.f90->sourcefile~urban_data_module.f90

Source Code

      subroutine sq_daycn

!!    ~ ~ ~ PURPOSE ~ ~ ~
!!    Predicts daily runoff given daily precipitation and snow melt
!!    using a modified SCS curve number approach

!!    ~ ~ ~ INCOMING VARIABLES ~ ~ ~
!!    name        |units         |definition
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    cnday(:)    |none          |curve number for current day, HRU and at 
!!                               |current soil moisture
!!    fcimp(:)    |fraction      |fraction of HRU area that is classified
!!                               |as directly connected impervious
!!    ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
!!    ~ ~ ~ ~ ~ ~ END SPECIFICATIONS ~ ~ ~ ~ ~ ~

      use urban_data_module
      use hru_module, only : hru, cnday, surfq, ihru, precip_eff
      
      implicit none
       
      real :: bb = 0.   !none          |variable used to store intermediate 
                        !              |calculation result
      real :: cnimp = 0.  !none          |curve number for impervious areas
      integer :: j = 0  !none          |HRU number
      real :: pb = 0.   !none          |variable used to store intermediate
                        !              |calculation result
      real :: r2 = 0.   !none          |retention parameter in CN equation
      real :: surfqimp = 0.!mm H2O        |surface runoff from impervious area
      integer :: ulu = 0  !              |

      j = ihru

      r2 = 25400. / cnday(j) - 254.
      bb = .2 * r2
      pb = precip_eff - bb

      surfq(j) = 0.
      if (pb > 0.) then
        surfq(j) = pb * pb / (precip_eff + .8 * r2)
      end if

      if (hru(j)%luse%urb_lu > 0) then
        surfqimp = 0.
        cnimp = 98.
        r2 = 25400. / cnimp - 254.
        bb = .2 * r2
        pb = precip_eff - bb
        if (pb > 0.) then
          surfqimp = pb * pb / (precip_eff + .8 * r2)
        end if
        ulu = hru(j)%luse%urb_lu
        surfq(j) = surfq(j) * (1. - urbdb(ulu)%fcimp) +                 &                 
                                          surfqimp * urbdb(ulu)%fcimp
      end if    

      return
      end subroutine sq_daycn