res_read.f90 Source File


This file depends on

sourcefile~~res_read.f90~~EfferentGraph sourcefile~res_read.f90 res_read.f90 sourcefile~basin_module.f90 basin_module.f90 sourcefile~res_read.f90->sourcefile~basin_module.f90 sourcefile~conditional_module.f90 conditional_module.f90 sourcefile~res_read.f90->sourcefile~conditional_module.f90 sourcefile~constituent_mass_module.f90 constituent_mass_module.f90 sourcefile~res_read.f90->sourcefile~constituent_mass_module.f90 sourcefile~hydrograph_module.f90 hydrograph_module.f90 sourcefile~res_read.f90->sourcefile~hydrograph_module.f90 sourcefile~input_file_module.f90 input_file_module.f90 sourcefile~res_read.f90->sourcefile~input_file_module.f90 sourcefile~maximum_data_module.f90 maximum_data_module.f90 sourcefile~res_read.f90->sourcefile~maximum_data_module.f90 sourcefile~pesticide_data_module.f90 pesticide_data_module.f90 sourcefile~res_read.f90->sourcefile~pesticide_data_module.f90 sourcefile~res_cs_module.f90 res_cs_module.f90 sourcefile~res_read.f90->sourcefile~res_cs_module.f90 sourcefile~res_salt_module.f90 res_salt_module.f90 sourcefile~res_read.f90->sourcefile~res_salt_module.f90 sourcefile~reservoir_conditions_module.f90 reservoir_conditions_module.f90 sourcefile~res_read.f90->sourcefile~reservoir_conditions_module.f90 sourcefile~reservoir_data_module.f90 reservoir_data_module.f90 sourcefile~res_read.f90->sourcefile~reservoir_data_module.f90 sourcefile~reservoir_module.f90 reservoir_module.f90 sourcefile~res_read.f90->sourcefile~reservoir_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 res_read
      
      use basin_module
      use input_file_module
      use maximum_data_module
      use reservoir_data_module
      use conditional_module
      use hydrograph_module
      use constituent_mass_module
      use reservoir_module
      use pesticide_data_module
      use res_salt_module
      use res_cs_module
      use reservoir_conditions_module
      
      implicit none

      integer :: i = 0
      
      character (len=80) :: titldum = ""!           |title of file
      character (len=80) :: header = "" !           |header of file
      integer :: eof = 0              !           |end of file
      integer :: imax = 0             !none       |determine max number for array (imax) and total number in file
      logical :: i_exist              !none       |check to determine if file exists
      integer :: ires = 0             !none       |counter 
      integer :: k = 0                !           |
      integer :: ihyd = 0             !none       |counter
      integer :: irel = 0             !none       |counter 
      integer :: ised = 0             !none       |counter
      integer :: inut = 0             !none       |counter
      integer :: isp_ini = 0          !          |
      integer :: ics = 0              !none      |counter
      
      eof = 0
      imax = 0
            
      !read reservoir.res
      imax = 0
      inquire (file=in_res%res, exist=i_exist)
      if (.not. i_exist .or. in_res%res == "null") then
        allocate (res_dat_c(0:0))
        allocate (res_dat(0:0))
      else   
      do
       open (105,file=in_res%res)
       read (105,*,iostat=eof) titldum
       if (eof < 0) exit
       read (105,*,iostat=eof) header
       if (eof < 0) exit
        do while (eof == 0)
          read (105,*,iostat=eof) i
          if (eof < 0) exit
          imax = imax + 1
        end do
        
      db_mx%res_dat = imax
       
      allocate (res_dat_c(0:imax))
      allocate (res_dat(0:imax))
      rewind (105)
      read (105,*,iostat=eof) titldum
      if (eof < 0) exit
      read (105,*,iostat=eof) header
      if (eof < 0) exit
      
       do i = 1, db_mx%res_dat
         read (105,*,iostat=eof) ires
         if (eof < 0) exit
         backspace (105)
         read (105,*,iostat=eof) k, res_dat_c(ires)
         if (eof < 0) exit
       end do
       
       do ires = 1, db_mx%res_dat
        !! initialize organics and minerals in water
        do isp_ini = 1, db_mx%res_init
          if (res_dat_c(ires)%init == res_init_dat_c(isp_ini)%init) then
            res_dat(ires)%init = isp_ini
            if (res_dat(ires)%init == 0) write (9001,*) res_init_dat_c(isp_ini)%init, " not found (res-init)"
            !! initial organic mineral
            do ics = 1, db_mx%om_water_init
              if (res_init_dat_c(isp_ini)%org_min == om_init_name(ics)) then
                res_init(isp_ini)%org_min = ics
                exit
              end if
            if (res_init(isp_ini)%org_min == 0) write (9001,*) om_init_name(ics), " not found"
            end do
            !! initial pesticides
            do ics = 1, db_mx%pestw_ini
              if (res_init_dat_c(isp_ini)%pest == pest_init_name(ics)) then
                res_init(isp_ini)%pest = ics
                exit
              end if
            if (res_init(isp_ini)%pest == 0) write (9001,*) pest_init_name(ics), " not found" 
            end do
            !! initial pathogens
            do ics = 1, db_mx%pathw_ini
              if (res_init_dat_c(isp_ini)%path == path_init_name(ics)) then
                res_init(isp_ini)%path = ics
                exit
              end if
            if (res_init(isp_ini)%path == 0) write (9001,*) path_init_name(ics), " not found"
            end do
            !! initial heavy metals
            !! initial salts
          end if
        end do

         do ihyd = 1, db_mx%res_hyd
           if (res_hyddb(ihyd)%name == res_dat_c(ires)%hyd) then
             res_hyd(ires) = res_hyddb(ihyd)
             res_dat(ires)%hyd = ihyd
             exit
           end if
         end do
                
         if (res_dat_c(ires)%release(1:5) == "ctbl_") then
           do irel = 1, db_mx%ctbl_res
             if (ctbl(irel)%name == res_dat_c(ires)%release) then 
               res_dat(ires)%release = irel
               res_ob(ires)%rel_tbl = "c"
               exit
             end if
           end do 
         else
          do irel = 1, db_mx%dtbl_res
            if (dtbl_res(irel)%name == res_dat_c(ires)%release) then
             res_dat(ires)%release = irel
             res_ob(ires)%rel_tbl = "d"
             exit
            end if
          end do
         end if
          
         do ised = 1, db_mx%res_sed
           if (res_sed(ised)%name == res_dat_c(ires)%sed) then
             res_prm(ires)%sed = res_sed(ised)
             !! d50 - micro meters
             res_prm(ires)%sed_stlr_co = exp(-0.184 * res_prm(ires)%sed%d50)
             res_dat(ires)%sed = ised
             exit
           end if
         end do      

         do inut = 1, db_mx%res_nut
           if (res_nut(inut)%name == res_dat_c(ires)%nut) then
             res_prm(ires)%nut = res_nut(inut)
             res_dat(ires)%nut = inut
             exit
           end if
         end do   
         

       if (res_dat(ires)%hyd == 0) write (9001,*) res_dat_c(ires)%hyd, " not found (res-hyd)"
       if (res_dat(ires)%release == 0) write (9001,*) res_dat_c(ires)%release, " not found (res-release)"         
       if (res_dat(ires)%sed == 0) write (9001,*) res_dat_c(ires)%sed, " not found (res-sed)"
       if (res_dat(ires)%nut == 0) write (9001,*) res_dat_c(ires)%nut, " not found (res-nut)"
       end do

      close (105)
      exit
      enddo
      endif
      
      return
      end subroutine res_read