gwflow_chan_read.f90 Source File


This file depends on

sourcefile~~gwflow_chan_read.f90~~EfferentGraph sourcefile~gwflow_chan_read.f90 gwflow_chan_read.f90 sourcefile~gwflow_module.f90 gwflow_module.f90 sourcefile~gwflow_chan_read.f90->sourcefile~gwflow_module.f90 sourcefile~hydrograph_module.f90 hydrograph_module.f90 sourcefile~gwflow_chan_read.f90->sourcefile~hydrograph_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

      !This subroutine reads in channel-cell connection information and writes the gwflow.con input file
  
      !  Prepared by: Ryan Bailey, Colorado State University
  
      subroutine gwflow_chan_read
      
      use gwflow_module
      use hydrograph_module
      
      implicit none

      character(len=20) :: col_head_con(17) = ""
      integer :: i = 0
      integer :: j = 0
      integer :: k = 0
      integer :: in_chan = 0
      integer :: in_con = 0
      integer :: cell_ID = 0
      integer :: channel = 0
      integer :: chan_zone = 0
      integer :: dum1 = 0
      integer :: dum2 = 0
      integer :: chan_cell = 0
      real :: bed_elev = 0.
      real :: chan_length = 0.
      real :: dum3 = 0.

      !message to record file
      write(out_gw,*) 'reading cell-channel connections in gwflow.chancells...'
      
      !integers for input and output files
      !in_chan = 1280
      !in_con = 1281
      open(1280,file='gwflow.chancells')
      open(1281,file='gwflow.con')
      
      !number of cells that intersect with channels
      num_chancells = sp_ob%gwflow
      
      !allocate global arrays for channel cells
      allocate (gw_chan_id(num_chancells), source = 0)
      allocate (gw_chan_chan(num_chancells), source = 0)
      allocate (gw_chan_len(num_chancells), source = 0.)
      allocate (gw_chan_elev(num_chancells), source = 0.)
      allocate (gw_chan_zone(num_chancells), source = 0)
      gw_chan_len = 0.
      
      !read in channel-cell connection information
      read(1280,*)
      read(1280,*)
      read(1280,*)
      do k=1,num_chancells
        read(1280,*) cell_ID,bed_elev,channel,chan_length,chan_zone
        gw_chan_id(k) = cell_ID
        gw_chan_elev(k) = bed_elev
        gw_chan_chan(k) = channel
        gw_chan_len(k) = chan_length
        gw_chan_zone(k) = chan_zone
      enddo
      
      !write out gwflow.con input file (connection file)
      write(out_gw,*) 'writing gwflow.con file...'
      write(1281,*) 'gwflow.con: channel-cell spatial connections'
      col_head_con = [character(len=17) :: "NUMB","NAME","GISID","AREA","LAT","LONG","ELEV","CELL","WST","CONST","OVER",  &
            "RULE","SRC_TOT ","OBTYPE_OUT1 ","OBTYPNO_OUT1 ","HTYPE_OUT1 ","FRAC_OUT1 "]
      write(1281,103) (col_head_con(j),j=1,17)
      dum1 = 1
      dum2 = 0
      dum3 = 1.00
      do k=1,num_chancells
        write(1281,107) dum1,dum1,dum1,dum2,dum2,dum2,dum2,gw_chan_id(k),dum1,dum2,dum2,dum2,dum1,'sdc',gw_chan_chan(k),'tot',dum3
      enddo     
      close(1281)
      
 103  format(30(a10))   
 107  format(i5,i5,i6,i5,i4,i5,i5,i10,i4,i6,i5,i5,i8,a12,i13,a11,f6.2)
 
      end subroutine gwflow_chan_read