diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 002b5bd..fa6f713 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -9,16 +9,139 @@ on: - '*.*.*' workflow_dispatch: + inputs: + rev: + description: 'tag, branch, or SHA to check out' + required: true + default: 'develop' permissions: contents: write packages: write pull-requests: write + + jobs: - build: + +# Get the version from tag + version: + name: Version + runs-on: ubuntu-latest + steps: + - name: Checkout + uses: actions/checkout@v4 + with: + ref: '${{ github.event.inputs.rev }}' + fetch-tags: true + fetch-depth: 0 + - name: Get SWAT+ version + id: get_version + run: | + V=`git describe --tags` + echo $V + echo $V >v.txt + cat v.txt + echo ${{ github.event.release.tag_name }} + echo ${GITHUB_REF#refs/*/} + - name: upload + uses: actions/upload-artifact@v4 + with: + name: release_tag + path: v.txt + +##### Build swat with GNU + build-gnu: runs-on: ${{ matrix.os }} - if: endsWith(github.event.base_ref, 'main') == true + needs: + - version + #if: endsWith(github.event.base_ref, 'main') == true + + strategy: + fail-fast: false + matrix: + os: [ubuntu-latest, windows-latest, macos-latest] + toolchain: + - {compiler: gcc, version: 13} + + steps: + - name: Install Compiler + uses: fortran-lang/setup-fortran@v1 + id: setup-fortran + with: + compiler: ${{ matrix.toolchain.compiler }} + version: ${{ matrix.toolchain.version }} + + - name: Checkout + uses: actions/checkout@v4 + + - name: Build SWAT+ + id: build_exe + run: | + echo ${{ env.FC }} + cmake --version + + RELEASE_VERSION=${GITHUB_REF#refs/*/} + os="$RUNNER_OS" + e="build/swatplus-*" + gen="Unix" + + if [ "$RUNNER_OS" == "Windows" ]; then + e="build/swatplus-*.exe" + gen="MinGW" + fi + + # generate + cmake -B build -G "${gen} Makefiles" \ + -D CMAKE_Fortran_COMPILER=${{ env.FC }} \ + -D TAG=$RELEASE_VERSION \ + -D CMAKE_BUILD_TYPE=Release + + # build + cmake --build build --parallel 4 + + exebase=`basename -s .exe build/swatplus-*` + exez="${exebase}.zip" + exe=`ls $e` + + echo $exe + echo $exez + echo $os + + echo "exe=$exe" >> $GITHUB_OUTPUT + echo "exez=$exez" >> $GITHUB_OUTPUT + echo "os=$os" >> $GITHUB_OUTPUT + + ls -hl build/swatplus-* + file build/swatplus-* + + if [ "$RUNNER_OS" != "Windows" ]; then + (cd build && zip ../$exez swatplus-*) + fi + + shell: bash + + - name: zip + if: matrix.os == 'windows-latest' + uses: vimtor/action-zip@v1.2 + with: + files: ${{ steps.build_exe.outputs.exe }} + dest: ${{ steps.build_exe.outputs.exez }} + + - name: upload + uses: actions/upload-artifact@v4 + with: + name: gnu-${{ steps.build_exe.outputs.os }} + path: ${{ steps.build_exe.outputs.exez }} + + +##### Build with Intel (ifx. ifort) + + build-intel: + runs-on: ${{ matrix.os }} + needs: + - version + # if: endsWith(github.event.base_ref, 'main') == true strategy: fail-fast: false @@ -38,7 +161,8 @@ jobs: steps: - name: Checkout uses: actions/checkout@v4 - # with: + with: + ref: '${{ github.event.inputs.rev }}' # fetch-tags: true # fetch-depth: 0 @@ -49,13 +173,19 @@ jobs: compiler: ${{ matrix.toolchain.compiler }} version: ${{ matrix.toolchain.version }} + - name: Download version + uses: actions/download-artifact@v4 + with: + name: release_tag + - name: Build SWAT+ id: build_exe run: | echo ${{ env.FC }} cmake --version - RELEASE_VERSION=${GITHUB_REF#refs/*/} + # RELEASE_VERSION=${GITHUB_REF#refs/*/} + RELEASE_VERSION=`cat v.txt` os="$RUNNER_OS" if [ "$RUNNER_OS" == "Linux" ]; then @@ -83,7 +213,7 @@ jobs: fi # compile - cmake --build build + cmake --build build --parallel 4 exebase=`basename -s .exe build/swatplus-*` exez="${exebase}.zip" @@ -114,48 +244,71 @@ jobs: dest: ${{ steps.build_exe.outputs.exez }} - name: upload - uses: actions/upload-artifact@v2 + uses: actions/upload-artifact@v4 with: - name: sp-${{ steps.build_exe.outputs.os }} + name: intel-${{ steps.build_exe.outputs.os }} path: ${{ steps.build_exe.outputs.exez }} - +##### Create a new release with all zip files release: name: Release runs-on: ubuntu-latest - needs: - - build + needs: [ build-gnu, build-intel ] steps: - - name: Download Linux - uses: actions/download-artifact@v2 + - name: Download GNU Linux + uses: actions/download-artifact@v4 + with: + name: gnu-Linux + + - name: Download GNU Windows + uses: actions/download-artifact@v4 with: - name: sp-Linux + name: gnu-Windows - - name: Download Windows - uses: actions/download-artifact@v2 + - name: Download GNU macOS + uses: actions/download-artifact@v4 with: - name: sp-Windows + name: gnu-macOS - - name: Download macOS - uses: actions/download-artifact@v2 + - name: Download Intel Linux + uses: actions/download-artifact@v4 with: - name: sp-macOS + name: intel-Linux + + - name: Download Intel Windows + uses: actions/download-artifact@v4 + with: + name: intel-Windows + + - name: Download Intel macOS + uses: actions/download-artifact@v4 + with: + name: intel-macOS + + - name: Download version + uses: actions/download-artifact@v4 + with: + name: release_tag + + - name: Read version + id: read_ver + run: | + RELEASE_VERSION=`cat v.txt` + echo "rv=$RELEASE_VERSION" >> $GITHUB_OUTPUT - name: Release uses: softprops/action-gh-release@v2 + if: startsWith(github.ref, 'refs/tags/') with: token: ${{ github.token }} - tag_name: ${{ github.event.release.tag_name }} - prerelease: false + # tag_name: ${{ github.event.release.tag_name }} + prerelease: true draft: false - name: ${{ github.event.release.tag_name }} + # name: ${{ github.event.release.tag_name }} + name: ${{ steps.read_ver.outputs.rv }} files: swatplus-* generate_release_notes: true - body: | -
- Autogenerated Changelog - ... changelog ... -
+ diff --git a/.gitignore b/.gitignore index 7a2f2fd..4bfcb14 100644 --- a/.gitignore +++ b/.gitignore @@ -59,4 +59,5 @@ CMakeCache.txt Resources/R* src/main.f90 ford.md -/.vs/SWAT_PLUS_DEV \ No newline at end of file +/.vs/SWAT_PLUS_DEV +/.vscode diff --git a/CMakeLists.txt b/CMakeLists.txt index d3468e8..61e4692 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -33,19 +33,19 @@ if (UNIX) set(fdialect "-free -fpe0 -traceback -diag-disable=10448") set(fdebug "-warn all") set(frelease "-O") - set(FFC "ifo") + set(FFC "ifo") link_libraries("-static") elseif(CMAKE_Fortran_COMPILER_ID STREQUAL IntelLLVM) set(fdialect "-free -fpe0 -traceback") set(fdebug "-warn all -O0") set(frelease "-O") - set(FFC "ifx") + set(FFC "ifx") link_libraries("-static") elseif(CMAKE_Fortran_COMPILER_ID MATCHES GNU) - set(fdialect "-fcheck=all -ffpe-trap=invalid,zero,overflow,underflow -fimplicit-none -ffree-line-length-none -fbacktrace -finit-local-zero -fno-unsafe-math-optimizations -frounding-math -fsignaling-nans") - set(fdebug "-Wall") - set(frelease "-O") - set(FFC "gcc") + set(fdialect "-fcheck=all -ffpe-trap=invalid,zero,overflow,underflow -fimplicit-none -ffree-line-length-none -fbacktrace -finit-local-zero -fno-unsafe-math-optimizations -frounding-math -fsignaling-nans") + set(fdebug "-Wall") + set(frelease "-O") + set(FFC "gnu") if(NOT APPLE) link_libraries("-static") endif() @@ -66,18 +66,18 @@ elseif(WIN32) elseif(CMAKE_Fortran_COMPILER_ID MATCHES GNU) set(fdialect "-fcheck=all -ffpe-trap=invalid,zero,overflow,underflow -fimplicit-none -ffree-line-length-none -fbacktrace -finit-local-zero -fno-unsafe-math-optimizations -frounding-math -fsignaling-nans") set(fdebug "-Wall ") - set(FFC "gcc") + set(FFC "gnu") set(frelease "-O") endif() endif() string(TOLOWER ${CMAKE_HOST_SYSTEM_PROCESSOR} ARCH) if(CMAKE_SYSTEM_NAME STREQUAL "Linux") - set(AR "${FFC}-lin_${ARCH}") + set(AR "lin_${ARCH}") elseif(CMAKE_SYSTEM_NAME STREQUAL "Windows") - set(AR "${FFC}-win_${ARCH}") + set(AR "win_${ARCH}") elseif(CMAKE_SYSTEM_NAME STREQUAL "Darwin") - set(AR "${FFC}-mac_${ARCH}") + set(AR "mac_${ARCH}") else() set(AR "unknown") endif() @@ -92,9 +92,9 @@ endif() # SWAT Version number set(SWAT_VERSION ${TAG}) -set(SWATPLUS_EXE "swatplus-${SWAT_VERSION}-${AR}${TY}") +set(SWATPLUS_EXE "swatplus-${SWAT_VERSION}-${FFC}-${AR}${TY}") -# Enable this to 'TRUE' to see the fortran command on compile +# Set this to 'TRUE' to see the fortran command on compile set(CMAKE_VERBOSE_MAKEFILE FALSE) set(CMAKE_Fortran_FLAGS "${CMAKE_Fortran_FLAGS} ${fdialect}") @@ -111,7 +111,6 @@ set(CMAKE_Fortran_FLAGS_RELEASE "${frelease}") if(EXISTS "${PROJECT_SOURCE_DIR}/src/main.f90.in") string(TIMESTAMP ISO "%Y-%m-%d %H:%M:%S") - # string(TIMESTAMP TODAY "%b %d %Y") # e.g. produces Dec 7 2023 string(TIMESTAMP TODAY "%Y-%m-%d") # e.g. produces 2023-12-07 string(TIMESTAMP YEAR "%Y") diff --git a/src/actions.f90 b/src/actions.f90 index b13ae15..cd48f9b 100644 --- a/src/actions.f90 +++ b/src/actions.f90 @@ -71,6 +71,8 @@ subroutine actions (ob_cur, ob_num, idtbl) integer :: imallo = 0 integer :: idmd = 0 integer :: irec = 0 + integer :: iplt = 0 + integer :: num_plts_cur = 0 real :: hiad1 = 0. ! | real :: biomass = 0. ! | real :: frt_kg = 0. @@ -88,7 +90,7 @@ subroutine actions (ob_cur, ob_num, idtbl) real :: cn_prev = 0. real :: stor_m3 = 0. character(len=1) :: action = "" ! | - character(len=25) :: lu_prev = "" ! | + character(len=40) :: lu_prev = "" ! | do iac = 1, d_tbl%acts action = "n" @@ -398,12 +400,13 @@ subroutine actions (ob_cur, ob_num, idtbl) harveff = d_tbl%act(iac)%const call mgt_harvresidue (j, harveff) case ("tree") + call mgt_harvbiomass (j, ipl, iharvop) case ("tuber") call mgt_harvtuber (j, ipl, iharvop) case ("peanuts") call mgt_harvtuber (j, ipl, iharvop) case ("stripper") - call mgt_harvgrain (j, ipl, iharvop) + call mgt_harvbiomass (j, ipl, iharvop) case ("picker") call mgt_harvgrain (j, ipl, iharvop) end select @@ -886,7 +889,10 @@ subroutine actions (ob_cur, ob_num, idtbl) case ("lu_change") j = d_tbl%act(iac)%ob_num if (j == 0) j = ob_cur + if (d_tbl%lu_chg_mx(iac) <= Int(d_tbl%act(iac)%const2)) then + d_tbl%lu_chg_mx(iac) = d_tbl%lu_chg_mx(iac) + 1 ilu = d_tbl%act_typ(iac) + hru(j)%land_use_mgt = ilu hru(j)%dbs%land_use_mgt = ilu lu_prev = hru(j)%land_use_mgt_c hru(j)%land_use_mgt_c = d_tbl%act(iac)%file_pointer @@ -902,6 +908,27 @@ subroutine actions (ob_cur, ob_num, idtbl) write (3612,*) j, time%yrc, time%mo, time%day_mo, " LU_CHANGE ", & lu_prev, hru(j)%land_use_mgt_c, " 0 0" + !! add new plants in simulation for yield output + do ipl = 1, pcom(j)%npl + if (basin_plants == 0) then + plts_bsn(1) = pcom(j)%pl(ipl) + basin_plants = 1 + else + num_plts_cur = basin_plants + do iplt = 1, num_plts_cur + if (pcom(j)%pl(ipl) == plts_bsn(iplt)) exit + if (iplt == basin_plants) then + plts_bsn(iplt+1) = pcom(j)%pl(ipl) + bsn_crop_yld(iplt+1) = bsn_crop_yld_z + bsn_crop_yld_aa(iplt+1) = bsn_crop_yld_z + basin_plants = basin_plants + 1 + pcom(j)%plcur(ipl)%bsn_num = basin_plants + end if + end do + end if + end do + !pcom(j)%dtbl(idtbl)%num_actions(iac) = pcom(j)%dtbl(idtbl)%num_actions(iac) + 1 + end if !land use change - contouring case ("p_factor") j = d_tbl%act(iac)%ob_num @@ -1033,7 +1060,8 @@ subroutine actions (ob_cur, ob_num, idtbl) do istr = 1, db_mx%grassop_db if (d_tbl%act(iac)%file_pointer == grwaterway_db(istr)%name) then - istr1 = istr + !istr1 = istr + hru(j)%lumv%grwat_i = 1 exit end if end do @@ -1045,6 +1073,13 @@ subroutine actions (ob_cur, ob_num, idtbl) write (3612,*) j, time%yrc, time%mo, time%day_mo, " GRASSWW_INSTALL ", & sdr(istr)%name, sdr(istr1)%name, " 0 0" + !install grass waterways + case ("grassww_uninstall") + j = d_tbl%act(iac)%ob_num + if (j == 0) j = ob_cur + hru(j)%lumv%grwat_i = 0 + write (3612,*) j, time%yrc, time%mo, time%day_mo, " GRASSWW_UNINSTALL ", & + sdr(istr)%name, sdr(istr1)%name, " 0 0" !user defined bmp reductions case ("user_def_bmp") j = d_tbl%act(iac)%ob_num diff --git a/src/allocate_parms.f90 b/src/allocate_parms.f90 index c4f2f39..471ae33 100644 --- a/src/allocate_parms.f90 +++ b/src/allocate_parms.f90 @@ -213,7 +213,7 @@ subroutine allocate_parms !! By Zhang for C/N cycling !! ============================ - + call zero0 call zero1 call zero2 diff --git a/src/aqu_cs_output.f90 b/src/aqu_cs_output.f90 index 3c72527..12035db 100644 --- a/src/aqu_cs_output.f90 +++ b/src/aqu_cs_output.f90 @@ -49,7 +49,7 @@ subroutine aqu_cs_output(iaq) !rtb cs (acsb_d(iaq)%cs(ics)%srbd,ics=1,cs_db%num_cs) if (pco%csvout == "y") then write (6061,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iaq, ob(iob)%gis_id, & - (acsb_d(iaq)%cs(ics)%csgw,ics=1,cs_db%num_cs), & + (acsb_d(iaq)%cs(ics)%csgw,ics=1,cs_db%num_cs), & (acsb_d(iaq)%cs(ics)%rchrg,ics=1,cs_db%num_cs), & (acsb_d(iaq)%cs(ics)%seep,ics=1,cs_db%num_cs), & (acsb_d(iaq)%cs(ics)%irr,ics=1,cs_db%num_cs), & diff --git a/src/aqu_salt_output.f90 b/src/aqu_salt_output.f90 index fdef427..70ca55d 100644 --- a/src/aqu_salt_output.f90 +++ b/src/aqu_salt_output.f90 @@ -44,7 +44,7 @@ subroutine aqu_salt_output(iaq) asaltb_d(iaq)%salt(1)%diss if (pco%csvout == "y") then write (5061,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iaq, ob(iob)%gis_id, & - (asaltb_d(iaq)%salt(isalt)%saltgw,isalt=1,cs_db%num_salts), & + (asaltb_d(iaq)%salt(isalt)%saltgw,isalt=1,cs_db%num_salts), & (asaltb_d(iaq)%salt(isalt)%rchrg,isalt=1,cs_db%num_salts), & (asaltb_d(iaq)%salt(isalt)%seep,isalt=1,cs_db%num_salts), & (asaltb_d(iaq)%salt(isalt)%irr,isalt=1,cs_db%num_salts), & diff --git a/src/basin_module.f90 b/src/basin_module.f90 index f7fa599..47a0498 100644 --- a/src/basin_module.f90 +++ b/src/basin_module.f90 @@ -21,32 +21,24 @@ module basin_module !! 0 = Priestley-Taylor !! 1 = Penman-Monteith !! 2 = Hargreaves method - !! 3 = read in daily pot ET values - integer :: event = 0 !! event code + integer :: event = 0 !! not used integer :: crk = 0 !! crack flow code !! 1 = compute flow in cracks integer :: swift_out = 0 !! write to SWIFT input file !! 0 = do not write !! 1 = write to swift_hru.inp - integer :: sed_det = 0 !! max half-hour rainfall frac calc - !! 0 = gen from triangular dist - !! 1 = use monthly mean frac + integer :: sed_det = 0 !! not used integer :: rte = 0 !! water routing method !! 0 variable storage method !! 1 Muskingum method - integer :: deg = 0 !! channel degradation code - !! 0 = do not compute - !! 1 = compute (downcutting and widening) - integer :: wq = 0 !! stream water quality code - !! 0 do not model - !! 1 model (QUAL2E) + integer :: deg = 0 !! not used + integer :: wq = 0 !! not used integer :: nostress = 0 !! redefined to the sequence number -- changed to no nutrient stress !! 0 = all stresses applied !! 1 = turn off all plant stress !! 2 = turn off nutrient plant stress only integer :: cn = 0 !! not used - integer :: cfac = 0 !! 0 = C-factor calc using CMIN - !! 1 = for new C-factor from RUSLE (no min needed) + integer :: cfac = 0 !! not used integer :: cswat = 0 !! carbon code !! = 0 Static soil carbon (old mineralization routines) !! = 1 C-FARM one carbon pool model @@ -57,29 +49,20 @@ module basin_module integer :: uhyd = 1 !! Unit hydrograph method: !! 0 = triangular UH !! 1 = gamma function UH - integer :: sed_ch = 0 !! Instream sediment model - !! 0 = Bagnold model - !! 1 = Brownlie model - !! 2 = Yang model + integer :: sed_ch = 0 !! not used integer :: tdrn = 0 !! tile drainage eq code - !! 1 = sim tile flow using subsurface drains (wt_shall) - !! 0 = sim tile flow using subsurface origtile (wt_shall,d) - integer :: wtdn = 0 !! water table depth algorithms code - !! 1 = sim wt_shall using subsurface new water table depth routine - !! 0 = sim wt_shall using subsurface orig water table depth routine - integer :: sol_p_model=0 !! 1 = new soil P model + !! 0 = tile flow using drawdown days equation + !! 1 = tile flow using drainmod equations + integer :: wtdn = 0 !! shallow water table depth algorithms code + !! 0 = depth using orig water table depth routine - fill to upper limit + !! 1 = depth using drainmod water table depth routine + integer :: sol_p_model=0 !! 0 = original soil P model in SWAT documentation + !! 1 = new soil P model in Vadas and White (2010) integer :: gampt = 0 !! 0 = curve number; 1 = Green and Ampt - character(len=1) :: atmo = "a" !! atmospheric deposition interval - !! "m" = monthly - !! "y" = yearly - !! "a" = annual - integer :: smax = 0 !! max depressional storage selection code - !! 1 = dynamic stmaxd computed as a cunfction of random - !! roughness and rain intensity - !! 0 = static stmaxd read from .bsn for the global value or .sdr - !! for specific hrus - integer :: qual2e = 0 !! 0 = channel routine using QUAL2E - !! 1 = channel routing with simplified nutrient transformations + character(len=1) :: atmo = "a" !! not used + integer :: smax = 0 !! not used + integer :: qual2e = 0 !! 0 = instream nutrient routing using QUAL2E + !! 1 = instream nutrient routing using QUAL2E - with simplified nutrient transformations integer :: gwflow = 0 !! 0 = gwflow module not active; 1 = gwflow module active end type basin_control_codes type (basin_control_codes) :: bsn_cc @@ -396,11 +379,11 @@ module basin_module ! type(snutc_old_header) :: snutc_old_hdr type basin_yld_header - character (len=10) :: year = " year " + character (len=11) :: year = " year " character (len=16) :: plant_no = " plant_no" character (len=16) :: plant_name = "plant_name " - character (len=16) :: area_ha = " harv_area(ha) " - character (len=16) :: yield_t = " yld(t) " + character (len=17) :: area_ha = " harv_area(ha) " + character (len=17) :: yield_t = " yld(t) " character (len=16) :: yield_tha = " yld(t/ha) " end type basin_yld_header type (basin_yld_header) :: bsn_yld_hdr diff --git a/src/cal_conditions.f90 b/src/cal_conditions.f90 index 0f503f8..0e1a9e4 100644 --- a/src/cal_conditions.f90 +++ b/src/cal_conditions.f90 @@ -12,7 +12,7 @@ subroutine cal_conditions implicit none - character(len=16) :: chg_parm = "" ! | + character(len=25) :: chg_parm = "" ! | character(len=16) :: chg_typ = "" !variable |type of change (absval, abschg, pctchg) character(len=1) :: cond_met = "" ! | character(len=1) :: pl_find = "" ! | @@ -79,13 +79,8 @@ subroutine cal_conditions cond_met = "n" exit end if - case ("region") !for hru - if (cal_upd(ichg_par)%cond(ic)%targc /= hru(ielem)%region) then - cond_met = "n" - exit - end if - case ("region_lte") !for hru - if (cal_upd(ichg_par)%cond(ic)%targc /= hru(ielem)%region) then + case ("cal_group") !for hru + if (cal_upd(ichg_par)%cond(ic)%targc /= hru(ielem)%cal_group) then cond_met = "n" exit end if diff --git a/src/cal_parm_select.f90 b/src/cal_parm_select.f90 index 75ac6c3..43ac894 100644 --- a/src/cal_parm_select.f90 +++ b/src/cal_parm_select.f90 @@ -34,7 +34,7 @@ subroutine cal_parm_select (ielem, ly, chg_parm, chg_typ, chg_val, absmin, absma use hydrograph_module use pesticide_data_module use plant_module - use gwflow_module + use gwflow_module implicit none @@ -438,6 +438,9 @@ subroutine cal_parm_select (ielem, ly, chg_parm, chg_typ, chg_val, absmin, absma chg_typ, chg_val, absmin, absmax) !! SWQ + case ("mumax") + ch_nut(ielem)%mumax = chg_par(ch_nut(ielem)%mumax, & + chg_typ, chg_val, absmin, absmax) case ("rs1") ch_nut(ielem)%rs1 = chg_par(ch_nut(ielem)%rs1, & chg_typ, chg_val, absmin, absmax) @@ -611,20 +614,16 @@ subroutine cal_parm_select (ielem, ly, chg_parm, chg_typ, chg_val, absmin, absma sd_ch(ielem)%chk = chg_par(sd_ch(ielem)%chk, & chg_typ, chg_val, absmin, absmax) - case ("cherod") - sd_ch(ielem)%cherod = chg_par(sd_ch(ielem)%cherod, & + case ("bank_exp") + sd_ch(ielem)%bank_exp = chg_par(sd_ch(ielem)%bank_exp, & chg_typ, chg_val, absmin, absmax) case ("cov") sd_ch(ielem)%cov = chg_par(sd_ch(ielem)%cov, & chg_typ, chg_val, absmin, absmax) - ! case ("wd_rto") - ! sd_ch(ielem)%wd_rto = chg_par(sd_ch(ielem)%wd_rto, & - ! chg_typ, chg_val, absmin, absmax) - - case ("flood_sedfrac") - sd_ch(ielem)%chseq = chg_par(sd_ch(ielem)%chseq, & + case ("vcr_coef") + sd_ch(ielem)%vcr_coef = chg_par(sd_ch(ielem)%vcr_coef, & chg_typ, chg_val, absmin, absmax) case ("d50") @@ -712,8 +711,8 @@ subroutine cal_parm_select (ielem, ly, chg_parm, chg_typ, chg_val, absmin, absma sd_ch(ielem)%arc_len_fr = chg_par(sd_ch(ielem)%arc_len_fr, & chg_typ, chg_val, absmin, absmax) - case ("part_size") - sd_ch(ielem)%part_size = chg_par(sd_ch(ielem)%part_size, & + case ("bed_exp") + sd_ch(ielem)%bed_exp = chg_par(sd_ch(ielem)%bed_exp, & chg_typ, chg_val, absmin, absmax) case ("wash_bed_fr") @@ -740,6 +739,11 @@ subroutine cal_parm_select (ielem, ly, chg_parm, chg_typ, chg_val, absmin, absma case ("nsed") res_prm(ielem)%sed%nsed = chg_par(res_prm(ielem)%sed%nsed, & chg_typ, chg_val, absmin, absmax) + case ("res_d50") + res_prm(ielem)%sed%d50 = chg_par(res_prm(ielem)%sed%d50, & + chg_typ, chg_val, absmin, absmax) + !! d50 -micro meters + res_prm(ielem)%sed_stlr_co = exp(-0.184 * res_prm(ielem)%sed%d50) case ("sed_stlr") res_prm(ielem)%sed%sed_stlr = chg_par(res_prm(ielem)%sed%sed_stlr, & @@ -952,45 +956,45 @@ subroutine cal_parm_select (ielem, ly, chg_parm, chg_typ, chg_val, absmin, absma hlt_db(ielem)%uslels = chg_par (hlt_db(ielem)%uslels, chg_typ, chg_val, absmin, absmax) - !!gwflow (rtb) + !!gwflow (rtb) case ("aquifer_K") - if(bsn_cc%gwflow.eq.1) then - gw_state(ielem)%hydc = chg_par(gw_state(ielem)%hydc, chg_typ, chg_val, absmin, absmax) - endif - - case ("aquifer_Sy") - if(bsn_cc%gwflow.eq.1) then - gw_state(ielem)%spyd = chg_par(gw_state(ielem)%spyd, chg_typ, chg_val, absmin, absmax) - endif - - case ("aquifer_delay") - if(bsn_cc%gwflow.eq.1) then - gw_delay(ielem) = chg_par(gw_delay(ielem), chg_typ, chg_val, absmin, absmax) + if(bsn_cc%gwflow.eq.1) then + gw_state(ielem)%hydc = chg_par(gw_state(ielem)%hydc, chg_typ, chg_val, absmin, absmax) + endif + + case ("aquifer_Sy") + if(bsn_cc%gwflow.eq.1) then + gw_state(ielem)%spyd = chg_par(gw_state(ielem)%spyd, chg_typ, chg_val, absmin, absmax) + endif + + case ("aquifer_delay") + if(bsn_cc%gwflow.eq.1) then + gw_delay(ielem) = chg_par(gw_delay(ielem), chg_typ, chg_val, absmin, absmax) endif - - case ("aquifer_exdp") - if(bsn_cc%gwflow.eq.1) then - gw_state(ielem)%exdp = chg_par(gw_state(ielem)%exdp, chg_typ, chg_val, absmin, absmax) - endif - - case ("stream_K") - if(bsn_cc%gwflow.eq.1) then - do icell=1,gw_chan_info(ielem)%ncon !loop through cells connected to channel - gw_chan_info(ielem)%hydc(icell) = chg_par(gw_chan_info(ielem)%hydc(icell), chg_typ, chg_val, absmin, absmax) - enddo - endif - - case ("stream_thk") - if(bsn_cc%gwflow.eq.1) then - do icell=1,gw_chan_info(ielem)%ncon !loop through cells connected to channel - gw_chan_info(ielem)%thck(icell) = chg_par(gw_chan_info(ielem)%thck(icell), chg_typ, chg_val, absmin, absmax) - enddo - endif - - case ("stream_bed") - if(bsn_cc%gwflow.eq.1) then - gw_bed_change = chg_par(gw_bed_change, chg_typ, chg_val, absmin, absmax) - endif + + case ("aquifer_exdp") + if(bsn_cc%gwflow.eq.1) then + gw_state(ielem)%exdp = chg_par(gw_state(ielem)%exdp, chg_typ, chg_val, absmin, absmax) + endif + + case ("stream_K") + if(bsn_cc%gwflow.eq.1) then + do icell=1,gw_chan_info(ielem)%ncon !loop through cells connected to channel + gw_chan_info(ielem)%hydc(icell) = chg_par(gw_chan_info(ielem)%hydc(icell), chg_typ, chg_val, absmin, absmax) + enddo + endif + + case ("stream_thk") + if(bsn_cc%gwflow.eq.1) then + do icell=1,gw_chan_info(ielem)%ncon !loop through cells connected to channel + gw_chan_info(ielem)%thck(icell) = chg_par(gw_chan_info(ielem)%thck(icell), chg_typ, chg_val, absmin, absmax) + enddo + endif + + case ("stream_bed") + if(bsn_cc%gwflow.eq.1) then + gw_bed_change = chg_par(gw_bed_change, chg_typ, chg_val, absmin, absmax) + endif !! initial soil properties case ("lab_p") diff --git a/src/cal_parmchg_read.f90 b/src/cal_parmchg_read.f90 index 8e46356..aa96f53 100644 --- a/src/cal_parmchg_read.f90 +++ b/src/cal_parmchg_read.f90 @@ -128,9 +128,9 @@ subroutine cal_parmchg_read cal_upd(i)%num_elem = db_mx%pcpfiles case ("tmp") cal_upd(i)%num_elem = db_mx%tmpfiles - case ("gwf") !rtb - all gwflow cells - cal_upd(i)%num_elem = ncell - case ("gwf_riv") !rtb - all channels + case ("gwf") !rtb - all gwflow cells + cal_upd(i)%num_elem = ncell + case ("gwf_riv") !rtb - all channels cal_upd(i)%num_elem = sp_ob%chandeg case ("gwf_sgl") !rtb - single value cal_upd(i)%num_elem = 1 diff --git a/src/calsoft_chsed.f90 b/src/calsoft_chsed.f90 deleted file mode 100644 index 7524c2c..0000000 --- a/src/calsoft_chsed.f90 +++ /dev/null @@ -1,520 +0,0 @@ - subroutine calsoft_chsed - - use hydrograph_module - use ru_module - use aquifer_module - use channel_module - use hru_lte_module - use sd_channel_module - use basin_module - use maximum_data_module - use calibration_data_module - use conditional_module - use reservoir_module - use organic_mineral_mass_module - - implicit none - - integer :: ical_sed = 0 ! | - integer :: iter_all = 0 ! |end of loop - integer :: iterall = 0 !none |counter - integer :: isim = 0 ! | - integer :: ireg = 0 !none |counter - integer :: iord = 0 !none |counter - real :: soft = 0. ! | - real :: diff = 0. ! | - real :: chg_val = 0. ! | - integer :: ich_s = 0 !none |counter - integer :: iich = 0 ! | - integer :: icov = 0 !none |counter - real :: rmeas = 0. ! | - real :: denom = 0. ! | - integer :: iter_ind = 0 ! |end of loop - integer :: ierod = 0 !none |counter - - - !calibrate sediment - ical_sed = 0 - - !calibrate hydrology - ical_sed = 0 - iter_all = 1 - iter_ind = 1 - - do iterall = 1, iter_all - ! 1st cover adjustment for channel widening - isim = 0 - do ireg = 1, db_mx%ch_reg - do iord = 1, chcal(ireg)%ord_num - soft = chcal(ireg)%ord(iord)%meas%chw - diff = 0. - if (soft > 1.e-6) diff = abs((soft - chcal(ireg)%ord(iord)%aa%chw) / soft) - if (diff > .02 .and. chcal(ireg)%ord(iord)%length > 1.e-6 .and. chcal(ireg)%ord(iord)%prm_lim%erod < 1.e-6) then - isim = 1 - - chcal(ireg)%ord(iord)%prm_prev = chcal(ireg)%ord(iord)%prm - chcal(ireg)%ord(iord)%prev = chcal(ireg)%ord(iord)%aa - - if (soft < chcal(ireg)%ord(iord)%aa%chw) then - chg_val = 1. / (abs((soft - chcal(ireg)%ord(iord)%aa%chw) / soft) + 1.05) - else - chg_val = abs((chcal(ireg)%ord(iord)%aa%chw - soft) / chcal(ireg)%ord(iord)%aa%chw) + 1.05 - end if - chcal(ireg)%ord(iord)%prm_prev%erod = chcal(ireg)%ord(iord)%prm%erod - chcal(ireg)%ord(iord)%prm%erod = chg_val - chcal(ireg)%ord(iord)%prev%chw = chcal(ireg)%ord(iord)%aa%chw - - if (chcal(ireg)%ord(iord)%prm%erod >= ch_prms(1)%pos) then - chg_val = ch_prms(1)%pos - chcal(ireg)%ord(iord)%prm%erod = ch_prms(1)%pos - chcal(ireg)%ord(iord)%prm_lim%erod = 1. - end if - if (chcal(ireg)%ord(iord)%prm%erod <= ch_prms(1)%neg) then - chg_val = ch_prms(1)%neg - chcal(ireg)%ord(iord)%prm%erod = ch_prms(1)%neg - chcal(ireg)%ord(iord)%prm_lim%erod = 1. - end if - - !check all channels for proper order - do ich_s = 1, chcal(ireg)%num_tot - iich = chcal(ireg)%num(ich_s) - if (chcal(ireg)%ord(iord)%meas%name == sd_ch(iich)%order .or. chcal(ireg)%ord(iord)%meas%name == "basin") then - !set parms for 1st width calibration and rerun - sd_ch(iich)%cherod = sd_ch(iich)%cherod * chg_val - sd_ch(iich)%cherod = amin1 (sd_ch(iich)%cherod, ch_prms(1)%up) - sd_ch(iich)%cherod = Max (sd_ch(iich)%cherod, ch_prms(1)%lo) - sdch_init(iich)%cherod = sd_ch(iich)%cherod - end if - end do - chcal(ireg)%ord(iord)%nbyr = 0 - chcal(ireg)%ord(iord)%aa = chcal_z - end if - end do - end do - - !! re-initialize all objects - call re_initialize - - ! 1st cover adjustment - if (isim > 0) then - cal_sim = " first chan erod adj " - cal_adj = chg_val - call time_control - end if - - ! cover adjustment for channel widening - do icov = 1, iter_ind - isim = 0 - do ireg = 1, db_mx%ch_reg - do iord = 1, chcal(ireg)%ord_num - soft = chcal(ireg)%ord(iord)%meas%chw - diff = 0. - if (soft > 1.e-6) diff = abs((soft - chcal(ireg)%ord(iord)%aa%chw) / soft) - if (diff > .02 .and. chcal(ireg)%ord(iord)%length > 1.e-6 .and. chcal(ireg)%ord(iord)%prm_lim%erod < 1.e-6) then - isim = 1 - - chcal(ireg)%ord(iord)%prm_prev = chcal(ireg)%ord(iord)%prm - chcal(ireg)%ord(iord)%prev = chcal(ireg)%ord(iord)%aa - - if (soft < chcal(ireg)%ord(iord)%aa%chw) then - chg_val = 1. / (abs((soft - chcal(ireg)%ord(iord)%aa%chw) / soft) + 1.05) - else - chg_val = abs((chcal(ireg)%ord(iord)%aa%chw - soft) / chcal(ireg)%ord(iord)%aa%chw) + 1.05 - end if - chcal(ireg)%ord(iord)%prm_prev%erod = chcal(ireg)%ord(iord)%prm%erod - chcal(ireg)%ord(iord)%prm%erod = chcal(ireg)%ord(iord)%prm%erod * chg_val - chcal(ireg)%ord(iord)%prev%chw = chcal(ireg)%ord(iord)%aa%chw - - if (chcal(ireg)%ord(iord)%prm%erod >= ch_prms(1)%pos) then - chg_val = ch_prms(1)%pos - chcal(ireg)%ord(iord)%prm%erod = ch_prms(1)%pos - chcal(ireg)%ord(iord)%prm_lim%erod = 1. - end if - if (chcal(ireg)%ord(iord)%prm%erod <= ch_prms(1)%neg) then - chg_val = ch_prms(1)%neg - chcal(ireg)%ord(iord)%prm%erod = ch_prms(1)%neg - chcal(ireg)%ord(iord)%prm_lim%erod = 1. - end if - - !check all channels for proper order - do ich_s = 1, chcal(ireg)%num_tot - iich = chcal(ireg)%num(ich_s) - if (chcal(ireg)%ord(iord)%meas%name == sd_ch(iich)%order .or. chcal(ireg)%ord(iord)%meas%name == "basin") then - !set parms for width calibration and rerun - sd_ch(iich)%cherod = sd_ch(iich)%cherod * chg_val - sd_ch(iich)%cherod = amin1 (sd_ch(iich)%cherod, ch_prms(1)%up) - sd_ch(iich)%cherod = Max (sd_ch(iich)%cherod, ch_prms(1)%lo) - sdch_init(iich)%cherod = sd_ch(iich)%cherod - end if - end do - chcal(ireg)%ord(iord)%nbyr = 0 - chcal(ireg)%ord(iord)%aa = chcal_z - end if - end do - end do - - !! re-initialize all objects - call re_initialize - - ! cover adjustment - if (isim > 0) then - cal_sim = " chan erodibility adj " - cal_adj = chg_val - call time_control - end if - end do ! icov - - !! finish - but leave code in case i need to add back - go to 777 - - - ! 1st bank shear coefficient adjustment for channel widening - isim = 0 - do ireg = 1, db_mx%ch_reg - do iord = 1, chcal(ireg)%ord_num - soft = chcal(ireg)%ord(iord)%meas%chw - diff = 0. - if (soft > 1.e-6) diff = abs((soft - chcal(ireg)%ord(iord)%aa%chw) / soft) - if (diff > .02 .and. chcal(ireg)%ord(iord)%length > 1.e-6 .and. chcal(ireg)%ord(iord)%prm_lim%shear_bnk < 1.e-6) then - isim = 1 - - chcal(ireg)%ord(iord)%prm_prev = chcal(ireg)%ord(iord)%prm - chcal(ireg)%ord(iord)%prev = chcal(ireg)%ord(iord)%aa - - chg_val = chcal(ireg)%ord(iord)%meas%chw / (chcal(ireg)%ord(iord)%aa%chw + 1.e-6) !assume same ratio of cover and width change - chcal(ireg)%ord(iord)%prm_prev%shear_bnk = chcal(ireg)%ord(iord)%prm%shear_bnk - chcal(ireg)%ord(iord)%prm%shear_bnk = chcal(ireg)%ord(iord)%prm%shear_bnk + chg_val - chcal(ireg)%ord(iord)%prev%chw = chcal(ireg)%ord(iord)%aa%chw - - if (chcal(ireg)%ord(iord)%prm%shear_bnk >= ch_prms(3)%pos) then - chg_val = ch_prms(3)%pos - chcal(ireg)%ord(iord)%prm_prev%shear_bnk - chcal(ireg)%ord(iord)%prm%shear_bnk = ch_prms(3)%pos - chcal(ireg)%ord(iord)%prm_lim%shear_bnk = 1. - end if - if (chcal(ireg)%ord(iord)%prm%shear_bnk <= ch_prms(3)%neg) then - chg_val = ch_prms(3)%neg - chcal(ireg)%ord(iord)%prm_prev%shear_bnk - chcal(ireg)%ord(iord)%prm%shear_bnk = ch_prms(3)%neg - chcal(ireg)%ord(iord)%prm_lim%shear_bnk = 1. - end if - - !check all channels for proper order - do ich_s = 1, chcal(ireg)%num_tot - iich = chcal(ireg)%num(ich_s) - if (chcal(ireg)%ord(iord)%meas%name == sd_ch(iich)%order .or. chcal(ireg)%ord(iord)%meas%name == "basin") then - !set parms for 1st width calibration and rerun - sdch_init(iich)%shear_bnk = sdch_init(iich)%shear_bnk + chg_val - sdch_init(iich)%shear_bnk = amin1 (sdch_init(iich)%shear_bnk, ch_prms(3)%up) - sdch_init(iich)%shear_bnk = Max (sdch_init(iich)%shear_bnk, ch_prms(3)%lo) - end if - end do - chcal(ireg)%ord(iord)%nbyr = 0 - chcal(ireg)%ord(iord)%aa = chcal_z - end if - end do - end do - - !! re-initialize all objects - call re_initialize - - ! 1st bank shear coefficient adjustment - if (isim > 0) then - write (4601,*) " first bank shear coeff adj " - call time_control - end if - - ! bank shear coefficient adjustment for channel widening - do icov = 1, iter_ind - isim = 0 - do ireg = 1, db_mx%cha_reg - do iord = 1, chcal(ireg)%ord_num - soft = chcal(ireg)%ord(iord)%meas%chw - diff = 0. - if (soft > 1.e-6) diff = abs((soft - chcal(ireg)%ord(iord)%aa%chw) / soft) - if (diff > .02 .and. chcal(ireg)%ord(iord)%length > 1.e-6 .and. chcal(ireg)%ord(iord)%prm_lim%shear_bnk < 1.e-6) then - isim = 1 - - rmeas = chcal(ireg)%ord(iord)%meas%chw - denom = chcal(ireg)%ord(iord)%prev%chw - chcal(ireg)%ord(iord)%aa%chw - if (abs(denom) > 1.e-6) then - chg_val = - (chcal(ireg)%ord(iord)%prm_prev%shear_bnk - chcal(ireg)%ord(iord)%prm%shear_bnk) & - * (chcal(ireg)%ord(iord)%aa%chw - rmeas) / denom - else - chg_val = chcal(ireg)%ord(iord)%meas%chw / chcal(ireg)%ord(iord)%aa%chw - end if - chcal(ireg)%ord(iord)%prm_prev%shear_bnk = chcal(ireg)%ord(iord)%prm%shear_bnk - chcal(ireg)%ord(iord)%prm%shear_bnk = chcal(ireg)%ord(iord)%prm%shear_bnk + chg_val - chcal(ireg)%ord(iord)%prev%chw = chcal(ireg)%ord(iord)%aa%chw - - if (chcal(ireg)%ord(iord)%prm%shear_bnk >= ch_prms(3)%pos) then - chg_val = ch_prms(3)%pos - chcal(ireg)%ord(iord)%prm_prev%shear_bnk - chcal(ireg)%ord(iord)%prm%shear_bnk = ch_prms(3)%pos - chcal(ireg)%ord(iord)%prm_lim%shear_bnk = 1. - end if - if (chcal(ireg)%ord(iord)%prm%shear_bnk <= ch_prms(3)%neg) then - chg_val = chcal(ireg)%ord(iord)%prm_prev%shear_bnk - ch_prms(3)%neg - chcal(ireg)%ord(iord)%prm%shear_bnk = ch_prms(3)%neg - chcal(ireg)%ord(iord)%prm_lim%shear_bnk = 1. - end if - - !check all channels for proper order - do ich_s = 1, chcal(ireg)%num_tot - iich = chcal(ireg)%num(ich_s) - if (chcal(ireg)%ord(iord)%meas%name == sd_ch(iich)%order .or. chcal(ireg)%ord(iord)%meas%name == "basin") then - !set parms for width calibration and rerun - sdch_init(iich)%shear_bnk = sdch_init(iich)%shear_bnk + chg_val - sdch_init(iich)%shear_bnk = amin1 (sdch_init(iich)%shear_bnk, ch_prms(3)%up) - sdch_init(iich)%shear_bnk = Max (sdch_init(iich)%shear_bnk, ch_prms(3)%lo) - end if - end do - chcal(ireg)%ord(iord)%nbyr = 0 - chcal(ireg)%ord(iord)%aa = chcal_z - end if - end do - end do - - !! re-initialize all objects - call re_initialize - - ! bank shear coefficient adjustment - if (isim > 0) then - write (4601,*) " bank shear coeff adj " - call time_control - end if - end do ! icov - - ! 1st erodibility adjustment for channel downcutting - isim = 0 - do ireg = 1, db_mx%ch_reg - do iord = 1, chcal(ireg)%ord_num - soft = chcal(ireg)%ord(iord)%meas%chd - diff = 0. - if (soft > 1.e-6) diff = abs((soft - chcal(ireg)%ord(iord)%aa%chd) / soft) - if (diff > .02 .and. chcal(ireg)%ord(iord)%length > 1.e-6 .and. chcal(ireg)%ord(iord)%prm_lim%erod < 1.e-6) then - isim = 1 - - chcal(ireg)%ord(iord)%prm_prev = chcal(ireg)%ord(iord)%prm - chcal(ireg)%ord(iord)%prev = chcal(ireg)%ord(iord)%aa - - chg_val = chcal(ireg)%ord(iord)%meas%chd / (chcal(ireg)%ord(iord)%aa%chd + 1.e-6) !assume same ratio of cover and width change - chcal(ireg)%ord(iord)%prm_prev%erod = chcal(ireg)%ord(iord)%prm%erod - chcal(ireg)%ord(iord)%prm%erod = chcal(ireg)%ord(iord)%prm%erod + chg_val - chcal(ireg)%ord(iord)%prev%chd = chcal(ireg)%ord(iord)%aa%chd - - if (chcal(ireg)%ord(iord)%prm%erod >= ch_prms(2)%pos) then - chg_val = ch_prms(2)%pos - chcal(ireg)%ord(iord)%prm_prev%erod - chcal(ireg)%ord(iord)%prm%erod = ch_prms(2)%pos - chcal(ireg)%ord(iord)%prm_lim%erod = 1. - end if - if (chcal(ireg)%ord(iord)%prm%erod <= ch_prms(2)%neg) then - chg_val = ch_prms(2)%neg - chcal(ireg)%ord(iord)%prm_prev%erod - chcal(ireg)%ord(iord)%prm%erod = ch_prms(2)%neg - chcal(ireg)%ord(iord)%prm_lim%erod = 1. - end if - - !check all channels for proper order - do ich_s = 1, chcal(ireg)%num_tot - iich = chcal(ireg)%num(ich_s) - if (chcal(ireg)%ord(iord)%meas%name == sd_ch(iich)%order .or. chcal(ireg)%ord(iord)%meas%name == "basin") then - !set parms for 1st erodibility calibration and rerun - sdch_init(iich)%cherod = sdch_init(iich)%cherod / chg_val - sdch_init(iich)%cherod = amin1 (sdch_init(iich)%cherod, ch_prms(2)%up) - sdch_init(iich)%cherod = Max (sdch_init(iich)%cherod, ch_prms(2)%lo) - end if - end do - chcal(ireg)%ord(iord)%nbyr = 0 - chcal(ireg)%ord(iord)%aa = chcal_z - end if - end do - end do - - !! re-initialize all objects - call re_initialize - - ! 1st erodibility adjustment - if (isim > 0) then - write (4601,*) " first erodibility adj " - call time_control - end if - - ! erodibility adjustment for channel downcutting - do ierod = 1, iter_ind - isim = 0 - do ireg = 1, db_mx%cha_reg - do iord = 1, chcal(ireg)%ord_num - soft = chcal(ireg)%ord(iord)%meas%chd - diff = 0. - if (soft > 1.e-6) diff = abs((soft - chcal(ireg)%ord(iord)%aa%chd) / soft) - if (diff > .02 .and. chcal(ireg)%ord(iord)%length > 1.e-6 .and. chcal(ireg)%ord(iord)%prm_lim%erod < 1.e-6) then - isim = 1 - - rmeas = chcal(ireg)%ord(iord)%meas%chd - denom = chcal(ireg)%ord(iord)%prev%chd - chcal(ireg)%ord(iord)%aa%chd - if (abs(denom) > 1.e-6) then - chg_val = (chcal(ireg)%ord(iord)%prm_prev%erod - chcal(ireg)%ord(iord)%prm%erod) & - * (chcal(ireg)%ord(iord)%aa%chd - rmeas) / denom - else - chg_val = chcal(ireg)%ord(iord)%meas%chd / chcal(ireg)%ord(iord)%aa%chd - end if - chcal(ireg)%ord(iord)%prm_prev%erod = chcal(ireg)%ord(iord)%prm%erod - chcal(ireg)%ord(iord)%prm%erod = chcal(ireg)%ord(iord)%prm%erod + chg_val - chcal(ireg)%ord(iord)%prev%chd = chcal(ireg)%ord(iord)%aa%chd - - if (chcal(ireg)%ord(iord)%prm%erod >= ch_prms(2)%pos) then - chg_val = ch_prms(2)%pos - chcal(ireg)%ord(iord)%prm_prev%erod - chcal(ireg)%ord(iord)%prm%erod = ch_prms(2)%pos - chcal(ireg)%ord(iord)%prm_lim%erod = 1. - end if - if (chcal(ireg)%ord(iord)%prm%erod <= ch_prms(2)%neg) then - chg_val = chcal(ireg)%ord(iord)%prm_prev%erod - ch_prms(2)%neg - chcal(ireg)%ord(iord)%prm%erod = ch_prms(2)%neg - chcal(ireg)%ord(iord)%prm_lim%erod = 1. - end if - - !check all channels for proper order - do ich_s = 1, chcal(ireg)%num_tot - iich = chcal(ireg)%num(ich_s) - if (chcal(ireg)%ord(iord)%meas%name == sd_ch(iich)%order .or. chcal(ireg)%ord(iord)%meas%name == "basin") then - !set parms for depth calibration and rerun - sdch_init(iich)%cherod = sdch_init(iich)%cherod / chg_val - sdch_init(iich)%cherod = amin1 (sdch_init(iich)%cherod, ch_prms(2)%up) - sdch_init(iich)%cherod = Max (sdch_init(iich)%cherod, ch_prms(2)%lo) - end if - end do - chcal(ireg)%ord(iord)%nbyr = 0 - chcal(ireg)%ord(iord)%aa = chcal_z - end if - end do - end do - - !! re-initialize all objects - call re_initialize - - ! erodibility adjustment - if (isim > 0) then - write (4601,*) " erodibility adj " - call time_control - end if - end do ! ierod - - ! 1st erodibility adjustment for head cut - isim = 0 - do ireg = 1, db_mx%ch_reg - do iord = 1, chcal(ireg)%ord_num - soft = chcal(ireg)%ord(iord)%meas%hc - diff = 0. - if (soft > 1.e-6) diff = abs((soft - chcal(ireg)%ord(iord)%aa%hc) / soft) - if (diff > .02 .and. chcal(ireg)%ord(iord)%length > 1.e-6 .and. chcal(ireg)%ord(iord)%prm_lim%hc_erod < 1.e-6) then - isim = 1 - - chcal(ireg)%ord(iord)%prm_prev = chcal(ireg)%ord(iord)%prm - chcal(ireg)%ord(iord)%prev = chcal(ireg)%ord(iord)%aa - - chg_val = chcal(ireg)%ord(iord)%meas%hc / (chcal(ireg)%ord(iord)%aa%hc + 1.e-6) !assume same ratio of cover and width change - chcal(ireg)%ord(iord)%prm_prev%hc_erod = chcal(ireg)%ord(iord)%prm%hc_erod - chcal(ireg)%ord(iord)%prm%hc_erod = chcal(ireg)%ord(iord)%prm%hc_erod + chg_val - chcal(ireg)%ord(iord)%prev%hc = chcal(ireg)%ord(iord)%aa%hc - - if (chcal(ireg)%ord(iord)%prm%hc_erod >= ch_prms(4)%pos) then - chg_val = ch_prms(4)%pos - chcal(ireg)%ord(iord)%prm_prev%hc_erod - chcal(ireg)%ord(iord)%prm%hc_erod = ch_prms(4)%pos - chcal(ireg)%ord(iord)%prm_lim%hc_erod = 1. - end if - if (chcal(ireg)%ord(iord)%prm%hc_erod <= ch_prms(4)%neg) then - chg_val = ch_prms(4)%neg - chcal(ireg)%ord(iord)%prm_prev%hc_erod - chcal(ireg)%ord(iord)%prm%hc_erod = ch_prms(4)%neg - chcal(ireg)%ord(iord)%prm_lim%hc_erod = 1. - end if - - !check all channels for proper order - do ich_s = 1, chcal(ireg)%num_tot - iich = chcal(ireg)%num(ich_s) - if (chcal(ireg)%ord(iord)%meas%name == sd_ch(iich)%order .or. chcal(ireg)%ord(iord)%meas%name == "basin") then - !if height is 0 - no head cut advance - sdch_init(iich)%hc_erod = sdch_init(iich)%hc_erod / chg_val - sdch_init(iich)%hc_erod = amin1 (sdch_init(iich)%hc_erod, ch_prms(4)%up) - sdch_init(iich)%hc_erod = Max (sdch_init(iich)%hc_erod, ch_prms(4)%lo) - !end if - end if - end do - chcal(ireg)%ord(iord)%nbyr = 0 - chcal(ireg)%ord(iord)%aa = chcal_z - end if - end do - end do - !initialize hru and hru_lte - - !! re-initialize all objects - call re_initialize - - ! 1st erodibility adjustment - if (isim > 0) then - write (4601,*) " first head cut erodibility adj " - call time_control - end if - - ! erodibility adjustment for head cut - do ierod = 1, iter_ind - isim = 0 - do ireg = 1, db_mx%cha_reg - do iord = 1, chcal(ireg)%ord_num - soft = chcal(ireg)%ord(iord)%meas%hc - diff = 0. - if (soft > 1.e-6) diff = abs((soft - chcal(ireg)%ord(iord)%aa%hc) / soft) - if (diff > .02 .and. chcal(ireg)%ord(iord)%length > 1.e-6 .and. chcal(ireg)%ord(iord)%prm_lim%hc_erod < 1.e-6) then - isim = 1 - - rmeas = chcal(ireg)%ord(iord)%meas%hc - denom = chcal(ireg)%ord(iord)%prev%hc - chcal(ireg)%ord(iord)%aa%hc - if (abs(denom) > 1.e-6) then - chg_val = - (chcal(ireg)%ord(iord)%prm_prev%hc_erod - chcal(ireg)%ord(iord)%prm%hc_erod) & - * (chcal(ireg)%ord(iord)%aa%hc - rmeas) / denom - else - chg_val = chcal(ireg)%ord(iord)%meas%hc / chcal(ireg)%ord(iord)%aa%hc - end if - chcal(ireg)%ord(iord)%prm_prev%hc_erod = chcal(ireg)%ord(iord)%prm%hc_erod - chcal(ireg)%ord(iord)%prm%hc_erod = chcal(ireg)%ord(iord)%prm%hc_erod + chg_val - chcal(ireg)%ord(iord)%prev%hc = chcal(ireg)%ord(iord)%aa%hc - - if (chcal(ireg)%ord(iord)%prm%hc_erod >= ch_prms(4)%pos) then - chg_val = ch_prms(4)%pos - chcal(ireg)%ord(iord)%prm_prev%hc_erod - chcal(ireg)%ord(iord)%prm%hc_erod = ch_prms(4)%pos - chcal(ireg)%ord(iord)%prm_lim%hc_erod = 1. - end if - if (chcal(ireg)%ord(iord)%prm%hc_erod <= ch_prms(4)%neg) then - chg_val = chcal(ireg)%ord(iord)%prm_prev%hc_erod - ch_prms(4)%neg - chcal(ireg)%ord(iord)%prm%hc_erod = ch_prms(4)%neg - chcal(ireg)%ord(iord)%prm_lim%hc_erod = 1. - end if - - !check all channels for proper order - do ich_s = 1, chcal(ireg)%num_tot - iich = chcal(ireg)%num(ich_s) - if (chcal(ireg)%ord(iord)%meas%name == sd_ch(iich)%order .or. chcal(ireg)%ord(iord)%meas%name == "basin") then - !if height is 0 - no head cut advance - if (sd_ch(iich)%hc_hgt > 1.e-6) then - sdch_init(iich)%hc_erod = sdch_init(iich)%hc_erod / chg_val - sdch_init(iich)%hc_erod = amin1 (sdch_init(iich)%hc_erod, ch_prms(4)%up) - sdch_init(iich)%hc_erod = Max (sdch_init(iich)%hc_erod, ch_prms(4)%lo) - end if - end if - end do - chcal(ireg)%ord(iord)%nbyr = 0 - chcal(ireg)%ord(iord)%aa = chcal_z - end if - end do - end do - - !! re-initialize all objects - call re_initialize - - ! erodibility adjustment - if (isim > 0) then - write (4601,*) " head cut erodibility adj " - call time_control - end if - end do ! ierod - -777 end do ! iter - - return - end subroutine calsoft_chsed \ No newline at end of file diff --git a/src/calsoft_control.f90 b/src/calsoft_control.f90 index 3a29827..8350920 100644 --- a/src/calsoft_control.f90 +++ b/src/calsoft_control.f90 @@ -98,9 +98,9 @@ subroutine calsoft_control end if !calibrate channel sediment - if (cal_codes%chsed == "y") then - call calsoft_chsed - end if + !if (cal_codes%chsed == "y") then + ! call calsoft_chsed + !end if if (cal_codes%chsed == "y") then do ireg = 1, db_mx%ch_reg @@ -160,7 +160,7 @@ subroutine calsoft_control end do end if ! channel sediment parms - 500 format (a16,f12.3,i12,f12.3,2(1x,a16,10f12.3),10f12.3) +!*** tu Wunused-label: 500 format (a16,f12.3,i12,f12.3,2(1x,a16,10f12.3),10f12.3) 503 format (2a16,f12.5,a) return diff --git a/src/calsoft_hyd_bfr.f90 b/src/calsoft_hyd_bfr.f90 index 03cae4c..cc737c6 100644 --- a/src/calsoft_hyd_bfr.f90 +++ b/src/calsoft_hyd_bfr.f90 @@ -26,8 +26,22 @@ subroutine calsoft_hyd_bfr do iterall = 1, iter_all - ! calibrate harg_pet for potential ET + ! calibrate petco for actual ET + ! start with half the range + ls_prms(4)%neg = ls_prms(4)%neg / 2. + ls_prms(4)%pos = ls_prms(4)%pos / 2. + ls_prms(4)%lo = (1. - ls_prms(4)%lo) / 2. + ls_prms(4)%lo + ls_prms(4)%up = ls_prms(4)%up - (ls_prms(4)%up - 1.) / 2. + call calsoft_hyd_bfr_pet + ! calibrate esco for actual ET call calsoft_hyd_bfr_et + ! calibrate petco for actual ET + ! allow full range + ls_prms(4)%neg = 2. * ls_prms(4)%neg + ls_prms(4)%pos = 2. * ls_prms(4)%pos + ls_prms(4)%lo = ls_prms(4)%lo - (1. - ls_prms(4)%lo) + ls_prms(4)%up = ls_prms(4)%up + (ls_prms(4)%up - 1.) + call calsoft_hyd_bfr_pet ! calibrate cn3_swf for surface runoff call calsoft_hyd_bfr_surq diff --git a/src/calsoft_hyd_bfr_et.f90 b/src/calsoft_hyd_bfr_et.f90 index 945f27a..eeaf17f 100644 --- a/src/calsoft_hyd_bfr_et.f90 +++ b/src/calsoft_hyd_bfr_et.f90 @@ -36,76 +36,15 @@ subroutine calsoft_hyd_bfr_et ! calibrate esco and pet for water yield iter_ind = 1 - ! first calibrate potential et - do ietco = 1, 2 !iter_ind - isim = 0 - do ireg = 1, db_mx%lsu_reg - do ilum = 1, region(ireg)%nlum - soft = lscal(ireg)%lum(ilum)%meas%wyr * lscal(ireg)%lum(ilum)%precip_aa - pred = lscal(ireg)%lum(ilum)%aa%wyr - diff = 0. - if (soft > 1.e-6) diff = abs((soft - pred) / soft) - if (diff > .01 .and. lscal(ireg)%lum(ilum)%ha > 1.e-6) then - isim = 1 - lscal(ireg)%lum(ilum)%prm_prev = lscal(ireg)%lum(ilum)%prm - lscal(ireg)%lum(ilum)%prev = lscal(ireg)%lum(ilum)%aa - if (soft < pred) then - chg_val = 1. + abs((soft - pred) / soft) - else - chg_val = 1. - abs((pred - soft) / pred) - end if - lscal(ireg)%lum(ilum)%prm_prev%petco = lscal(ireg)%lum(ilum)%prm%petco - if (ietco == 1) then - lscal(ireg)%lum(ilum)%prm%petco = chg_val - else - lscal(ireg)%lum(ilum)%prm%petco = lscal(ireg)%lum(ilum)%prm%petco * chg_val - end if - lscal(ireg)%lum(ilum)%prm_prev%petco = pred - if (lscal(ireg)%lum(ilum)%prm%petco >= ls_prms(4)%pos) then - chg_val = ls_prms(4)%pos - lscal(ireg)%lum(ilum)%prm%petco = ls_prms(4)%pos - lscal(ireg)%lum(ilum)%prm_lim%petco = 1. - end if - if (lscal(ireg)%lum(ilum)%prm%petco <= ls_prms(4)%neg) then - chg_val = ls_prms(4)%neg - lscal(ireg)%lum(ilum)%prm%petco = ls_prms(4)%neg - lscal(ireg)%lum(ilum)%prm_lim%petco = 1. - end if - !check all hru"s for proper lum - do ihru_s = 1, region(ireg)%num_tot - iihru = region(ireg)%num(ihru_s) - if (lscal(ireg)%lum(ilum)%meas%name == hru(iihru)%lum_group_c .or. lscal(ireg)%lum(ilum)%meas%name == "basin") then - !set parms for pet adjustment - hru(iihru)%hyd%pet_co = hru(iihru)%hyd%pet_co * chg_val - hru(iihru)%hyd%pet_co = amin1 (hru(iihru)%hyd%pet_co, ls_prms(4)%up) - hru(iihru)%hyd%pet_co = Max (hru(iihru)%hyd%pet_co, ls_prms(4)%lo) - hru_init(iihru)%hyd%pet_co = hru(iihru)%hyd%pet_co - end if - end do - lscal(ireg)%lum(ilum)%nbyr = 0 - lscal(ireg)%lum(ilum)%precip_aa = 0. - lscal(ireg)%lum(ilum)%aa = lscal_z - end if - end do - end do - !! re-initialize all objects - call re_initialize - ! 1st cover adjustment - if (isim > 0) then - cal_sim = " first pet adj " - cal_adj = chg_val - call time_control - end if - end do ! petco iterations ! 1st esco adjustment isim = 0 diff --git a/src/calsoft_hyd_bfr_pet.f90 b/src/calsoft_hyd_bfr_pet.f90 new file mode 100644 index 0000000..8121cad --- /dev/null +++ b/src/calsoft_hyd_bfr_pet.f90 @@ -0,0 +1,96 @@ + subroutine calsoft_hyd_bfr_pet + use hru_module, only : hru, hru_init + use soil_module + use plant_module + use hydrograph_module + use ru_module + use aquifer_module + use channel_module + use hru_lte_module + use sd_channel_module + use basin_module + use maximum_data_module + use calibration_data_module + use conditional_module + use reservoir_module + use organic_mineral_mass_module + use time_module + implicit none + integer :: isim = 0 ! | + integer :: ireg = 0 !none |counter + integer :: ilum = 0 !none |counter + integer :: iihru = 0 !none |counter + integer :: ihru_s = 0 !none |counter + integer :: iter_ind = 0 ! |end of loop + integer :: ietco = 0 !none |counter + real :: rmeas = 0. ! | + real :: denom = 0. ! | + real :: soft = 0. ! | + real :: diff = 0. ! | + real :: chg_val = 0. ! | + real :: pred = 0. + ! calibrate esco and pet for water yield + iter_ind = 1 + ! first calibrate potential et + do ietco = 1, 2 !iter_ind + isim = 0 + do ireg = 1, db_mx%lsu_reg + do ilum = 1, region(ireg)%nlum + soft = lscal(ireg)%lum(ilum)%meas%wyr * lscal(ireg)%lum(ilum)%precip_aa + pred = lscal(ireg)%lum(ilum)%aa%wyr + diff = 0. + if (soft > 1.e-6) diff = abs((soft - pred) / soft) + if (diff > .01 .and. lscal(ireg)%lum(ilum)%ha > 1.e-6) then + isim = 1 + lscal(ireg)%lum(ilum)%prm_prev = lscal(ireg)%lum(ilum)%prm + lscal(ireg)%lum(ilum)%prev = lscal(ireg)%lum(ilum)%aa + if (soft < pred) then + chg_val = 1. + abs((soft - pred) / soft) + else + chg_val = 1. - abs((pred - soft) / pred) + end if + lscal(ireg)%lum(ilum)%prm_prev%petco = lscal(ireg)%lum(ilum)%prm%petco + if (ietco == 1) then + lscal(ireg)%lum(ilum)%prm%petco = chg_val + else + lscal(ireg)%lum(ilum)%prm%petco = lscal(ireg)%lum(ilum)%prm%petco * chg_val + end if + lscal(ireg)%lum(ilum)%prm_prev%petco = pred + if (lscal(ireg)%lum(ilum)%prm%petco >= ls_prms(4)%pos) then + chg_val = ls_prms(4)%pos + lscal(ireg)%lum(ilum)%prm%petco = ls_prms(4)%pos + lscal(ireg)%lum(ilum)%prm_lim%petco = 1. + end if + if (lscal(ireg)%lum(ilum)%prm%petco <= ls_prms(4)%neg) then + chg_val = ls_prms(4)%neg + lscal(ireg)%lum(ilum)%prm%petco = ls_prms(4)%neg + lscal(ireg)%lum(ilum)%prm_lim%petco = 1. + end if + !check all hru"s for proper lum + do ihru_s = 1, region(ireg)%num_tot + iihru = region(ireg)%num(ihru_s) + if (lscal(ireg)%lum(ilum)%meas%name == hru(iihru)%lum_group_c .or. lscal(ireg)%lum(ilum)%meas%name == "basin") then + !set parms for pet adjustment + hru(iihru)%hyd%pet_co = hru(iihru)%hyd%pet_co * chg_val + hru(iihru)%hyd%pet_co = amin1 (hru(iihru)%hyd%pet_co, ls_prms(4)%up) + hru(iihru)%hyd%pet_co = Max (hru(iihru)%hyd%pet_co, ls_prms(4)%lo) + hru_init(iihru)%hyd%pet_co = hru(iihru)%hyd%pet_co + end if + end do + lscal(ireg)%lum(ilum)%nbyr = 0 + lscal(ireg)%lum(ilum)%precip_aa = 0. + lscal(ireg)%lum(ilum)%aa = lscal_z + end if + end do + end do + !! re-initialize all objects + call re_initialize + ! 1st cover adjustment + if (isim > 0) then + cal_sim = " first pet adj " + cal_adj = chg_val + call time_control + end if + end do ! petco iterations + return + end subroutine calsoft_hyd_bfr_pet \ No newline at end of file diff --git a/src/carbon_module.f90 b/src/carbon_module.f90 index cf31b6a..436528e 100644 --- a/src/carbon_module.f90 +++ b/src/carbon_module.f90 @@ -1,27 +1,27 @@ module carbon_module - + implicit none type carbon_terrestrial_inputs real :: er_POC_para = 1.5 ! |POC enrichment ratio ! 0-10 ! 0.0-5.0 MOST SENSITIVE real :: CFB_para = 0.42 ! |Carbon fraction of residue (0.42; from data of Pinck et al., 1950) - real :: Sf_para_sur = 0.05 ! |Fraction of mineral N sorbed to litter: 0.05 for surface litter, 0.1 for below ground litter - real :: Sf_para_sub = 0.10 ! |Fraction of mineral N sorbed to litter: 0.05 for surface litter, 0.1 for belowg round litter + real :: Sf_para_sur = 0.05 ! |Fraction of mineral N sorbed to litter: 0.05 for surface litter, 0.1 for below ground litter + real :: Sf_para_sub = 0.10 ! |Fraction of mineral N sorbed to litter: 0.05 for surface litter, 0.1 for belowg round litter !Dissovled carbon - real :: ABL_para = 0.0 ! |Calculated - Carbon allocation from Microbial Biomass to Leaching + real :: ABL_para = 0.0 ! |Calculated - Carbon allocation from Microbial Biomass to Leaching real :: peroc_DIC_para = 0.95 !0-1 |DIC percolation coefficient - real :: peroc_DOC_para = 0.70 !0-1 |DOC percolation coefficient + real :: peroc_DOC_para = 0.70 !0-1 |DOC percolation coefficient real :: part_DOC_para = 4000. ! |organic carbon partition coefficient 1000 to 1200 ! 500-2000 !replacing KOC=Liquid-solid partition coefficient for Microbial Biomass (10^3 m3 Mg-1) real :: hlife_doc_para = 50. !days |DOC half life in groundwater, calculating DOC decay in groundwater ! 0-100 !Allocation of CO2 and Carbon transformation - real :: ABCO2_para_sur = 0.6 ! |Allocation from Microbial Biomass C pool to CO2; 0.6 (surface Litter), 0.85 - 0.68 x (CLAY+SILT) (all other layers) (Parton et al., 1993, 1994) + real :: ABCO2_para_sur = 0.6 ! |Allocation from Microbial Biomass C pool to CO2; 0.6 (surface Litter), 0.85 - 0.68 x (CLAY+SILT) (all other layers) (Parton et al., 1993, 1994) real :: ABCO2_para_sub = 0. ! |Calculated -Allocation from Microbial Biomass C pool to CO2; 0.6 (surface Litter), 0.85 - 0.68 x (CLAY+SILT) (all other layers) (Parton et al., 1993, 1994) - real :: ABP_para_sur = 0.0 ! |Allocation from Biomass to passive Humus; 0 (surface Litter), 0.003 + 0.032 x SOL_CLAY (all other layers) (Parton et al., 1993, 1994) + real :: ABP_para_sur = 0.0 ! |Allocation from Biomass to passive Humus; 0 (surface Litter), 0.003 + 0.032 x SOL_CLAY (all other layers) (Parton et al., 1993, 1994) real :: ABP_para_sub = 0.0 ! |Calculated - Allocation from Biomass to passive Humus; 0 (surface Litter), 0.003 + 0.032 x SOL_CLAY (all other layers) (Parton et al., 1993, 1994) - real :: ALMCO2_para_sur = 0.6 ! |Allocation from metabolic Litter to CO2; 0.6 (surface Litter), 0.55 (all other layers) (Parton et al., 1993, 1994) - real :: ALMCO2_para_sub = 0.55 ! |Allocation from metabolic Litter to CO2; 0.6 (surface Litter), 0.55 (all other layers) (Parton et al., 1993, 1994) + real :: ALMCO2_para_sur = 0.6 ! |Allocation from metabolic Litter to CO2; 0.6 (surface Litter), 0.55 (all other layers) (Parton et al., 1993, 1994) + real :: ALMCO2_para_sub = 0.55 ! |Allocation from metabolic Litter to CO2; 0.6 (surface Litter), 0.55 (all other layers) (Parton et al., 1993, 1994) real :: ALSLNCO2_para_sur = 0.6 ! |Allocation from non-lignin of structural Litter to CO2; 0.6 (surface Litter), 0.55 (all other layers) (Parton et al., 1993, 1994) - real :: ALSLNCO2_para_sub =0.55 ! |Allocation from non-lignin of structural Litter to CO2; 0.6 (surface Litter), 0.55 (all other layers) (Parton et al., 1993, 1994) + real :: ALSLNCO2_para_sub =0.55 ! |Allocation from non-lignin of structural Litter to CO2; 0.6 (surface Litter), 0.55 (all other layers) (Parton et al., 1993, 1994) real :: ASP_para_sur = 0.0 ! |Allocation from slow Humus to passive; 0 (surface Litter), 0.003 + 0.00009 x CLAF (all other layers) (Parton et al., 1993, 1994) real :: ASP_para_sub = 0.0 ! |Calculated - Allocation from slow Humus to passive; 0 (surface Litter), 0.003 + 0.00009 x CLAF (all other layers) (Parton et al., 1993, 1994) real :: ALSLCO2_para = 0.3 ! |Allocation from lignin of structural Litter to CO2; 0.3 (Parton et al., 1993, 1994) @@ -30,8 +30,8 @@ module carbon_module !decomposition rates real :: PRMT_51_para = 1.0 ! |COEF ADJUSTS MICROBIAL ACTIVITY FUNCTION IN TOP SOIL LAYER (0.1_1.), real :: PRMT_45_para = 0.003 ! |COEF IN CENTURY EQ ALLOCATING SLOW TO PASSIVE HUMUS(0.001_0.05) ORIGINAL VALUE = 0.003, ASP=MAX(.001,PRMT_45-.00009*sol_clay(k,j)), ASP=MAX(.001,PRMT_45+.009*sol_clay(k,j)/100) - real :: BMR_para_sur = 0.0164 ! |Rate of transformation of microbial Biomass and associated products under optimal conditions (surface = 0.0164 d-1; all other layers = 0.02 d-1) (Parton et al., 1993, 1994) - real :: BMR_para_sub = 0.02 ! |Rate of transformation of microbial Biomass and associated products under optimal conditions (surface = 0.0164 d-1; all other layers = 0.02 d-1) (Parton et al., 1993, 1994) + real :: BMR_para_sur = 0.0164 ! |Rate of transformation of microbial Biomass and associated products under optimal conditions (surface = 0.0164 d-1; all other layers = 0.02 d-1) (Parton et al., 1993, 1994) + real :: BMR_para_sub = 0.02 ! |Rate of transformation of microbial Biomass and associated products under optimal conditions (surface = 0.0164 d-1; all other layers = 0.02 d-1) (Parton et al., 1993, 1994) real :: HPR_para = 0.000012 ! |Rate of transformation of passive Humus under optimal conditions (subsurface layers = 0.000012 d-1) (Parton et al., 1993, 1994) real :: HSR_para = 0.000548 ! |Rate of transformation of slow Humus under optimal conditions (all layers = 0.0005 d-1) (Parton et al., 1993, 1994; Vitousek et al., 1993) real :: LMR_para_sur = 0.0405 ! |Rate of transformation of metabolic Litter under optimal conditions (surface = 0.0405 d-1; all other layers = 0.0507 d-1) (Parton et al., 1994) @@ -62,32 +62,32 @@ module carbon_module end type carbon_inputs type (carbon_inputs) :: carbdb type (carbon_inputs) :: carbz - + type organic_allocations real :: abco2 = 0. ! |Fraction of decomposed microbial biomass allocated to CO2 - real :: abl = 0. ! |Fraction of microbial biomass loss due to leaching - real :: abp = 0. ! |Fraction of decomposed microbial biomass allocated to passive humus - real :: almco2 = 0. ! |Fraction of decomposed metabolic litter allocated to CO2 - real :: alslco2 = 0. ! |Fraction of decomposed lignin of structural litter allocated to CO2 - real :: alslnco2 = 0. ! |Fraction of decomposed lignin of structural litter allocated to CO2 - real :: apco2 = 0. ! |Fraction of decomposed passive humus allocated to CO2 - real :: asco2 = 0. ! |Fraction of decomposed slow humus allocated to CO2 - real :: asp = 0. ! |Fraction of decomposed slow humus allocated to passive + real :: abl = 0. ! |Fraction of microbial biomass loss due to leaching + real :: abp = 0. ! |Fraction of decomposed microbial biomass allocated to passive humus + real :: almco2 = 0. ! |Fraction of decomposed metabolic litter allocated to CO2 + real :: alslco2 = 0. ! |Fraction of decomposed lignin of structural litter allocated to CO2 + real :: alslnco2 = 0. ! |Fraction of decomposed lignin of structural litter allocated to CO2 + real :: apco2 = 0. ! |Fraction of decomposed passive humus allocated to CO2 + real :: asco2 = 0. ! |Fraction of decomposed slow humus allocated to CO2 + real :: asp = 0. ! |Fraction of decomposed slow humus allocated to passive end type organic_allocations type (organic_allocations) :: org_allo type (organic_allocations) :: org_alloz - + type organic_controls - real :: cdg = 0. ! |soil temperature control on biological processes - real :: cs = 0. ! |combined factor controlling biological processes - real :: ox = 0. ! |oxygen control on biological processes - real :: sut = 0. ! |soil water control on biological processes - real :: x1 = 0. ! |tillage control on residue decomposition + real :: cdg = 0. ! |soil temperature control on biological processes + real :: cs = 0. ! |combined factor controlling biological processes + real :: ox = 0. ! |oxygen control on biological processes + real :: sut = 0. ! |soil water control on biological processes + real :: x1 = 0. ! |tillage control on residue decomposition real :: xbmt = 0. ! |control on transformation of microbial biomass by soil texture and structure real :: xlslf = 0. ! |control on potential transformation of structural litter by lignin fraction end type organic_controls type (organic_controls) :: org_con - + type organic_fractions real :: lmf = 0. !frac |fraction of the litter that is metabolic real :: lmnf = 0. !kg kg-1 |fraction of metabolic litter that is N @@ -101,23 +101,23 @@ module carbon_module real :: cnr = 0. ! |c/n ratio of standing dead real :: ncbm = 0. ! |n/c ratio of biomass real :: nchp = 0. ! |n/c ratio of passive humus - real :: nchs = 0. ! |n/c ration of slow humus + real :: nchs = 0. ! |n/c ration of slow humus end type organic_ratio type (organic_ratio) :: org_ratio - + type organic_transformations real :: bmctp = 0. !kg ha-1 day-1 |potential transformation of C in microbial biomass - real :: bmntp = 0. !kg ha-1 day-1 |potential transformation of N in microbial biomass - real :: hsctp = 0. !kg ha-1 day-1 |potential transformation of C in slow humus - real :: hsntp = 0. !kg ha-1 day-1 |potential transformation of N in slow humus + real :: bmntp = 0. !kg ha-1 day-1 |potential transformation of N in microbial biomass + real :: hsctp = 0. !kg ha-1 day-1 |potential transformation of C in slow humus + real :: hsntp = 0. !kg ha-1 day-1 |potential transformation of N in slow humus real :: hpctp = 0. !kg ha-1 day-1 |potential transformation of C in passive humus real :: hpntp = 0. !kg ha-1 day-1 |potential transformation of N in passive humus real :: lmctp = 0. !kg ha-1 day-1 |potential transformation of C in metabolic litter - real :: lmntp = 0. !kg ha-1 day-1 |potential transformation of N in metabolic litter + real :: lmntp = 0. !kg ha-1 day-1 |potential transformation of N in metabolic litter real :: lsctp = 0. !kg ha-1 day-1 |potential transformation of C in structural litter real :: lslctp = 0. !kg ha-1 day-1 |potential transformation of C in lignin of structural litter real :: lslnctp = 0. !kg ha-1 day-1 |potential transformation of C in nonlignin structural litter - real :: lsntp = 0. !kg ha-1 day-1 |potential transformation of N in structural litter + real :: lsntp = 0. !kg ha-1 day-1 |potential transformation of N in structural litter end type organic_transformations type (organic_transformations) :: org_tran @@ -231,7 +231,7 @@ module carbon_module type (carbon_soil_gain_losses) :: bsc_a type carbon_residue_gain_losses - real :: plant_c = 0. !kg C/ha |carbon added to residue from leaf drop and kill + real :: plant_c = 0. !kg C/ha |carbon added to residue from leaf drop and kill real :: res_decay_c = 0. !kg C/ha |carbon lost to soil from residue decay real :: harv_stov_c = 0. !kg C/ha |carbon removed during residue harvest real :: emit_c = 0. !kg C/ha |CO2 production from burning residue carbon diff --git a/src/cbn_zhang2.f90 b/src/cbn_zhang2.f90 index 1317247..64de2c4 100644 --- a/src/cbn_zhang2.f90 +++ b/src/cbn_zhang2.f90 @@ -279,12 +279,20 @@ subroutine cbn_zhang2 j = ihru + !! calculate carbon loss in surface residue + !soil1(j)%str(k)%n = soil1(j)%str(k)%n * (1. - decr) + !soil1(j)%lig(k)%n = soil1(j)%lig(k)%n * (1. - decr) + !soil1(j)%meta(k)%n = soil1(j)%meta(k)%n * (1. - decr) + !soil1(j)%str(k)%p = soil1(j)%str(k)%p * (1. - decr) + !soil1(j)%lig(k)%p = soil1(j)%lig(k)%p * (1. - decr) + !soil1(j)%meta(k)%p = soil1(j)%meta(k)%p * (1. - decr) + !calculate tillage factor using dssat if (tillage_switch(j) .eq. 1 .and. tillage_days(j) .le. 30) then tillage_factor(j) = 1.6 else tillage_factor(j) = 1.0 - end if + end if !!calculate c/n dynamics for each soil layer !!=========================================== @@ -333,11 +341,11 @@ subroutine cbn_zhang2 till_eff = 1.6 else if (soil(j)%phys(k-1)%d .lt. tillage_depth(j)) then till_eff = 1.0 + 0.6 * (tillage_depth(j) - soil(j)%phys(k-1)%d) / (soil(j)%phys(k)%d - soil(j)%phys(k-1)%d) - end if + end if end if else till_eff = 1.0 - end if + end if !!compute soil temperature factor - when sol_tep is larger than 35, cdg is negative? org_con%cdg = soil(j)%phys(k)%tmp / (soil(j)%phys(k)%tmp + exp(5.058459 - 0.2503591 * soil(j)%phys(k)%tmp)) @@ -630,16 +638,16 @@ subroutine cbn_zhang2 ! update if (rnmn > 0.) then soil1(j)%mn(k)%nh4 = soil1(j)%mn(k)%nh4 + rnmn - min_n = soil1(j)%mn(k)%no3 + rnmn - if (min_n < 0.) then - rnmn = -soil1(j)%mn(k)%no3 - soil1(j)%mn(k)%no3 = 1.e-10 - else - soil1(j)%mn(k)%no3 = min_n + min_n = soil1(j)%mn(k)%no3 + rnmn + if (min_n < 0.) then + rnmn = -soil1(j)%mn(k)%no3 + soil1(j)%mn(k)%no3 = 1.e-10 + else + soil1(j)%mn(k)%no3 = min_n end if end if - ! calculate p flows + ! calculate p flows ! compute humus mineralization on active organic p hmp_rate = 1.4 * (hsnta + hpnta) / (soil1(j)%hs(k)%n + soil1(j)%hp(k)%n + 1.e-6) @@ -647,9 +655,9 @@ subroutine cbn_zhang2 hmp = hmp_rate * soil1(j)%hp(k)%p hmp = min(hmp, soil1(j)%hp(k)%p) soil1(j)%hp(k)%p = soil1(j)%hp(k)%p - hmp - soil1(j)%mp(k)%lab = soil1(j)%mp(k)%lab + hmp - - !! compute residue decomp and mineralization of + soil1(j)%mp(k)%lab = soil1(j)%mp(k)%lab + hmp + + !! compute residue decomp and mineralization of !! fresh organic n and p (upper two layers only) decr = (lscta + lmcta) / (soil1(j)%str(k)%c + soil1(j)%meta(k)%c + 1.e-6) decr = min(1., decr) @@ -657,12 +665,12 @@ subroutine cbn_zhang2 soil1(j)%tot(k)%p = soil1(j)%tot(k)%p - rmp soil1(j)%mp(k)%lab = soil1(j)%mp(k)%lab + .8 * rmp - soil1(j)%hp(k)%p = soil1(j)%hp(k)%p + .2 * rmp + soil1(j)%hp(k)%p = soil1(j)%hp(k)%p + .2 * rmp !!!================================= !!determine the final rate of the decomposition of each carbon pool and !!allocation of c and nutrients to different som pools, as well as co2 emissions from different pools - lscta = min(soil1(j)%str(k)%c, lscta) + lscta = min(soil1(j)%str(k)%c, lscta) lslcta = min(soil1(j)%lig(k)%c, lslcta) org_flux%co2fstr = .3 * lslcta @@ -775,7 +783,7 @@ subroutine cbn_zhang2 !!epic procedures (not used): calculating n supply - n demand !!df1 is the supply of n during structural litter decomposition (lsnta) - demand of n to meet the transformaitons of other pools !! c pools into structural litter (0 as no other pools transformed into structural litter) - df1 = lsnta + df1 = lsnta !!df2 is the supply of n during metabolic litter decomposition (lsnta) - demand of n to meet the transformaitons of other pools !! c pools into metabolic litter (0 as no other pools transformed into structural litter) diff --git a/src/ch_initial.f90 b/src/ch_initial.f90 index f350e01..fd0edf3 100644 --- a/src/ch_initial.f90 +++ b/src/ch_initial.f90 @@ -16,84 +16,84 @@ subroutine ch_initial (idat, irch) bnksize = ch_sed(ised)%bnk_d50 / 1000. !! Units conversion Micrometer to Millimeters !! Channel sediment particle size distribution !! Clayey bank - if (bnksize <= 0.005) then - ch(irch)%bnk_cla = 0.65 + if (bnksize <= 0.005) then + ch(irch)%bnk_cla = 0.65 ch(irch)%bnk_sil = 0.15 - ch(irch)%bnk_san = 0.15 - ch(irch)%bnk_gra = 0.05 - end if + ch(irch)%bnk_san = 0.15 + ch(irch)%bnk_gra = 0.05 + end if !! Silty bank - if (bnksize > 0.005 .and. bnksize <= 0.05) then + if (bnksize > 0.005 .and. bnksize <= 0.05) then ch(irch)%bnk_sil = 0.65 - ch(irch)%bnk_cla = 0.15 - ch(irch)%bnk_san = 0.15 - ch(irch)%bnk_gra = 0.05 - end if + ch(irch)%bnk_cla = 0.15 + ch(irch)%bnk_san = 0.15 + ch(irch)%bnk_gra = 0.05 + end if !! Sandy bank - if (bnksize > 0.05 .and. bnksize <= 2.) then - ch(irch)%bnk_san = 0.65 + if (bnksize > 0.05 .and. bnksize <= 2.) then + ch(irch)%bnk_san = 0.65 ch(irch)%bnk_sil = 0.15 - ch(irch)%bnk_cla = 0.15 - ch(irch)%bnk_gra = 0.05 - end if + ch(irch)%bnk_cla = 0.15 + ch(irch)%bnk_gra = 0.05 + end if !! Gravel bank - if (bnksize > 2.) then - ch(irch)%bnk_gra = 0.65 - ch(irch)%bnk_san = 0.15 + if (bnksize > 2.) then + ch(irch)%bnk_gra = 0.65 + ch(irch)%bnk_san = 0.15 ch(irch)%bnk_sil = 0.15 - ch(irch)%bnk_cla = 0.05 - end if + ch(irch)%bnk_cla = 0.05 + end if !! Channel sediment particle size distribution !! Clayey bed bedsize = ch_sed(ised)%bed_d50 / 1000. !! Units conversion Micrometer to Millimeters - if (bedsize <= 0.005) then - ch(irch)%bed_cla = 0.65 + if (bedsize <= 0.005) then + ch(irch)%bed_cla = 0.65 ch(irch)%bed_sil = 0.15 - ch(irch)%bed_san = 0.15 - ch(irch)%bed_gra = 0.05 - end if + ch(irch)%bed_san = 0.15 + ch(irch)%bed_gra = 0.05 + end if !! Silty bed - if (bedsize > 0.005 .and. bedsize <= 0.05) then + if (bedsize > 0.005 .and. bedsize <= 0.05) then ch(irch)%bed_sil = 0.65 - ch(irch)%bed_cla = 0.15 - ch(irch)%bed_san = 0.15 - ch(irch)%bed_gra = 0.05 - end if + ch(irch)%bed_cla = 0.15 + ch(irch)%bed_san = 0.15 + ch(irch)%bed_gra = 0.05 + end if !! Sandy bed - if (bedsize > 0.05 .and. bedsize <= 2.) then - ch(irch)%bed_san = 0.65 + if (bedsize > 0.05 .and. bedsize <= 2.) then + ch(irch)%bed_san = 0.65 ch(irch)%bed_sil = 0.15 - ch(irch)%bed_cla = 0.15 - ch(irch)%bed_gra = 0.05 - end if + ch(irch)%bed_cla = 0.15 + ch(irch)%bed_gra = 0.05 + end if !! Gravel bed - if (bedsize > 2.) then - ch(irch)%bed_gra = 0.65 - ch(irch)%bed_san = 0.15 + if (bedsize > 2.) then + ch(irch)%bed_gra = 0.65 + ch(irch)%bed_san = 0.15 ch(irch)%bed_sil = 0.15 - ch(irch)%bed_cla = 0.05 + ch(irch)%bed_cla = 0.05 end if !! An estimate of Critical shear stress if it is not given (N/m^2) -!! Critical shear stress based on silt and clay % -!! Critical Shear Stress based on Julian and Torres (2005) +!! Critical shear stress based on silt and clay % +!! Critical Shear Stress based on Julian and Torres (2005) !! Units of critical shear stress (N/m^2) - SC = 0. - if (ch_sed(ised)%tc_bnk <= 1.e-6) then - SC = (ch(irch)%bnk_sil + ch(irch)%bnk_cla) * 100. + SC = 0. + if (ch_sed(ised)%tc_bnk <= 1.e-6) then + SC = (ch(irch)%bnk_sil + ch(irch)%bnk_cla) * 100. ch_sed(ised)%tc_bnk = (0.1 + (0.1779*SC) + (0.0028*(SC)**2) & - ((2.34E-05)*(SC)**3)) * ch_sed(ised)%cov1 end if - if (ch_sed(ised)%tc_bed <= 1.e-6) then - SC = (ch(irch)%bed_sil + ch(irch)%bed_cla) * 100. + if (ch_sed(ised)%tc_bed <= 1.e-6) then + SC = (ch(irch)%bed_sil + ch(irch)%bed_cla) * 100. ch_sed(ised)%tc_bed = (0.1 + (0.1779*SC) + (0.0028*(SC)**2) & - ((2.34E-05)*(SC)**3)) * ch_sed(ised)%cov2 end if diff --git a/src/ch_pathogen_output.f90 b/src/ch_pathogen_output.f90 index e434f29..89706ba 100644 --- a/src/ch_pathogen_output.f90 +++ b/src/ch_pathogen_output.f90 @@ -98,9 +98,9 @@ subroutine ch_pathogen_output(ihru) return 100 format (4i6,2i8,2x,a,28f12.3) -101 format (4i6,2i8,2x,a,20f12.3) -102 format (4i6,2i8,2x,a,20f12.3) -103 format (2i6,i8,4x,a,5x,f12.3) -104 format (4i6,2i8,2x,a,27f18.3) +!*** tu Wunused-label: 101 format (4i6,2i8,2x,a,20f12.3) +!*** tu Wunused-label: 102 format (4i6,2i8,2x,a,20f12.3) +!*** tu Wunused-label: 103 format (2i6,i8,4x,a,5x,f12.3) +!*** tu Wunused-label: 104 format (4i6,2i8,2x,a,27f18.3) end subroutine ch_pathogen_output \ No newline at end of file diff --git a/src/ch_read_elements.f90 b/src/ch_read_elements.f90 index d0a6ba7..f2a6af7 100644 --- a/src/ch_read_elements.f90 +++ b/src/ch_read_elements.f90 @@ -74,7 +74,7 @@ subroutine ch_read_elements db_mx%cha_reg = mreg end do - end if + end if !! setting up regions for channel soft cal and/or output by order inquire (file=in_regs%def_cha_reg, exist=i_exist) @@ -118,7 +118,7 @@ subroutine ch_read_elements db_mx%cha_reg = mreg end do - end if + end if !! if no regions are input, don"t need elements if (mreg > 0) then diff --git a/src/ch_read_sed.f90 b/src/ch_read_sed.f90 index 6b66358..b57b597 100644 --- a/src/ch_read_sed.f90 +++ b/src/ch_read_sed.f90 @@ -66,13 +66,13 @@ subroutine ch_read_sed if (ch_sed(ich)%cov2 <= 0.0) ch_sed(ich)%cov2 = 0.0 if (ch_sed(ich)%cov1 >= 1.0) ch_sed(ich)%cov1 = 1.0 if (ch_sed(ich)%cov2 >= 1.0) ch_sed(ich)%cov2 = 1.0 - else + else if (ch_sed(ich)%cov1 <= 0.0) ch_sed(ich)%cov1 = 1.0 if (ch_sed(ich)%cov2 <= 0.0) ch_sed(ich)%cov2 = 1.0 if (ch_sed(ich)%cov1 >= 25.) ch_sed(ich)%cov1 = 25. if (ch_sed(ich)%cov2 >= 25.) ch_sed(ich)%cov2 = 25. - end if - + end if + !! Bank material is assumed to be silt type partcile if not given. if (ch_sed(ich)%bnk_d50 <= 1.e-6) ch_sed(ich)%bnk_d50 = 50. !! Units are in Micrometer @@ -83,31 +83,31 @@ subroutine ch_read_sed if (ch_sed(ich)%bed_d50 > 10000) ch_sed(ich)%bed_d50 = 10000. !! Bulk density of channel bank sediment - if (ch_sed(ich)%bnk_bd <= 1.e-6) ch_sed(ich)%bnk_bd = 1.40 !! Silty loam bank + if (ch_sed(ich)%bnk_bd <= 1.e-6) ch_sed(ich)%bnk_bd = 1.40 !! Silty loam bank !! Bulk density of channel bed sediment - if (ch_sed(ich)%bed_bd <= 1.e-6) ch_sed(ich)%bed_bd = 1.50 !! Sandy loam bed + if (ch_sed(ich)%bed_bd <= 1.e-6) ch_sed(ich)%bed_bd = 1.50 !! Sandy loam bed !! An estimate of channel bank erodibility coefficient from jet test if it is not available !! Units of kd is (cm^3/N/s) !! Base on Hanson and Simon, 2001 if (ch_sed(ich)%bnk_kd <= 1.e-6) then - if (ch_sed(ich)%tc_bnk <= 1.e-6) then - ch_sed(ich)%bnk_kd = 0.2 - else + if (ch_sed(ich)%tc_bnk <= 1.e-6) then + ch_sed(ich)%bnk_kd = 0.2 + else ch_sed(ich)%bnk_kd = 0.2 / sqrt(ch_sed(ich)%tc_bnk) - end if - end if + end if + end if !! An estimate of channel bed erodibility coefficient from jet test if it is not available !! Units of kd is (cm^3/N/s) !! Base on Hanson and Simon, 2001 if (ch_sed(ich)%bed_kd <= 1.e-6) then - if (ch_sed(ich)%tc_bed <= 1.e-6) then - ch_sed(ich)%bed_kd = 0.2 - else + if (ch_sed(ich)%tc_bed <= 1.e-6) then + ch_sed(ich)%bed_kd = 0.2 + else ch_sed(ich)%bed_kd = 0.2 / sqrt(ch_sed(ich)%tc_bed) - end if + end if end if sumerod = 0. diff --git a/src/ch_rtday.f90 b/src/ch_rtday.f90 index 7eac0d3..050a6c1 100644 --- a/src/ch_rtday.f90 +++ b/src/ch_rtday.f90 @@ -101,15 +101,15 @@ subroutine ch_rtday !! Find maximum flow capacity of the channel at bank full c = ch_hyd(jhyd)%side - p = ch_vel(jrch)%wid_btm + 2. * ch_hyd(jhyd)%d * Sqrt(1. + c * c) - rh = ch_vel(jrch)%area / p - maxrt = Qman(ch_vel(jrch)%area, rh, ch_hyd(jhyd)%n, ch_hyd(jhyd)%s) + p = ch_vel(jrch)%wid_btm + 2. * ch_hyd(jhyd)%d * Sqrt(1. + c * c) + rh = ch_vel(jrch)%area / p + maxrt = Qman(ch_vel(jrch)%area, rh, ch_hyd(jhyd)%n, ch_hyd(jhyd)%s) sdti = 0. - rchdep = 0. - p = 0. - rh = 0. - vc = 0. + rchdep = 0. + p = 0. + rh = 0. + vc = 0. ch(jrch)%chfloodvol = 0. !! If average flowrate is greater than than the channel capacity at bank full @@ -139,44 +139,44 @@ subroutine ch_rtday end if if (volrt > maxrt) then - rcharea = ch_vel(jrch)%area - rchdep = ch_hyd(jhyd)%d - p = ch_vel(jrch)%wid_btm + 2. * ch_hyd(jhyd)%d * Sqrt(1. + c * c) - rh = ch_vel(jrch)%area / p - sdti = maxrt - adddep = 0 - !! find the crossectional area and depth for volrt - !! by iteration method at 1cm interval depth - !! find the depth until the discharge rate is equal to volrt + rcharea = ch_vel(jrch)%area + rchdep = ch_hyd(jhyd)%d + p = ch_vel(jrch)%wid_btm + 2. * ch_hyd(jhyd)%d * Sqrt(1. + c * c) + rh = ch_vel(jrch)%area / p + sdti = maxrt + adddep = 0 + !! find the crossectional area and depth for volrt + !! by iteration method at 1cm interval depth + !! find the depth until the discharge rate is equal to volrt itermx = 0 - Do While (sdti < volrt) + Do While (sdti < volrt) adddep = adddep + 0.01 addarea = rcharea + ((ch_hyd(jhyd)%w * 5) + 4 * adddep) * adddep addp = p + (ch_hyd(jhyd)%w * 4) + 2. * adddep * Sqrt(1. + 4 * 4) - rh = addarea / addp + rh = addarea / addp sdti = Qman(addarea, rh, ch_hyd(jhyd)%n, ch_hyd(jhyd)%s) itermx = itermx + 1 if (itermx > 100) exit - end do - rcharea = addarea - rchdep = ch_hyd(jhyd)%d + adddep - p = addp - sdti = volrt + end do + rcharea = addarea + rchdep = ch_hyd(jhyd)%d + adddep + p = addp + sdti = volrt ! store floodplain water that can be used by riparian HRU"s - else - !! find the crossectional area and depth for volrt - !! by iteration method at 1cm interval depth - !! find the depth until the discharge rate is equal to volrt - Do While (sdti < volrt) - rchdep = rchdep + 0.01 - rcharea = (ch_vel(jrch)%wid_btm + c * rchdep) * rchdep - p = ch_vel(jrch)%wid_btm + 2. * rchdep * Sqrt(1. + c * c) - rh = rcharea / p + else + !! find the crossectional area and depth for volrt + !! by iteration method at 1cm interval depth + !! find the depth until the discharge rate is equal to volrt + Do While (sdti < volrt) + rchdep = rchdep + 0.01 + rcharea = (ch_vel(jrch)%wid_btm + c * rchdep) * rchdep + p = ch_vel(jrch)%wid_btm + 2. * rchdep * Sqrt(1. + c * c) + rh = rcharea / p sdti = Qman(rcharea, rh, ch_hyd(jhyd)%n, ch_hyd(jhyd)%s) - end do - sdti = volrt - end if + end do + sdti = volrt + end if !! calculate top width of channel at water level topw = 0. @@ -193,9 +193,9 @@ subroutine ch_rtday if (sdti > 0.) then !! calculate velocity and travel time - vc = sdti / rcharea + vc = sdti / rcharea ch(jrch)%vel_chan = vc - rttime = ch_hyd(jhyd)%l * 1000. / (3600. * vc) + rttime = ch_hyd(jhyd)%l * 1000. / (3600. * vc) !! calculate volume of water leaving reach on day scoef = 2. * det / (2. * rttime + det) @@ -217,77 +217,77 @@ subroutine ch_rtday !! channel storage and from volume flowing out !! calculate transmission losses - rttlc = 0. + rttlc = 0. - if (rtwtr > 0.) then + if (rtwtr > 0.) then - !! Total time in hours to clear the water + !! Total time in hours to clear the water rttlc = det * ch_hyd(jhyd)%k * ch_hyd(jhyd)%l * p - if (ch(jrch)%rchstor <= rttlc) then - rttlc1 = min(rttlc, ch(jrch)%rchstor) - ch(jrch)%rchstor = ch(jrch)%rchstor - rttlc1 - rttlc2 = rttlc - rttlc1 - if (rtwtr <= rttlc2) then - rttlc2 = min(rttlc2, rtwtr) - rtwtr = rtwtr - rttlc2 - else - rtwtr = rtwtr - rttlc2 + if (ch(jrch)%rchstor <= rttlc) then + rttlc1 = min(rttlc, ch(jrch)%rchstor) + ch(jrch)%rchstor = ch(jrch)%rchstor - rttlc1 + rttlc2 = rttlc - rttlc1 + if (rtwtr <= rttlc2) then + rttlc2 = min(rttlc2, rtwtr) + rtwtr = rtwtr - rttlc2 + else + rtwtr = rtwtr - rttlc2 end if rttlc = rttlc1 + rttlc2 - else - ch(jrch)%rchstor = ch(jrch)%rchstor - rttlc - end if + else + ch(jrch)%rchstor = ch(jrch)%rchstor - rttlc + end if end if !! calculate evaporation - rtevp = 0. + rtevp = 0. if (rtwtr > 0.) then aaa = bsn_prm%evrch * pet_ch / 1000. * rt_delt - if (rchdep <= ch_hyd(jhyd)%d) then + if (rchdep <= ch_hyd(jhyd)%d) then rtevp = aaa * ch_hyd(jhyd)%l * 1000. * topw - else - if (aaa <= (rchdep - ch_hyd(jhyd)%d)) then + else + if (aaa <= (rchdep - ch_hyd(jhyd)%d)) then rtevp = aaa * ch_hyd(jhyd)%l * 1000. * topw - else - rtevp = (rchdep - ch_hyd(jhyd)%d) - rtevp = rtevp + (aaa - (rchdep - ch_hyd(jhyd)%d)) + else + rtevp = (rchdep - ch_hyd(jhyd)%d) + rtevp = rtevp + (aaa - (rchdep - ch_hyd(jhyd)%d)) topw = ch_vel(jrch)%wid_btm + 2. * ch_hyd(jhyd)%d * c - rtevp = rtevp * ch_hyd(jhyd)%l * 1000. * topw - end if - end if + rtevp = rtevp * ch_hyd(jhyd)%l * 1000. * topw + end if + end if - rtevp2 = rtevp * ch(jrch)%rchstor / (rtwtr + ch(jrch)%rchstor) + rtevp2 = rtevp * ch(jrch)%rchstor / (rtwtr + ch(jrch)%rchstor) - if (ch(jrch)%rchstor <= rtevp2) then - rtevp2 = min(rtevp2, ch(jrch)%rchstor) - ch(jrch)%rchstor = ch(jrch)%rchstor - rtevp2 - rtevp1 = rtevp - rtevp2 - if (rtwtr <= rtevp1) then - rtevp1 = min(rtevp1, rtwtr) - rtwtr = rtwtr - rtevp1 - else - rtwtr = rtwtr - rtevp1 - end if - else - ch(jrch)%rchstor = ch(jrch)%rchstor - rtevp2 - rtevp1 = rtevp - rtevp2 - if (rtwtr <= rtevp1) then - rtevp1 = min(rtevp1, rtwtr) - rtwtr = rtwtr - rtevp1 - else - rtwtr = rtwtr - rtevp1 - end if - end if - rtevp = rtevp1 + rtevp2 + if (ch(jrch)%rchstor <= rtevp2) then + rtevp2 = min(rtevp2, ch(jrch)%rchstor) + ch(jrch)%rchstor = ch(jrch)%rchstor - rtevp2 + rtevp1 = rtevp - rtevp2 + if (rtwtr <= rtevp1) then + rtevp1 = min(rtevp1, rtwtr) + rtwtr = rtwtr - rtevp1 + else + rtwtr = rtwtr - rtevp1 + end if + else + ch(jrch)%rchstor = ch(jrch)%rchstor - rtevp2 + rtevp1 = rtevp - rtevp2 + if (rtwtr <= rtevp1) then + rtevp1 = min(rtevp1, rtwtr) + rtwtr = rtwtr - rtevp1 + else + rtwtr = rtwtr - rtevp1 + end if + end if + rtevp = rtevp1 + rtevp2 end if else rtwtr = 0. sdti = 0. - ch(jrch)%rchstor = 0. - ch(jrch)%vel_chan = 0. + ch(jrch)%rchstor = 0. + ch(jrch)%vel_chan = 0. ch(jrch)%flwin = 0. ch(jrch)%flwout = 0. end if diff --git a/src/ch_rthr.f90 b/src/ch_rthr.f90 index 5c2f5b1..6ede8b5 100644 --- a/src/ch_rthr.f90 +++ b/src/ch_rthr.f90 @@ -3,7 +3,7 @@ subroutine ch_rthr !! ~ ~ ~ PURPOSE ~ ~ ~ !! This subroutine routes flow at any required time step through the reach !! using a constant storage coefficient -!! Routing method: Variable Storage routing +!! Routing method: Variable Storage routing !! ~ ~ ~ INCOMING VARIABLES ~ ~ ~ !! name |units |definition @@ -34,7 +34,7 @@ subroutine ch_rthr !! subroutine developed by A. Van Griensven, !! Hydrology-Vrije Universiteit Brussel, Belgium -!! Modified by Jeahak Jeong, Blackland Research, Temple, USA +!! Modified by Jeahak Jeong, Blackland Research, Temple, USA use basin_module use climate_module diff --git a/src/ch_rtmusk.f90 b/src/ch_rtmusk.f90 index c2b2a0e..6ebac06 100644 --- a/src/ch_rtmusk.f90 +++ b/src/ch_rtmusk.f90 @@ -151,7 +151,7 @@ subroutine ch_rtmusk !! Muskingum flood routing method outflo = sd_ch(jrch)%msk%c1 * inflo + sd_ch(jrch)%msk%c2 * sd_ch(jrch)%in1_vol + & sd_ch(jrch)%msk%c3 * sd_ch(jrch)%out1_vol - outflo = Min (outflo, tot_stor(jrch)%flo) + outflo = Min (outflo, tot_stor(jrch)%flo) outflo = Max (outflo, 0.) !! save inflow/outflow volumes for next time step (and day) for Muskingum @@ -161,6 +161,7 @@ subroutine ch_rtmusk !! Variable Storage Coefficent method - sc=2*dt/(2*ttime+dt) - ttime=(in2+out1)/2 scoef = dthr / (ch_rcurv(jrch)%in2%ttime + ch_rcurv(jrch)%out1%ttime + dthr) + scoef = bsn_prm%scoef * 2. * dthr / (2.* ch_rcurv(jrch)%out1%ttime + dthr) !***jga scoef = Min (scoef, 1.) outflo = scoef * tot_stor(jrch)%flo end if diff --git a/src/ch_rtpath.f90 b/src/ch_rtpath.f90 index b6b815d..c458a69 100644 --- a/src/ch_rtpath.f90 +++ b/src/ch_rtpath.f90 @@ -89,9 +89,9 @@ subroutine ch_rtpath !! new concentration netwtr = ob(icmd)%hin%flo + rchwtr - - !! change made by CS while running region 4; date 2 jan 2006 - if (path_tot < 1.e-6) path_tot = 0.0 + + !! change made by CS while running region 4; date 2 jan 2006 + if (path_tot < 1.e-6) path_tot = 0.0 if (netwtr >= 1.) then ch_water(jrch)%path(ipath) = path_tot / netwtr else diff --git a/src/ch_rtpest.f90 b/src/ch_rtpest.f90 index f039a51..c017659 100644 --- a/src/ch_rtpest.f90 +++ b/src/ch_rtpest.f90 @@ -160,7 +160,7 @@ subroutine ch_rtpest !! calculate amount of pesticide that undergoes chemical or biological degradation on day in reach pest_init = chpstmass if (pest_init > 1.e-12) then - pest_end = chpstmass * (pestcp(jpst)%decay_a * tday) + pest_end = chpstmass * (pestcp(jpst)%decay_a ** tday) chpstmass = pest_end chpst%pest(ipest)%react = pest_init - pest_end !! add decay to daughter pesticides diff --git a/src/ch_watqual4.f90 b/src/ch_watqual4.f90 index a80a79e..9a78b56 100644 --- a/src/ch_watqual4.f90 +++ b/src/ch_watqual4.f90 @@ -105,16 +105,6 @@ subroutine ch_watqual4 ht3%cbod = 1000. * ht1%cbod / ht1%flo ht3%dox = 1000. * ht1%dox / ht1%flo - !! ht5 is concentration from previous time step - ht5%orgn = 1000. * ob(icmd)%conc_prev%orgn / ht1%flo - ht5%sedp = 1000. * ob(icmd)%conc_prev%sedp / ht1%flo - ht5%no3 = 1000. * ob(icmd)%conc_prev%no3 / ht1%flo - ht5%solp = 1000. * ob(icmd)%conc_prev%solp / ht1%flo - ht5%chla = 1000. * ob(icmd)%conc_prev%chla / ht1%flo - ht5%nh3 = 1000. * ob(icmd)%conc_prev%nh3 / ht1%flo - ht5%no2 = 1000. * ob(icmd)%conc_prev%no2 / ht1%flo - ht5%cbod = 1000. * ob(icmd)%conc_prev%cbod / ht1%flo - ht5%dox = 1000. * ob(icmd)%conc_prev%dox / ht1%flo !! calculate temperature in stream Stefan and Preudhomme. 1993. Stream temperature estimation !! from air temperature. Water Res. Bull. p. 27-45 SWAT manual equation 2.3.13 @@ -123,6 +113,7 @@ subroutine ch_watqual4 ht2%temp = wtmp !! benthic sources/losses in mg + !ch_nut(jnut)%rs2 = 5. !!***jga rs2_s = Theta(ch_nut(jnut)%rs2,thrs2,wtmp) * ben_area !ch_hyd(jhyd)%l *ch_hyd(jhyd)%w * rt_delt rs3_s = Theta(ch_nut(jnut)%rs3,thrs3,wtmp) * ben_area !ch_hyd(jhyd)%l *ch_hyd(jhyd)%w * rt_delt rk4_s = Theta(ch_nut(jnut)%rk4,thrk4,wtmp) * ben_area !ch_hyd(jhyd)%l *ch_hyd(jhyd)%w * rt_delt @@ -192,6 +183,7 @@ subroutine ch_watqual4 (ch_nut(jnut)%k_l + algi * (Exp(-lambda * rchdep)))) fll = 0.92 * (wgn_pms(iwgn)%daylth / 24.) * fl_1 + !ch_nut(jnut)%mumax = 3. !***jga !! calculcate local algal growth rate if (algcon < 5000.) then select case (ch_nut(jnut)%igropt) @@ -244,13 +236,13 @@ subroutine ch_watqual4 cbodo = min (ht3%cbod, ht3%dox) cbodoin = min (ht3%cbod, ht3%dox) rk1_k = -Theta (ch_nut(jnut)%rk1, thrk1,wtmp) - rk1_m = wq_k2m (tday, rt_delt, rk1_k, ht5%cbod, ht3%cbod) + rk1_m = wq_k2m (tday, rt_delt, rk1_k, ht3%cbod, ht3%cbod) !! calculate corresponding m-term rk3_k=0. if (rchdep > 0.001) rk3_k = -Theta (ch_nut(jnut)%rk3, thrk3, wtmp) / rchdep factm = rk1_m factk = rk3_k - ht3%cbod = wq_semianalyt (tday, rt_delt, factm, factk, ht5%cbod, ht3%cbod) + ht3%cbod = wq_semianalyt (tday, rt_delt, factm, factk, ht3%cbod, ht3%cbod) !! nitrogen calculations !! calculate organic N concentration at end of day @@ -262,10 +254,10 @@ subroutine ch_watqual4 rs4_k = 0. if (rchdep > 0.001) rs4_k = Theta (ch_nut(jnut)%rs4, thrs4, wtmp) / rchdep - bc3_m = wq_k2m (tday, rt_delt, -bc3_k, ht5%orgn, ht3%orgn) + bc3_m = wq_k2m (tday, rt_delt, -bc3_k, ht3%orgn, ht3%orgn) factk = -rs4_k factm = bc3_m - ht3%orgn = wq_semianalyt (tday, rt_delt, factm, factk, ht5%orgn, ht3%orgn) + ht3%orgn = wq_semianalyt (tday, rt_delt, factm, factk, ht3%orgn, ht3%orgn) if (ht3%orgn <0.) ht3%orgn = 0. !! calculate dissolved oxygen concentration if reach at end of day QUAL2E section 3.6 equation III-28 @@ -277,10 +269,10 @@ subroutine ch_watqual4 factk = - rk2_k bc2_k = -Theta (ch_nut(jnut)%bc2, thbc2, wtmp) - bc1_m = wq_k2m (tday, rt_delt, factk, ht5%nh3, ammoin) - bc2_m = wq_k2m (tday, rt_delt, bc2_k, ht5%no2, ht3%no2) + bc1_m = wq_k2m (tday, rt_delt, factk, ht3%nh3, ammoin) + bc2_m = wq_k2m (tday, rt_delt, bc2_k, ht3%no2, ht3%no2) factm = rk1_m + rk2_m - rs4_k + bc1_m * ch_nut(jnut)%ai5 + bc2_m * ch_nut(jnut)%ai6 - ht3%dox = wq_semianalyt (tday, rt_delt, factm, factk, ht5%dox, ht3%dox) + ht3%dox = wq_semianalyt (tday, rt_delt, factm, factk, ht3%dox, ht3%dox) if (ht3%dox <0.) ht3%dox = 0. !! end oxygen calculations @@ -288,53 +280,52 @@ subroutine ch_watqual4 !! calculate ammonia nitrogen concentration at end of day QUAL2E section 3.3.2 equation III-17 factk = -bc1_k factm = bc1_m - bc3_m - ht3%nh3 = wq_semianalyt (tday, rt_delt, factm, 0., ht5%nh3, ammoin) + ht3%nh3 = wq_semianalyt (tday, rt_delt, factm, 0., ht3%nh3, ammoin) if (ht3%nh3 < 1.e-6) ht3%nh3 = 0. !! calculate concentration of nitrite at end of day QUAL2E section 3.3.3 equation III-19 factm = -bc1_m + bc2_m - ht3%no2 = wq_semianalyt (tday, rt_delt, factm, 0., ht5%no2, ht3%no2) + ht3%no2 = wq_semianalyt (tday, rt_delt, factm, 0., ht3%no2, ht3%no2) if (ht3%no2 < 1.e-6) ht3%no2 = 0. !! calculate nitrate concentration at end of day QUAL2E section 3.3.4 equation III-20 factk = 0. factm = -bc2_m - ht3%no3 = wq_semianalyt (tday, rt_delt, factm, 0., ht5%no3, ht3%no3) + ht3%no3 = wq_semianalyt (tday, rt_delt, factm, 0., ht3%no3, ht3%no3) if (ht3%no3 < 1.e-6) ht3%no3 = 0. !! end nitrogen calculations !! phosphorus calculations !! calculate organic phosphorus concentration at end of day QUAL2E section 3.3.6 equation III-24 bc4_k = Theta (ch_nut(jnut)%bc4, thbc4,wtmp) - bc4_m = wq_k2m (tday, rt_delt, -bc4_k, ht5%sedp, ht3%sedp) + bc4_m = wq_k2m (tday, rt_delt, -bc4_k, ht3%sedp, ht3%sedp) rs5_k = 0. + !ch_nut(jnut)%rs5 = 0. ! ***jga if (rchdep > 0.001) rs5_k = Theta (ch_nut(jnut)%rs5, thrs5, wtmp) / rchdep factk = -rs5_k factm = bc4_m - ht3%sedp = wq_semianalyt (tday, rt_delt, factm, factk, ht5%sedp, ht3%sedp) + ht3%sedp = wq_semianalyt (tday, rt_delt, factm, factk, ht3%sedp, ht3%sedp) if (ht3%sedp < 1.e-6) ht3%sedp = 0. + !! calculate dissolved phosphorus concentration at end of day QUAL2E section 3.4.2 equation III-25 + !factk = 0. + !factm = -bc4_m + ch_nut(jnut)%ai2 * alg_m + !ht3%solp = wq_semianalyt (tday, rt_delt, factm, 0., ht3%solp, dispin) + !if (ht3%solp < 1.e-6) ht3%solp = 0. !! calculate dissolved phosphorus concentration at end of day QUAL2E section 3.4.2 equation III-25 factk = 0. factm = -bc4_m + ch_nut(jnut)%ai2 * alg_m - ht3%solp = wq_semianalyt (tday, rt_delt, factm, 0., ht5%solp, dispin) + !ht3%solp = wq_semianalyt (tday, rt_delt, factm, 0., ht5%solp, dispin) + xx = Theta (ch_nut(jnut)%bc4, thbc4,wtmp) * ht3%sedp + yy = Theta(ch_nut(jnut)%rs2, thrs2, wtmp) / (sd_chd(jrch)%chd) + zz = ch_nut(jnut)%ai2 * Theta(gra,thgra,wtmp) * algin + ht3%solp = ht3%solp + (xx + yy - zz) * tday if (ht3%solp < 1.e-6) ht3%solp = 0. !! end phosphorus calculations - !! save concentration for next time step - ob(icmd)%conc_prev%orgn = ht3%orgn * ht1%flo / 1000. - ob(icmd)%conc_prev%sedp = ht3%sedp * ht1%flo / 1000. - ob(icmd)%conc_prev%no3 = ht3%no3 * ht1%flo / 1000. - ob(icmd)%conc_prev%solp = ht3%solp * ht1%flo / 1000. - ob(icmd)%conc_prev%chla = ht3%chla * ht1%flo / 1000. - ob(icmd)%conc_prev%nh3 = ht3%nh3 * ht1%flo / 1000. - ob(icmd)%conc_prev%no2 = ht3%no2 * ht1%flo / 1000. - ob(icmd)%conc_prev%cbod = ht3%cbod * ht1%flo / 1000. - ob(icmd)%conc_prev%dox = ht3%dox * ht1%flo / 1000. - !! convert back from concentration to mass for routing ht2%orgn = ht3%orgn * ht1%flo / 1000. ht2%sedp = ht3%sedp * ht1%flo / 1000. diff --git a/src/channel_control.f90 b/src/channel_control.f90 index 3d8cb7e..97ff681 100644 --- a/src/channel_control.f90 +++ b/src/channel_control.f90 @@ -95,25 +95,25 @@ subroutine channel_control ch(jrch)%dep_chan = 0. sedrch = 0. rch_san = 0. - rch_cla = 0. rch_sil = 0. + rch_cla = 0. rch_sag = 0. - rch_gra = 0. rch_lag = 0. + rch_gra = 0. wtrin = 0. - algin = 0. chlin = 0. + algin = 0. orgnin = 0. - nitritin = 0. ammoin = 0. + nitritin = 0. nitratin = 0. orgpin = 0. dispin = 0. cbodin = 0. disoxin = 0. + cinn = 0. !! route water through reach rtwtr_d=0. - cinn = 0. rttlc_d=0. rtevp_d =0. @@ -186,16 +186,16 @@ subroutine channel_control !! Channel Deposition (Only new deposits during the current time step) if (ch(jrch)%depch >= ch(jrch)%depprch) then - ch_d(jrch)%ch_dep = ch(jrch)%depch - ch(jrch)%depprch - else - ch_d(jrch)%ch_dep = 0. - end if + ch_d(jrch)%ch_dep = ch(jrch)%depch - ch(jrch)%depprch + else + ch_d(jrch)%ch_dep = 0. + end if !! Floodplain Deposition (Only new deposits during the current time step) if (ch(jrch)%depfp >= ch(jrch)%depprfp) then - ch_d(jrch)%fp_dep = ch(jrch)%depfp - ch(jrch)%depprfp - else - ch_d(jrch)%fp_dep = 0. - end if + ch_d(jrch)%fp_dep = ch(jrch)%depfp - ch(jrch)%depprfp + else + ch_d(jrch)%fp_dep = 0. + end if !! Total suspended sediments (only silt and clay) if (ch_sed(jsed)%eqn == 0) then ch_d(jrch)%tot_ssed = sedrch diff --git a/src/cli_precip_control.f90 b/src/cli_precip_control.f90 index 6c90e3d..2582759 100644 --- a/src/cli_precip_control.f90 +++ b/src/cli_precip_control.f90 @@ -89,16 +89,16 @@ subroutine cli_precip_control (istart) do ist = 1, time%step wst(iwst)%weat%ts_next(ist) = pcp(ipg)%tss(ist,cur_day,time%yrs) if (wst(iwst)%weat%ts_next(ist) <= -97.) then - !! simulate missing data - call cli_pgen(iwgn) - call cli_pgenhr - exit - end if - wst(iwst)%weat%precip_next = wst(iwst)%weat%precip_next + wst(iwst)%weat%ts_next(ist) + !! simulate missing data + call cli_pgen(iwgn) + call cli_pgenhr + exit + end if + wst(iwst)%weat%precip_next = wst(iwst)%weat%precip_next + wst(iwst)%weat%ts_next(ist) end do wst(iwst)%weat%precip_next = sum (pcp(ipg)%tss(:,cur_day,time%yrs)) else - !! daily precip + !! daily precip if (out_bounds == "y") then wst(iwst)%weat%precip_next = -98. else @@ -109,7 +109,7 @@ subroutine cli_precip_control (istart) if (wst(iwst)%weat%precip_next <= -97.) then call cli_pgen(iwgn) pcp(ipg)%days_gen = pcp(ipg)%days_gen + 1 - end if + end if end if end if diff --git a/src/cli_read_atmodep_cs.f90 b/src/cli_read_atmodep_cs.f90 index 2322c97..f5ddfe2 100644 --- a/src/cli_read_atmodep_cs.f90 +++ b/src/cli_read_atmodep_cs.f90 @@ -79,7 +79,7 @@ subroutine cli_read_atmodep_cs read(5050,*) (atmodep_cs(iadep)%cs(ics)%drymo(imo),imo=1,atmodep_cont%num) enddo end if - + !yearly values if (atmodep_cont%timestep == "yr") then read(5050,*) station_name !station name diff --git a/src/cli_read_atmodep_salt.f90 b/src/cli_read_atmodep_salt.f90 index 50000d0..83c3e74 100644 --- a/src/cli_read_atmodep_salt.f90 +++ b/src/cli_read_atmodep_salt.f90 @@ -77,7 +77,7 @@ subroutine cli_read_atmodep_salt read(5050,*) salt_ion,(atmodep_salt(iadep)%salt(isalt)%drymo(imo),imo=1,atmodep_cont%num) enddo end if - + !yearly values if (atmodep_cont%timestep == "yr") then read(5050,*) station_name !station name diff --git a/src/climate_control.f90 b/src/climate_control.f90 index 889e258..48c4210 100644 --- a/src/climate_control.f90 +++ b/src/climate_control.f90 @@ -211,9 +211,9 @@ subroutine climate_control xl = 2.501 - 2.361e-3 * wst(iwst)%weat%tave wst(iwst)%weat%pet = .0023 * (ramm / xl) * (wst(iwst)%weat%tave & + 17.8) * (wst(iwst)%weat%tmax - wst(iwst)%weat%tmin) ** 0.5 - wst(iwst)%weat%pet = Max(0., wst(iwst)%weat%pet) + wst(iwst)%weat%pet = Max(0.01, wst(iwst)%weat%pet) else - wst(iwst)%weat%pet = 0. + wst(iwst)%weat%pet = 0.01 endif if (wst(iwst)%weat%pet > 0.1) then wst(iwst)%weat%ppet = wst(iwst)%weat%ppet + wst(iwst)%weat%precip / wst(iwst)%weat%pet diff --git a/src/climate_module.f90 b/src/climate_module.f90 index 6670016..43c5fbb 100644 --- a/src/climate_module.f90 +++ b/src/climate_module.f90 @@ -120,7 +120,7 @@ module climate_module character (len=50) :: sgage = "" !! gage name for solar radiation character (len=50) :: hgage = "" !! gage name for relative humidity character (len=50) :: wgage = "" !! gage name for windspeed - character (len=50) :: petgage = "" !! name of pet gage ? + character (len=50) :: petgage = "" !! name of pet gage character (len=50) :: atmodep = "" !! atmospheric depostion data file locator end type weather_codes_station_char diff --git a/src/command.f90 b/src/command.f90 index a1e5be6..ff8402a 100644 --- a/src/command.f90 +++ b/src/command.f90 @@ -112,6 +112,11 @@ subroutine command if (cs_db%num_tot > 0 .and. obcs_alloc(icmd).eq.1) then obcs(icmd)%hin_sur(1) = obcs(icmd)%hin_sur(1) + frac_in * obcs(iob)%hd(3) end if + ! add to tile flow + ob(icmd)%hin_til = ob(icmd)%hin_til + frac_in * ob(iob)%hd(5) + if (cs_db%num_tot > 0 .and. obcs_alloc(icmd).eq.1) then + obcs(icmd)%hin_til(1) = obcs(icmd)%hin_til(1) + frac_in * obcs(iob)%hd(5) + end if ! add to lateral soil runon ob(icmd)%hin_lat = ob(icmd)%hin_lat + frac_in * ob(iob)%hd(4) if (cs_db%num_tot > 0 .and. obcs_alloc(icmd).eq.1) then @@ -618,7 +623,7 @@ subroutine command enddo 102 format(i6,11x,i3,8x,i5,5x,1000(f16.4)) -103 format(4i6,2i8,2x,a,35f12.3) +!*** tu Wunused-label: 103 format(4i6,2i8,2x,a,35f12.3) return diff --git a/src/conditional_module.f90 b/src/conditional_module.f90 index 523f2c7..c5241b6 100644 --- a/src/conditional_module.f90 +++ b/src/conditional_module.f90 @@ -18,7 +18,7 @@ module conditional_module character(len=25) :: ob = "" ! object variable (ie res, hru, canal, etc) integer :: ob_num = 0 ! object number character(len=25) :: name = "" ! name of action - character(len=25) :: option = "" ! action option - specific to type of action (ie for reservoir, option to + character(len=40) :: option = "" ! action option - specific to type of action (ie for reservoir, option to ! input rate, days of drawdown, weir equation pointer, etc real :: const = 0. ! constant used for rate, days, etc real :: const2 = 1 ! additional constant used for rate, days, etc @@ -33,6 +33,7 @@ module conditional_module type (conditions_var), dimension(:), allocatable :: cond ! conditions character(len=25), dimension(:,:), allocatable :: alt ! condition alternatives type (actions_var), dimension(:), allocatable :: act ! actions + integer, dimension(:), allocatable :: lu_chg_mx ! max times lu change can occur character(len=1), dimension(:,:), allocatable :: act_outcomes ! action outcomes ("y" to perform action; "n" to not perform) character(len=1), dimension(:), allocatable :: act_hit ! "y" if all condition alternatives (rules) are met; "n" if not integer, dimension(:), allocatable :: act_typ ! pointer to action type (ie plant, fert type, tillage implement, release type, etc) diff --git a/src/conditions.f90 b/src/conditions.f90 index 507984c..8afbdff 100644 --- a/src/conditions.f90 +++ b/src/conditions.f90 @@ -191,7 +191,7 @@ subroutine conditions (ob_cur, idtbl) ipl = Max (Int(d_tbl%cond(ic)%lim_const), 1) do ialt = 1, d_tbl%alts if (d_tbl%alt(ic,ialt) == "=") then !determine if growing (y) or not (n) - if (pcom(ob_num)%plcur(ipl)%gro /= d_tbl%cond(ic)%lim_var) then + if (pcom(ob_num)%plcur(ipl)%gro == "n") then d_tbl%act_hit(ialt) = "n" end if end if @@ -343,6 +343,12 @@ subroutine conditions (ob_cur, idtbl) ivar_tbl = int(d_tbl%cond(ic)%lim_const) call cond_integer (ic, ivar_cur, ivar_tbl) + !sequential year of simulation + case ("year_start") + ivar_cur = time%yrc_start + ivar_tbl = int(d_tbl%cond(ic)%lim_const) + call cond_integer (ic, ivar_cur, ivar_tbl) + !current years of maturity for perennial plants case ("cur_yrs_mat") ob_num = d_tbl%cond(ic)%ob_num @@ -450,12 +456,12 @@ subroutine conditions (ob_cur, idtbl) do ialt = 1, d_tbl%alts if (d_tbl%alt(ic,ialt) == "=") then - if (hru(ob_num)%tiledrain /= Int(d_tbl%cond(ic)%lim_const)) then + if (hru(ob_num)%tiledrain == 0) then d_tbl%act_hit(ialt) = "n" end if end if if (d_tbl%alt(ic,ialt) == "/") then - if (hru(ob_num)%tiledrain == Int(d_tbl%cond(ic)%lim_const)) then + if (hru(ob_num)%tiledrain == 1) then d_tbl%act_hit(ialt) = "n" end if end if @@ -643,6 +649,17 @@ subroutine conditions (ob_cur, idtbl) end if end do + !calibration group in landuse.lum - ie: cropland, urban, forest, etc + case ("cal_group") + ob_num = d_tbl%cond(ic)%ob_num + if (ob_num == 0) ob_num = ob_cur + do ialt = 1, d_tbl%alts + if (d_tbl%alt(ic,ialt) == "=") then + if (hru(ob_num)%cal_group /= d_tbl%cond(ic)%lim_var) then + d_tbl%act_hit(ialt) = "n" + end if + end if + end do !tillage system - name of tillage decision table in lum.dtl case ("tillage") ob_num = d_tbl%cond(ic)%ob_num @@ -663,7 +680,7 @@ subroutine conditions (ob_cur, idtbl) end do !plants - if plant is in the cummunity - case ("plant") + case ("plant_com") ob_num = d_tbl%cond(ic)%ob_num if (ob_num == 0) ob_num = ob_cur @@ -692,7 +709,7 @@ subroutine conditions (ob_cur, idtbl) end do !channel management - case ("ch_use") + case ("ch_order") ob_num = d_tbl%cond(ic)%ob_num if (ob_num == 0) ob_num = ob_cur @@ -724,6 +741,8 @@ subroutine conditions (ob_cur, idtbl) targ = targ_val + 10000. * d_tbl%cond(ic)%lim_const case ("-") targ = targ_val - 10000. * d_tbl%cond(ic)%lim_const !convert ha-m to m3 + case ("/") + targ = targ_val / d_tbl%cond(ic)%lim_const end select case ("evol") !emergency storage volume targ_val = res_ob(ires)%evol @@ -735,6 +754,8 @@ subroutine conditions (ob_cur, idtbl) targ = targ_val + 10000. * d_tbl%cond(ic)%lim_const case ("-") targ = targ_val - 10000. * d_tbl%cond(ic)%lim_const !convert ha-m to m3 + case ("/") + targ = targ_val / d_tbl%cond(ic)%lim_const end select end select @@ -749,20 +770,15 @@ subroutine conditions (ob_cur, idtbl) iob = sp_ob1%res + ob_num - 1 flo_m3 = ob(iob)%hin%flo / 86400. call cond_real (ic, flo_m3, d_tbl%cond(ic)%lim_const, idtbl) - - !impounded water depth -paddy average water depth of water + !impounded water depth -paddy average water depth case ("wet_depth") !determine target variable ires = d_tbl%cond(ic)%ob_num if (ires == 0) ires = ob_cur - !set limit constant if comparing to weir height - if (d_tbl%cond(ic)%lim_var == "hwater") then - targ = d_tbl%cond(ic)%lim_const/1000. !m - else - targ = wet_ob(ires)%weir_hgt - end if + !convert depth to m + targ = d_tbl%cond(ic)%lim_const/1000. !check alternatives call cond_real (ic, wet_ob(ires)%depth, targ, idtbl) @@ -773,8 +789,8 @@ subroutine conditions (ob_cur, idtbl) ires = d_tbl%cond(ic)%ob_num if (ires == 0) ires = ob_cur - !set limit constant if comparing to weir height - targ = d_tbl%cond(ic)%lim_const/1000. !m + !convert depth to m + targ = d_tbl%cond(ic)%lim_const/1000. !check alternatives call cond_real (ic, wet_ob(ires)%weir_hgt, targ, idtbl) diff --git a/src/constituent_mass_module.f90 b/src/constituent_mass_module.f90 index b77313b..41bd6a5 100644 --- a/src/constituent_mass_module.f90 +++ b/src/constituent_mass_module.f90 @@ -596,9 +596,9 @@ function hydcsout_add (hydcs1, hydcs2) result (hydcs3) integer :: ics = 0 allocate (hydcs3%pest(cs_db%num_pests), source = 0.) allocate (hydcs3%path(cs_db%num_paths), source = 0.) + allocate (hydcs3%hmet(cs_db%num_metals), source = 0.) allocate (hydcs3%salt(cs_db%num_salts), source = 0.) allocate (hydcs3%cs(cs_db%num_cs), source = 0.) - allocate (hydcs3%hmet(cs_db%num_metals), source = 0.) do ipest = 1, cs_db%num_pests hydcs3%pest(ipest) = hydcs2%pest(ipest) + hydcs1%pest(ipest) @@ -629,10 +629,10 @@ function hydcsout_mult_const (const, hydcs1) result (hydcs2) integer :: ics = 0 allocate (hydcs2%pest(cs_db%num_pests), source = 0.) allocate (hydcs2%path(cs_db%num_paths), source = 0.) + allocate (hydcs2%hmet(cs_db%num_metals), source = 0.) allocate (hydcs2%salt(cs_db%num_salts), source = 0.) - allocate (hydcs2%cs(cs_db%num_cs), source = 0.) !rtb cs - allocate (hydcs2%hmet(cs_db%num_metals), source = 0.) + allocate (hydcs2%cs(cs_db%num_cs), source = 0.) !rtb cs do ipest = 1, cs_db%num_pests hydcs2%pest(ipest) = const * hydcs1%pest(ipest) diff --git a/src/cs_balance.f90 b/src/cs_balance.f90 index 335db27..3417cce 100644 --- a/src/cs_balance.f90 +++ b/src/cs_balance.f90 @@ -682,14 +682,14 @@ subroutine cs_balance !rtb cs gwsol_ss(i)%solute(sol_index)%sorb = 0. enddo sol_index = sol_index + 1 - enddo !go to next constituent + enddo !go to next constituent endif endif 7000 format(i8,i8,i8,100e16.8) -7001 format(20e16.8) -7002 format(i8,50f16.8) +!*** tu Wunused-label: 7001 format(20e16.8) +!*** tu Wunused-label: 7002 format(i8,50f16.8) return end \ No newline at end of file diff --git a/src/cs_divert.f90 b/src/cs_divert.f90 index 4f09489..18ffe30 100644 --- a/src/cs_divert.f90 +++ b/src/cs_divert.f90 @@ -45,7 +45,7 @@ subroutine cs_divert(iwallo,idmd,dem_id) !rtb cs !determine number of water sources nsource = wallo(iwallo)%dmd(idmd)%dmd_src_obs - + !demand object type obj_type_dem = wallo(iwallo)%dmd(idmd)%rcv_ob diff --git a/src/cs_lch.f90 b/src/cs_lch.f90 index 6f1057b..e85c6a1 100644 --- a/src/cs_lch.f90 +++ b/src/cs_lch.f90 @@ -106,7 +106,7 @@ subroutine cs_lch !rtb cs ro_mass = surfq(j) * cosurfcs ro_mass = Min(ro_mass, cs_soil(j)%ly(jj)%cs(ics)) cs_soil(j)%ly(jj)%cs(ics) = cs_soil(j)%ly(jj)%cs(ics) - ro_mass - surqcs(j,ics) = ro_mass + surqcs(j,ics) = ro_mass endif !Daniel 1/2012 @@ -155,7 +155,7 @@ subroutine cs_lch !rtb cs hru_area_m2 = hru(j)%area_ha * 10000. !ha --> m2 water_volume = (soil(j)%phys(jj)%st/1000.) * hru_area_m2 if(cs_soil(j)%ly(jj)%cs(ics).lt.0) then - cs_soil(j)%ly(jj)%cs(ics) = 0. + cs_soil(j)%ly(jj)%cs(ics) = 0. endif cs_mass_kg = cs_soil(j)%ly(jj)%cs(ics) * hru(j)%area_ha !kg !calculate concentration in mg/L diff --git a/src/dtbl_scen_read.f90 b/src/dtbl_scen_read.f90 index 4926b78..3bffe2a 100644 --- a/src/dtbl_scen_read.f90 +++ b/src/dtbl_scen_read.f90 @@ -51,6 +51,8 @@ subroutine dtbl_scen_read allocate (dtbl_scen(i)%act_hit(dtbl_scen(i)%alts)) allocate (dtbl_scen(i)%act_typ(dtbl_scen(i)%acts), source = 0) allocate (dtbl_scen(i)%act_app(dtbl_scen(i)%acts), source = 0) + allocate (dtbl_scen(i)%lu_chg_mx(dtbl_scen(i)%acts), source = 0) + allocate (dtbl_scen(i)%act_outcomes(dtbl_scen(i)%acts,dtbl_scen(i)%alts)) !read conditions and condition alternatives diff --git a/src/ero_ovrsed.f90 b/src/ero_ovrsed.f90 index 658eea6..1827630 100644 --- a/src/ero_ovrsed.f90 +++ b/src/ero_ovrsed.f90 @@ -11,7 +11,7 @@ subroutine ero_ovrsed() !! hru_km(:) |km2 |area of HRU in square kilometers !! rwst(:)%weat%ts(:) |mm H2O |precipitation for the time step during the !! |day in HRU -!! eros_spl |none |coefficient of splash erosion varing 0.9-3.1 +!! eros_spl |none |coefficient of splash erosion varing 0.9-3.1 !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! ~ ~ ~ OUTGOING VARIABLES ~ ~ ~ @@ -25,8 +25,8 @@ subroutine ero_ovrsed() !! ~ ~ ~ LOCAL DEFINITIONS ~ ~ ~ !! name |units |definition !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ -!! jj |none |HRU number -!! kk |none |time step of the day +!! jj |none |HRU number +!! kk |none |time step of the day !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~ @@ -35,7 +35,7 @@ subroutine ero_ovrsed() !! ~ ~ ~ ~ ~ ~ END SPECIFICATIONS ~ ~ ~ ~ ~ ~ !! Splash erosion model is adopted from EUROSEM model developed by Morgan (2001). -!! Rill/interill erosion model is adoped from Modified ANSWERS model by Park et al.(1982) +!! Rill/interill erosion model is adoped from Modified ANSWERS model by Park et al.(1982) !! Code developed by J. Jeong and N. Kannan, BRC. use urban_data_module @@ -73,114 +73,114 @@ subroutine ero_ovrsed() real :: rintnsty = 0. !mm/hr |rainfall intensity real :: cover = 0. !kg/ha |soil cover - j = ihru - ulu = hru(j)%luse%urb_lu + j = ihru + ulu = hru(j)%luse%urb_lu !! Fraction of sand percent_clay = soil(j)%phys(1)%clay - percent_silt = soil(j)%phys(1)%silt - percent_sand = 100. - percent_clay - percent_silt + percent_silt = soil(j)%phys(1)%silt + percent_sand = 100. - percent_clay - percent_silt !! Soil detachability values adopted from EUROSEM User Guide (Table 1) - if ((percent_clay>=40.) .and. (percent_sand>=20.) .and. & + if ((percent_clay>=40.) .and. (percent_sand>=20.) .and. & (percent_sand<=45.)) then - erod_k = 2.0 !clay + erod_k = 2.0 !clay elseif ((percent_clay>=27.) .and. (percent_sand>=20.) .and. & (percent_sand<=45.)) then - erod_k = 1.7 !Clay loam + erod_k = 1.7 !Clay loam elseif ((percent_silt<=40.).and.(percent_sand<=20.)) then - erod_k = 2.0 !Clay + erod_k = 2.0 !Clay elseif ((percent_silt>40.).and.(percent_clay>=40.)) then - erod_k = 1.6 !Silty clay + erod_k = 1.6 !Silty clay elseif ((percent_clay>=35.).and.(percent_sand>=45.)) then - erod_k = 1.9 !Sandy clay + erod_k = 1.9 !Sandy clay elseif ((percent_clay>=27.).and.(percent_sand<20.)) then - erod_k = 1.6 !Silty clay loam + erod_k = 1.6 !Silty clay loam elseif ((percent_clay<=10.).and.(percent_silt>=80.)) then - erod_k = 1.2 !Silt + erod_k = 1.2 !Silt elseif (percent_silt>=50.) then - erod_k = 1.5 !Silt loam + erod_k = 1.5 !Silt loam elseif ((percent_clay>=7.) .and. (percent_sand<=52.) .and. & (percent_silt>=28.)) then - erod_k = 2.0 !Loam + erod_k = 2.0 !Loam elseif (percent_clay>=20.) then - erod_k = 2.1 !Sandy clay loam + erod_k = 2.1 !Sandy clay loam elseif (percent_clay>=percent_sand-70.) then - erod_k = 2.6 !Sandy loam + erod_k = 2.6 !Sandy loam elseif (percent_clay>=(2. * percent_sand) - 170.) then - erod_k = 3.0 !Loamy sand + erod_k = 3.0 !Loamy sand else - erod_k = 1.9 !Sand + erod_k = 1.9 !Sand end if - - !! canopy cover based on leaf area index -!! canopy cover is assumed to be 100% if LAI>=1 - if(pcom(j)%lai_sum >= 1.) then - canopy_cover = 1. - else - canopy_cover = pcom(j)%lai_sum + + !! canopy cover based on leaf area index +!! canopy cover is assumed to be 100% if LAI>=1 + if(pcom(j)%lai_sum >= 1.) then + canopy_cover = 1. + else + canopy_cover = pcom(j)%lai_sum end if if (bsn_cc%gampt > 0) then do k = 1, time%step - rintnsty = 60. * wst(iwst)%weat%ts(k) / Real(time%dtm) - rain_d50 = 0.188 * rintnsty ** 0.182 + rintnsty = 60. * wst(iwst)%weat%ts(k) / Real(time%dtm) + rain_d50 = 0.188 * rintnsty ** 0.182 - if (rintnsty > 0) then - + if (rintnsty > 0) then + !! Rainfall kinetic energy generated by direct throughfall (J/m^2/mm) - ke_direct = 8.95 + 8.44 * log10(rintnsty) + ke_direct = 8.95 + 8.44 * log10(rintnsty) if(ke_direct<0.) ke_direct = 0. - !! Rainfall kinetic energy generated by leaf drainage (J/m^2) - pheff = 0.5 * pcom(j)%cht_mx - ke_leaf = 15.8 * pheff ** 0.5 - 5.87 - if (ke_leaf<0) ke_leaf = 0. - - !! Depth of rainfall - rdepth_tot = wst(iwst)%weat%ts(k) / (time%dtm * 60.) - rdepth_leaf = rdepth_tot * canopy_cover - rdepth_direct = rdepth_tot - rdepth_leaf - else - ke_direct = 0. - ke_leaf = 0. - rdepth_tot = 0. - rdepth_leaf = 0. - rdepth_direct = 0. - endif - - !! total kinetic energy by rainfall (J/m^2) - ke_total = 0.001 * (rdepth_direct * ke_direct + rdepth_leaf * ke_leaf) - - !! total soil detachment by raindrop impact - sedspl = erod_k * ke_total * exp(-bsn_prm%eros_spl * & + !! Rainfall kinetic energy generated by leaf drainage (J/m^2) + pheff = 0.5 * pcom(j)%cht_mx + ke_leaf = 15.8 * pheff ** 0.5 - 5.87 + if (ke_leaf<0) ke_leaf = 0. + + !! Depth of rainfall + rdepth_tot = wst(iwst)%weat%ts(k) / (time%dtm * 60.) + rdepth_leaf = rdepth_tot * canopy_cover + rdepth_direct = rdepth_tot - rdepth_leaf + else + ke_direct = 0. + ke_leaf = 0. + rdepth_tot = 0. + rdepth_leaf = 0. + rdepth_direct = 0. + endif + + !! total kinetic energy by rainfall (J/m^2) + ke_total = 0.001 * (rdepth_direct * ke_direct + rdepth_leaf * ke_leaf) + + !! total soil detachment by raindrop impact + sedspl = erod_k * ke_total * exp(-bsn_prm%eros_spl * & hhqday(j,k) / 1000.) * hru(j)%km ! tons - !! Impervious area of HRU - if(hru(j)%luse%urb_lu > 0) sedspl = sedspl * (1.- urbdb(ulu)%fimp) + !! Impervious area of HRU + if(hru(j)%luse%urb_lu > 0) sedspl = sedspl * (1.- urbdb(ulu)%fimp) - !! maximum water depth that allows splash erosion - if(hhqday(j,k)>=3.* rain_d50.or.hhqday(j,k)<=1.e-3) sedspl = 0. + !! maximum water depth that allows splash erosion + if(hhqday(j,k)>=3.* rain_d50.or.hhqday(j,k)<=1.e-3) sedspl = 0. - !! Overland flow erosion + !! Overland flow erosion !! cover and management factor used in usle equation (ysed.f) cover = pl_mass(j)%ab_gr_com%m + rsd1(j)%tot_com%m - c = Exp((-.2231 - cvm_com(j)) * Exp(-.00115 * cover) + cvm_com(j)) - !! specific weight of water at 5 centigrate =9807N/m3 - bed_shear = 9807 * (hhqday(j,k) / 1000.) * hru(j)%topo%slope ! N/m2 - sedov = 11.02 * bsn_prm%rill_mult * soil(j)%ly(1)%usle_k * & + c = Exp((-.2231 - cvm_com(j)) * Exp(-.00115 * cover) + cvm_com(j)) + !! specific weight of water at 5 centigrate =9807N/m3 + bed_shear = 9807 * (hhqday(j,k) / 1000.) * hru(j)%topo%slope ! N/m2 + sedov = 11.02 * bsn_prm%rill_mult * soil(j)%ly(1)%usle_k * & bsn_prm%c_factor * c * bed_shear ** bsn_prm%eros_expo ! kg/hour/m2 - if (time%step > 1) then - sedov = 16.667 * sedov * hru(j)%km * time%dtm ! tons per time step - else - sedov = 24000. * sedov * hru(j)%km ! tons per day - end if + if (time%step > 1) then + sedov = 16.667 * sedov * hru(j)%km * time%dtm ! tons per time step + else + sedov = 24000. * sedov * hru(j)%km ! tons per day + end if - !! Impervious area of HRU - if (hru(j)%luse%urb_lu > 0) sedov = sedov * (1.- urbdb(ulu)%fimp) + !! Impervious area of HRU + if (hru(j)%luse%urb_lu > 0) sedov = sedov * (1.- urbdb(ulu)%fimp) - hhsedy(j,k) = (sedspl + sedov) - if (hhsedy(j,k) < 1.e-10) hhsedy(j,k) = 0. + hhsedy(j,k) = (sedspl + sedov) + if (hhsedy(j,k) < 1.e-10) hhsedy(j,k) = 0. end do end if diff --git a/src/exco_read_om.f90 b/src/exco_read_om.f90 index cf65aab..922a010 100644 --- a/src/exco_read_om.f90 +++ b/src/exco_read_om.f90 @@ -42,7 +42,7 @@ subroutine exco_read_om db_mx%exco_om = imax - allocate (exco(0:imax)) ! + allocate (exco(0:imax)) !! change to exco_om allocate (exco_om_num(0:imax), source = 0) allocate (exco_om_name(0:imax)) rewind (107) diff --git a/src/gwflow_chan_read.f90 b/src/gwflow_chan_read.f90 index d401284..2c6be53 100644 --- a/src/gwflow_chan_read.f90 +++ b/src/gwflow_chan_read.f90 @@ -10,7 +10,7 @@ subroutine gwflow_chan_read implicit none - character(len=8) :: col_head_con(17) = "" + character(len=20) :: col_head_con(17) = "" integer :: i = 0 integer :: j = 0 integer :: k = 0 diff --git a/src/gwflow_chem.f90 b/src/gwflow_chem.f90 index e6a081a..62b4e32 100644 --- a/src/gwflow_chem.f90 +++ b/src/gwflow_chem.f90 @@ -39,17 +39,17 @@ subroutine gwflow_chem(cell_id,gw_vol) !rtb gwflow mass_rct = 0. !no3 - mass_rct(sol_index) = gwsol_state(cell_id)%solute(sol_index)%conc * gw_vol * gwsol_rctn(sol_index) !g/day + mass_rct(sol_index) = gwsol_state(cell_id)%solute(sol_index)%conc * gw_vol * gwsol_rctn(sol_index) !g/day !p sol_index = sol_index + 1 - mass_rct(sol_index) = gwsol_state(cell_id)%solute(sol_index)%conc * gw_vol * gwsol_rctn(sol_index) !g/day + mass_rct(sol_index) = gwsol_state(cell_id)%solute(sol_index)%conc * gw_vol * gwsol_rctn(sol_index) !g/day !salt ions if (gwsol_salt == 1) then do isalt=1,cs_db%num_salts sol_index = sol_index + 1 - mass_rct(sol_index) = gwsol_state(cell_id)%solute(sol_index)%conc * gw_vol * gwsol_rctn(sol_index) !g/day + mass_rct(sol_index) = gwsol_state(cell_id)%solute(sol_index)%conc * gw_vol * gwsol_rctn(sol_index) !g/day enddo endif @@ -107,7 +107,7 @@ subroutine gwflow_chem(cell_id,gw_vol) !rtb gwflow !boron sol_index = sol_index + 1 - mass_rct(sol_index) = gwsol_state(cell_id)%solute(sol_index)%conc * gw_vol * gwsol_rctn(sol_index) !g/day + mass_rct(sol_index) = gwsol_state(cell_id)%solute(sol_index)%conc * gw_vol * gwsol_rctn(sol_index) !g/day endif !if constituents are active diff --git a/src/gwflow_module.f90 b/src/gwflow_module.f90 index d3411b5..7afabb9 100644 --- a/src/gwflow_module.f90 +++ b/src/gwflow_module.f90 @@ -146,7 +146,7 @@ module gwflow_module real, dimension (:), allocatable :: gw_delay ! | real, dimension (:), allocatable :: gw_rech ! | real, dimension (:), allocatable :: delay ! | - + !gwet: variables for groundwater evapotranspiration ----------------------------------------- integer :: gw_et_flag = 0 ! | real, dimension (:), allocatable :: etremain ! | diff --git a/src/gwflow_read.f90 b/src/gwflow_read.f90 index 9151681..a824455 100644 --- a/src/gwflow_read.f90 +++ b/src/gwflow_read.f90 @@ -323,7 +323,7 @@ subroutine gwflow_read gw_state(i)%xcrd = 0. gw_state(i)%ycrd = 0. gw_state(i)%area = 0. - gw_state(i)%init = 0. + gw_state(i)%init = 0. gw_state(i)%head = 0. gw_state(i)%hydc = 0. gw_state(i)%spyd = 0. @@ -532,7 +532,7 @@ subroutine gwflow_read gw_state(i)%xcrd = 0. gw_state(i)%ycrd = 0. gw_state(i)%area = 0. - gw_state(i)%init = 0. + gw_state(i)%init = 0. gw_state(i)%head = 0. gw_state(i)%hydc = 0. gw_state(i)%spyd = 0. @@ -1929,7 +1929,7 @@ subroutine gwflow_read write(out_gwbal,*) 'ppex: mm groundwater pumping specified by user' write(out_gwbal,*) 'tile: mm groundwater removed via tile drains' write(out_gwbal,*) 'resv: mm groundwater exchanged with reservoirs' - write(out_gwbal,*) 'wetl: mm groundwater outflow to wetlands' + write(out_gwbal,*) 'wetl: mm groundwater outflow to wetlands' write(out_gwbal,*) 'canl: mm canal seepage to groundwater' write(out_gwbal,*) 'fpln: mm floodplain exchange' write(out_gwbal,*) 'error: -- water balance error for aquifer' @@ -2427,7 +2427,7 @@ subroutine gwflow_read write(out_hyd_sep,*) 'chan_satexsw: channel flow contributed from saturation excess runoff' write(out_hyd_sep,*) 'chan_tile: channel flow contributed from tile drain flow' write(out_hyd_sep,*) - hydsep_hdr = [character(len=16) :: " year"," day","channel","chan_surf","chan_lat","chan_gwsw","chan_swgw", & + hydsep_hdr = [character(len=12) :: " year"," day","channel","chan_surf","chan_lat","chan_gwsw","chan_swgw", & "chan_satexgw","chan_satexsw","chan_tile"] write(out_hyd_sep,121) (hydsep_hdr(j),j=1,10) @@ -2440,14 +2440,14 @@ subroutine gwflow_read return -100 format(i6,i6,10(f10.2)) +!*** tu Wunused-label: 100 format(i6,i6,10(f10.2)) !output files for all cells !101 format((f12.4)) !102 format((i4)) 101 format(f12.4) -102 format(i4) +!*** tu Wunused-label: 102 format(i4) !other formats -103 format(10000(i8)) +!*** tu Wunused-label: 103 format(10000(i8)) 111 format(1x,a, 5x,"Time",2x,i2,":",i2,":",i2) 119 format(4x,a8,a8,a10,a16,a19,50(a13)) 120 format(a8,50(a13)) diff --git a/src/gwflow_resv.f90 b/src/gwflow_resv.f90 index bf1bd0a..b895515 100644 --- a/src/gwflow_resv.f90 +++ b/src/gwflow_resv.f90 @@ -59,10 +59,10 @@ subroutine gwflow_resv(res_id) !rtb gwflow conn_length = sqrt(min_area) !exchange volume (m3/day) using Darcy's Law - head_diff = gw_resv_info(res_id)%elev(k) - gw_state(cell_id)%head + head_diff = gw_resv_info(res_id)%elev(k) - gw_state(cell_id)%head res_K = gw_resv_info(res_id)%hydc(k) res_thick = gw_resv_info(res_id)%thck(k) - Q = res_K * (head_diff / res_thick) * (res_thick * conn_length) + Q = res_K * (head_diff / res_thick) * (res_thick * conn_length) !check against available storage volumes (m3) if(Q > 0) then !reservoir --> aquifer @@ -73,9 +73,9 @@ subroutine gwflow_resv(res_id) !rtb gwflow !if((Q*-1 == 1).ge.gw_state(cell_id)%stor) then if (-Q .ge.gw_state(cell_id)%stor) then !Q = gw_state(cell_id)%stor * (-1) - Q = -gw_state(cell_id)%stor - gw_state(cell_id)%stor = gw_state(cell_id)%stor + Q - endif + Q = -gw_state(cell_id)%stor + gw_state(cell_id)%stor = gw_state(cell_id)%stor + Q + endif endif !store for gwflow water balance calculations (in gwflow_simulate) diff --git a/src/gwflow_simulate.f90 b/src/gwflow_simulate.f90 index 304a411..7b1367c 100644 --- a/src/gwflow_simulate.f90 +++ b/src/gwflow_simulate.f90 @@ -1555,7 +1555,7 @@ subroutine gwflow_simulate write(out_gw_res,101) (grid_val(i,j),j=1,grid_ncol) enddo else - write(out_gw_res,121) (gw_ss_sum(i)%resv,i=1,ncell) + write(out_gw_res,121) (gw_ss_sum(i)%resv,i=1,ncell) endif write(out_gw_res,*) if (gw_solute_flag == 1) then !solute mass flux @@ -1582,7 +1582,7 @@ subroutine gwflow_simulate endif !groundwater-wetland exchange if (gw_wet_flag == 1) then - write(out_gw_wet,*) 'Groundwater outflow to wetlands for:',time%yrc + write(out_gw_wet,*) 'Groundwater outflow to wetlands for:',time%yrc if(grid_type == "structured") then grid_val = 0. do i=1,grid_nrow @@ -1596,7 +1596,7 @@ subroutine gwflow_simulate write(out_gw_wet,101) (grid_val(i,j),j=1,grid_ncol) enddo else - write(out_gw_wet,121) (gw_ss_sum(i)%wetl,i=1,ncell) + write(out_gw_wet,121) (gw_ss_sum(i)%wetl,i=1,ncell) endif write(out_gw_wet,*) if (gw_solute_flag == 1) then !solute mass flux @@ -1622,8 +1622,8 @@ subroutine gwflow_simulate endif endif !groundwater-canal exchange - if (gw_canal_flag == 1) then - write(out_gw_canal,*) 'Groundwater-Canal Exchange Volumes for:',time%yrc + if (gw_canal_flag == 1) then + write(out_gw_canal,*) 'Groundwater-Canal Exchange Volumes for:',time%yrc if(grid_type == "structured") then grid_val = 0. do i=1,grid_nrow @@ -1637,7 +1637,7 @@ subroutine gwflow_simulate write(out_gw_canal,101) (grid_val(i,j),j=1,grid_ncol) enddo else - write(out_gw_canal,121) (gw_ss_sum(i)%canl,i=1,ncell) + write(out_gw_canal,121) (gw_ss_sum(i)%canl,i=1,ncell) endif write(out_gw_canal,*) if (gw_solute_flag == 1) then !solute mass flux @@ -1664,7 +1664,7 @@ subroutine gwflow_simulate endif !floodplain exchange if (gw_fp_flag == 1) then - write(out_gw_fp,*) 'Floodplain Exchange Volumes for:',time%yrc + write(out_gw_fp,*) 'Floodplain Exchange Volumes for:',time%yrc if(grid_type == "structured") then grid_val = 0. do i=1,grid_nrow @@ -1678,7 +1678,7 @@ subroutine gwflow_simulate write(out_gw_fp,101) (grid_val(i,j),j=1,grid_ncol) enddo else - write(out_gw_fp,121) (gw_ss_sum(i)%fpln,i=1,ncell) + write(out_gw_fp,121) (gw_ss_sum(i)%fpln,i=1,ncell) endif write(out_gw_fp,*) if (gw_solute_flag == 1) then !solute mass flux @@ -1884,7 +1884,7 @@ subroutine gwflow_simulate if(gwflag_yr.eq.1) then write(out_solbal_yr+s,105) time%yrc, & sol_grid_chng_yr,sol_grid_rech_yr,sol_grid_gwsw_yr,sol_grid_swgw_yr,sol_grid_satx_yr, & - sol_grid_soil_yr,sol_grid_advn_yr,sol_grid_disp_yr, & + sol_grid_soil_yr,sol_grid_advn_yr,sol_grid_disp_yr, & sol_grid_rcti_yr,sol_grid_rcto_yr,sol_grid_minl_yr,sol_grid_sorb_yr, & sol_grid_ppag_yr,sol_grid_ppex_yr,sol_grid_tile_yr,sol_grid_resv_yr,sol_grid_wetl_yr, & sol_grid_canl_yr,sol_grid_fpln_yr @@ -2510,12 +2510,12 @@ subroutine gwflow_simulate 100 format(10000(f12.3)) 101 format(10000(e12.3)) 102 format(i8,i8,f10.3,e16.7,e16.7,1000(e13.4)) -103 format(i8,i8,i8,i8,i8,i8,i8,50(f15.3)) -104 format(10000(f12.2)) +!*** tu Wunused-label: 103 format(i8,i8,i8,i8,i8,i8,i8,50(f15.3)) +!*** tu Wunused-label: 104 format(10000(f12.2)) 105 format(i8,50(e13.4)) -106 format(i8,i8,i8,50(f12.3)) -108 format(i8,2x,50(e12.4)) -109 format(i8,i8,1000(e12.3)) +!*** tu Wunused-label: 106 format(i8,i8,i8,50(f12.3)) +!*** tu Wunused-label: 108 format(i8,2x,50(e12.4)) +!*** tu Wunused-label: 109 format(i8,i8,1000(e12.3)) 110 format(i8,f20.1,i8,f12.3,f12.3,f12.3) 111 format(f20.1,f12.3,f12.3,i8) 112 format(f15.1,50(e13.4)) @@ -2529,9 +2529,9 @@ subroutine gwflow_simulate !121 format((e12.3)) 120 format(f12.3) 121 format(e12.3) -125 format(3x,i8,2x,i8,7x,f15.1,50(e13.4)) +125 format(3x,i8,2x,i8,7x,f15.1,50(e13.4)) return end subroutine gwflow_simulate - \ No newline at end of file + \ No newline at end of file diff --git a/src/gwflow_soil.f90 b/src/gwflow_soil.f90 index 5957deb..ed3d558 100644 --- a/src/gwflow_soil.f90 +++ b/src/gwflow_soil.f90 @@ -18,9 +18,9 @@ subroutine gwflow_soil(hru_id) !rtb gwflow integer :: cell_id = 0 ! |cell in connection with the channel real :: hru_Q = 0. !m3 |volume transferred from cell to the soil profile real :: hru_soilz = 0. !m |thickness of HRU soil profile + real :: vadose_z = 0. !m |thickness of cell vadose zone real :: poly_area = 0. !m2 |area of cell within the HRU real :: solmass(100) = 0. !g |solute mass transferred from cell - real :: vadose_z = 0. !m |thickness of cell vadose zone real :: water_depth(100) = 0. !m |depth of groundwater in each soil layer real :: water_depth_tot = 0. !m |total depth of groundwater in the soil profile real :: sol_thick = 0. !m |thickness of soil layer diff --git a/src/hcsout_output.f90 b/src/hcsout_output.f90 index 7f0bb79..e5f578a 100644 --- a/src/hcsout_output.f90 +++ b/src/hcsout_output.f90 @@ -35,29 +35,29 @@ subroutine hcsout_output ob(iob)%frac_out(iiout), (hcs1%path(ipath), ipath = 1, cs_db%num_paths) if (pco%csvout == "y") then write (2760,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (hcs1%path(ipath), ipath = 1, cs_db%num_paths) end if !! cvs paths end if !! paths if (cs_db%num_metals > 0) then !! metals write (2748,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (hcs1%hmet(imetal), imetal = 1, cs_db%num_metals) if (pco%csvout == "y") then write (2764,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (hcs1%hmet(imetal), imetal = 1, cs_db%num_metals) end if !! cvs metals end if !! metals if (cs_db%num_salts > 0) then !! salts write (2752,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (hcs1%salt(isalt), isalt = 1, cs_db%num_salts) if (pco%csvout == "y") then write (2768,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (hcs1%salt(isalt), isalt = 1, cs_db%num_salts) end if !! cvs salts end if !! salts @@ -71,44 +71,44 @@ subroutine hcsout_output if (pco%hyd%m == "y") then if (cs_db%num_pests > 0) then !! pests write (2741,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_m(iiout)%pest(ipest), ipest = 1, cs_db%num_pests) if (pco%csvout == "y") then write (2757,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_m(iiout)%pest(ipest), ipest = 1, cs_db%num_pests) end if !! cvs pests end if !! pests if (cs_db%num_paths > 0) then !! paths write (2745,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_m(iiout)%path(ipath), ipath = 1, cs_db%num_paths) if (pco%csvout == "y") then write (2761,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_m(iiout)%path(ipath), ipath = 1, cs_db%num_paths) end if !! cvs paths end if !! paths if (cs_db%num_metals > 0) then !! metals write (2749,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_m(iiout)%hmet(imetal), imetal = 1, cs_db%num_metals) if (pco%csvout == "y") then write (2765,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_m(iiout)%hmet(imetal), imetal = 1, cs_db%num_metals) end if !! cvs metals end if !! metals if (cs_db%num_salts > 0) then !! salts write (2753,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_m(iiout)%salt(isalt), isalt = 1, cs_db%num_salts) if (pco%csvout == "y") then write (2769,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_m(iiout)%salt(isalt), isalt = 1, cs_db%num_salts) end if !! cvs salts end if !! salts @@ -122,44 +122,44 @@ subroutine hcsout_output if (pco%hyd%y == "y") then if (cs_db%num_pests > 0) then !! pests write (2742,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_y(iiout)%pest(ipest), ipest = 1, cs_db%num_pests) if (pco%csvout == "y") then write (2752,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_y(iiout)%pest(ipest), ipest = 1, cs_db%num_pests) end if !! cvs pests end if !! pests if (cs_db%num_paths > 0) then !! paths write (2746,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_y(iiout)%path(ipath), ipath = 1, cs_db%num_paths) if (pco%csvout == "y") then write (2762,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_y(iiout)%path(ipath), ipath = 1, cs_db%num_paths) end if !! cvs paths end if !! paths if (cs_db%num_metals > 0) then !! metals write (2750,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_y(iiout)%hmet(imetal), imetal = 1, cs_db%num_metals) if (pco%csvout == "y") then write (2766,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_y(iiout)%hmet(imetal), imetal = 1, cs_db%num_metals) end if !! cvs metals end if !! metals if (cs_db%num_salts > 0) then !! salts write (2754,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_y(iiout)%salt(isalt), isalt = 1, cs_db%num_salts) if (pco%csvout == "y") then write (2770,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_y(iiout)%salt(isalt), isalt = 1, cs_db%num_salts) end if !! cvs salts end if !! salts @@ -173,44 +173,44 @@ subroutine hcsout_output ob(iob)%hin_a(iiout) = ob(iob)%hin_a(iiout) / time%yrs_prt if (cs_db%num_pests > 0) then !! pests write (2743,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_a(iiout)%pest(ipest), ipest = 1, cs_db%num_pests) if (pco%csvout == "y") then write (2759,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_a(iiout)%pest(ipest), ipest = 1, cs_db%num_pests) end if !! cvs pests end if !! pests if (cs_db%num_paths > 0) then !! paths write (2747,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_a(iiout)%path(ipath), ipath = 1, cs_db%num_paths) if (pco%csvout == "y") then write (2763,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_a(iiout)%path(ipath), ipath = 1, cs_db%num_paths) end if !! cvs paths end if !! paths if (cs_db%num_metals > 0) then !! metals write (2751,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_a(iiout)%hmet(imetal), imetal = 1, cs_db%num_metals) if (pco%csvout == "y") then write (2767,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_a(iiout)%hmet(imetal), imetal = 1, cs_db%num_metals) end if !! cvs metals end if !! metals if (cs_db%num_salts > 0) then !! salts write (2755,*) time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_a(iiout)%salt(isalt), isalt = 1, cs_db%num_salts) if (pco%csvout == "y") then write (2771,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iob, ob(iob)%gis_id, ob(iob)%typ, & - ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & + ob(iob)%num, ob(iob)%obtyp_out(iiout), ob(iob)%obtypno_out(iiout), ob(iob)%htyp_out(iiout), & ob(iob)%frac_out(iiout), (obcs(iob)%hcsout_a(iiout)%salt(isalt), isalt = 1, cs_db%num_salts) end if !! cvs salts end if !! salts diff --git a/src/header_sd_channel.f90 b/src/header_sd_channel.f90 index 28a3cfc..3bc1562 100644 --- a/src/header_sd_channel.f90 +++ b/src/header_sd_channel.f90 @@ -23,7 +23,7 @@ subroutine header_sd_channel write (4814,'(*(G0.3,:,","))') sdch_hdr_units_sub write (9000,*) "SWAT-DEG_CHANNEL channel_sd_subday.csv" end if - end if + end if end if open (2500,file="channel_sd_day.txt",recl = 1500) diff --git a/src/header_write.f90 b/src/header_write.f90 index 12037f4..2b129d7 100644 --- a/src/header_write.f90 +++ b/src/header_write.f90 @@ -45,14 +45,14 @@ subroutine header_write !!!!!! hru-lte-out.cal - hru lte soft calibration output including soft and predicted budgets and !!!!!! calibration parameter adjustments !open (5003,file="hru-lte-out.cal", recl = 800) - !write (9000,*) "LTE SOFT OUT CALIB hru-lte-out.cal" - !write (5003,*) calb_hdr - + !write (9000,*) "LTE SOFT OUT CALIB hru-lte-out.cal" + !write (5003,*) calb_hdr + !!!!!! hru-lte-new.cal - hru lte soft calibration output file. The same format as hru-lte.hru and !!!!!! can be used as input (hru-lte.hru) in subsequent simulations !open (5002,file="hru-lte-new.cal", recl = 800) - !write (9000,*) "LTE SOFT CAL INPUT hru-lte-new.cal" - !write (5002,*) calb2_hdr + !write (9000,*) "LTE SOFT CAL INPUT hru-lte-new.cal" + !write (5002,*) calb2_hdr !! BASIN AQUIFER OUTPUT if (pco%aqu_bsn%d == "y") then diff --git a/src/hru_carbon_output.f90 b/src/hru_carbon_output.f90 index 30a726a..bb59160 100644 --- a/src/hru_carbon_output.f90 +++ b/src/hru_carbon_output.f90 @@ -126,12 +126,12 @@ subroutine hru_carbon_output (ihru) return -100 format (4i6,2i8,2x,a,40f12.3) -101 format (4i6,2i8,2x,a,24f12.3) -102 format (4i6,2i8,2x,a,24f12.3) -103 format (4i6,i8,4x,a,5x,4f12.3) -104 format (4i6,2i8,2x,a8,4f12.3,23f17.3) -105 format (4i6,2i8,2x,a8,8f17.3) -106 format (4i6,2i8,2x,a8,29f17.3) +!*** tu Wunused-label: 100 format (4i6,2i8,2x,a,40f12.3) +!*** tu Wunused-label: 101 format (4i6,2i8,2x,a,24f12.3) +!*** tu Wunused-label: 102 format (4i6,2i8,2x,a,24f12.3) +!*** tu Wunused-label: 103 format (4i6,i8,4x,a,5x,4f12.3) +!*** tu Wunused-label: 104 format (4i6,2i8,2x,a8,4f12.3,23f17.3) +!*** tu Wunused-label: 105 format (4i6,2i8,2x,a8,8f17.3) +!*** tu Wunused-label: 106 format (4i6,2i8,2x,a8,29f17.3) end subroutine hru_carbon_output \ No newline at end of file diff --git a/src/hru_control.f90 b/src/hru_control.f90 index 5e48e35..fd8d856 100644 --- a/src/hru_control.f90 +++ b/src/hru_control.f90 @@ -12,7 +12,7 @@ subroutine hru_control snofall, snomlt, usle, canev, ep_day, es_day, etday, inflpcp, isep, iwgen, ls_overq, & nd_30, pet_day, precip_eff, qday, latqrunon, gwsoilq, satexq, surf_bs, bss, bss_ex, brt, & gwsoiln, gwsoilp, satexn, satexq_chan, surqsalt, latqsalt, tilesalt, percsalt, urbqsalt, & !rtb gwflow; rtb salt - wetqsalt, wtspsalt,gwupsalt, & + wetqsalt, wtspsalt,gwupsalt, usle_cfac, & surqcs, latqcs, tilecs, perccs, gwupcs, sedmcs, urbqcs, wetqcs, wtspcs !rtb cs !HAK 7/27/22 use soil_module @@ -77,6 +77,9 @@ subroutine hru_control real :: sum_conc = 0. !rtb salt real :: sum_mass = 0. !rtb salt real :: sum_sorb = 0. !rtb salt + real :: saltcon = 0. !Jeong 2024 + real :: qsurf = 0. !Jeong 2024 + real :: sedppm = 0. !Jeong 2024 j = ihru @@ -254,9 +257,9 @@ subroutine hru_control end if !!add tile flow to tile (subirrigation and saturated buffer) - if (ob(icmd)%hin_til%flo > 1.e-6 .and. tile_fr_surf > 1.e-6) then - call rls_routetile (icmd, tile_fr_surf) - end if + !if (ob(icmd)%hin_til%flo > 1.e-6 .and. tile_fr_surf > 1.e-6) then + ! call rls_routetile (icmd, tile_fr_surf) + !end if !!add aquifer flow to bottom soil layer and redistribute upwards if (ob(icmd)%hin_aqu%flo > 0) then @@ -348,18 +351,21 @@ subroutine hru_control end if end if + !! compute residue decomposition + call rsd_decomp + !! compute nitrogen and phosphorus mineralization if (bsn_cc%cswat == 0) then call nut_nminrl end if - if (bsn_cc%cswat == 2) then - call cbn_zhang2 - end if + if (bsn_cc%cswat == 2) then + call cbn_zhang2 + end if call nut_nitvol - if (bsn_cc%sol_P_model == 1) then + if (bsn_cc%sol_P_model == 1) then call nut_pminrl2 else call nut_pminrl @@ -368,12 +374,19 @@ subroutine hru_control !! compute biozone processes in septic HRUs !! if 1) current is septic hru and 2) soil temperature is above zero isep = iseptic(j) - if (sep(isep)%opt /= 0. .and. time%yrc >= sep(isep)%yr) then - if (soil(j)%phys(i_sep(j))%tmp > 0.) call sep_biozone + if (sep(isep)%opt /= 0. .and. time%yrc >= sep(isep)%yr) then + if (soil(j)%phys(i_sep(j))%tmp > 0.) call sep_biozone endif !! compute plant community partitions call pl_community + !if (j == 136) then + !write (7778,*) time%day, j, pl_mass(j)%tot(1)%m, pl_mass(j)%ab_gr(1)%m, pl_mass(j)%stem(1)%m, & + ! pl_mass(j)%leaf(1)%m, pl_mass(j)%root(1)%m, pl_mass(j)%seed(1)%m + !end if + !if (j == 173) then + ! write (7778,*) time%day, j, sedyld(j)/hru(j)%area_ha, usle_cfac(j), surfq(j), qp_cms + !end if !! check irrigation demand decision table for water allocation (after adding irrigation) if (hru(j)%irr_dmd_dtbl > 0) then @@ -517,6 +530,20 @@ subroutine hru_control !! compute nitrate movement leaching call nut_nlch + if (ires > 0) then + if (wet(j)%flo>0) then + sedppm=wet(j)%sed/wet(j)%flo*1000000. + else + sedppm=0. + end if + if (wet_dat_c(ires)%hyd.eq.'paddy') then !.and.time%yrs > pco%nyskip) then + if (wet_ob(j)%depth > 100.) then + write(100100,'(4(I6,","),20(f20.1,","))') time%yrc,time%mo,time%day_mo,j,w%precip,irrig(j)%applied,hru(j)%water_seep, & + pet_day,etday,wet_ob(j)%weir_hgt*1000,wet_ob(j)%depth*1000.,ht2%flo/(hru(j)%area_ha*10.),soil(j)%sw,sedppm,ht2%sed*1000, & + wet(j)%no3,ht2%no3,pcom(j)%lai_sum,saltcon + end if + end if + end if !! compute phosphorus movement call nut_solp @@ -547,12 +574,12 @@ subroutine hru_control !! compute loadings from urban areas if (hru(j)%luse%urb_lu > 0) then - if (time%step == 1) then + if (time%step == 1) then call hru_urban ! daily simulation - else + else call hru_urbanhr ! subdaily simulation J.Jeong 4/20/2009 - endif - endif + endif + endif !! compute sediment loading in lateral flow and add to sedyld call swr_latsed @@ -569,19 +596,20 @@ subroutine hru_control if (filterw(j) > 0.) call smp_buffer end if - !! compute reduction in pollutants due to in field grass waterway + !! compute reduction in pollutants due to in field grass waterway if (hru(j)%lumv%grwat_i == 1) then call smp_grass_wway end if - !! compute reduction in pollutants due to in fixed BMP eff - if (hru(j)%lumv%bmp_flag == 1) then + !! compute reduction in pollutants due to in fixed BMP eff + if (hru(j)%lumv%bmp_flag == 1) then call smp_bmpfixed end if !! ht2%flo is outflow from wetland or total saturation excess if no wetland if(ht2%flo > 0.) then wet_outflow = ht2%flo / hru(j)%area_ha / 10. !! mm = m3/ha *ha/10000m2 *1000mm/m + qday = qday + wet_outflow qdr(j) = qdr(j) + wet_outflow ht2%flo = 0. end if @@ -616,6 +644,7 @@ subroutine hru_control if (ob(iob)%ru_tot > 0) then iob_out = sp_ob1%ru + ob(iob)%ru(1) - 1 end if + qsurf=surfq(j) hwb_d(j)%surq_cha = 0. hwb_d(j)%latq_cha = 0. diff --git a/src/hru_cs_output.f90 b/src/hru_cs_output.f90 index 7de4ed7..5b1c3af 100644 --- a/src/hru_cs_output.f90 +++ b/src/hru_cs_output.f90 @@ -69,7 +69,7 @@ subroutine hru_cs_output(ihru) !rtb cs (hcsb_d(j)%cs(ics)%srbd,ics=1,cs_db%num_cs) if (pco%csvout == "y") then write (6022,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, & - (hcsb_d(j)%cs(ics)%soil,ics=1,cs_db%num_cs), & + (hcsb_d(j)%cs(ics)%soil,ics=1,cs_db%num_cs), & (hcsb_d(j)%cs(ics)%surq,ics=1,cs_db%num_cs), & (hcsb_d(j)%cs(ics)%sedm,ics=1,cs_db%num_cs), & (hcsb_d(j)%cs(ics)%latq,ics=1,cs_db%num_cs), & diff --git a/src/hru_hyds.f90 b/src/hru_hyds.f90 index b1d1138..8c9cf74 100644 --- a/src/hru_hyds.f90 +++ b/src/hru_hyds.f90 @@ -93,10 +93,10 @@ subroutine hru_hyds obcs(icmd)%hd(3)%path(ipath) = 0 end do do isalt = 1, cs_db%num_salts !rtb salt - obcs(icmd)%hd(3)%salt(isalt) = (surqsalt(j,isalt)+urbqsalt(j,isalt)+wetqsalt(j,isalt)) * cnv_kg !kg of each salt ion + obcs(icmd)%hd(3)%salt(isalt) = (surqsalt(j,isalt)+urbqsalt(j,isalt)+wetqsalt(j,isalt)) * cnv_kg !kg of each salt ion enddo do ics = 1, cs_db%num_cs !rtb cs - obcs(icmd)%hd(3)%cs(ics) = (surqcs(j,ics)+sedmcs(j,ics)+urbqcs(j,ics)+wetqcs(j,ics)) * cnv_kg !kg of each constituent (surface runoff + attached) + obcs(icmd)%hd(3)%cs(ics) = (surqcs(j,ics)+sedmcs(j,ics)+urbqcs(j,ics)+wetqcs(j,ics)) * cnv_kg !kg of each constituent (surface runoff + attached) enddo !recharge hydrograph (2) diff --git a/src/hru_lte_control.f90 b/src/hru_lte_control.f90 index e6a9989..f773e51 100644 --- a/src/hru_lte_control.f90 +++ b/src/hru_lte_control.f90 @@ -347,19 +347,19 @@ subroutine hru_lte_control (isd) !! compute channel peak rate using SCS triangular unit hydrograph chflow_m3 = 1000. * chflow * ob(icmd)%area_ha - runoff_m3 = 1000. * runoff * ob(icmd)%area_ha - bf_m3 = 1000. * (flowlat + hlt(isd)%gwflow)*ob(icmd)%area_ha + runoff_m3 = 1000. * runoff * ob(icmd)%area_ha + bf_m3 = 1000. * (flowlat + hlt(isd)%gwflow)*ob(icmd)%area_ha peakr = 2. * runoff_m3 / (1.5 * hlt_db(ihlt_db)%tc) - peakrbf = bf_m3 / 86400. + peakrbf = bf_m3 / 86400. peakr = (peakr + peakrbf) !* prf !! compute sediment yield with MUSLE sedin = (runoff * peakr * 1000. * ob(icmd)%area_ha) ** .56 * hlt(isd)%uslefac - !! add subsurf sediment - t=ppm*mm*km2/1000. - qssubconc = 500. - qssub = qssubconc * (flowlat + hlt(isd)%gwflow) * ob(icmd)%area_ha / 1000. - sedin = sedin + qssub + !! add subsurf sediment - t=ppm*mm*km2/1000. + qssubconc = 500. + qssub = qssubconc * (flowlat + hlt(isd)%gwflow) * ob(icmd)%area_ha / 1000. + sedin = sedin + qssub cnv = ob(icmd)%area_ha * 1000. diff --git a/src/hru_module.f90 b/src/hru_module.f90 index 73b16bb..4adf6e6 100644 --- a/src/hru_module.f90 +++ b/src/hru_module.f90 @@ -28,7 +28,7 @@ module hru_module type topography character(len=40) :: name = "" real :: elev = 0. !! |m |elevation of HRU - real :: slope = 0. !! hru_slp(:) |m/m |average slope steepness in HRU + real :: slope = 0. !! hru_slp(:) |m/m |average slope steepness in HRU real :: slope_len = 0. !! slsubbsn(:) |m |average slope length for erosion real :: dr_den = 0. !! |km/km2 |drainage density real :: lat_len = 0. !! slsoil(:) |m |slope length for lateral subsurface flow @@ -100,7 +100,7 @@ module hru_module integer :: cn_lu = 0 integer :: cons_prac = 0 real :: usle_p = 0. !! none | USLE equation support practice (P) factor daily - character (len=16) :: urb_ro = ""!! none | urban runoff model + character (len=40) :: urb_ro = ""!! none | urban runoff model !! | "usgs_reg", simulate using USGS regression eqs !! | "buildup_washoff", simulate using build up/wash off alg integer :: urb_lu = 0 !! none | urban land type identification number @@ -184,7 +184,7 @@ module hru_module integer :: vfsi = 0 !! |none |on/off flag for vegetative filter strip real :: vfsratio = 0. !! |none |contouring USLE P factor real :: vfscon = 0. !! |none |fraction of the total runoff from the entire field - real :: vfsch = 0; !! |none |fraction of flow entering the most concentrated 10% of the VFS. + real :: vfsch = 0. !! |none |fraction of flow entering the most concentrated 10% of the VFS. !! which is fully channelized integer :: ngrwat = 0 integer :: grwat_i = 0 !! |none |On/off Flag for waterway simulation @@ -215,7 +215,7 @@ module hru_module character(len=40) :: land_use_mgt_c = "" integer :: lum_group = 0 character(len=40) :: lum_group_c = "" !land use group for soft cal and output - character(len=40) :: region = "" + character(len=40) :: cal_group = "" integer :: plant_cov = 0 integer :: mgt_ops = 0 integer :: tiledrain = 0 @@ -251,7 +251,7 @@ module hru_module real :: wet_obank_in = 0. !mm |inflow from overbank into wetlands real :: precip_aa = 0. character(len=1) :: wet_fp = "n" - character(len=5) :: irr_src = "unlim" ! |irrigation source, Jaehak 2022 + character(len=40) :: irr_src = "unlim" ! |irrigation source, Jaehak 2022 real :: strsa = 0. real :: irr_hmax = 0 !mm H2O |target ponding depth during paddy irrigation Jaehak 2022 real :: irr_hmin = 0 !mm H2O |threshold ponding depth to trigger paddy irrigation @@ -489,15 +489,15 @@ module hru_module ! Modifications to Pesticide and Water routing routines by Balaji Narasimhan !Additional buffer and filter strip variables Mike White - real, dimension (:), allocatable :: ubnrunoff - real, dimension (:), allocatable :: ubntss - real, dimension (:,:), allocatable :: ovrlnd_dt - real, dimension (:,:), allocatable :: hhsurfq - real, dimension (:,:,:), allocatable :: hhsurf_bs + real, dimension (:), allocatable :: ubnrunoff + real, dimension (:), allocatable :: ubntss + real, dimension (:,:), allocatable :: ovrlnd_dt + real, dimension (:,:), allocatable :: hhsurfq + real, dimension (:,:,:), allocatable :: hhsurf_bs !! subdaily erosion modeling by Jaehak Jeong - real, dimension(:,:), allocatable:: hhsedy - real, dimension(:), allocatable:: init_abstrc + real, dimension(:,:), allocatable:: hhsedy + real, dimension(:), allocatable:: init_abstrc integer, dimension(:), allocatable :: tillage_switch real, dimension(:), allocatable :: tillage_depth diff --git a/src/hru_output.f90 b/src/hru_output.f90 index 74239c5..8d9f138 100644 --- a/src/hru_output.f90 +++ b/src/hru_output.f90 @@ -10,6 +10,7 @@ subroutine hru_output (ihru) use soil_module use carbon_module use hru_module, only : hru + use landuse_data_module implicit none @@ -18,6 +19,7 @@ subroutine hru_output (ihru) integer :: j = 0 integer :: iob = 0 integer :: ipl = 0 + integer :: ilu = 0 real :: const = 0. real :: sw_init = 0. real :: sno_init = 0. @@ -28,6 +30,7 @@ subroutine hru_output (ihru) j = ihru iob = sp_ob1%hru + j - 1 !!!!!! added for new output write + ilu = hru(j)%land_use_mgt hwb_m(j) = hwb_m(j) + hwb_d(j) hnb_m(j) = hnb_m(j) + hnb_d(j) @@ -42,31 +45,39 @@ subroutine hru_output (ihru) !! daily print if (pco%day_print == "y" .and. pco%int_day_cur == pco%int_day) then if (pco%wb_hru%d == "y") then - write (2000,100) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_d(j) !! waterbal + write (2000,100) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_d(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! water bal day if (pco%csvout == "y") then !! changed write unit below (2004 to write file data) - write (2004,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_d(j) !! waterbal + write (2004,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hwb_d(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if hwb_d(j)%sw_init = hwb_d(j)%sw_final hwb_d(j)%sno_init = hwb_d(j)%sno_final if (pco%nb_hru%d == "y") then - write (2020,104) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_d(j) !! nutrient bal + write (2020,104) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_d(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! nutrient bal day if (pco%csvout == "y") then - write (2024,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_d(j) !! nutrient bal + write (2024,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hnb_d(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if if (pco%ls_hru%d == "y") then - write (2030,102) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_d(j) !! losses + write (2030,108) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_d(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! losses day if (pco%csvout == "y") then - write (2034,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_d(j) !! losses + write (2034,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hls_d(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if if (pco%pw_hru%d == "y") then - write (2040,101) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_d(j) !! plant weather + write (2040,101) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_d(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! plant weather day if (pco%csvout == "y") then - write (2044,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_d(j) !! plant weather + write (2044,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hpw_d(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if end if @@ -87,32 +98,40 @@ subroutine hru_output (ihru) hwb_m(j)%sno_final = hwb_d(j)%sno_final if (pco%wb_hru%m == "y") then - write (2001,100) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_m(j) + write (2001,100) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_m(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! water bal mon if (pco%csvout == "y") then - write (2005,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_m(j) + write (2005,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hwb_m(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if if (pco%nb_hru%m == "y") then - write (2021,104) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_m(j) + write (2021,104) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_m(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! nutrient bal mon if (pco%csvout == "y") then - write (2025,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_m(j) + write (2025,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hnb_m(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if if (pco%ls_hru%m == "y") then - write (2031,102) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_m(j) + write (2031,108) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_m(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! losses mon if (pco%csvout == "y") then - write (2035,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_m(j) + write (2035,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hls_m(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if if (pco%pw_hru%m == "y") then hpw_m(j)%nplnt = pl_mass(j)%tot_com%n hpw_m(j)%pplnt = pl_mass(j)%tot_com%p - write (2041,101) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_m(j) + write (2041,101) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_m(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! plant weather mon if (pco%csvout == "y") then - write (2045,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_m(j) + write (2045,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hpw_m(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if @@ -145,32 +164,40 @@ subroutine hru_output (ihru) hru(j)%irr = 1 end if if (pco%wb_hru%y == "y") then - write (2002,100) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_y(j) + write (2002,100) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_y(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! water balance yr if (pco%csvout == "y") then - write (2006,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_y(j) + write (2006,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hwb_y(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if if (pco%nb_hru%y == "y") then - write (2022,104) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_y(j) + write (2022,104) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_y(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! nutrient balance yr if (pco%csvout == "y") then - write (2026,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_y(j) + write (2026,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hnb_y(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if if (pco%ls_hru%y == "y") then - write (2032,102) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_y(j) + write (2032,108) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_y(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! losses yr if (pco%csvout == "y") then - write (2036,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_y(j) + write (2036,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hls_y(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if if (pco%pw_hru%y == "y") then hpw_y(j)%nplnt = pl_mass(j)%tot_com%n hpw_y(j)%pplnt = pl_mass(j)%tot_com%p - write (2042,101) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_y(j) + write (2042,101) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_y(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! plant weather yr if (pco%csvout == "y") then - write (2046,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_y(j) + write (2046,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hpw_y(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if @@ -188,9 +215,11 @@ subroutine hru_output (ihru) hwb_a(j)%sno_init = sno_init hwb_a(j)%sno_final = hwb_d(j)%sno_final if (pco%wb_hru%a == "y") then - write (2003,100) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_a(j) + write (2003,100) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_a(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! water balance ann if (pco%csvout == "y") then - write (2007,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hwb_a(j) + write (2007,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hwb_a(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if end if sw_init = hwb_d(j)%sw_final @@ -208,18 +237,22 @@ subroutine hru_output (ihru) if (time%end_sim == 1 .and. pco%nb_hru%a == "y") then hnb_a(j) = hnb_a(j) / time%yrs_prt - write (2023,104) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_a(j) + write (2023,104) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_a(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! nutrient bal ann if (pco%csvout == "y") then - write (2027,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hnb_a(j) + write (2027,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hnb_a(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if hnb_a(j) = hnbz end if if (time%end_sim == 1 .and. pco%ls_hru%a == "y") then hls_a(j) = hls_a(j) / time%yrs_prt - write (2033,101) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_a(j) + write (2033,107) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_a(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! losses ann if (pco%csvout == "y") then - write (2037,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hls_a(j) + write (2037,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hls_a(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if hls_a(j) = hlsz end if @@ -229,9 +262,11 @@ subroutine hru_output (ihru) hpw_a(j) = hpw_a(j) // time%days_prt hpw_a(j)%nplnt = pl_mass(j)%tot_com%n hpw_a(j)%pplnt = pl_mass(j)%tot_com%p - write (2043,102) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_a(j) + write (2043,102) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_a(j), & + lum(ilu)%plant_cov, lum(ilu)%mgt_ops !! plant weather ann if (pco%csvout == "y") then - write (2047,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, hpw_a(j) + write (2047,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & + hpw_a(j), lum(ilu)%plant_cov, lum(ilu)%mgt_ops end if hru(j)%strsa = hpw_a(j)%strsa hpw_a(j) = hpwz @@ -240,43 +275,41 @@ subroutine hru_output (ihru) !! write yearly crop yields if (time%end_yr == 1) then if (pco%crop_yld == "y" .or. pco%crop_yld == "b") then - do ipl = 1, pcom(j)%npl - if (pcom(j)%plcur(ipl)%harv_num_yr > 0) then - pl_mass(j)%yield_yr(ipl) = pl_mass(j)%yield_yr(ipl) / float(pcom(j)%plcur(ipl)%harv_num_yr) - endif - if (pco%crop_yld == "y" .or. pco%crop_yld == "b") then - write (4010,103) time%day, time%mo, time%day_mo, time%yrc, j, pcom(j)%pl(ipl), pl_mass(j)%yield_yr(ipl) - end if - if (pco%csvout == "y") then - write (4011,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, pcom(j)%pl(ipl), pl_mass(j)%yield_yr(ipl) - end if - end do + do ipl = 1, pcom(j)%npl + if (pcom(j)%plcur(ipl)%harv_num_yr > 0) then + pl_mass(j)%yield_yr(ipl) = pl_mass(j)%yield_yr(ipl) / float(pcom(j)%plcur(ipl)%harv_num_yr) + endif + write (4010,103) time%day, time%mo, time%day_mo, time%yrc, j, pcom(j)%pl(ipl), pl_mass(j)%yield_yr(ipl) + if (pco%csvout == "y") then + write (4011,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, pcom(j)%pl(ipl), pl_mass(j)%yield_yr(ipl) + end if + end do end if end if !! write average annual crop yields if (time%end_sim == 1) then if (pco%crop_yld == "a" .or. pco%crop_yld == "b") then - do ipl = 1, pcom(j)%npl - idp = pcom(j)%plcur(ipl)%idplt - if (pcom(j)%plcur(ipl)%harv_num > 0) then - pl_mass(j)%yield_tot(ipl) = pl_mass(j)%yield_tot(ipl) / float(pcom(j)%plcur(ipl)%harv_num) - endif - write (4008,103) time%day, time%mo, time%day_mo, time%yrc, j,pldb(idp)%plantnm, pl_mass(j)%yield_tot(ipl) - if (pco%csvout == "y") then - write (4009,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j,pldb(idp)%plantnm, pl_mass(j)%yield_tot(ipl) - end if - end do + do ipl = 1, pcom(j)%npl + idp = pcom(j)%plcur(ipl)%idplt + if (pcom(j)%plcur(ipl)%harv_num > 0) then + pl_mass(j)%yield_tot(ipl) = pl_mass(j)%yield_tot(ipl) / float(pcom(j)%plcur(ipl)%harv_num) + endif + write (4008,103) time%day, time%mo, time%day_mo, time%yrc, j,pldb(idp)%plantnm, pl_mass(j)%yield_tot(ipl) + if (pco%csvout == "y") then + write (4009,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j,pldb(idp)%plantnm, pl_mass(j)%yield_tot(ipl) + end if + end do end if end if return -100 format (4i6,2i8,2x,a,42f12.3) -101 format (4i6,2i8,2x,a,25f12.3) !!!!!!!!!! nbs chg -102 format (4i6,2i8,2x,a,25f12.3) !!!!!!!!!! nbs chg +100 format (4i6,2i8,2x,a,42f12.3,3x,a16,a30) +101 format (4i6,2i8,2x,a,25f12.3,3x,a16,a30) +102 format (4i6,2i8,2x,a,25f12.3,3x,a16,a30) 103 format (4i6,i8,4x,a,5x,4f12.3) -104 format (4i6,2i8,2x,a8,4f12.3,23f17.3) -105 format (4i6,2i8,2x,a8,8f17.3) -106 format (4i6,2i8,2x,a8,29f17.3) +104 format (4i6,2i8,2x,a8,4f12.3,15f17.3,7x,a16,a30) +107 format (4i6,2i8,2x,a,12f12.3,3x,a16,a30) +108 format (4i6,2i8,2x,a,12f12.3,3x,a16,a30) end subroutine hru_output \ No newline at end of file diff --git a/src/hru_pathogen_output.f90 b/src/hru_pathogen_output.f90 index 4a50735..abbee3b 100644 --- a/src/hru_pathogen_output.f90 +++ b/src/hru_pathogen_output.f90 @@ -98,8 +98,8 @@ subroutine hru_pathogen_output(ihru) return 100 format (4i6,2i8,2x,a,11e12.3) -101 format (4i6,2i8,2x,a,11e12.3) -102 format (4i6,2i8,2x,a,11e12.3) -103 format (2i6,i8,4x,a,5x,11e12.3) +!*** tu Wunused-label: 101 format (4i6,2i8,2x,a,11e12.3) +!*** tu Wunused-label: 102 format (4i6,2i8,2x,a,11e12.3) +!*** tu Wunused-label: 103 format (2i6,i8,4x,a,5x,11e12.3) end subroutine hru_pathogen_output \ No newline at end of file diff --git a/src/hru_read.f90 b/src/hru_read.f90 index e59f809..97d13b7 100644 --- a/src/hru_read.f90 +++ b/src/hru_read.f90 @@ -59,7 +59,7 @@ subroutine hru_read read (113,*,iostat=eof) header if (eof < 0) exit - do ihru = 1, sp_ob%hru + do ihru = 1, imax read (113,*,iostat=eof) i if (eof < 0) exit backspace (113) diff --git a/src/hru_salt_output.f90 b/src/hru_salt_output.f90 index 5034569..c3f6128 100644 --- a/src/hru_salt_output.f90 +++ b/src/hru_salt_output.f90 @@ -67,7 +67,7 @@ subroutine hru_salt_output(ihru) hsaltb_d(j)%salt(1)%diss if (pco%csvout == "y") then write (5022,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, & - (hsaltb_d(j)%salt(isalt)%soil,isalt=1,cs_db%num_salts), & + (hsaltb_d(j)%salt(isalt)%soil,isalt=1,cs_db%num_salts), & (hsaltb_d(j)%salt(isalt)%surq,isalt=1,cs_db%num_salts), & (hsaltb_d(j)%salt(isalt)%latq,isalt=1,cs_db%num_salts), & (hsaltb_d(j)%salt(isalt)%urbq,isalt=1,cs_db%num_salts), & diff --git a/src/hru_urb_bmp.f90 b/src/hru_urb_bmp.f90 index 25c63a3..5606b72 100644 --- a/src/hru_urb_bmp.f90 +++ b/src/hru_urb_bmp.f90 @@ -14,12 +14,12 @@ subroutine hru_urb_bmp real :: sednppm = 0. ! | real :: sedpppm = 0. ! | - j = 0 - j = ihru + j = 0 + j = ihru !! convert to ppm -> (kg/ha)*100./mm = ppm if (qdr(j) > 0.1) then - xx = 100. / qdr(j) + xx = 100. / qdr(j) sedppm = 1000. * xx * sedyld(j) / hru(j)%area_ha solnppm = xx * (surqno3(j) + latno3(j)) solpppm = xx * surqsolp(j) @@ -31,7 +31,7 @@ subroutine hru_urb_bmp endif if (solnppm > soln_con(j)) then - surqno3(j) = soln_con(j) / xx + surqno3(j) = soln_con(j) / xx latno3(j) = soln_con(j) / xx endif @@ -44,12 +44,12 @@ subroutine hru_urb_bmp endif if (sedpppm > orgp_con(j)) then - sedorgn(j)= orgp_con(j) / xx + sedorgn(j)= orgp_con(j) / xx sedminpa(j)= orgp_con(j) / xx - sedminps(j)= orgp_con(j) / xx + sedminps(j)= orgp_con(j) / xx endif - endif + endif return end subroutine hru_urb_bmp \ No newline at end of file diff --git a/src/hru_urbanhr.f90 b/src/hru_urbanhr.f90 index 042121b..a8924f2 100644 --- a/src/hru_urbanhr.f90 +++ b/src/hru_urbanhr.f90 @@ -68,7 +68,7 @@ subroutine hru_urbanhr ! |surfaces at the beginning of time step integer :: j = 0 !none |HRU number real :: qdt = 0. ! | - real*8 :: dirt = 0.d0 !kg/curb km |amount of solids built up on impervious + real*8 :: dirt = 0.d0 !kg/curb km |amount of solids built up on impervious ! |surfaces integer :: k = 0 !none |counter integer :: tno3 = 0 ! | @@ -76,14 +76,14 @@ subroutine hru_urbanhr j = ihru ulu = hru(j)%luse%urb_lu - do k = 1, time%step + do k = 1, time%step !! build-up/wash-off algorithm !! rainy day: no build-up, street cleaning allowed - - qdt = ubnrunoff(k) * 60./ real(time%dtm) !urban runoff in mm/hr - if (qdt > 0.025 .and. surfq(j) > 0.1) then ! SWMM : 0.001 in/hr (=0.0254mm/hr) + + qdt = ubnrunoff(k) * 60./ real(time%dtm) !urban runoff in mm/hr + if (qdt > 0.025 .and. surfq(j) > 0.1) then ! SWMM : 0.001 in/hr (=0.0254mm/hr) !! calculate amount of dirt on streets prior to wash-off dirt = 0. @@ -91,7 +91,7 @@ subroutine hru_urbanhr dirto = urbdb(ulu)%dirtmx * twash(j) / (urbdb(ulu)%thalf + twash(j)) !! calculate wash-off of solids - urbk = 0. ! qp_cms -> hhqday for subdaily time steps 6/19/09 JJ + urbk = 0. ! qp_cms -> hhqday for subdaily time steps 6/19/09 JJ urbk = urbdb(ulu)%urbcoef * qdt dirt=dirto * Exp (- urbk * real(time%dtm) / 60.) @@ -119,7 +119,7 @@ subroutine hru_urbanhr (1. - urbdb(ulu)%fimp) surqsolp(j) = .25 * tp * urbdb(ulu)%fimp + surqsolp(j) * & (1. - urbdb(ulu)%fimp) - else + else !! no surface runoff twash(j) = twash(j) + time%dtm / 1440. @@ -135,26 +135,26 @@ subroutine hru_urbanhr end if end if - sus_sol=0 - - ! Compute evaporation of water (initial abstraction) from impervious cover - init_abstrc(j) = init_abstrc(j) - etday / time%step - init_abstrc(j) = max(0.,init_abstrc(j)) - end do + sus_sol=0 + + ! Compute evaporation of water (initial abstraction) from impervious cover + init_abstrc(j) = init_abstrc(j) - etday / time%step + init_abstrc(j) = max(0.,init_abstrc(j)) + end do !! perform street sweeping if(surfq(j) < 0.1) then - if (isweep(j) > 0 .and. time%day >= isweep(j)) then + if (isweep(j) > 0 .and. time%day >= isweep(j)) then call hru_sweep else if (phusw(j) > 0.0001) then if (pcom(j)%plcur(ipl)%gro == "n") then if (phubase(j) > phusw(j)) then - call hru_sweep - endif + call hru_sweep + endif else if (pcom(j)%plcur(1)%phuacc > phusw(j)) then - call hru_sweep - endif + call hru_sweep + endif end if end if end if diff --git a/src/hrudb_init.f90 b/src/hrudb_init.f90 index abdce2f..e70a5b4 100644 --- a/src/hrudb_init.f90 +++ b/src/hrudb_init.f90 @@ -2,6 +2,7 @@ subroutine hrudb_init use hydrograph_module, only : sp_ob, sp_ob1, ob use hru_module, only : hru, hru_db + use landuse_data_module implicit none @@ -9,6 +10,8 @@ subroutine hrudb_init integer :: ihru = 0 !none |counter integer :: iob = 0 ! | integer :: ihru_db = 0 ! | + integer :: ilu = 0 ! | + !!assign database pointers for the hru imp = 0 @@ -21,6 +24,8 @@ subroutine hrudb_init hru(ihru)%area_ha = ob(iob)%area_ha hru(ihru)%km = ob(iob)%area_ha / 100. hru(ihru)%land_use_mgt_c = hru_db(ihru_db)%dbsc%land_use_mgt + ilu = hru(ihru)%dbs%land_use_mgt + hru(ihru)%cal_group = lum(ilu)%cal_group end do return diff --git a/src/hyd_connect.f90 b/src/hyd_connect.f90 index 834af9e..793f0fd 100644 --- a/src/hyd_connect.f90 +++ b/src/hyd_connect.f90 @@ -298,36 +298,28 @@ subroutine hyd_connect !! allocate zero arrays for constituents allocate (hin_csz%pest(cs_db%num_pests), source = 0.) allocate (hin_csz%path(cs_db%num_paths), source = 0.) + allocate (hin_csz%hmet(cs_db%num_metals), source = 0.) allocate (hin_csz%salt(cs_db%num_salts), source = 0.) !rtb salt - allocate (hin_csz%cs(cs_db%num_cs), source = 0.) !rtb se - + allocate (hcs1%pest(cs_db%num_pests), source = 0.) allocate (hcs1%path(cs_db%num_paths), source = 0.) + allocate (hcs1%hmet(cs_db%num_metals), source = 0.) allocate (hcs1%salt(cs_db%num_salts), source = 0.) !rtb salt - allocate (hcs1%cs(cs_db%num_cs), source = 0.) !rtb cs - + allocate (hcs2%pest(cs_db%num_pests), source = 0.) allocate (hcs2%path(cs_db%num_paths), source = 0.) + allocate (hcs2%hmet(cs_db%num_metals), source = 0.) allocate (hcs2%salt(cs_db%num_salts), source = 0.) !rtb salt - allocate (hcs2%cs(cs_db%num_cs), source = 0.) !rtb cs - + allocate (hcs3%pest(cs_db%num_pests), source = 0.) allocate (hcs3%path(cs_db%num_paths), source = 0.) + allocate (hcs3%hmet(cs_db%num_metals), source = 0.) allocate (hcs3%salt(cs_db%num_salts), source = 0.) !rtb salt - allocate (hcs3%cs(cs_db%num_cs), source = 0.) !rtb cs - - allocate (hcs1%hmet(cs_db%num_metals), source = 0.) - - allocate (hcs2%hmet(cs_db%num_metals), source = 0.) - - allocate (hcs3%hmet(cs_db%num_metals), source = 0.) - allocate (hin_csz%hmet(cs_db%num_metals), source = 0.) - hin_csz%pest = 0. hin_csz%path = 0. hin_csz%hmet = 0. diff --git a/src/hyd_read_connect.f90 b/src/hyd_read_connect.f90 index c97884a..8e81a69 100644 --- a/src/hyd_read_connect.f90 +++ b/src/hyd_read_connect.f90 @@ -73,7 +73,7 @@ subroutine hyd_read_connect(con_file, obtyp, nspu1, nspu, nhyds, ndsave) ob(i)%trans = hz ob(i)%hin_tot = hz ob(i)%hout_tot = hz - + ob(i)%hd_aa(:) = hz if (cs_db%num_tot > 0) then @@ -96,13 +96,14 @@ subroutine hyd_read_connect(con_file, obtyp, nspu1, nspu, nhyds, ndsave) allocate (obcs(i)%hin_sur(1)%pest(npests), source = 0.) allocate (obcs(i)%hin_lat(1)%pest(npests), source = 0.) allocate (obcs(i)%hin_til(1)%pest(npests), source = 0.) - allocate (obcs(i)%hin(1)%path(npaths), source = 0.) - allocate (obcs(i)%hin_sur(1)%path(npaths), source = 0.) - allocate (obcs(i)%hin_lat(1)%path(npaths), source = 0.) - allocate (obcs(i)%hin_til(1)%path(npaths), source = 0.) + end if npaths = cs_db%num_paths if (npaths > 0) then + allocate (obcs(i)%hin(1)%path(npaths), source = 0.) + allocate (obcs(i)%hin_sur(1)%path(npaths), source = 0.) + allocate (obcs(i)%hin_lat(1)%path(npaths), source = 0.) + allocate (obcs(i)%hin_til(1)%path(npaths), source = 0.) end if nmetals = cs_db%num_metals if (nmetals > 0) then @@ -141,18 +142,18 @@ subroutine hyd_read_connect(con_file, obtyp, nspu1, nspu, nhyds, ndsave) ncs = cs_db%num_cs !rtb cs if (ncs > 0) then allocate (obcs(i)%hin(1)%cs(ncs), source = 0.) - allocate (obcs(i)%hin_sur(1)%cs(ncs), source = 0.) - allocate (obcs(i)%hin_lat(1)%cs(ncs), source = 0.) - allocate (obcs(i)%hin_til(1)%cs(ncs), source = 0.) allocate (obcs(i)%hin(1)%cs_sorb(ncs), source = 0.) allocate (obcs(i)%hin(1)%csc(ncs), source = 0.) allocate (obcs(i)%hin(1)%csc_sorb(ncs), source = 0.) + allocate (obcs(i)%hin_sur(1)%cs(ncs), source = 0.) allocate (obcs(i)%hin_sur(1)%cs_sorb(ncs), source = 0.) allocate (obcs(i)%hin_sur(1)%csc(ncs), source = 0.) allocate (obcs(i)%hin_sur(1)%csc_sorb(ncs), source = 0.) + allocate (obcs(i)%hin_lat(1)%cs(ncs), source = 0.) allocate (obcs(i)%hin_lat(1)%cs_sorb(ncs), source = 0.) allocate (obcs(i)%hin_lat(1)%csc(ncs), source = 0.) allocate (obcs(i)%hin_lat(1)%csc_sorb(ncs), source = 0.) + allocate (obcs(i)%hin_til(1)%cs(ncs), source = 0.) allocate (obcs(i)%hin_til(1)%cs_sorb(ncs), source = 0.) allocate (obcs(i)%hin_til(1)%csc(ncs), source = 0.) allocate (obcs(i)%hin_til(1)%csc_sorb(ncs), source = 0.) @@ -249,12 +250,13 @@ subroutine hyd_read_connect(con_file, obtyp, nspu1, nspu, nhyds, ndsave) allocate (obcs(i)%hcsout_m(iout)%pest(npests), source = 0.) allocate (obcs(i)%hcsout_y(iout)%pest(npests), source = 0.) allocate (obcs(i)%hcsout_a(iout)%pest(npests), source = 0.) - allocate (obcs(i)%hcsout_m(iout)%path(npaths), source = 0.) - allocate (obcs(i)%hcsout_y(iout)%path(npaths), source = 0.) - allocate (obcs(i)%hcsout_a(iout)%path(npaths), source = 0.) + end if npaths = cs_db%num_paths if (npaths > 0) then + allocate (obcs(i)%hcsout_m(iout)%path(npaths), source = 0.) + allocate (obcs(i)%hcsout_y(iout)%path(npaths), source = 0.) + allocate (obcs(i)%hcsout_a(iout)%path(npaths), source = 0.) end if if (nmetals > 0) then @@ -264,25 +266,25 @@ subroutine hyd_read_connect(con_file, obtyp, nspu1, nspu, nhyds, ndsave) end if if (nsalts > 0) then !rtb salt allocate (obcs(i)%hcsout_m(iout)%salt(nsalts), source = 0.) - allocate (obcs(i)%hcsout_y(iout)%salt(nsalts), source = 0.) - allocate (obcs(i)%hcsout_a(iout)%salt(nsalts), source = 0.) allocate (obcs(i)%hcsout_m(iout)%salt_min(nsalts), source = 0.) allocate (obcs(i)%hcsout_m(iout)%saltc(nsalts), source = 0.) + allocate (obcs(i)%hcsout_y(iout)%salt(nsalts), source = 0.) allocate (obcs(i)%hcsout_y(iout)%salt_min(nsalts), source = 0.) allocate (obcs(i)%hcsout_y(iout)%saltc(nsalts), source = 0.) + allocate (obcs(i)%hcsout_a(iout)%salt(nsalts), source = 0.) allocate (obcs(i)%hcsout_a(iout)%salt_min(nsalts), source = 0.) allocate (obcs(i)%hcsout_a(iout)%saltc(nsalts), source = 0.) end if if (ncs > 0) then !rtb cs allocate (obcs(i)%hcsout_m(iout)%cs(ncs), source = 0.) - allocate (obcs(i)%hcsout_y(iout)%cs(ncs), source = 0.) - allocate (obcs(i)%hcsout_a(iout)%cs(ncs), source = 0.) allocate (obcs(i)%hcsout_m(iout)%cs_sorb(ncs), source = 0.) allocate (obcs(i)%hcsout_m(iout)%csc(ncs), source = 0.) allocate (obcs(i)%hcsout_m(iout)%csc_sorb(ncs), source = 0.) + allocate (obcs(i)%hcsout_y(iout)%cs(ncs), source = 0.) allocate (obcs(i)%hcsout_y(iout)%cs_sorb(ncs), source = 0.) allocate (obcs(i)%hcsout_y(iout)%csc(ncs), source = 0.) allocate (obcs(i)%hcsout_y(iout)%csc_sorb(ncs), source = 0.) + allocate (obcs(i)%hcsout_a(iout)%cs(ncs), source = 0.) allocate (obcs(i)%hcsout_a(iout)%cs_sorb(ncs), source = 0.) allocate (obcs(i)%hcsout_a(iout)%csc(ncs), source = 0.) allocate (obcs(i)%hcsout_a(iout)%csc_sorb(ncs), source = 0.) diff --git a/src/hydro_init.f90 b/src/hydro_init.f90 index e78d5bd..18f258b 100644 --- a/src/hydro_init.f90 +++ b/src/hydro_init.f90 @@ -88,7 +88,6 @@ subroutine hydro_init if (bsn_prm%ffcb <= 0.) then sffc = wgn_pms(iwgn)%pcp_an / (wgn_pms(iwgn)%pcp_an + Exp(9.043 - & .002135 * wgn_pms(iwgn)%pcp_an)) - !!S-curve equation Jeff made up. else sffc = bsn_prm%ffcb end if diff --git a/src/hydrograph_module.f90 b/src/hydrograph_module.f90 index ff837ef..b9f2b9c 100644 --- a/src/hydrograph_module.f90 +++ b/src/hydrograph_module.f90 @@ -362,6 +362,8 @@ module hydrograph_module real :: runoff = 0. !irrigation surface runoff |mm real :: eff = 1. !irrigation efficiency as a fraction of irrigation. Jaehak 2022 real :: frac_surq = 0. !fraction of irrigation lost in runoff flow. Jaehak 2022 + real :: no3 = 0. !nitrate concentration in irrigation water |kg Jaehak 2023 + real :: salt = 0. !salt concentration in irrigation water |ppm !hyd_output units are in mm and mg/L type (hyd_output) :: water !irrigation water end type irrigation_water_transfer @@ -785,6 +787,9 @@ module hydrograph_module character (len=15) :: lag = " tons" !! tons |detached large ag character (len=15) :: grv = " tons" !! tons |gravel character (len=15) :: temp = " " !! deg c |temperature + !Jaehak 2023 + !character (len=15) :: salt = " kg" !! deg c |temperature + !character (len=15) :: pest = " mg" !! deg c |temperature end type hyd_header_units1 type (hyd_header_units1) :: hyd_hdr_units1 @@ -807,6 +812,9 @@ module hydrograph_module character (len=15) :: lag = " tons" !! tons |detached large ag character (len=15) :: grv = " tons" !! tons |gravel character (len=15) :: temp = " " !! deg c |temperature + !Jaehak 2023 + !character (len=15) :: salt = " kg" !! deg c |temperature + !character (len=15) :: pest = " mg" !! deg c |temperature end type hyd_header_units3 type (hyd_header_units3) :: hyd_hdr_units3 @@ -967,47 +975,47 @@ module hydrograph_module character (len=11) :: min = " min " end type output_flow_duration_header type (output_flow_duration_header) :: fdc_hdr - + type calibration_header character (len=16) :: name = " name " character (len=12) :: ha = " ha " character (len=12) :: nbyr = " nbyr " character (len=12) :: prec = " precip " - character (len=16) :: meas = " name " - character (len=12) :: srr = " srr " - character (len=12) :: lfr = " lfr " - character (len=12) :: pcr = " pcr " - character (len=12) :: etr = " etr " - character (len=12) :: tfr = " tfr " - character (len=12) :: sed = " sed " - character (len=12) :: orgn = " orgn " - character (len=12) :: orgp = " orgp " - character (len=12) :: no3 = " no3 " - character (len=12) :: solp = " solp " - character (len=16) :: aa = " name " - character (len=12) :: srr_aa = " srr " - character (len=12) :: lfr_aa = " lfr " - character (len=12) :: pcr_aa = " pcr " - character (len=12) :: etr_aa = " etr " - character (len=12) :: tfr_aa = " tfr " - character (len=12) :: sed_aa = " sed " - character (len=12) :: orgn_aa = " orgn " - character (len=12) :: orgp_aa = " orgp " - character (len=12) :: no3_aa = " no3 " - character (len=12) :: solp_aa = " solp " - character (len=12) :: cn_prm_aa = " cn " - character (len=12) :: esco = " esco " - character (len=12) :: lat_len = "lat_len " - character (len=12) :: petco = " petco " - character (len=12) :: slope = " slope " - character (len=12) :: tconc = " tconc " - character (len=12) :: etco = " etco " - character (len=12) :: perco = " perco " - character (len=12) :: revapc = " revapc " - character (len=12) :: cn3_swf = " cn3_swf " + character (len=16) :: meas = " name " + character (len=12) :: srr = " srr " + character (len=12) :: lfr = " lfr " + character (len=12) :: pcr = " pcr " + character (len=12) :: etr = " etr " + character (len=12) :: tfr = " tfr " + character (len=12) :: sed = " sed " + character (len=12) :: orgn = " orgn " + character (len=12) :: orgp = " orgp " + character (len=12) :: no3 = " no3 " + character (len=12) :: solp = " solp " + character (len=16) :: aa = " name " + character (len=12) :: srr_aa = " srr " + character (len=12) :: lfr_aa = " lfr " + character (len=12) :: pcr_aa = " pcr " + character (len=12) :: etr_aa = " etr " + character (len=12) :: tfr_aa = " tfr " + character (len=12) :: sed_aa = " sed " + character (len=12) :: orgn_aa = " orgn " + character (len=12) :: orgp_aa = " orgp " + character (len=12) :: no3_aa = " no3 " + character (len=12) :: solp_aa = " solp " + character (len=12) :: cn_prm_aa = " cn " + character (len=12) :: esco = " esco " + character (len=12) :: lat_len = "lat_len " + character (len=12) :: petco = " petco " + character (len=12) :: slope = " slope " + character (len=12) :: tconc = " tconc " + character (len=12) :: etco = " etco " + character (len=12) :: perco = " perco " + character (len=12) :: revapc = " revapc " + character (len=12) :: cn3_swf = " cn3_swf " end type calibration_header - type (calibration_header) :: calb_hdr - + type (calibration_header) :: calb_hdr + type calibration2_header character (len=16) :: name = " name " character (len=12) :: dakm2 = " da_km2 " @@ -1042,7 +1050,7 @@ module hydrograph_module character (len=12) :: uslep = " uslep " character (len=12) :: uslels = " uslels " end type calibration2_header - type (calibration2_header) :: calb2_hdr + type (calibration2_header) :: calb2_hdr type calibration3_header character (len=16) :: name = " name " @@ -1119,7 +1127,7 @@ module hydrograph_module end type hru_swift_header_baseunit type hru_swift_header_base2 - character (len=16) :: flo = "flo " !! ha-m |volume of water + character (len=17) :: flo = "flo " !! ha-m |volume of water type(hru_swift_header_base) :: base end type hru_swift_header_base2 @@ -1129,7 +1137,7 @@ module hydrograph_module end type hru_swift_header_baseunit2 type hru_swift_header - character(len=16) :: hd_type(5) = ["total_flow ", "percolation ", "surface_runoff ", "lateral_flow ", "tile_flow "] + character(len=17) :: hd_type(5) = ["total_flow ", "percolation ", "surface_runoff ", "lateral_flow ", "tile_flow "] type (hru_swift_header_base) :: exco type (hru_swift_header_baseunit) :: exco_unit type (hru_swift_header_base2) :: dr diff --git a/src/input_file_module.f90 b/src/input_file_module.f90 index 80e5f56..3154700 100644 --- a/src/input_file_module.f90 +++ b/src/input_file_module.f90 @@ -20,7 +20,7 @@ module input_file_module character(len=25) :: parms_bas = "parameters.bsn" end type input_basin type (input_basin) :: in_basin - + !! climate type input_cli character(len=25) :: weat_sta = "weather-sta.cli" @@ -95,7 +95,7 @@ module input_file_module character(len=25) :: hru_ez = "hru-lte.hru" end type input_hru type (input_hru) :: in_hru - + !! exco (recall constant) type input_exco character(len=25) :: exco = "exco.exc" @@ -106,7 +106,7 @@ module input_file_module character(len=25) :: salt = "exco_salt.exc" end type input_exco type (input_exco) :: in_exco - + !! recall (daily, monthly and annual) type input_rec character(len=25) :: recall_rec = "recall.rec" @@ -116,11 +116,11 @@ module input_file_module !! delivery ratio type input_delr character(len=25) :: del_ratio = "delratio.del" - character(len=25) :: om = "dr_om.del" - character(len=25) :: pest = "dr_pest.del" - character(len=25) :: path = "dr_path.del" - character(len=25) :: hmet = "dr_hmet.del" - character(len=25) :: salt = "dr_salt.del" + character(len=25) :: om = "dr_om.del" + character(len=25) :: pest = "dr_pest.del" + character(len=25) :: path = "dr_path.del" + character(len=25) :: hmet = "dr_hmet.del" + character(len=25) :: salt = "dr_salt.del" end type input_delr type (input_delr) :: in_delr @@ -178,9 +178,9 @@ module input_file_module character(len=25) :: fert_frt = "fertilizer.frt" character(len=25) :: till_til = "tillage.til" character(len=25) :: pest = "pesticide.pes" - character(len=25) :: pathcom_db = "pathogens.pth" - character(len=25) :: hmetcom_db = "metals.mtl" - character(len=25) :: saltcom_db = "salt.slt" + character(len=25) :: pathcom_db = "pathogens.pth" + character(len=25) :: hmetcom_db = "metals.mtl" + character(len=25) :: saltcom_db = "salt.slt" character(len=25) :: urban_urb = "urban.urb" character(len=25) :: septic_sep = "septic.sep" character(len=25) :: snow = "snow.sno" @@ -224,17 +224,17 @@ module input_file_module !! initial conditions type input_init - character(len=25) :: plant = "plant.ini" + character(len=25) :: plant = "plant.ini" character(len=25) :: soil_plant_ini = "soil_plant.ini" character(len=25) :: om_water = "om_water.ini" - character(len=25) :: pest_soil = "pest_hru.ini" - character(len=25) :: pest_water = "pest_water.ini" - character(len=25) :: path_soil = "path_hru.ini" - character(len=25) :: path_water = "path_water.ini" - character(len=25) :: hmet_soil = "hmet_hru.ini" - character(len=25) :: hmet_water = "hmet_water.ini" - character(len=25) :: salt_soil = "salt_hru.ini" - character(len=25) :: salt_water = "salt_water.ini" + character(len=25) :: pest_soil = "pest_hru.ini" + character(len=25) :: pest_water = "pest_water.ini" + character(len=25) :: path_soil = "path_hru.ini" + character(len=25) :: path_water = "path_water.ini" + character(len=25) :: hmet_soil = "hmet_hru.ini" + character(len=25) :: hmet_water = "hmet_water.ini" + character(len=25) :: salt_soil = "salt_hru.ini" + character(len=25) :: salt_water = "salt_water.ini" end type input_init type (input_init) :: in_init diff --git a/src/lcu_read_softcal.f90 b/src/lcu_read_softcal.f90 index 033969d..c001615 100644 --- a/src/lcu_read_softcal.f90 +++ b/src/lcu_read_softcal.f90 @@ -25,7 +25,7 @@ subroutine lcu_read_softcal imax = 0 mcal = 0 mreg = 0 - + inquire (file=in_chg%water_balance_sft, exist=i_exist) if (.not. i_exist .or. in_chg%water_balance_sft == "null") then allocate (lscal(0:0)) diff --git a/src/ls_read_parms_cal.f90 b/src/ls_read_parms_cal.f90 index 266c50d..8ff6629 100644 --- a/src/ls_read_parms_cal.f90 +++ b/src/ls_read_parms_cal.f90 @@ -38,7 +38,7 @@ subroutine ls_read_lsparms_cal if (eof < 0) exit end do - end if + end if close(107) return diff --git a/src/lsreg_output.f90 b/src/lsreg_output.f90 index abdc39b..e4806f7 100644 --- a/src/lsreg_output.f90 +++ b/src/lsreg_output.f90 @@ -336,6 +336,6 @@ subroutine lsreg_output 100 format (4i6,2a16,22f12.3) 101 format (4i6,2a16,24f12.3) 102 format (4i6,2a16,24f12.3) -103 format (4i6,i8,4x,a,5x,f12.3) +!*** tu Wunused-label: 103 format (4i6,i8,4x,a,5x,f12.3) end subroutine lsreg_output \ No newline at end of file diff --git a/src/lsu_output.f90 b/src/lsu_output.f90 index 0a9bfb3..3546bd9 100644 --- a/src/lsu_output.f90 +++ b/src/lsu_output.f90 @@ -260,6 +260,6 @@ subroutine lsu_output 102 format (1x,4i6,i7,a,2x,a,40f12.3) !103 format (4i6,i8,a,2x,a,6f12.3,29f17.3) 103 format (4i6,i8,a,2x,a,4f12.3,23f17.3) -104 format (4i6,i8,a,2x,a,6f12.3,29f17.3) +!*** tu Wunused-label: 104 format (4i6,i8,a,2x,a,6f12.3,29f17.3) end subroutine lsu_output \ No newline at end of file diff --git a/src/lsu_read_elements.f90 b/src/lsu_read_elements.f90 index 9bc6af1..1d6346c 100644 --- a/src/lsu_read_elements.f90 +++ b/src/lsu_read_elements.f90 @@ -90,7 +90,7 @@ subroutine lsu_read_elements exit end do - end if + end if !!read data for each element in all landscape cataloging units inquire (file=in_regs%ele_lsu, exist=i_exist) diff --git a/src/manure_allocation_module.f90 b/src/manure_allocation_module.f90 index c891a13..a452e82 100644 --- a/src/manure_allocation_module.f90 +++ b/src/manure_allocation_module.f90 @@ -66,56 +66,56 @@ module manure_allocation_module type (manure_allocation), dimension(:), allocatable :: mallo !dimension by water allocation objects type mallo_header - character(len=6) :: day = " jday" - character(len=6) :: mo = " mon" - character(len=6) :: day_mo = " day " - character(len=6) :: yrc = " yr " - character(len=8) :: idmd = " unit " - character(len=16) :: dmd_typ = "dmd_typ " - character(len=16) :: dmd_num = " dmd_num " + character(len=6) :: day = " jday" + character(len=6) :: mo = " mon" + character(len=6) :: day_mo = " day " + character(len=6) :: yrc = " yr " + character(len=8) :: idmd = " unit " + character(len=16) :: dmd_typ = "dmd_typ " + character(len=16) :: dmd_num = " dmd_num " character(len=12) :: src1_obj = " src1_obj " - character(len=12) :: src1_typ = " src1_typ " - character(len=12) :: src1_num = " src1_num " - character(len=15) :: dmd1 = " demand " !! ha-m |demand - muni or irrigation + character(len=12) :: src1_typ = " src1_typ " + character(len=12) :: src1_num = " src1_num " + character(len=15) :: dmd1 = " demand " !! ha-m |demand - muni or irrigation character(len=15) :: s1out = "src1_withdraw " !! ha-m |withdrawal from source 1 character(len=12) :: s1un = " src1_unmet" !! ha-m |unmet from source 1 - character(len=12) :: src2_typ = " src2_typ " - character(len=12) :: src2_num = " src2_num " - character(len=15) :: dmd2 = " demand " !! ha-m |demand - muni or irrigation + character(len=12) :: src2_typ = " src2_typ " + character(len=12) :: src2_num = " src2_num " + character(len=15) :: dmd2 = " demand " !! ha-m |demand - muni or irrigation character(len=15) :: s2out = "src2_withdraw " !! ha-m |withdrawal from source 2 character(len=12) :: s2un = " src2_unmet" !! ha-m |unmet from source 2 - character(len=12) :: src3_typ = " src3_typ " - character(len=12) :: src3_num = " src3_num " - character(len=15) :: dmd3 = " demand " !! ha-m |demand - muni or irrigation + character(len=12) :: src3_typ = " src3_typ " + character(len=12) :: src3_num = " src3_num " + character(len=15) :: dmd3 = " demand " !! ha-m |demand - muni or irrigation character(len=15) :: s3out = "src3_withdraw " !! ha-m |withdrawal from source 3 character(len=12) :: s3un = " src3_unmet" !! ha-m |unmet from source 3 end type mallo_header type (mallo_header) :: mallo_hdr type mallo_header_units - character (len=8) :: day = " " - character (len=8) :: mo = " " - character (len=8) :: day_mo = " " - character (len=8) :: yrc = " " - character (len=8) :: idmd = " " - character (len=16) :: dmd_typ = " " - character (len=16) :: dmd_num = " " + character (len=8) :: day = " " + character (len=8) :: mo = " " + character (len=8) :: day_mo = " " + character (len=8) :: yrc = " " + character (len=8) :: idmd = " " + character (len=16) :: dmd_typ = " " + character (len=16) :: dmd_num = " " character (len=12) :: src1_obj = " " - character (len=12) :: src1_typ = " " - character (len=8) :: src1_num = " " + character (len=12) :: src1_typ = " " + character (len=8) :: src1_num = " " character (len=15) :: dmd1 = "m^3 " !! ha-m |demand - muni or irrigation - character (len=15) :: s1out = "m^3 " !! ha-m |withdrawal from source 1 + character (len=15) :: s1out = "m^3 " !! ha-m |withdrawal from source 1 character (len=9) :: s1un = "m^3 " !! ha-m |unmet from source 1 - character (len=15) :: src2_typ = " " - character (len=15) :: src2_num = " " + character (len=15) :: src2_typ = " " + character (len=15) :: src2_num = " " character (len=15) :: dmd2 = "m^3 " !! ha-m |demand - muni or irrigation - character (len=15) :: s2out = "m^3 " !! ha-m |withdrawal from source 2 - character (len=10) :: s2un = "m^3 " !! ha-m |unmet from source 2 - character (len=15) :: src3_typ = " " - character (len=15) :: src3_num = " " + character (len=15) :: s2out = "m^3 " !! ha-m |withdrawal from source 2 + character (len=15) :: s2un = "m^3 " !! ha-m |unmet from source 2 + character (len=15) :: src3_typ = " " + character (len=15) :: src3_num = " " character (len=15) :: dmd3 = "m^3 " !! ha-m |demand - muni or irrigation - character (len=15) :: s3out = "m^3 " !! ha-m |withdrawal from source 3 - character (len=10) :: s3un = "m^3 " !! ha-m |unmet from source 3 + character (len=15) :: s3out = "m^3 " !! ha-m |withdrawal from source 3 + character (len=15) :: s3un = "m^3 " !! ha-m |unmet from source 3 end type mallo_header_units type (mallo_header_units) :: mallo_hdr_units diff --git a/src/mgt_killop.f90 b/src/mgt_killop.f90 index 10ad6fc..8dc7aff 100644 --- a/src/mgt_killop.f90 +++ b/src/mgt_killop.f90 @@ -27,7 +27,7 @@ subroutine mgt_killop (jj, iplant) !! allocate dead roots, N, P to soil layers do ly = 1, soil(j)%nly - soil1(j)%rsd(ly) = soil(j)%ly(ly)%rtfr * pl_mass(j)%root(ipl) + soil1(j)%rsd(ly) + soil1(j)%rsd(ly) = soil(j)%ly(ly)%rtfr * pl_mass(j)%root(ipl) + soil1(j)%rsd(ly) end do !! add above ground mass to residue pool diff --git a/src/mgt_newtillmix.f90 b/src/mgt_newtillmix.f90 index 282ccc5..e18d202 100644 --- a/src/mgt_newtillmix.f90 +++ b/src/mgt_newtillmix.f90 @@ -124,8 +124,8 @@ subroutine mgt_newtillmix (jj, bmix, idtill) if (soil(jj)%phys(l)%d <= dtil) then !! msm = mass of soil mixed for the layer - !! msn = mass of soil not mixed for the layer - sol_msm(l) = emix * sol_mass(l) + !! msn = mass of soil not mixed for the layer + sol_msm(l) = emix * sol_mass(l) sol_msn(l) = sol_mass(l) - sol_msm(l) frac_dep(l) = soil(jj)%phys(l)%thick / dtil else if (soil(jj)%phys(l)%d > dtil .and. soil(jj)%phys(l-1)%d < dtil) then @@ -165,21 +165,21 @@ subroutine mgt_newtillmix (jj, bmix, idtill) !!by zhang !!============== if (bsn_cc%cswat == 2) then - smix(20+npmx+1) = smix(20+npmx+1) + soil1(jj)%str(l)%c * frac_mixed - smix(20+npmx+2) = smix(20+npmx+2) + soil1(jj)%lig(l)%c * frac_mixed - smix(20+npmx+3) = smix(20+npmx+3) + soil1(jj)%lig(l)%n* frac_mixed - smix(20+npmx+4) = smix(20+npmx+4) + soil1(jj)%meta(l)%c * frac_mixed - smix(20+npmx+5) = smix(20+npmx+5) + soil1(jj)%meta(l)%m * frac_mixed - smix(20+npmx+6) = smix(20+npmx+6) + soil1(jj)%lig(l)%m * frac_mixed - smix(20+npmx+7) = smix(20+npmx+7) + soil1(jj)%str(l)%m * frac_mixed - - smix(20+npmx+8) = smix(20+npmx+8) + soil1(jj)%str(l)%n * frac_mixed - smix(20+npmx+9) = smix(20+npmx+9) + soil1(jj)%meta(l)%n * frac_mixed - smix(20+npmx+10) = smix(20+npmx+10) +soil1(jj)%microb(l)%n* frac_mixed - smix(20+npmx+11) = smix(20+npmx+11) + soil1(jj)%hact(l)%n * frac_mixed - smix(20+npmx+12) = smix(20+npmx+12) + soil1(jj)%hsta(l)%n * frac_mixed - end if - !!by zhang + smix(20+npmx+1) = smix(20+npmx+1) + soil1(jj)%str(l)%c * frac_mixed + smix(20+npmx+2) = smix(20+npmx+2) + soil1(jj)%lig(l)%c * frac_mixed + smix(20+npmx+3) = smix(20+npmx+3) + soil1(jj)%lig(l)%n* frac_mixed + smix(20+npmx+4) = smix(20+npmx+4) + soil1(jj)%meta(l)%c * frac_mixed + smix(20+npmx+5) = smix(20+npmx+5) + soil1(jj)%meta(l)%m * frac_mixed + smix(20+npmx+6) = smix(20+npmx+6) + soil1(jj)%lig(l)%m * frac_mixed + smix(20+npmx+7) = smix(20+npmx+7) + soil1(jj)%str(l)%m * frac_mixed + + smix(20+npmx+8) = smix(20+npmx+8) + soil1(jj)%str(l)%n * frac_mixed + smix(20+npmx+9) = smix(20+npmx+9) + soil1(jj)%meta(l)%n * frac_mixed + smix(20+npmx+10) = smix(20+npmx+10) +soil1(jj)%microb(l)%n* frac_mixed + smix(20+npmx+11) = smix(20+npmx+11) + soil1(jj)%hact(l)%n * frac_mixed + smix(20+npmx+12) = smix(20+npmx+12) + soil1(jj)%hsta(l)%n * frac_mixed + end if + !!by zhang !!============= end do @@ -189,7 +189,7 @@ subroutine mgt_newtillmix (jj, bmix, idtill) smix(19) = smix(19) / dtil do l = 1, soil(jj)%nly - + ! reconstitute each soil layer frac_non_mixed = sol_msn(l) / sol_mass(l) @@ -234,8 +234,8 @@ subroutine mgt_newtillmix (jj, bmix, idtill) !!by zhang !!============== - end do - + end do + if (bsn_cc%cswat == 1) then call mgt_tillfactor(jj,bmix,emix,dtil) end if diff --git a/src/mgt_newtillmix_wet.f90 b/src/mgt_newtillmix_wet.f90 index 80d84bc..95cd2e6 100644 --- a/src/mgt_newtillmix_wet.f90 +++ b/src/mgt_newtillmix_wet.f90 @@ -94,8 +94,8 @@ subroutine mgt_newtillmix_wet (jj, idtill) if (soil(jj)%phys(l)%d <= dtil) then !! msm = mass of soil mixed for the layer - !! msn = mass of soil not mixed for the layer - sol_msm(l) = emix * sol_mass(l) + !! msn = mass of soil not mixed for the layer + sol_msm(l) = emix * sol_mass(l) sol_msn(l) = sol_mass(l) - sol_msm(l) frac_dep(l) = soil(jj)%phys(l)%thick / dtil frac_dep1(l) = soil(jj)%phys(l)%thick / tdep @@ -137,20 +137,20 @@ subroutine mgt_newtillmix_wet (jj, idtill) !!by zhang !!============== if (bsn_cc%cswat == 2) then - smix(20+npmx+1) = smix(20+npmx+1) + soil1(jj)%str(l)%c * frac_mixed - smix(20+npmx+2) = smix(20+npmx+2) + soil1(jj)%lig(l)%c * frac_mixed - smix(20+npmx+3) = smix(20+npmx+3) + soil1(jj)%lig(l)%n* frac_mixed - smix(20+npmx+4) = smix(20+npmx+4) + soil1(jj)%meta(l)%c * frac_mixed - smix(20+npmx+5) = smix(20+npmx+5) + soil1(jj)%meta(l)%m * frac_mixed - smix(20+npmx+6) = smix(20+npmx+6) + soil1(jj)%lig(l)%m * frac_mixed - smix(20+npmx+7) = smix(20+npmx+7) + soil1(jj)%str(l)%m * frac_mixed - - smix(20+npmx+8) = smix(20+npmx+8) + soil1(jj)%str(l)%n * frac_mixed - smix(20+npmx+9) = smix(20+npmx+9) + soil1(jj)%meta(l)%n * frac_mixed - smix(20+npmx+10) = smix(20+npmx+10) +soil1(jj)%microb(l)%n* frac_mixed - smix(20+npmx+11) = smix(20+npmx+11) + soil1(jj)%hact(l)%n * frac_mixed - smix(20+npmx+12) = smix(20+npmx+12) + soil1(jj)%hsta(l)%n * frac_mixed - end if + smix(20+npmx+1) = smix(20+npmx+1) + soil1(jj)%str(l)%c * frac_mixed + smix(20+npmx+2) = smix(20+npmx+2) + soil1(jj)%lig(l)%c * frac_mixed + smix(20+npmx+3) = smix(20+npmx+3) + soil1(jj)%lig(l)%n* frac_mixed + smix(20+npmx+4) = smix(20+npmx+4) + soil1(jj)%meta(l)%c * frac_mixed + smix(20+npmx+5) = smix(20+npmx+5) + soil1(jj)%meta(l)%m * frac_mixed + smix(20+npmx+6) = smix(20+npmx+6) + soil1(jj)%lig(l)%m * frac_mixed + smix(20+npmx+7) = smix(20+npmx+7) + soil1(jj)%str(l)%m * frac_mixed + + smix(20+npmx+8) = smix(20+npmx+8) + soil1(jj)%str(l)%n * frac_mixed + smix(20+npmx+9) = smix(20+npmx+9) + soil1(jj)%meta(l)%n * frac_mixed + smix(20+npmx+10) = smix(20+npmx+10) +soil1(jj)%microb(l)%n* frac_mixed + smix(20+npmx+11) = smix(20+npmx+11) + soil1(jj)%hact(l)%n * frac_mixed + smix(20+npmx+12) = smix(20+npmx+12) + soil1(jj)%hsta(l)%n * frac_mixed + end if end do ! sand, silt and clay are % so divide by tillage depth @@ -167,7 +167,7 @@ subroutine mgt_newtillmix_wet (jj, idtill) do l = 1, soil(jj)%nly - + ! reconstitute each soil layer frac_non_mixed = sol_msn(l) / sol_mass(l) @@ -209,8 +209,8 @@ subroutine mgt_newtillmix_wet (jj, idtill) soil1(jj)%hact(l)%n = soil1(jj)%hact(l)%n * frac_non_mixed + smix(20 + npmx + 11) * frac_dep(l) soil1(jj)%hsta(l)%n = soil1(jj)%hsta(l)%n * frac_non_mixed + smix(20 + npmx+12) * frac_dep(l) end if - end do - + end do + !if (bsn_cc%cswat == 1) then ! call mgt_tillfactor(jj,bmix,emix,dtil) !end if diff --git a/src/mgt_sched.f90 b/src/mgt_sched.f90 index cbbc30b..9484244 100644 --- a/src/mgt_sched.f90 +++ b/src/mgt_sched.f90 @@ -155,12 +155,13 @@ subroutine mgt_sched (isched) harveff = mgt%op3 call mgt_harvresidue (j, harveff) case ("tree") + call mgt_harvbiomass (j, ipl, iharvop) case ("tuber") call mgt_harvtuber (j, ipl, iharvop) case ("peanuts") call mgt_harvtuber (j, ipl, iharvop) case ("stripper") - call mgt_harvgrain (j, ipl, iharvop) + call mgt_harvbiomass (j, ipl, iharvop) case ("picker") call mgt_harvgrain (j, ipl, iharvop) end select @@ -436,19 +437,24 @@ subroutine mgt_sched (isched) !! set weir height and adjust principal spillway storage and depth wet_ob(j)%weir_hgt = mgt%op3 / 1000. !weir height, m - wet_ob(j)%pvol = hru(j)%area_ha * wet_ob(j)%weir_hgt * 10. + wet_ob(j)%pvol = hru(j)%area_ha * wet_ob(j)%weir_hgt * 10000. !m3 if (wet_ob(j)%evol < wet_ob(j)%pvol*1.1) then wet_ob(j)%evol = wet_ob(j)%pvol * 1.1 endif case ("irrp") !! continuous irrigation to maintain surface ponding in rice fields Jaehak 2022 - hru(j)%irr_src = mgt%op_plant !irrigation source: cha; res; aqu; or unlim - hru(j)%irr_hmin = irrop_db(mgt%op1)%dep_mm !threshold ponding depth, mm + hru(j)%irr_src = mgt%op_plant !irrigation source: cha; res; aqu; or unlim + hru(j)%irr_isc = mgt%op3 !irrigation source object ID: cha; res; aqu; or unlim + hru(j)%irr_hmax = irrop_db(mgt%op1)%amt_mm !irrigation amount in irr.org, mm + hru(j)%irr_hmin = hru(j)%irr_hmax * 0.9 !threshold ponding depth, mm irrig(j)%eff = irrop_db(mgt%op1)%eff irrig(j)%frac_surq = irrop_db(mgt%op1)%surq + irrig(j)%salt = irrop_db(mgt%op1)%salt !ppm salt Jaehak 2023 + irrig(j)%no3 = irrop_db(mgt%op1)%no3 !ppm no3 pcom(j)%days_irr = 1 ! reset days since last irrigation if (mgt%op3 < 0) then hru(j)%irr_hmax = irrop_db(mgt%op1)%amt_mm !irrigation amount in irr.org, mm + if (hru(j)%irr_hmax>0) hru(j)%paddy_irr = 1 !paddy irrigation is on with manual scheduling else hru(j)%irr_hmax = mgt%op3 !target ponding depth, mm if (mgt%op3 > 0) then diff --git a/src/mgt_tillfactor.f90 b/src/mgt_tillfactor.f90 index eff98c8..08d6df8 100644 --- a/src/mgt_tillfactor.f90 +++ b/src/mgt_tillfactor.f90 @@ -1,24 +1,24 @@ subroutine mgt_tillfactor(jj,bmix,emix,dtil) - !!!!!!!!!!!!!!!!!!!!!!! - ! Armen 16 January 2008 - ! This procedure increases tillage factor (tillagef(l,jj) per layer for each operation - ! The tillage factor settling will depend of soil moisture (tentatively) and must be called every day - ! For simplicity the settling is calculated now at the soil carbon subroutine because soil water content is available + !!!!!!!!!!!!!!!!!!!!!!! + ! Armen 16 January 2008 + ! This procedure increases tillage factor (tillagef(l,jj) per layer for each operation + ! The tillage factor settling will depend of soil moisture (tentatively) and must be called every day + ! For simplicity the settling is calculated now at the soil carbon subroutine because soil water content is available - ! The tillage factor depends on the cumulative soil disturbance rating = csdr - ! For simplicity, csdr is a function of emix - ! First step is to calculate "current" csdr by inverting tillage factor function - ! The effect of texture on tillage factor (ZZ) is removed first (and recovered at the end of the procedure) - ! YY = tillagef(l,jj) / ZZ - ! Since the tillage factor function is non linear, iterations are needed - ! XX = 0.5 is the initial value that works OK for the range of values observed - ! If a layer is only partially tilled then emix is corrected accordingly + ! The tillage factor depends on the cumulative soil disturbance rating = csdr + ! For simplicity, csdr is a function of emix + ! First step is to calculate "current" csdr by inverting tillage factor function + ! The effect of texture on tillage factor (ZZ) is removed first (and recovered at the end of the procedure) + ! YY = tillagef(l,jj) / ZZ + ! Since the tillage factor function is non linear, iterations are needed + ! XX = 0.5 is the initial value that works OK for the range of values observed + ! If a layer is only partially tilled then emix is corrected accordingly - use soil_module + use soil_module implicit none - integer, intent (in) :: jj !none |HRU number + integer, intent (in) :: jj !none |HRU number real, intent (in) :: bmix !none |biological mixing efficiency: this ! |number is zero for tillage operations integer :: l = 0 !none |counter @@ -34,43 +34,43 @@ subroutine mgt_tillfactor(jj,bmix,emix,dtil) real :: xx2 = 0. ! | real :: csdr = 0. ! | - emix = emix - bmix ! this is to avoid affecting tillage factor with biological mixing - - if (emix > 0.) then + emix = emix - bmix ! this is to avoid affecting tillage factor with biological mixing + + if (emix > 0.) then - do l = 1, soil(j)%nly - - if (soil(jj)%phys(l)%d <= dtil) then - emix = emix + do l = 1, soil(j)%nly + + if (soil(jj)%phys(l)%d <= dtil) then + emix = emix else if (soil(jj)%phys(l)%d > dtil .and. soil(jj)%phys(l-1)%d < dtil) then - emix = emix * (dtil - soil(jj)%phys(l-1)%d) / soil(jj)%phys(l)%thick - else - emix = 0. - end if - - ! to save computation time if emix = 0 here then the other layers can be avoided - ! tillage always proceeds from top to bottom - if (emix == 0.) exit + emix = emix * (dtil - soil(jj)%phys(l-1)%d) / soil(jj)%phys(l)%thick + else + emix = 0. + end if + + ! to save computation time if emix = 0 here then the other layers can be avoided + ! tillage always proceeds from top to bottom + if (emix == 0.) exit - xx = 0. - zz = 3. + (8. - 3.)*exp(-5.5*soil(jj)%phys(1)%clay/100.) - yy = soil(jj)%ly(l)%tillagef / zz - m1 = 1 - m2 = 2 + xx = 0. + zz = 3. + (8. - 3.)*exp(-5.5*soil(jj)%phys(1)%clay/100.) + yy = soil(jj)%ly(l)%tillagef / zz + m1 = 1 + m2 = 2 - ! empirical solution for x when y is known and y=x/(x+exp(m1-m2*x)) - if (yy > 0.01) then - xx1 = yy ** exp(-0.13 + 1.06 * yy) - xx2 = exp(0.64 + 0.64 * yy ** 100.) - xx = xx1 * xx2 - end if + ! empirical solution for x when y is known and y=x/(x+exp(m1-m2*x)) + if (yy > 0.01) then + xx1 = yy ** exp(-0.13 + 1.06 * yy) + xx2 = exp(0.64 + 0.64 * yy ** 100.) + xx = xx1 * xx2 + end if - csdr = xx + emix - soil(jj)%ly(l)%tillagef = zz * (csdr / (csdr + exp(m1 - m2*csdr))) + csdr = xx + emix + soil(jj)%ly(l)%tillagef = zz * (csdr / (csdr + exp(m1 - m2*csdr))) - end do - - end if - - return - end subroutine mgt_tillfactor \ No newline at end of file + end do + + end if + + return + end subroutine mgt_tillfactor \ No newline at end of file diff --git a/src/mgt_transplant.f90 b/src/mgt_transplant.f90 index fd8b99e..2a5c21d 100644 --- a/src/mgt_transplant.f90 +++ b/src/mgt_transplant.f90 @@ -53,7 +53,7 @@ subroutine mgt_transplant (itrans) !! initialize plant mass call pl_root_gro(j) call pl_seed_gro(j) - call pl_partition(j) + call pl_partition(j, 1) return end subroutine mgt_transplant \ No newline at end of file diff --git a/src/nut_denit.f90 b/src/nut_denit.f90 index 57f1821..8271a18 100644 --- a/src/nut_denit.f90 +++ b/src/nut_denit.f90 @@ -7,19 +7,19 @@ subroutine nut_denit(k,j,cdg,wdn,void) implicit none - integer :: k !none |counter + integer :: k !none |counter integer :: j !none |HRU number - real :: cdg !none |soil temperature factor + real :: cdg !none |soil temperature factor real :: wdn !kg N/ha |amount of nitrogen lost from nitrate pool in ! |layer due to denitrification real :: void ! | real :: vof = 0. ! | wdn = 0. - vof = 1. / (1. + (void/0.04)**5) - wdn = soil1(j)%mn(k)%no3 * (1. - Exp(-bsn_prm%cdn * cdg * vof * & + vof = 1. / (1. + (void/0.04)**5) + wdn = soil1(j)%mn(k)%no3 * (1. - Exp(-bsn_prm%cdn * cdg * vof * & soil1(j)%tot(k)%c)) - soil1(j)%mn(k)%no3 = max(0.0001,soil1(j)%mn(k)%no3 - wdn) + soil1(j)%mn(k)%no3 = max(0.0001,soil1(j)%mn(k)%no3 - wdn) - return - end subroutine nut_denit \ No newline at end of file + return + end subroutine nut_denit \ No newline at end of file diff --git a/src/nut_nlch.f90 b/src/nut_nlch.f90 index 382f434..6c5acb5 100644 --- a/src/nut_nlch.f90 +++ b/src/nut_nlch.f90 @@ -71,7 +71,7 @@ subroutine nut_nlch !! add nitrate leached from layer above soil1(j)%mn(jj)%no3 = soil1(j)%mn(jj)%no3 + percnlyr - if (soil1(j)%mn(jj)%no3 < 1.e-6) soil1(j)%mn(jj)%no3 = 0.0 + if (soil1(j)%mn(jj)%no3 < 1.e-6) soil1(j)%mn(jj)%no3 = 0.0 !! determine concentration of nitrate in mobile water if (jj == 1) then diff --git a/src/nut_nminrl.f90 b/src/nut_nminrl.f90 index 6e7204e..90e0ad0 100644 --- a/src/nut_nminrl.f90 +++ b/src/nut_nminrl.f90 @@ -30,7 +30,6 @@ subroutine nut_nminrl !! ~ ~ ~ ~ ~ ~ END SPECIFICATIONS ~ ~ ~ ~ ~ ~ use septic_data_module - use plant_data_module use basin_module use organic_mineral_mass_module use hru_module, only : rsdco_plcom, i_sep, ihru, ipl, isep @@ -74,89 +73,11 @@ subroutine nut_nminrl j = ihru nactfr = .02 !zero transformations for summing layers - hnb_d(j)%rsd_nitorg_n = 0. - hnb_d(j)%rsd_laborg_p = 0. hnb_d(j)%act_nit_n = 0. hnb_d(j)%org_lab_p = 0. hnb_d(j)%act_sta_n = 0. hnb_d(j)%denit = 0. - !! mineralization can occur only if temp above 0 deg - if (soil(j)%phys(1)%tmp > 0.) then - !! compute residue decomp and mineralization of fresh organic n and p of flat residue - do ipl = 1, pcom(j)%npl !! we need to decompose each plant - rmn1 = 0. - rmp = 0. - if (rsd1(j)%tot(ipl)%n > 1.e-4) then - cnr = rsd1(j)%tot(ipl)%c / rsd1(j)%tot(ipl)%n - if (cnr > 500.) cnr = 500. - cnrf = Exp(-.693 * (cnr - 25.) / 25.) - else - cnrf = 1. - end if - - if (rsd1(j)%tot(ipl)%p > 1.e-4) then - cpr = rsd1(j)%tot(ipl)%c / rsd1(j)%tot(ipl)%p - if (cpr > 5000.) cpr = 5000. - cprf = Exp(-.693 * (cpr - 200.) / 200.) - else - cprf = 1. - end if - - !! compute soil water factor - if (soil(j)%phys(1)%st < 0.) soil(j)%phys(1)%st = .0000001 - sut = .1 + .9 * Sqrt(soil(j)%phys(1)%st / soil(j)%phys(1)%fc) - sut = Max(.05, sut) - - !!compute soil temperature factor - xx = soil(j)%phys(1)%tmp - cdg = .9 * xx / (xx + Exp(9.93 - .312 * xx)) + .1 - cdg = Max(.1, cdg) - - !! compute combined factor - xx = cdg * sut - if (xx < 0.) xx = 0. - if (xx > 1.e6) xx = 1.e6 - csf = Sqrt(xx) - ca = Min(cnrf, cprf, 1.) - !! compute residue decomp and mineralization for each plant - if (pcom(j)%npl > 0) then - idp = pcom(j)%plcur(ipl)%idplt - decr = pldb(idp)%rsdco_pl * ca * csf - else - decr = 0.05 * ca * csf - end if - decr = Max(bsn_prm%decr_min, decr) - decr = Min(decr, 1.) - - !! mineralization of mass and carbon - rsd1(j)%tot(ipl)%m = Max(1.e-6, rsd1(j)%tot(ipl)%m) - rdc = decr * rsd1(j)%tot(ipl)%m - rsd1(j)%tot(ipl)%m = rsd1(j)%tot(ipl)%m - rdc - if (rsd1(j)%tot(ipl)%m < 0.) rsd1(j)%tot(ipl)%m = 0. - rsd1(j)%tot(ipl)%c = (1. - decr) * rsd1(j)%tot(ipl)%c - if (rsd1(j)%tot(ipl)%c < 0.) rsd1(j)%tot(ipl)%c = 0. - soil1(j)%hact(1)%c = soil1(j)%hact(1)%c + decr * rsd1(j)%tot(ipl)%c - - !! mineralization of residue n and p - rmn1 = decr * rsd1(j)%tot(ipl)%n - rsd1(j)%tot(ipl)%n = Max(1.e-6, rsd1(j)%tot(ipl)%n) - rsd1(j)%tot(ipl)%n = rsd1(j)%tot(ipl)%n - rmn1 - soil1(j)%mn(1)%no3 = soil1(j)%mn(1)%no3 + .8 * rmn1 - soil1(j)%hact(1)%n = soil1(j)%hact(1)%n + .2 * rmn1 - - rsd1(j)%tot(ipl)%p = Max(1.e-6, rsd1(j)%tot(ipl)%p) - rmp = decr * rsd1(j)%tot(ipl)%p - rsd1(j)%tot(ipl)%p = rsd1(j)%tot(ipl)%p - rmp - soil1(j)%mp(1)%lab = soil1(j)%mp(1)%lab + .8 * rmp - soil1(j)%hact(1)%p = soil1(j)%hact(1)%p + .2 * rmp - - hnb_d(j)%rsd_nitorg_n = hnb_d(j)%rsd_nitorg_n + .8 * rmn1 - hnb_d(j)%rsd_laborg_p = hnb_d(j)%rsd_laborg_p + .8 * rmp - - end do ! ipl = 1, pcom(j)%npl - end if - !! compute humus mineralization of organic soil pools do k = 1, soil(j)%nly @@ -170,8 +91,8 @@ subroutine nut_nminrl if (soil(j)%phys(kk)%tmp > 0.) then !! compute soil water factor sut = 0. - !! change for domain error 1/29/09 gsm check with Jeff !!! - if (soil(j)%phys(kk)%st < 0.) soil(j)%phys(kk)%st = .0000001 + !! change for domain error 1/29/09 gsm check with Jeff !!! + if (soil(j)%phys(kk)%st < 0.) soil(j)%phys(kk)%st = .0000001 sut = .1 + .9 * Sqrt(soil(j)%phys(kk)%st / soil(j)%phys(kk)%fc) sut = Max(.05, sut) @@ -252,30 +173,20 @@ subroutine nut_nminrl rmn1 = decr * (soil1(j)%str(k)%n + soil1(j)%lig(k)%n + soil1(j)%meta(k)%n) rmp = decr * (soil1(j)%str(k)%p + soil1(j)%lig(k)%p + soil1(j)%meta(k)%p) - soil1(j)%str(k)%n = soil1(j)%str(k)%n * (1. - decr) - soil1(j)%lig(k)%n = soil1(j)%lig(k)%n * (1. - decr) - soil1(j)%meta(k)%n = soil1(j)%meta(k)%n * (1. - decr) - soil1(j)%str(k)%p = soil1(j)%str(k)%p * (1. - decr) - soil1(j)%lig(k)%p = soil1(j)%lig(k)%p * (1. - decr) - soil1(j)%meta(k)%p = soil1(j)%meta(k)%p * (1. - decr) - - ! soil1(j)%mn(k)%no3 = soil1(j)%mn(k)%no3 + .8 * rmn1 - ! soil1(j)%hact(k)%n = soil1(j)%hact(k)%n + .2 * rmn1 - ! soil1(j)%mp(k)%lab = soil1(j)%mp(k)%lab + .8 * rmp - ! soil1(j)%hsta(k)%p = soil1(j)%hsta(k)%p + .2 * rmp - - ! hnb_d(j)%rsd_nitorg_n = hnb_d(j)%rsd_nitorg_n + rmn1 - ! hnb_d(j)%rsd_laborg_p = hnb_d(j)%rsd_laborg_p + rmp + soil1(j)%mn(k)%no3 = soil1(j)%mn(k)%no3 + .8 * rmn1 + soil1(j)%hact(k)%n = soil1(j)%hact(k)%n + .2 * rmn1 + soil1(j)%mp(k)%lab = soil1(j)%mp(k)%lab + .8 * rmp + soil1(j)%hsta(k)%p = soil1(j)%hsta(k)%p + .2 * rmp !! compute denitrification wdn = 0. - if (i_sep(j) /= k .or. sep(isep)%opt /= 1) then - if (sut >= bsn_prm%sdnco) then - wdn = soil1(j)%mn(k)%no3 * (1.-Exp(-bsn_prm%cdn * cdg * soil1(j)%cbn(k) / 100.)) - else - wdn = 0. - endif - soil1(j)%mn(k)%no3 = max(0.0001,soil1(j)%mn(k)%no3 - wdn) + if (i_sep(j) /= k .or. sep(isep)%opt /= 1) then + if (sut >= bsn_prm%sdnco) then + wdn = soil1(j)%mn(k)%no3 * (1.-Exp(-bsn_prm%cdn * cdg * soil1(j)%cbn(k) / 100.)) + else + wdn = 0. + endif + soil1(j)%mn(k)%no3 = max(0.0001,soil1(j)%mn(k)%no3 - wdn) end if hnb_d(j)%denit = hnb_d(j)%denit + wdn diff --git a/src/nut_orgnc.f90 b/src/nut_orgnc.f90 index e2997a9..7e752ea 100644 --- a/src/nut_orgnc.f90 +++ b/src/nut_orgnc.f90 @@ -42,12 +42,12 @@ subroutine nut_orgnc conc = xx * er / wt1 sedorgn(j) = .001 * conc * sedyld(j) / hru(j)%area_ha - !! update soil nitrogen pools only for HRU calculations + !! update soil nitrogen pools only for HRU calculations if (xx > 1.e-6) then xx1 = (1. - sedorgn(j) / xx) - soil1(j)%tot(1)%n = soil1(j)%tot(1)%n * xx1 - rsd1(j)%tot(1)%n = rsd1(j)%tot(1)%n * xx1 - rsd1(j)%man%n = rsd1(j)%man%n * xx1 + soil1(j)%tot(1)%n = soil1(j)%tot(1)%n * xx1 + rsd1(j)%tot(1)%n = rsd1(j)%tot(1)%n * xx1 + rsd1(j)%man%n = rsd1(j)%man%n * xx1 end if return diff --git a/src/nut_orgnc2.f90 b/src/nut_orgnc2.f90 index 6716e52..87b14ea 100644 --- a/src/nut_orgnc2.f90 +++ b/src/nut_orgnc2.f90 @@ -60,8 +60,8 @@ subroutine nut_orgnc2 latc_clyr = 0. perc_clyr = 0. - wt1 = 0. !! conversion factor - er = 0. !! enrichment ratio + wt1 = 0. !! conversion factor + er = 0. !! enrichment ratio !! HRU calculations c_ly1 = rsd1(j)%tot_str%n + rsd1(j)%tot_meta%n + soil1(j)%hp(1)%n + soil1(j)%hs(1)%n !wt = sol_bd(1,j) * sol_z(1,j) * 10. (tons/ha) @@ -79,17 +79,17 @@ subroutine nut_orgnc2 !! HRU calculations sedorgn(j) = .001 * conc * sedyld(j) / hru(j)%area_ha - !! update soil nitrogen pools only for HRU calculations + !! update soil nitrogen pools only for HRU calculations if (xx > 1.e-6) then xx1 = (1. - sedorgn(j) / xx) !!add by zhang to update soil nitrogen pools - rsd1(j)%tot_str%n = rsd1(j)%tot_str%n * xx1 - rsd1(j)%tot_meta%n = rsd1(j)%tot_meta%n * xx1 - soil1(j)%hp(1)%n = soil1(j)%hp(1)%n * xx1 - soil1(j)%hs(1)%n = soil1(j)%hs(1)%n * xx1 - !sol_BMN(1,j) = sol_BMN(1,j) * xx1 + rsd1(j)%tot_str%n = rsd1(j)%tot_str%n * xx1 + rsd1(j)%tot_meta%n = rsd1(j)%tot_meta%n * xx1 + soil1(j)%hp(1)%n = soil1(j)%hp(1)%n * xx1 + soil1(j)%hs(1)%n = soil1(j)%hs(1)%n * xx1 + !sol_BMN(1,j) = sol_BMN(1,j) * xx1 end if !return @@ -111,10 +111,10 @@ subroutine nut_orgnc2 ! Not sure whether should consider enrichment ratio or not! YEW = MIN((sedyld(j)/hru(j)%area_ha+YW/hru(j)%area_ha)/(sol_mass/1000.),.9) !fraction of soil erosion of total soil mass X1=1.-YEW - !YEW=MIN(ER*(YSD(NDRV)+YW)/WT(LD1),.9) - !ER enrichment ratio - !YSD water erosion - !YW wind erosion + !YEW=MIN(ER*(YSD(NDRV)+YW)/WT(LD1),.9) + !ER enrichment ratio + !YSD water erosion + !YW wind erosion YOC=YEW*TOT soil1(j)%hs(1)%c = soil1(j)%hs(1)%c * X1 soil1(j)%hp(1)%c = soil1(j)%hp(1)%c * X1 @@ -138,7 +138,7 @@ subroutine nut_orgnc2 XX=X1+DK !V=QD+Y4 V = surfq(j) + soil(j)%ly(1)%prk + soil(j)%ly(1)%flat - !QD surface runoff + !QD surface runoff X3=0. IF(V>1.E-10)THEN X3 = soil1(j)%microb(1)%c * (1.-EXP(-V/XX)) !loss of biomass C diff --git a/src/nut_pminrl2.f90 b/src/nut_pminrl2.f90 index 2ec1458..1e188c8 100644 --- a/src/nut_pminrl2.f90 +++ b/src/nut_pminrl2.f90 @@ -26,14 +26,14 @@ subroutine nut_pminrl2 ! |mineral to the stable mineral pool in the soil layer real :: wetness = 0. ! | real :: base = 0. ! | - real :: vara = 0. ! |Intermediate Variable - real :: varb = 0. ! |Intermediate Variable - real :: varc = 0. ! |Intermediate Variable + real :: vara = 0. ! |Intermediate Variable + real :: varb = 0. ! |Intermediate Variable + real :: varc = 0. ! |Intermediate Variable real :: as_p_coeff = 0. ! | - real :: solp = 0. !mg/kg |Solution pool phosphorous content - real :: actpp = 0. !mg/kg |Active pool phosphorous content - real :: stap = 0. !mg/kg |Stable pool phosphorous content - real :: arate = 0. ! |Intermediate Variable + real :: solp = 0. !mg/kg |Solution pool phosphorous content + real :: actpp = 0. !mg/kg |Active pool phosphorous content + real :: stap = 0. !mg/kg |Stable pool phosphorous content + real :: arate = 0. ! |Intermediate Variable real :: ssp = 0. ! | real :: psp = 0. ! | @@ -42,126 +42,126 @@ subroutine nut_pminrl2 hnb_d(j)%lab_min_p = 0. hnb_d(j)%act_sta_p = 0. do l = 1, soil(j)%nly !! loop through soil layers in this HRU - !! make sure that no zero or negative pool values come in - if (soil1(j)%mp(l)%lab <= 1.e-6) soil1(j)%mp(l)%lab = 1.e-6 - if (soil1(j)%mp(l)%act <= 1.e-6) soil1(j)%mp(l)%act = 1.e-6 + !! make sure that no zero or negative pool values come in + if (soil1(j)%mp(l)%lab <= 1.e-6) soil1(j)%mp(l)%lab = 1.e-6 + if (soil1(j)%mp(l)%act <= 1.e-6) soil1(j)%mp(l)%act = 1.e-6 if (soil1(j)%mp(l)%sta <= 1.e-6) soil1(j)%mp(l)%sta = 1.e-6 !! Convert kg/ha to ppm so that it is more meaningful to compare between soil layers - solp = soil1(j)%mp(l)%lab / soil(j)%phys(l)%conv_wt - actpp = soil1(j)%mp(l)%act / soil(j)%phys(l)%conv_wt - stap = soil1(j)%mp(l)%sta / soil(j)%phys(l)%conv_wt - -!! ***************Soluble - Active Transformations*************** - - !! Dynamic PSP Ratio - !!PSP = -0.045*log (% clay) + 0.001*(Solution P, mg kg-1) - 0.035*(% Organic C) + 0.43 - if (soil(j)%phys(l)%clay > 0.) then - psp = -0.045 * log(soil(j)%phys(l)%clay)+ (0.001 * solp) - psp = psp - (0.035 * soil1(j)%cbn(l)) + 0.43 - else - psp = 0.4 - end if - !! Limit PSP range - if (psp < .1) psp = 0.1 ! limits on PSP - if (psp > 0.7) psp = 0.7 + solp = soil1(j)%mp(l)%lab / soil(j)%phys(l)%conv_wt + actpp = soil1(j)%mp(l)%act / soil(j)%phys(l)%conv_wt + stap = soil1(j)%mp(l)%sta / soil(j)%phys(l)%conv_wt + +!! ***************Soluble - Active Transformations*************** + + !! Dynamic PSP Ratio + !!PSP = -0.045*log (% clay) + 0.001*(Solution P, mg kg-1) - 0.035*(% Organic C) + 0.43 + if (soil(j)%phys(l)%clay > 0.) then + psp = -0.045 * log(soil(j)%phys(l)%clay)+ (0.001 * solp) + psp = psp - (0.035 * soil1(j)%cbn(l)) + 0.43 + else + psp = 0.4 + end if + !! Limit PSP range + if (psp < .1) psp = 0.1 ! limits on PSP + if (psp > 0.7) psp = 0.7 !! Calculate smoothed PSP average - if (soil(j)%ly(l)%psp_store > 0.) then - psp = (soil(j)%ly(l)%psp_store * 29. + psp * 1.) / 30. - end if + if (soil(j)%ly(l)%psp_store > 0.) then + psp = (soil(j)%ly(l)%psp_store * 29. + psp * 1.) / 30. + end if !! Store PSP for tomrrows smoothing calculation - soil(j)%ly(l)%psp_store = psp + soil(j)%ly(l)%psp_store = psp !!***************Dynamic Active/Soluble Transformation Coeff****************** - !! on day 1 just set to a value of zero + !! on day 1 just set to a value of zero if ((time%day == 1) .and. (time%yrs == 1)) then soil(j)%ly(l)%a_days = 0 !! days since P Application soil(j)%ly(l)%b_days = 0 !! days since P deficit - end if + end if !! Calculate P balance rto = psp / (1. - psp) rmp1 = soil1(j)%mp(l)%lab - soil1(j)%mp(l)%act * rto !! P imbalance - !! Move P between the soluble and active pools based on Vadas et al., 2006 - if (rmp1 >= 0.) then !! Net movement from soluble to active - rmp1 = Max(rmp1, (-1 * soil1(j)%mp(l)%lab)) - !! Calculate Dynamic Coefficant + !! Move P between the soluble and active pools based on Vadas et al., 2006 + if (rmp1 >= 0.) then !! Net movement from soluble to active + rmp1 = Max(rmp1, (-1 * soil1(j)%mp(l)%lab)) + !! Calculate Dynamic Coefficant vara = 0.918 * (exp(-4.603 * psp)) - varb = (-0.238 * ALOG(vara)) - 1.126 - if (soil(j)%ly(l)%a_days >0) then - arate = vara * (soil(j)%ly(l)%a_days ** varb) - else - arate = vara * (1) ** varb - end if - !! limit rate coeff from 0.05 to .5 helps on day 1 when a_days is zero - if (arate > 0.5) arate = 0.5 - if (arate < 0.1) arate = 0.1 - rmp1 = arate * rmp1 - soil(j)%ly(l)%a_days = soil(j)%ly(l)%a_days + 1 !! add a day to the imbalance counter - soil(j)%ly(l)%b_days = 0 + varb = (-0.238 * ALOG(vara)) - 1.126 + if (soil(j)%ly(l)%a_days >0) then + arate = vara * (soil(j)%ly(l)%a_days ** varb) + else + arate = vara * (1) ** varb + end if + !! limit rate coeff from 0.05 to .5 helps on day 1 when a_days is zero + if (arate > 0.5) arate = 0.5 + if (arate < 0.1) arate = 0.1 + rmp1 = arate * rmp1 + soil(j)%ly(l)%a_days = soil(j)%ly(l)%a_days + 1 !! add a day to the imbalance counter + soil(j)%ly(l)%b_days = 0 end if - if (rmp1 < 0.) then !! Net movement from Active to Soluble - rmp1 = Min(rmp1, soil1(j)%mp(l)%act) - !! Calculate Dynamic Coefficant - base = (-1.08 * psp) + 0.79 - varc = base * (exp (-0.29)) - !! limit varc from 0.1 to 1 - if (varc > 1.0) varc = 1.0 - if (varc < 0.1) varc = 0.1 + if (rmp1 < 0.) then !! Net movement from Active to Soluble + rmp1 = Min(rmp1, soil1(j)%mp(l)%act) + !! Calculate Dynamic Coefficant + base = (-1.08 * psp) + 0.79 + varc = base * (exp (-0.29)) + !! limit varc from 0.1 to 1 + if (varc > 1.0) varc = 1.0 + if (varc < 0.1) varc = 0.1 rmp1 = rmp1 * varc - soil(j)%ly(l)%a_days = 0 - soil(j)%ly(l)%b_days = soil(j)%ly(l)%b_days + 1 !! add a day to the imbalance counter + soil(j)%ly(l)%a_days = 0 + soil(j)%ly(l)%b_days = soil(j)%ly(l)%b_days + 1 !! add a day to the imbalance counter End if !!*************** Active - Stable Transformations ****************** !! Estimate active stable transformation rate coeff - !! original value was .0006 - !! based on linear regression rate coeff = 0.005 @ 0% CaCo3 0.05 @ 20% CaCo3 - as_p_coeff = 0.0023 * soil(j)%ly(l)%cal + 0.005 + !! original value was .0006 + !! based on linear regression rate coeff = 0.005 @ 0% CaCo3 0.05 @ 20% CaCo3 + as_p_coeff = 0.0023 * soil(j)%ly(l)%cal + 0.005 if (as_p_coeff > 0.05) as_p_coeff = 0.05 if (as_p_coeff < 0.002) as_p_coeff = 0.002 !! Estimate active/stable pool ratio !! Generated from sharpley 2003 - ssp = 25.044 * (actpp + (actpp * rto))** (-0.3833) - ! limit ssp to range in measured data - if (ssp > 10.) ssp = 10. - if (ssp < 0.7) ssp = 0.7 + ssp = 25.044 * (actpp + (actpp * rto))** (-0.3833) + ! limit ssp to range in measured data + if (ssp > 10.) ssp = 10. + if (ssp < 0.7) ssp = 0.7 - ! Smooth ssp, no rapid changes - if (soil(j)%ly(l)%ssp_store > 0.) then - ssp = (ssp + soil(j)%ly(l)%ssp_store * 99.)/100. - end if + ! Smooth ssp, no rapid changes + if (soil(j)%ly(l)%ssp_store > 0.) then + ssp = (ssp + soil(j)%ly(l)%ssp_store * 99.)/100. + end if roc = ssp * (soil1(j)%mp(l)%act + soil1(j)%mp(l)%act * rto) - roc = roc - soil1(j)%mp(l)%sta - roc = as_p_coeff * roc - !! Store todays ssp for tomarrows calculation - soil(j)%ly(l)%ssp_store = ssp + roc = roc - soil1(j)%mp(l)%sta + roc = as_p_coeff * roc + !! Store todays ssp for tomarrows calculation + soil(j)%ly(l)%ssp_store = ssp !! **************** Account for Soil Water content, do not allow movement in dry soil************ wetness = (soil(j)%phys(l)%st/soil(j)%phys(l)%fc) !! range from 0-1 1 = field cap - if (wetness >1.) wetness = 1. - if (wetness <0.25) wetness = 0.25 - rmp1 = rmp1 * wetness - roc = roc * wetness - + if (wetness >1.) wetness = 1. + if (wetness <0.25) wetness = 0.25 + rmp1 = rmp1 * wetness + roc = roc * wetness + !! If total P is greater than 10,000 mg/kg do not allow transformations at all - If ((solp + actpp + stap) < 10000.) then - !! Allow P Transformations - soil1(j)%mp(l)%sta = soil1(j)%mp(l)%sta + roc - if (soil1(j)%mp(l)%sta < 0.) soil1(j)%mp(l)%sta = 0. - soil1(j)%mp(l)%act = soil1(j)%mp(l)%act - roc + rmp1 - if (soil1(j)%mp(l)%act < 0.) soil1(j)%mp(l)%act = 0. - soil1(j)%mp(l)%lab = soil1(j)%mp(l)%lab - rmp1 - if (soil1(j)%mp(l)%lab < 0.) soil1(j)%mp(l)%lab = 0. - end if + If ((solp + actpp + stap) < 10000.) then + !! Allow P Transformations + soil1(j)%mp(l)%sta = soil1(j)%mp(l)%sta + roc + if (soil1(j)%mp(l)%sta < 0.) soil1(j)%mp(l)%sta = 0. + soil1(j)%mp(l)%act = soil1(j)%mp(l)%act - roc + rmp1 + if (soil1(j)%mp(l)%act < 0.) soil1(j)%mp(l)%act = 0. + soil1(j)%mp(l)%lab = soil1(j)%mp(l)%lab - rmp1 + if (soil1(j)%mp(l)%lab < 0.) soil1(j)%mp(l)%lab = 0. + end if !! Add water soluble P pool assume 1:5 ratio based on sharpley 2005 et al - soil(j)%ly(l)%watp = soil1(j)%mp(l)%lab / 5. + soil(j)%ly(l)%watp = soil1(j)%mp(l)%lab / 5. hnb_d(j)%lab_min_p = hnb_d(j)%lab_min_p + rmp1 hnb_d(j)%act_sta_p = hnb_d(j)%act_sta_p + roc diff --git a/src/nut_solp.f90 b/src/nut_solp.f90 index 8af6668..2eceebe 100644 --- a/src/nut_solp.f90 +++ b/src/nut_solp.f90 @@ -34,7 +34,6 @@ subroutine nut_solp real :: plch = 0. !kg P/ha |amount of P leached from soil layer integer :: ly = 0 !none - real :: tmp_calc = 0. j = ihru @@ -65,14 +64,11 @@ subroutine nut_solp !! compute soluble P leaching do ly = 1, soil(j)%nly vap = 0. - if (ly /= i_sep(j)) then + if (ly /= i_sep(j)) then vap = -soil(j)%ly(ly)%prk / (.01 * soil(j)%phys(ly)%st + .1 * bsn_prm%pperco * soil(j)%phys(ly)%bd) - if (vap < -80.0) then ! This check was added to prevent gfortran aborting on the Exp(ww) function below. - vap = -80 - endif plch = .001 * soil1(j)%mp(ly)%lab * (1. - Exp(vap)) plch = Min(plch, soil1(j)%mp(ly)%lab) - soil1(j)%mp(ly)%lab = soil1(j)%mp(ly)%lab - plch + soil1(j)%mp(ly)%lab = soil1(j)%mp(ly)%lab - plch if (ly == soil(j)%nly) then !! leach p from bottom layer hls_d(j)%lchlabp = plch diff --git a/src/object_read_output.f90 b/src/object_read_output.f90 index 54a4892..5430b30 100644 --- a/src/object_read_output.f90 +++ b/src/object_read_output.f90 @@ -86,15 +86,15 @@ subroutine object_read_output ob_out(i)%hydno = 4 case ("til") !tile ob_out(i)%hydno = 5 - case ("sol") !soil moisture by layer + case ("sol_water") !soil moisture by layer ob_out(i)%hydno = 6 - case ("soln") !soil n and p by layer + case ("solnut_ly") !soil n and p by layer ob_out(i)%hydno = 7 - case ("solpn") !soil n and p for profile + case ("solnut_pr") !soil n and p for profile ob_out(i)%hydno = 8 - case ("plt") !plants status + case ("plant") !plants status ob_out(i)%hydno = 9 - case ("ch_fp") !channel and flood plain water balance + case ("cha_fp") !channel and flood plain water balance ob_out(i)%hydno = 10 end select iunit = ob_out(i)%unitno diff --git a/src/organic_mineral_mass_module.f90 b/src/organic_mineral_mass_module.f90 index 9be7ae4..1e3e6a4 100644 --- a/src/organic_mineral_mass_module.f90 +++ b/src/organic_mineral_mass_module.f90 @@ -39,6 +39,7 @@ module organic_mineral_mass_module character (len=16) :: name = "" real :: tot_mn = 0. ! |total mineral n pool (no3+nh4) in soil profile real :: tot_mp = 0. ! |mineral p pool (wsol+lab+act+sta) in soil profile + real :: salt = 0. ! |total salt amount (kg/ha) in soil profile type (organic_mass) :: tot_org ! |total organics in soil profile real, dimension(:), allocatable :: sw !mm |soil water dimensioned by layer real, dimension(:), allocatable :: cbn !% |percent carbon @@ -93,7 +94,7 @@ module organic_mineral_mass_module type (organic_mass), dimension(:), allocatable :: tot ! |total mass surface residue litter pool-dimensioned by plant type (organic_mass), dimension(:), allocatable :: meta ! |metabolic litter pool-dimensioned by plant type (organic_mass), dimension(:), allocatable :: str ! |structural litter pool-dimensioned by plant - type (organic_mass), dimension(:), allocatable :: lignin ! |lignin pool-dimensioned by plant + type (organic_mass), dimension(:), allocatable :: lignin ! |lignin pool-dimensioned by plant type (organic_mass) :: tot_com !kg/ha |total type (organic_mass) :: tot_meta ! | type (organic_mass) :: tot_str ! | diff --git a/src/orgncswat2.f90 b/src/orgncswat2.f90 index c4acf6d..3047430 100644 --- a/src/orgncswat2.f90 +++ b/src/orgncswat2.f90 @@ -59,8 +59,8 @@ subroutine orgncswat2 perc_clyr = 0. xx = 0. - wt1 = 0. !! conversion factor - er = 0. !! enrichment ratio + wt1 = 0. !! conversion factor + er = 0. !! enrichment ratio !! HRU calculations xx = rsd1(j)%tot_str%n + rsd1(j)%tot_meta%n + soil1(j)%hsta(1)%n + soil1(j)%hact(1)%n !wt = sol_bd(1,j) * sol_z(1,j) * 10. (tons/ha) @@ -78,17 +78,17 @@ subroutine orgncswat2 !! HRU calculations sedorgn(j) = .001 * conc * sedyld(j) / hru(j)%area_ha - !! update soil nitrogen pools only for HRU calculations + !! update soil nitrogen pools only for HRU calculations if (xx > 1.e-6) then xx1 = (1. - sedorgn(j) / xx) !!add by zhang to update soil nitrogen pools - rsd1(j)%str%n = rsd1(j)%str%n * xx1 - rsd1(j)%meta%n = rsd1(j)%meta%n * xx1 - soil1(j)%hsta(1)%n = soil1(j)%hsta(1)%n * xx1 - soil1(j)%hact(1)%n = soil1(j)%hact(1)%n * xx1 - !sol_BMN(1,j) = sol_BMN(1,j) * xx1 + rsd1(j)%str%n = rsd1(j)%str%n * xx1 + rsd1(j)%meta%n = rsd1(j)%meta%n * xx1 + soil1(j)%hsta(1)%n = soil1(j)%hsta(1)%n * xx1 + soil1(j)%hact(1)%n = soil1(j)%hact(1)%n * xx1 + !sol_BMN(1,j) = sol_BMN(1,j) * xx1 end if !return @@ -110,10 +110,10 @@ subroutine orgncswat2 ! Not sure whether should consider enrichment ratio or not! YEW = MIN((sedyld(j)/hru(j)%area_ha+YW/hru(j)%area_ha)/(sol_mass/1000.),.9) !fraction of soil erosion of total soil mass X1=1.-YEW - !YEW=MIN(ER*(YSD(NDRV)+YW)/WT(LD1),.9) - !ER enrichment ratio - !YSD water erosion - !YW wind erosion + !YEW=MIN(ER*(YSD(NDRV)+YW)/WT(LD1),.9) + !ER enrichment ratio + !YSD water erosion + !YW wind erosion YOC=YEW*TOT soil1(j)%hact(1)%c = soil1(j)%hact(1)%c * X1 soil1(j)%hsta(1)%c = soil1(j)%hsta(1)%c * X1 @@ -139,7 +139,7 @@ subroutine orgncswat2 XX=X1+DK !V=QD+Y4 V = surfq(j) + soil(j)%ly(k)%prk + soil(j)%ly(1)%flat - !QD surface runoff + !QD surface runoff X3=0. IF(V>1.E-10)THEN X3 = soil1(j)%microb(1)%c * (1.-EXP(-V/XX)) !loss of biomass C diff --git a/src/output_landscape_init.f90 b/src/output_landscape_init.f90 index 2b22c1f..ab2c495 100644 --- a/src/output_landscape_init.f90 +++ b/src/output_landscape_init.f90 @@ -477,8 +477,8 @@ subroutine output_landscape_init end if endif - open (4561,file = "hru_resc_stat.txt", recl = 1500) if (pco%nb_hru%a == "y") then + open (4561,file = "hru_resc_stat.txt", recl = 1500) write (4561,*) bsn%name, prog write (4561,*) resc_hdr write (4561,*) resc_hdr_units @@ -1423,7 +1423,8 @@ subroutine output_landscape_init !! headers for annual crop yields if (pco%crop_yld == "a" .or. pco%crop_yld == "b") then open (4008,file="crop_yld_aa.txt", recl = 1500) - write (4008,*) bsn%name, prog + write (4008,*) bsn%name + write (4008,*) prog write (4008,1000) write (9000,*) "CROP crop_yld_aa.txt" if (pco%csvout == "y") then diff --git a/src/output_landscape_module.f90 b/src/output_landscape_module.f90 index cbbcaf4..10fc2a6 100644 --- a/src/output_landscape_module.f90 +++ b/src/output_landscape_module.f90 @@ -39,12 +39,12 @@ module output_landscape_module real :: satex = 0. !mm H2O |saturation excess flow developed from high water table !rtb gwflow real :: satex_chan = 0. !mm H2O |saturation excess flow reaching main channel !rtb gwflow real :: delsw = 0. !mm H2O |change in soil water volume !rtb gwflow - real :: lagsurf = 0. !mm H2O |surface runoff in transit to channel - real :: laglatq = 0. !mm H2O |lateral flow in transit to channel - real :: lagsatex = 0. !mm H2O |saturation excess flow in transit to channel - real :: wet_evap = 0. !mm H2O |evaporation from wetland surface - real :: wet_out = 0. !mm H2O |outflow (spill) from wetland - real :: wet_stor = 0. !mm H2O |volume stored in wetland at end of time period + real :: lagsurf = 0. !mm H2O |surface runoff in transit to channel + real :: laglatq = 0. !mm H2O |lateral flow in transit to channel + real :: lagsatex = 0. !mm H2O |saturation excess flow in transit to channel + real :: wet_evap = 0. !mm H2O |evaporation from wetland surface + real :: wet_out = 0. !mm H2O |outflow (spill) from wetland + real :: wet_stor = 0. !mm H2O |volume stored in wetland at end of time period end type output_waterbal type (output_waterbal), pointer :: h @@ -292,15 +292,15 @@ module output_landscape_module character (len=6) :: day_mo = " day" character (len=6) :: yrc = " yr" character (len=8) :: isd = " unit" - character (len=8) :: id = " gis_id" - character (len=16) :: name = " name " + character (len=8) :: id = " gis_id" + character (len=16) :: name = " name " character (len=14) :: precip = " precip" character (len=12) :: snofall = " snofall" - character (len=12) :: snomlt = " snomlt" - character (len=12) :: surq_gen = " surq_gen" - character (len=12) :: latq = " latq" + character (len=12) :: snomlt = " snomlt" + character (len=12) :: surq_gen = " surq_gen" + character (len=12) :: latq = " latq" character (len=12) :: wateryld = " wateryld" - character (len=12) :: perc = " perc" + character (len=12) :: perc = " perc" character (len=12) :: et = " et" character (len=12) :: ecanopy = " ecanopy" character (len=12) :: eplant = " eplant" @@ -313,7 +313,7 @@ module output_landscape_module character (len=12) :: sw_300 = " sw_300" character (len=12) :: sno_init = " sno_init" character (len=12) :: sno_final = " sno_final" - character (len=12) :: snopack = " snopack" + character (len=12) :: snopack = " snopack" character (len=12) :: pet = " pet" character (len=12) :: qtile = " qtile" character (len=12) :: irr = " irr" @@ -336,6 +336,8 @@ module output_landscape_module character (len=12) :: wet_evap = " wet_evap" character (len=12) :: wet_oflo = " wet_oflo" character (len=12) :: wet_stor = " wet_stor" + character (len=16) :: plt_cov = " plant_cov " + character (len=30) :: mgt_ops = " mgt_ops " end type output_waterbal_header type (output_waterbal_header) :: wb_hdr @@ -345,15 +347,15 @@ module output_landscape_module character (len=6) :: day_mo = " " character (len=6) :: yrc = " " character (len=8) :: isd = " " - character (len=8) :: id = " " - character (len=16) :: name = " " + character (len=8) :: id = " " + character (len=16) :: name = " " character (len=14) :: precip = " mm" character (len=12) :: snofall = " mm" - character (len=12) :: snomlt = " mm" - character (len=12) :: surq_gen = " mm" - character (len=12) :: latq = " mm" + character (len=12) :: snomlt = " mm" + character (len=12) :: surq_gen = " mm" + character (len=12) :: latq = " mm" character (len=12) :: wateryld = " mm" - character (len=12) :: perc = " mm" + character (len=12) :: perc = " mm" character (len=12) :: et = " mm" character (len=12) :: ecanopy = " mm" character (len=12) :: eplant = " mm" @@ -366,7 +368,7 @@ module output_landscape_module character (len=12) :: sw_300 = " mm" character (len=12) :: sno_init = " mm" character (len=12) :: sno_final = " mm" - character (len=12) :: snopack = " mm" + character (len=12) :: snopack = " mm" character (len=12) :: pet = " mm" character (len=12) :: qtile = " mm" character (len=12) :: irr = " mm" @@ -397,28 +399,30 @@ module output_landscape_module character (len=6) :: mo = " mon" character (len=6) :: day_mo = " day" character (len=6) :: yrc = " yr" - character (len=9) :: isd = " unit " - character (len=8) :: id = " gis_id " - character (len=16) :: name = " name " + character (len=9) :: isd = " unit " + character (len=8) :: id = " gis_id " + character (len=16) :: name = " name " character(len=12) :: grazn = " grzn " - character(len=12) :: grazp = " grzp " - character(len=12) :: lab_min_p = " lab_min_p " - character(len=12) :: act_sta_p = " act_sta_p " - character(len=17) :: fertn = " fertn " - character(len=17) :: fertp = " fertp " - character(len=17) :: fixn = " fixn " + character(len=12) :: grazp = " grzp " + character(len=12) :: lab_min_p = " lab_min_p " + character(len=12) :: act_sta_p = " act_sta_p " + character(len=17) :: fertn = " fertn " + character(len=17) :: fertp = " fertp " + character(len=17) :: fixn = " fixn " character(len=17) :: denit = " denit " character(len=17) :: act_nit_n = " act_nit_n " character(len=17) :: act_sta_n = " act_sta_n " character(len=17) :: org_lab_p = " org_lab_p " - character(len=17) :: rsd_nitorg_n = " rsd_nitorg_n" - character(len=17) :: rsd_laborg_p = " rsd_laborg_p" - character(len=17) :: no3atmo = " no3atmo " - character(len=17) :: nh4atmo = " nh4atmo " - character(len=17) :: puptake = " puptake " - character(len=17) :: nuptake = " nuptake " - character(len=17) :: gwsoiln = " gwsoiln " - character(len=17) :: gwsoilp = " gwsoilp " + character(len=17) :: rsd_nitorg_n = " rsd_nitorg_n" + character(len=17) :: rsd_laborg_p = " rsd_laborg_p" + character(len=17) :: no3atmo = " no3atmo " + character(len=17) :: nh4atmo = " nh4atmo " + character(len=17) :: nuptake = " nuptake " + character(len=17) :: puptake = " puptake " + character(len=17) :: gwsoiln = " gwsoiln " + character(len=17) :: gwsoilp = " gwsoilp " + character (len=16) :: plt_cov = "plant_cov " + character (len=30) :: mgt_ops = "mgt_ops " end type output_nutbal_header type (output_nutbal_header) :: nb_hdr @@ -427,26 +431,26 @@ module output_landscape_module character (len=6) :: mo = " " character (len=6) :: day_mo = " " character (len=6) :: yrc = " " - character (len=9) :: isd = " " - character (len=8) :: id = " " - character (len=16) :: name = " " + character (len=9) :: isd = " " + character (len=8) :: id = " " + character (len=16) :: name = " " character(len=12) :: grazn = " kgha " - character(len=12) :: grazp = " kgha " - character(len=12) :: lab_min_p = " kgha " - character(len=12) :: act_sta_p = " kgha " - character(len=17) :: fertn = " kgha " - character(len=17) :: fertp = " kgha " - character(len=17) :: fixn = " kgha " - character(len=17) :: denit = " kgha " - character(len=17) :: act_nit_n = " kgha " - character(len=17) :: act_sta_n = " kgha " - character(len=17) :: org_lab_p = " kgha " - character(len=17) :: rsd_nitorg_n = " kgha " - character(len=17) :: rsd_laborg_p = " kgha " - character(len=17) :: no3atmo = " kgha " - character(len=17) :: nh4atmo = " kgha " - character(len=17) :: nuptake = " kgha " - character(len=17) :: puptake = " kgha " + character(len=12) :: grazp = " kgha " + character(len=12) :: lab_min_p = " kgha " + character(len=12) :: act_sta_p = " kgha " + character(len=17) :: fertn = " kgha " + character(len=17) :: fertp = " kgha " + character(len=17) :: fixn = " kgha " + character(len=17) :: denit = " kgha " + character(len=17) :: act_nit_n = " kgha " + character(len=17) :: act_sta_n = " kgha " + character(len=17) :: org_lab_p = " kgha " + character(len=17) :: rsd_nitorg_n = " kgha " + character(len=17) :: rsd_laborg_p = " kgha " + character(len=17) :: no3atmo = " kgha " + character(len=17) :: nh4atmo = " kgha " + character(len=17) :: nuptake = " kgha " + character(len=17) :: puptake = " kgha " character(len=17) :: gwsoiln = " kgha " character(len=17) :: gwsoilp = " kgha " end type output_nutbal_header_units @@ -458,20 +462,22 @@ module output_landscape_module character (len=6) :: day_mo = " day" character (len=6) :: yrc = " yr" character (len=8) :: isd = " unit " - character (len=8) :: id = " gis_id " - character (len=16) :: name = " name " + character (len=8) :: id = " gis_id " + character (len=16) :: name = " name " character (len=12) :: sedyld = " sedyld" character (len=12) :: sedorgn = " sedorgn" character (len=12) :: sedorgp = " sedorgp" character (len=12) :: surqno3 = " surqno3" - character (len=12) :: latno3 = " lat3no3" + character (len=12) :: latno3 = " lat3no3" character (len=12) :: surqsolp = " surqsolp" - character (len=12) :: usle = " usle" + character (len=12) :: usle = " usle" character (len=12) :: sedminp = " sedminp" character (len=12) :: tileno3 = " tileno3" character (len=12) :: lchlabp = " lchlabp" character (len=12) :: tilelabp = " tilelabp" character (len=12) :: satexn = " satexn" + character (len=16) :: plt_cov = " plant_cov " + character (len=30) :: mgt_ops = " mgt_ops " end type output_losses_header type (output_losses_header) :: ls_hdr @@ -481,15 +487,15 @@ module output_landscape_module character (len=6) :: day_mo = " " character (len=6) :: yrc = " " character (len=8) :: isd = " " - character (len=8) :: id = " " - character (len=16) :: name = " " + character (len=8) :: id = " " + character (len=16) :: name = " " character (len=12) :: sedyld = " tha" character (len=12) :: sedorgn = " kgha" character (len=12) :: sedorgp = " kgha" character (len=12) :: surqno3 = " kgha" - character (len=12) :: latno3 = " kgha" + character (len=12) :: latno3 = " kgha" character (len=12) :: surqsolp = " kgha" - character (len=12) :: usle = " tons" + character (len=12) :: usle = " tons" character (len=12) :: sedmin = " kgha" character (len=12) :: tileno3 = " kgha" character (len=12) :: lchlabp = " kgha" @@ -503,17 +509,17 @@ module output_landscape_module character (len=6) :: mo = " mon" character (len=6) :: day_mo = " day" character (len=6) :: yrc = " yr" - character (len=9) :: isd = " unit " - character (len=8) :: id = " gis_id " - character (len=9) :: name = " name " - character(len=17) :: lab_min_p = " lab_min_p" + character (len=9) :: isd = " unit " + character (len=8) :: id = " gis_id " + character (len=9) :: name = " name " + character(len=17) :: lab_min_p = " lab_min_p" character(len=17) :: act_sta_p = " act_sta_p" character(len=17) :: act_nit_n = " act_nit_n" character(len=17) :: act_sta_n = " act_sta_n" character(len=17) :: org_lab_p = " org_lab_p" character(len=17) :: rsd_hs_c = " rsd_hs_c" character(len=17) :: rsd_nitorg_n = " rsd_nitrorg_n" - character(len=17) :: rsd_laborg_p = " rsd_laborg_p" + character(len=17) :: rsd_laborg_p = " rsd_laborg_p" end type output_nutcarb_cycling_header type (output_nutcarb_cycling_header) :: nb_hdr1 @@ -522,17 +528,17 @@ module output_landscape_module character (len=6) :: mo = " " character (len=6) :: day_mo = " " character (len=6) :: yrc = " " - character (len=9) :: isd = " " - character (len=8) :: id = " " - character (len=9) :: name = " " + character (len=9) :: isd = " " + character (len=8) :: id = " " + character (len=9) :: name = " " character(len=17) :: lab_min_p = " kgha" - character(len=17) :: act_sta_p = " kgha" - character(len=17) :: act_nit_n = " kgha" - character(len=17) :: act_sta_n = " kgha" - character(len=17) :: org_lab_p = " kgha" - character(len=17) :: rsd_hs_c = " kgha" - character(len=17) :: rsd_nitorg_n = " kgha" - character(len=17) :: rsd_laborg_p = " kgha" + character(len=17) :: act_sta_p = " kgha" + character(len=17) :: act_nit_n = " kgha" + character(len=17) :: act_sta_n = " kgha" + character(len=17) :: org_lab_p = " kgha" + character(len=17) :: rsd_hs_c = " kgha" + character(len=17) :: rsd_nitorg_n = " kgha" + character(len=17) :: rsd_laborg_p = " kgha" end type output_nutbal_header_units1 type (output_nutbal_header_units1) :: nb_hdr_units1 @@ -542,10 +548,10 @@ module output_landscape_module character (len=6) :: mo = " mon" character (len=6) :: day_mo = " day" character (len=6) :: yrc = " yr" - character (len=9) :: isd = " unit " - character (len=8) :: id = " gis_id " - character (len=9) :: name = " name " - character(len=17) :: sed_c = " sed_c" + character (len=9) :: isd = " unit " + character (len=8) :: id = " gis_id " + character (len=9) :: name = " name " + character(len=17) :: sed_c = " sed_c" character(len=17) :: surq_c = " surq_c" character(len=17) :: surq_doc = " surq_doc" character(len=17) :: surq_dic = " surq_dic" @@ -553,8 +559,8 @@ module output_landscape_module character(len=17) :: latq_doc = " latq_doc" character(len=17) :: latq_dic = " latq_dic" character(len=17) :: perc_c = " perc_c" - character(len=17) :: perc_doc = " perc_doc" - character(len=17) :: perc_dic = " perc_dic" + character(len=17) :: perc_doc = " perc_doc" + character(len=17) :: perc_dic = " perc_dic" character(len=17) :: npp_c = " npp_c" character(len=17) :: rsd_c = " rsd_c" character(len=17) :: grain_c = " grain_c" @@ -569,16 +575,16 @@ module output_landscape_module character (len=6) :: mo = " " character (len=6) :: day_mo = " " character (len=6) :: yrc = " " - character (len=9) :: isd = " " - character (len=8) :: id = " " - character (len=9) :: name = " " + character (len=9) :: isd = " " + character (len=8) :: id = " " + character (len=9) :: name = " " character(len=17) :: sed_c = " kg C/ha" - character(len=17) :: surq_c = " kg C/ha" - character(len=17) :: surq_doc = " kg C/ha" - character(len=17) :: surq_dic = " kg C/ha" - character(len=17) :: latq_c = " kg C/ha" - character(len=17) :: latq_doc = " kg C/ha" - character(len=17) :: latq_dic = " kg C/ha" + character(len=17) :: surq_c = " kg C/ha" + character(len=17) :: surq_doc = " kg C/ha" + character(len=17) :: surq_dic = " kg C/ha" + character(len=17) :: latq_c = " kg C/ha" + character(len=17) :: latq_doc = " kg C/ha" + character(len=17) :: latq_dic = " kg C/ha" character(len=17) :: perc_c = " kg C/ha" character(len=17) :: perc_doc = " kg C/ha" character(len=17) :: perc_dic = " kg C/ha" @@ -597,20 +603,20 @@ module output_landscape_module character (len=11) :: day = " jday" character (len=11) :: mo = " mon" character (len=11) :: day_mo = " day" - character (len=11) :: yrc = " yr" - character (len=16) :: isd = " unit" - character (len=21) :: id = " gis_id " + character (len=11) :: yrc = " yr" + character (len=16) :: isd = " unit" + character (len=21) :: id = " gis_id " character (len=16) :: name = " name " character(len=15) :: sed_c = " sed_c" - character(len=15) :: surq_c = " surq_c" - character(len=15) :: surq_doc = " surq_doc" + character(len=15) :: surq_c = " surq_c" + character(len=15) :: surq_doc = " surq_doc" character(len=15) :: surq_dic = " surq_dic" - character(len=15) :: latq_c = " latq_c" + character(len=15) :: latq_c = " latq_c" character(len=15) :: latq_doc = " latq_doc" character(len=15) :: latq_dic = " latq_dic" character(len=15) :: perc_c = " perc_c" - character(len=15) :: perc_doc = " perc_doc" - character(len=15) :: perc_dic = " perc_dic" + character(len=15) :: perc_doc = " perc_doc" + character(len=15) :: perc_dic = " perc_dic" character(len=15) :: res_decay = " res_decay" character(len=15) :: man_app_c = " man_app_c" character(len=15) :: man_graze_c = " man_graze_c" @@ -623,17 +629,17 @@ module output_landscape_module character (len=11) :: day = " " character (len=11) :: mo = " " character (len=11) :: day_mo = " " - character (len=11) :: yrc = " " - character (len=16) :: isd = " " - character (len=21) :: id = " " - character (len=16) :: name = " " + character (len=11) :: yrc = " " + character (len=16) :: isd = " " + character (len=21) :: id = " " + character (len=16) :: name = " " character(len=15) :: sed_c = " kg C/ha" - character(len=15) :: surq_c = " kg C/ha" - character(len=15) :: surq_doc = " kg C/ha" - character(len=15) :: surq_dic = " kg C/ha" - character(len=15) :: latq_c = " kg C/ha" - character(len=15) :: latq_doc = " kg C/ha" - character(len=15) :: latq_dic = " kg C/ha" + character(len=15) :: surq_c = " kg C/ha" + character(len=15) :: surq_doc = " kg C/ha" + character(len=15) :: surq_dic = " kg C/ha" + character(len=15) :: latq_c = " kg C/ha" + character(len=15) :: latq_doc = " kg C/ha" + character(len=15) :: latq_dic = " kg C/ha" character(len=15) :: perc_c = " kg C/ha" character(len=15) :: perc_doc = " kg C/ha" character(len=15) :: perc_dic = " kg C/ha" @@ -653,13 +659,13 @@ module output_landscape_module character (len=11) :: day = " jday" character (len=11) :: mo = " mon" character (len=11) :: day_mo = " day" - character (len=11) :: yrc = " yr" - character (len=16) :: isd = " unit" - character (len=21) :: id = " gis_id " + character (len=11) :: yrc = " yr" + character (len=16) :: isd = " unit" + character (len=21) :: id = " gis_id " character (len=16) :: name = " name " character(len=15) :: plant_c = " plant_c" - character(len=15) :: res_decay_c = " res_decay_c" - character(len=15) :: harv_stov_c = " harv_stov_c" + character(len=15) :: res_decay_c = " res_decay_c" + character(len=15) :: harv_stov_c = " harv_stov_c" character(len=15) :: emit_c = " emit_c" end type output_rescarb_header type (output_rescarb_header) :: rescarb_hdr @@ -668,13 +674,13 @@ module output_landscape_module character (len=11) :: day = " " character (len=11) :: mo = " " character (len=11) :: day_mo = " " - character (len=11) :: yrc = " " - character (len=16) :: isd = " " - character (len=21) :: id = " " - character (len=16) :: name = " " + character (len=11) :: yrc = " " + character (len=16) :: isd = " " + character (len=21) :: id = " " + character (len=16) :: name = " " character(len=15) :: plant_c = " kg C/ha" - character(len=15) :: res_decay_c = " kg C/ha" - character(len=15) :: harv_stov_c = " kg C/ha" + character(len=15) :: res_decay_c = " kg C/ha" + character(len=15) :: harv_stov_c = " kg C/ha" character(len=15) :: emit_c = " kg C/ha" end type output_rescarb_header_units type (output_rescarb_header_units) :: rescarb_hdr_units @@ -687,13 +693,13 @@ module output_landscape_module character (len=11) :: day = " jday" character (len=11) :: mo = " mon" character (len=11) :: day_mo = " day" - character (len=11) :: yrc = " yr" - character (len=16) :: isd = " unit" - character (len=21) :: id = " gis_id " - character (len=16) :: name = " name " + character (len=11) :: yrc = " yr" + character (len=16) :: isd = " unit" + character (len=21) :: id = " gis_id " + character (len=16) :: name = " name " character(len=15) :: npp_c = " npp_c" - character(len=15) :: harv_c = " harv_c" - character(len=15) :: drop_c = " drop_c" + character(len=15) :: harv_c = " harv_c" + character(len=15) :: drop_c = " drop_c" character(len=15) :: grazeat_c = " grazeat_c" character(len=15) :: emit_c = " emit_c" end type output_plcarb_header @@ -703,14 +709,14 @@ module output_landscape_module character (len=11) :: day = " " character (len=11) :: mo = " " character (len=11) :: day_mo = " " - character (len=11) :: yrc = " " - character (len=16) :: isd = " " - character (len=21) :: id = " " - character (len=16) :: name = " " + character (len=11) :: yrc = " " + character (len=16) :: isd = " " + character (len=21) :: id = " " + character (len=16) :: name = " " character(len=15) :: npp_c = " kg C/ha" - character(len=15) :: harv_c = " kg C/ha" - character(len=15) :: drop_c = " kg C/ha" - character(len=15) :: grazeat_c = " kg C/ha" + character(len=15) :: harv_c = " kg C/ha" + character(len=15) :: drop_c = " kg C/ha" + character(len=15) :: grazeat_c = " kg C/ha" character(len=15) :: emit_c = " kg C/ha" end type output_plcarb_header_units type (output_plcarb_header_units) :: plcarb_hdr_units @@ -723,18 +729,18 @@ module output_landscape_module character (len=11) :: day = " jday" character (len=11) :: mo = " mon" character (len=11) :: day_mo = " day" - character (len=11) :: yrc = " yr" - character (len=16) :: isd = " unit" - character (len=21) :: id = " gis_id " - character (len=16) :: name = " name " + character (len=11) :: yrc = " yr" + character (len=16) :: isd = " unit" + character (len=21) :: id = " gis_id " + character (len=16) :: name = " name " character(len=15) :: meta_micr = " meta_micr" - character(len=15) :: str_micr = " str_micr" - character(len=15) :: str_hs = " str_hs" + character(len=15) :: str_micr = " str_micr" + character(len=15) :: str_hs = " str_hs" character(len=15) :: co2_meta = " co2_meta" character(len=15) :: co2_str = " co2_str" character(len=15) :: micr_hs = " micr_hs" character(len=15) :: micr_hp = " micr_hp" - character(len=15) :: hs_micr = " hs_micr" + character(len=15) :: hs_micr = " hs_micr" character(len=15) :: hs_hp = " hs_hp" character(len=15) :: hp_micr = " hp_micr" character(len=15) :: co2_micr = " co2_micr" @@ -747,13 +753,13 @@ module output_landscape_module character (len=11) :: day = " " character (len=11) :: mo = " " character (len=11) :: day_mo = " " - character (len=11) :: yrc = " " - character (len=16) :: isd = " " - character (len=21) :: id = " " - character (len=16) :: name = " " + character (len=11) :: yrc = " " + character (len=16) :: isd = " " + character (len=21) :: id = " " + character (len=16) :: name = " " character(len=15) :: meta_micr = " kg C/ha" - character(len=15) :: str_micr = " kg C/ha" - character(len=15) :: str_hs = " kg C/ha" + character(len=15) :: str_micr = " kg C/ha" + character(len=15) :: str_hs = " kg C/ha" character(len=15) :: co2_meta = " kg C/ha" character(len=15) :: co2_str = " kg C/ha" character(len=15) :: micr_hs = " kg C/ha" @@ -763,7 +769,7 @@ module output_landscape_module character(len=15) :: hp_micr = " kg C/ha" character(len=15) :: co2_micr = " kg C/ha" character(len=15) :: co2_hs = " kg C/ha" - character(len=15) :: co2_hp = " kg C/ha" + character(len=15) :: co2_hp = " kg C/ha" end type output_hscf_header_units type (output_hscf_header_units) :: hscf_hdr_units @@ -775,13 +781,13 @@ module output_landscape_module character (len=11) :: day = " jday" character (len=11) :: mo = " mon" character (len=11) :: day_mo = " day" - character (len=11) :: yrc = " yr" - character (len=16) :: isd = " unit" - character (len=21) :: id = " gis_id " - character (len=16) :: name = " name " + character (len=11) :: yrc = " yr" + character (len=16) :: isd = " unit" + character (len=21) :: id = " gis_id " + character (len=16) :: name = " name " character(len=15) :: tot_c = " meta_micr" - character(len=15) :: ab_gr_c = " ab_gr_c" - character(len=15) :: leaf_c = " leaf_c" + character(len=15) :: ab_gr_c = " ab_gr_c" + character(len=15) :: leaf_c = " leaf_c" character(len=15) :: stem_c = " stem_c" character(len=15) :: seed_c = " seed_c" character(len=15) :: root_c = " root_c" @@ -792,13 +798,13 @@ module output_landscape_module character (len=11) :: day = " " character (len=11) :: mo = " " character (len=11) :: day_mo = " " - character (len=11) :: yrc = " " - character (len=16) :: isd = " " - character (len=21) :: id = " " - character (len=16) :: name = " " + character (len=11) :: yrc = " " + character (len=16) :: isd = " " + character (len=21) :: id = " " + character (len=16) :: name = " " character(len=15) :: tot_c = " kg/ha" - character(len=15) :: ab_gr_c = " kg/ha" - character(len=15) :: leaf_c = " kg/ha" + character(len=15) :: ab_gr_c = " kg/ha" + character(len=15) :: leaf_c = " kg/ha" character(len=15) :: stem_c = " kg/ha" character(len=15) :: seed_c = " kg/ha" character(len=15) :: root_c = " kg/ha" @@ -813,13 +819,13 @@ module output_landscape_module character (len=11) :: day = " jday" character (len=11) :: mo = " mon" character (len=11) :: day_mo = " day" - character (len=11) :: yrc = " yr" - character (len=16) :: isd = " unit" - character (len=21) :: id = " gis_id " - character (len=16) :: name = " name " + character (len=11) :: yrc = " yr" + character (len=16) :: isd = " unit" + character (len=21) :: id = " gis_id " + character (len=16) :: name = " name " character(len=15) :: tot_c = " tot_c" - character(len=15) :: meta_c = " meta_c" - character(len=15) :: str_c = " str_c" + character(len=15) :: meta_c = " meta_c" + character(len=15) :: str_c = " str_c" character(len=15) :: lig_c = " lig_c" end type output_resc_header @@ -829,13 +835,13 @@ module output_landscape_module character (len=11) :: day = " " character (len=11) :: mo = " " character (len=11) :: day_mo = " " - character (len=11) :: yrc = " " - character (len=16) :: isd = " " - character (len=21) :: id = " " - character (len=16) :: name = " " + character (len=11) :: yrc = " " + character (len=16) :: isd = " " + character (len=21) :: id = " " + character (len=16) :: name = " " character(len=15) :: tot_c = " kg/ha" - character(len=15) :: meta_c = " kg/ha" - character(len=15) :: str_c = " kg/ha" + character(len=15) :: meta_c = " kg/ha" + character(len=15) :: str_c = " kg/ha" character(len=15) :: lig_c = " kg/ha" end type output_resc_header_units type (output_resc_header_units) :: resc_hdr_units @@ -848,17 +854,17 @@ module output_landscape_module character (len=11) :: day = " jday" character (len=11) :: mo = " mon" character (len=11) :: day_mo = " day" - character (len=11) :: yrc = " yr" - character (len=16) :: isd = " unit" - character (len=21) :: id = " gis_id " - character (len=16) :: name = " name " + character (len=11) :: yrc = " yr" + character (len=16) :: isd = " unit" + character (len=21) :: id = " gis_id " + character (len=16) :: name = " name " character(len=15) :: tot_org_c = " tot_org_c" - character(len=15) :: str_c = " str_c" - character(len=15) :: lig_c = " lib_c" + character(len=15) :: str_c = " str_c" + character(len=15) :: lig_c = " lib_c" character(len=15) :: meta_c = " meta_c" character(len=15) :: man_c = " man_c" - character(len=15) :: humus_low_c = " humus_low_c" - character(len=15) :: humus_pass_c = " humus_pass_c" + character(len=15) :: humus_low_c = " humus_low_c" + character(len=15) :: humus_pass_c = " humus_pass_c" character(len=15) :: microb_c = " microb_c" end type output_soilc_header type (output_soilc_header) :: soilc_hdr @@ -867,17 +873,17 @@ module output_landscape_module character (len=11) :: day = " " character (len=11) :: mo = " " character (len=11) :: day_mo = " " - character (len=11) :: yrc = " " - character (len=16) :: isd = " " - character (len=21) :: id = " " - character (len=16) :: name = " " + character (len=11) :: yrc = " " + character (len=16) :: isd = " " + character (len=21) :: id = " " + character (len=16) :: name = " " character(len=15) :: tot_org_c = " kg/ha" - character(len=15) :: str_c = " kg/ha" - character(len=15) :: lig_c = " kg/ha" + character(len=15) :: str_c = " kg/ha" + character(len=15) :: lig_c = " kg/ha" character(len=15) :: meta_c = " kg/ha" character(len=15) :: man_c = " kg/ha" - character(len=15) :: humus_low_c = " kg/ha" - character(len=15) :: humus_pass_c = " kg/ha" + character(len=15) :: humus_low_c = " kg/ha" + character(len=15) :: humus_pass_c = " kg/ha" character(len=15) :: microb_c = " kg/ha" end type output_soilc_header_units type (output_soilc_header_units) :: soilc_hdr_units @@ -888,21 +894,21 @@ module output_landscape_module type output_bsn_carb_header character (len=11) :: day = " jday" - character (len=11) :: yrc = " yr" + character (len=11) :: yrc = " yr" character (len=6) :: blnk = " " character (len=15) :: org_soilc = " org_soilc" - character (len=15) :: org_plc = " org_plc" - character (len=15) :: org_resc = " org_resc" + character (len=15) :: org_plc = " org_plc" + character (len=15) :: org_resc = " org_resc" end type output_bsn_carb_header type (output_bsn_carb_header) :: bsn_carb_hdr type output_bsn_carb_header_units character (len=11) :: day = " " - character (len=11) :: yrc = " " + character (len=11) :: yrc = " " character (len=6) :: blnk = " " character(len=15) :: org_soilc = " kg/ha" - character(len=15) :: org_plc = " kg/ha" - character(len=15) :: org_resc = " kg/ha" + character(len=15) :: org_plc = " kg/ha" + character(len=15) :: org_resc = " kg/ha" end type output_bsn_carb_header_units type (output_bsn_carb_header_units) :: bsn_carb_hdr_units @@ -910,21 +916,21 @@ module output_landscape_module type output_losses_header1 - character (len=6) :: day = " jday" + character (len=5) :: day = " jday" character (len=6) :: mo = " mon" character (len=6) :: day_mo = " day" character (len=6) :: yrc = " yr" character (len=9) :: isd = " unit " - character (len=8) :: id = " gis_id " - character (len=9) :: name = " name " + character (len=8) :: id = " gis_id " + character (len=9) :: name = " name " character (len=17) :: sedyld = " sedyld" - character (len=17) :: usle = " usle" - character (len=17) :: sedorgc = " sedorgc" + character (len=17) :: usle = " usle" + character (len=17) :: sedorgc = " sedorgc" character (len=17) :: sedorgn = " sedorgn" character (len=17) :: sedorgp = " sedorgp" character (len=17) :: surqno3 = " surqno3" - character (len=17) :: latno3 = " lat3no3" - character (len=17) :: surqsolp = " surqsolp" + character (len=17) :: latno3 = " lat3no3" + character (len=17) :: surqsolp = " surqsolp" character (len=17) :: sedminp = " sedminp" character (len=17) :: tileno3 = " tileno3" character (len=17) :: no3atmo = " no3atmo" @@ -950,20 +956,20 @@ module output_landscape_module type (output_losses_header1) :: ls_hdr1 type output_losses_header_units1 - character (len=6) :: day = " " + character (len=5) :: day = " " character (len=6) :: mo = " " character (len=6) :: day_mo = " " character (len=6) :: yrc = " " character (len=9) :: isd = " " - character (len=8) :: id = " " - character (len=9) :: name = " " + character (len=8) :: id = " " + character (len=9) :: name = " " character (len=17) :: sedyld = " tons" character (len=17) :: usle = " tha" character (len=17) :: sedorgc = " kgha" character (len=17) :: sedorgn = " kgha" character (len=17) :: sedorgp = " kgha" character (len=17) :: surqno3 = " kgha" - character (len=17) :: latno3 = " kgha" + character (len=17) :: latno3 = " kgha" character (len=17) :: surqsolp = " kgha" character (len=17) :: sedmin = " ----" character (len=17) :: tileno3 = " kgha" @@ -995,8 +1001,8 @@ module output_landscape_module character (len=6) :: day_mo = " day" character (len=6) :: yrc = " yr" character (len=8) :: isd = " unit " - character (len=8) :: id = " gis_id " - character (len=16) :: name = " name " + character (len=8) :: id = " gis_id " + character (len=16) :: name = " name " character (len=13) :: lai = " lai" character (len=12) :: bioms = " bioms" character (len=12) :: yield = " yield" @@ -1021,7 +1027,9 @@ module output_landscape_module character (len=12) :: lai_max = " lai_max" character (len=12) :: bm_max = " bm_max" character (len=12) :: bm_grow = " bm_grow" - character (len=12) :: c_gro = " c_gro" + character (len=12) :: c_gro = " c_gro" + character (len=16) :: plt_cov = " plant_cov " + character (len=30) :: mgt_ops = " mgt_ops " end type output_plantweather_header type (output_plantweather_header) :: pw_hdr @@ -1031,19 +1039,19 @@ module output_landscape_module character (len=6) :: day_mo = " " character (len=6) :: yrc = " " character (len=8) :: isd = " " - character (len=8) :: id = " " - character (len=16) :: name = " " + character (len=8) :: id = " " + character (len=16) :: name = " " character (len=13) :: lai = " m**2/m**2" character (len=12) :: bioms = " kgha" character (len=12) :: yield = " kgha" character (len=12) :: residue = " kgha" character (len=12) :: sol_tmp = " degc" - character (len=12) :: strsw = " ----" - character (len=12) :: strsa = " ----" - character (len=12) :: strstmp = " ----" - character (len=12) :: strsn = " ----" - character (len=12) :: strsp = " ----" - character (len=12) :: strss = " ----" + character (len=12) :: strsw = " ----" + character (len=12) :: strsa = " ----" + character (len=12) :: strstmp = " ----" + character (len=12) :: strsn = " ----" + character (len=12) :: strsp = " ----" + character (len=12) :: strss = " ----" character (len=12) :: nplnt = " kgha" character (len=12) :: percn = " kgha" character (len=12) :: pplnt = " kgha" diff --git a/src/pathogen_init.f90 b/src/pathogen_init.f90 index 4daf628..0e5ac71 100644 --- a/src/pathogen_init.f90 +++ b/src/pathogen_init.f90 @@ -54,11 +54,11 @@ subroutine pathogen_init !! allocate pathogens associated with soil and plant do ly = 1, soil(ihru)%nly allocate (cs_soil(ihru)%ly(ly)%path(mpath), source = 0.) - allocate (cs_pl(ihru)%pl_in(ipl)%pest(mpath), source = 0.) - allocate (cs_pl(ihru)%pl_on(ipl)%pest(mpath), source = 0.) - allocate (cs_pl(ihru)%pl_up(ipl)%pest(mpath), source = 0.) end do do ipl = 1, pcom(ihru)%npl + allocate (cs_pl(ihru)%pl_in(ipl)%path(mpath), source = 0.) + allocate (cs_pl(ihru)%pl_on(ipl)%path(mpath), source = 0.) + allocate (cs_pl(ihru)%pl_up(ipl)%path(mpath), source = 0.) end do allocate (cs_irr(ihru)%path(mpath)) end if diff --git a/src/pesticide_init.f90 b/src/pesticide_init.f90 index a68bd93..b3b2b0a 100644 --- a/src/pesticide_init.f90 +++ b/src/pesticide_init.f90 @@ -40,14 +40,14 @@ subroutine pesticide_init allocate (cs_pl(ihru)%pl_up(npl)) do ly = 1, nly allocate (cs_soil(ihru)%ly(ly)%pest(npmx), source = 0.) - allocate (cs_pl(ihru)%pl_in(ipl)%pest(npmx), source = 0.) - allocate (cs_pl(ihru)%pl_on(ipl)%pest(npmx), source = 0.) - allocate (cs_pl(ihru)%pl_up(ipl)%pest(npmx), source = 0.) cs_soil(ihru)%ly(ly)%pest = 0. end do do ipl = 1, npl + allocate (cs_pl(ihru)%pl_in(ipl)%pest(npmx), source = 0.) cs_pl(ihru)%pl_in(ipl)%pest = 0. + allocate (cs_pl(ihru)%pl_on(ipl)%pest(npmx), source = 0.) cs_pl(ihru)%pl_on(ipl)%pest = 0. + allocate (cs_pl(ihru)%pl_up(ipl)%pest(npmx), source = 0.) cs_pl(ihru)%pl_up(ipl)%pest = 0. end do allocate (cs_irr(ihru)%pest(npmx)) diff --git a/src/pl_burnop.f90 b/src/pl_burnop.f90 index 9ba0008..4ed13dd 100644 --- a/src/pl_burnop.f90 +++ b/src/pl_burnop.f90 @@ -46,7 +46,7 @@ subroutine pl_burnop (jj, iburn) soil1(j)%hact(1)%n = soil1(j)%hact(1)%n * fr_burn soil1(j)%hsta(1)%n = soil1(j)%hsta(1)%n* fr_burn - !!insert new biomss by zhang + !!insert new biomss by zhang !!================================= if (bsn_cc%cswat == 2) then rsd1(j)%tot_meta%m = rsd1(j)%tot_meta%m * fr_burn diff --git a/src/pl_fert.f90 b/src/pl_fert.f90 index d45e53a..f349305 100644 --- a/src/pl_fert.f90 +++ b/src/pl_fert.f90 @@ -81,18 +81,18 @@ subroutine pl_fert (ifrt, frt_kg, fertop) soil1(j)%hsta(l)%p = soil1(j)%hsta(l)%p + (1. - rtof)*xx*frt_kg * & fertdb(ifrt)%forgp end if - if (bsn_cc%cswat == 1) then - soil1(j)%man(l)%c = soil1(j)%man(l)%c + xx * frt_kg * & - fertdb(ifrt)%forgn * 10. - soil1(j)%man(l)%n = soil1(j)%man(l)%n + xx * frt_kg * & - fertdb(ifrt)%forgn - soil1(j)%man(l)%p = soil1(j)%man(l)%p + xx * frt_kg * & - fertdb(ifrt)%forgp - end if + if (bsn_cc%cswat == 1) then + soil1(j)%man(l)%c = soil1(j)%man(l)%c + xx * frt_kg * & + fertdb(ifrt)%forgn * 10. + soil1(j)%man(l)%n = soil1(j)%man(l)%n + xx * frt_kg * & + fertdb(ifrt)%forgn + soil1(j)%man(l)%p = soil1(j)%man(l)%p + xx * frt_kg * & + fertdb(ifrt)%forgp + end if !!By Zhang for C/N cycling !!=========================== - if (bsn_cc%cswat == 2) then + if (bsn_cc%cswat == 2) then soil1(j)%tot(l)%p = soil1(j)%tot(l)%p + rtof * xx * & frt_kg * fertdb(ifrt)%forgp soil1(j)%hsta(l)%p = soil1(j)%hsta(l)%p + (1. - rtof) * xx * & @@ -158,7 +158,7 @@ subroutine pl_fert (ifrt, frt_kg, fertop) !end if - end if + end if !!By Zhang for C/N cycling !!=========================== diff --git a/src/pl_fert_wet.f90 b/src/pl_fert_wet.f90 index 70eeb1b..6730b93 100644 --- a/src/pl_fert_wet.f90 +++ b/src/pl_fert_wet.f90 @@ -67,18 +67,18 @@ subroutine pl_fert_wet (ifrt, frt_kg) wet(j)%sedp = wet(j)%sedp + frt_kg * fertdb(ifrt)%forgp end if - ! if (bsn_cc%cswat == 1) then - ! soil1(j)%man(l)%c = soil1(j)%man(l)%c + xx * frt_kg * & - ! fertdb(ifrt)%forgn * 10. - ! soil1(j)%man(l)%n = soil1(j)%man(l)%n + xx * frt_kg * & - ! fertdb(ifrt)%forgn - ! soil1(j)%man(l)%p = soil1(j)%man(l)%p + xx * frt_kg * & - ! fertdb(ifrt)%forgp - ! end if + ! if (bsn_cc%cswat == 1) then + ! soil1(j)%man(l)%c = soil1(j)%man(l)%c + xx * frt_kg * & + ! fertdb(ifrt)%forgn * 10. + ! soil1(j)%man(l)%n = soil1(j)%man(l)%n + xx * frt_kg * & + ! fertdb(ifrt)%forgn + ! soil1(j)%man(l)%p = soil1(j)%man(l)%p + xx * frt_kg * & + ! fertdb(ifrt)%forgp + ! end if ! ! !!By Zhang for C/N cycling ! !!=========================== - ! if (bsn_cc%cswat == 2) then + ! if (bsn_cc%cswat == 2) then ! soil1(j)%tot(l)%p = soil1(j)%tot(l)%p + rtof * xx * & ! frt_kg * fertdb(ifrt)%forgp ! soil1(j)%hsta(l)%p = soil1(j)%hsta(l)%p + (1. - rtof) * xx * & @@ -144,7 +144,7 @@ subroutine pl_fert_wet (ifrt, frt_kg) ! ! !end if ! - !end if + !end if ! !!By Zhang for C/N cycling ! !!=========================== ! diff --git a/src/pl_grow.f90 b/src/pl_grow.f90 index 246a4fc..c2107de 100644 --- a/src/pl_grow.f90 +++ b/src/pl_grow.f90 @@ -40,7 +40,7 @@ subroutine pl_grow call pl_seed_gro(j) - call pl_partition(j) + call pl_partition(j, 0) end if diff --git a/src/pl_leaf_drop.f90 b/src/pl_leaf_drop.f90 index 0bdd226..ecfcac1 100644 --- a/src/pl_leaf_drop.f90 +++ b/src/pl_leaf_drop.f90 @@ -49,7 +49,7 @@ subroutine pl_leaf_drop (resnew, resnew_n) real :: LSF = 0. !frac |fraction of the litter that is structural real :: LMNF = 0. !kg kg-1 |fraction of metabolic litter that is N real :: LSLF = 0. !kg kg-1 |fraction of structural litter that is lignin - real :: LSNF = 0. !kg kg-1 |fraction of structural litter that is N + real :: LSNF = 0. !kg kg-1 |fraction of structural litter that is N orgc_f = 0. BLG1 = 0. @@ -89,13 +89,13 @@ subroutine pl_leaf_drop (resnew, resnew_n) CLG=BLG3*pcom(j)%plcur(ipl)%phuacc/ (pcom(j)%plcur(ipl)%phuacc + & EXP(BLG1-BLG2*pcom(j)%plcur(ipl)%phuacc)) - sf = 0.05 - sol_min_n = (soil1(j)%mn(1)%no3 + soil1(j)%mn(1)%nh4) + sf = 0.05 + sol_min_n = (soil1(j)%mn(1)%no3 + soil1(j)%mn(1)%nh4) resnew_ne = resnew_n + sf * sol_min_n RLN = (resnew * CLG/(resnew_n+1.E-5)) RLR = MIN(.8, resnew * CLG/1000/(resnew/1000+1.E-5)) - + LMF = 0.85 - 0.018 * RLN if (LMF <0.01) then LMF = 0.01 @@ -103,17 +103,17 @@ subroutine pl_leaf_drop (resnew, resnew_n) if (LMF >0.7) then LMF = 0.7 end if - end if + end if LSF = 1 - LMF - + rsd1(j)%meta%m = rsd1(j)%meta%m + LMF * resnew rsd1(j)%str%m = rsd1(j)%str%m + LSF * resnew LSLF = CLG - + rsd1(j)%tot_str%c = rsd1(j)%tot_str%c + 0.42*LSF * resnew - + rsd1(j)%tot_lignin%c = rsd1(j)%tot_lignin%c + RLR * 0.42 * LSF * resnew rsd1(j)%tot_lignin%c = rsd1(j)%tot_str%c - rsd1(j)%tot_lignin%c @@ -124,7 +124,7 @@ subroutine pl_leaf_drop (resnew, resnew_n) else rsd1(j)%tot_str%n = rsd1(j)%tot_str%n + resnew_ne rsd1(j)%tot_meta%n = rsd1(j)%tot_meta%n + 1.E-25 - end if + end if rsd1(j)%tot_meta%c = rsd1(j)%tot_meta%c + 0.42 * LMF * resnew diff --git a/src/pl_leaf_gro.f90 b/src/pl_leaf_gro.f90 index b6fe069..f1d5928 100644 --- a/src/pl_leaf_gro.f90 +++ b/src/pl_leaf_gro.f90 @@ -78,7 +78,6 @@ subroutine pl_leaf_gro real :: rto = 0. !none |ratio of current years of growth:years to maturity of perennial real :: sumlaiht = 0. ! | integer :: jpl = 0 !none |counter - real :: tmp_calc j = ihru idp = pcom(j)%plcur(ipl)%idplt @@ -89,14 +88,9 @@ subroutine pl_leaf_gro ff = f - pcom(j)%plg(ipl)%laimxfr pcom(j)%plg(ipl)%laimxfr = f - tmp_calc = plcp(idp)%leaf1 - plcp(idp)%leaf2 * pcom(j)%plcur(ipl)%phuacc_p !Changed by fg to prevent underflow in gfortran - if (tmp_calc < -20.) then !Changed by fg to prevent underflow in gfortran - tmp_calc = -20. !Changed by fg to prevent underflow in gfortran - endif - f_p = pcom(j)%plcur(ipl)%phuacc_p / (pcom(j)%plcur(ipl)%phuacc_p + Exp(tmp_calc)) !Changed by fg to prevent underflow in gfortran - !f_p = pcom(j)%plcur(ipl)%phuacc_p / (pcom(j)%plcur(ipl)%phuacc_p + & - ! Exp(plcp(idp)%leaf1 - plcp(idp)%leaf2 * pcom(j)%plcur(ipl)%phuacc_p)) + f_p = pcom(j)%plcur(ipl)%phuacc_p / (pcom(j)%plcur(ipl)%phuacc_p + & + Exp(plcp(idp)%leaf1 - plcp(idp)%leaf2 * pcom(j)%plcur(ipl)%phuacc_p)) !pcom(j)%plg(ipl)%laimxfr_p = amin1 (f_p, pcom(j)%plg(ipl)%laimxfr_p) !ff_p = f_p - pcom(j)%plg(ipl)%laimxfr_p diff --git a/src/pl_leaf_senes.f90 b/src/pl_leaf_senes.f90 index d7e2ed9..495557b 100644 --- a/src/pl_leaf_senes.f90 +++ b/src/pl_leaf_senes.f90 @@ -76,10 +76,11 @@ subroutine pl_leaf_senes end if lai_drop = max (0., lai_drop) lai_drop = amin1 (1., lai_drop) - leaf_drop%m = lai_drop * pl_mass(j)%leaf(ipl)%m - leaf_drop%n = leaf_drop%m * pcom(j)%plm(ipl)%n_fr + !! forest -- total tree n_conc = 1.75%; leaf = 2.25%, falling leaf = 50%*2.25% = 1.12% --> 1.12/1.75 = 0.68 + leaf_drop%m = pcom(j)%plcur(ipl)%leaf_tov * pl_mass(j)%leaf(ipl)%m + leaf_drop%n = 0.68 * leaf_drop%m * pcom(j)%plm(ipl)%n_fr leaf_drop%n = max (0., leaf_drop%n) - leaf_drop%p = leaf_drop%m * pcom(j)%plm(ipl)%p_fr + leaf_drop%p = 0.68 * leaf_drop%m * pcom(j)%plm(ipl)%p_fr leaf_drop%p = max (0., leaf_drop%p) end if end if @@ -109,10 +110,11 @@ subroutine pl_leaf_senes !pcom(j)%plg(ipl)%lai = max (pcom(j)%plg(ipl)%lai, pldb(idp)%alai_min) !! compute leaf biomass drop + !! forest -- total tree n_conc = 1.75%; leaf = 2.25%, falling leaf = 50%*2.25% = 1.12% --> 1.12/1.75 = 0.68 leaf_drop%m = pcom(j)%plcur(ipl)%leaf_tov * pl_mass(j)%leaf(ipl)%m - leaf_drop%n = leaf_drop%m * pcom(j)%plm(ipl)%n_fr + leaf_drop%n = 0.68 * leaf_drop%m * pcom(j)%plm(ipl)%n_fr leaf_drop%n = max (0., leaf_drop%n) - leaf_drop%p = leaf_drop%m * pcom(j)%plm(ipl)%p_fr + leaf_drop%p = 0.68 * leaf_drop%m * pcom(j)%plm(ipl)%p_fr leaf_drop%p = max (0., leaf_drop%p) end if diff --git a/src/pl_partition.f90 b/src/pl_partition.f90 index 76b5c56..434353a 100644 --- a/src/pl_partition.f90 +++ b/src/pl_partition.f90 @@ -1,4 +1,4 @@ - subroutine pl_partition(j) + subroutine pl_partition(j, init) use plant_data_module use basin_module @@ -10,6 +10,7 @@ subroutine pl_partition(j) implicit none integer, intent (in) :: j !none |HRU number + integer, intent (in) :: init !none |init=1 to intialize and transplant; init=0 during simulation integer :: idp = 0 ! | real :: root_frac = 0. !none |root mass fraction real :: ab_gr_frac = 0. !none |above ground mass fraction @@ -20,7 +21,9 @@ subroutine pl_partition(j) real :: n_frac = 0. !none |n fraction in remainder of plant real :: p_left = 0. !none |p left after seed is removed real :: p_frac = 0. !none |p fraction in remainder of plant - real :: m_left = 0. !none |mass left after seed is removed + real :: mass_left = 0. !none |mass left after plant component is removed + real :: mass_act = 0. !none |actual mass in each plant component + real :: mass_opt = 0. !none |optimal mass in each plant component real :: leaf_frac_veg = 0. !none |fraction veg mass (stem+leaf) that is leaf real :: leaf_mass_frac_veg = 0. !none |fraction veg mass (stem+leaf) that is leaf @@ -32,7 +35,7 @@ subroutine pl_partition(j) !! partition leaf and stem (stalk) and seed (grain) mass if (pldb(idp)%typ == "perennial") then - leaf_frac_veg = 0.05 !forest + leaf_frac_veg = 0.02 !forest else leaf_frac_veg = 0.30 !should be plant parm end if @@ -56,11 +59,50 @@ subroutine pl_partition(j) stem_mass_frac = 1. - (leaf_mass_frac_veg + seed_mass_frac) end if + !! check if initializing + if (init == 0) then + !! first maintain root fraction - root mass/total mass + mass_left = pl_mass_up%m + mass_act = pl_mass(j)%root(ipl)%m + mass_opt = root_frac * pl_mass(j)%tot(ipl)%m + if (mass_act > mass_opt) then + mass_left = mass_act - mass_opt + pl_mass(j)%root(ipl)%m = mass_opt + else + pl_mass(j)%root(ipl)%m = pl_mass(j)%root(ipl)%m + pl_mass_up%m + mass_left = 0. + end if + !! next maintain harvest index on yield (seed/fruit) component + mass_act = pl_mass(j)%seed(ipl)%m + mass_opt = seed_mass_frac * pl_mass(j)%tot(ipl)%m + if (mass_act > mass_opt) then + mass_left = mass_act - mass_opt + pl_mass(j)%seed(ipl)%m = mass_opt + else + pl_mass(j)%seed(ipl)%m = pl_mass(j)%seed(ipl)%m + pl_mass_up%m + mass_left = 0. + end if + !! next maintain leaf component + mass_act = pl_mass(j)%leaf(ipl)%m + mass_opt = leaf_mass_frac * pl_mass(j)%tot(ipl)%m + if (mass_act > mass_opt) then + mass_left = mass_act - mass_opt + pl_mass(j)%leaf(ipl)%m = mass_opt + else + pl_mass(j)%leaf(ipl)%m = pl_mass(j)%leaf(ipl)%m + pl_mass_up%m + mass_left = 0. + end if + !! remainder goes to stem + pl_mass(j)%stem(ipl)%m = pl_mass(j)%stem(ipl)%m + mass_left + pl_mass(j)%ab_gr(ipl)%m = pl_mass(j)%stem(ipl)%m + pl_mass(j)%leaf(ipl)%m + pl_mass(j)%seed(ipl)%m + else + !! initialize at initial fractions pl_mass(j)%ab_gr(ipl)%m = ab_gr_frac * pl_mass(j)%tot(ipl)%m pl_mass(j)%root(ipl)%m = root_frac * pl_mass(j)%tot(ipl)%m pl_mass(j)%leaf(ipl)%m = leaf_mass_frac * pl_mass(j)%ab_gr(ipl)%m pl_mass(j)%seed(ipl)%m = seed_mass_frac * pl_mass(j)%ab_gr(ipl)%m pl_mass(j)%stem(ipl)%m = stem_mass_frac * pl_mass(j)%ab_gr(ipl)%m + end if !! partition carbon with constant fractions pl_mass(j)%leaf(ipl)%c = c_frac%leaf * pl_mass(j)%leaf(ipl)%m @@ -73,8 +115,8 @@ subroutine pl_partition(j) !! partition n and p if (pldb(idp)%typ == "perennial") then !! partition leaves and seed (stem is woody biomass) - m_left = pl_mass(j)%leaf(ipl)%m + pl_mass(j)%stem(ipl)%m + pl_mass(j)%root(ipl)%m - if (m_left > 1.e-9) then + mass_left = pl_mass(j)%leaf(ipl)%m + pl_mass(j)%stem(ipl)%m + pl_mass(j)%root(ipl)%m + if (mass_left > 1.e-9) then pl_mass(j)%seed(ipl)%n = pldb(idp)%cnyld * pl_mass(j)%seed(ipl)%m n_left = pl_mass(j)%tot(ipl)%n - pl_mass(j)%seed(ipl)%n !! if n is neg after seed is removed - assume 0 n in seed - plant database cnyld and fr_n_mat are off @@ -83,9 +125,9 @@ subroutine pl_partition(j) n_left = pl_mass(j)%seed(ipl)%n + n_left end if !! partition n_left between remaining masses - assume equal concentrations - pl_mass(j)%leaf(ipl)%n = n_left * pl_mass(j)%leaf(ipl)%m / m_left - pl_mass(j)%stem(ipl)%n = n_left * pl_mass(j)%stem(ipl)%m / m_left - pl_mass(j)%root(ipl)%n = n_left * pl_mass(j)%root(ipl)%m / m_left + pl_mass(j)%leaf(ipl)%n = n_left * pl_mass(j)%leaf(ipl)%m / mass_left + pl_mass(j)%stem(ipl)%n = n_left * pl_mass(j)%stem(ipl)%m / mass_left + pl_mass(j)%root(ipl)%n = n_left * pl_mass(j)%root(ipl)%m / mass_left pl_mass(j)%ab_gr(ipl)%n = pl_mass(j)%seed(ipl)%n + pl_mass(j)%leaf(ipl)%n + pl_mass(j)%stem(ipl)%n pl_mass(j)%seed(ipl)%p = pldb(idp)%cpyld * pl_mass(j)%seed(ipl)%m @@ -96,9 +138,9 @@ subroutine pl_partition(j) p_left = pl_mass(j)%seed(ipl)%p + p_left end if !! partition p_left between remaining masses - assume equal concentrations - pl_mass(j)%leaf(ipl)%p = p_left * pl_mass(j)%leaf(ipl)%m / m_left - pl_mass(j)%stem(ipl)%p = p_left * pl_mass(j)%stem(ipl)%m / m_left - pl_mass(j)%root(ipl)%p = p_left * pl_mass(j)%root(ipl)%m / m_left + pl_mass(j)%leaf(ipl)%p = p_left * pl_mass(j)%leaf(ipl)%m / mass_left + pl_mass(j)%stem(ipl)%p = p_left * pl_mass(j)%stem(ipl)%m / mass_left + pl_mass(j)%root(ipl)%p = p_left * pl_mass(j)%root(ipl)%m / mass_left pl_mass(j)%ab_gr(ipl)%p = pl_mass(j)%seed(ipl)%p + pl_mass(j)%leaf(ipl)%p + pl_mass(j)%stem(ipl)%p end if else diff --git a/src/pl_read_parms_cal.f90 b/src/pl_read_parms_cal.f90 index 573abf8..4594720 100644 --- a/src/pl_read_parms_cal.f90 +++ b/src/pl_read_parms_cal.f90 @@ -109,10 +109,10 @@ subroutine pl_read_parms_cal exit end do - end if + end if db_mx%plcal_reg = mreg - + close(107) return end subroutine pl_read_parms_cal \ No newline at end of file diff --git a/src/pl_read_regions_cal.f90 b/src/pl_read_regions_cal.f90 index 9b4f509..9db82ff 100644 --- a/src/pl_read_regions_cal.f90 +++ b/src/pl_read_regions_cal.f90 @@ -90,10 +90,10 @@ subroutine pl_read_regions_cal exit end do - end if + end if db_mx%plcal_reg = mreg - + close(107) return end subroutine pl_read_regions_cal \ No newline at end of file diff --git a/src/pl_root_gro.f90 b/src/pl_root_gro.f90 index f0df557..bbd9177 100644 --- a/src/pl_root_gro.f90 +++ b/src/pl_root_gro.f90 @@ -51,7 +51,7 @@ subroutine pl_root_gro(j) end if !! root mass - pl_mass(j)%root(ipl)%m = pcom(j)%plg(ipl)%root_frac * pl_mass(j)%tot(ipl)%m + !pl_mass(j)%root(ipl)%m = pcom(j)%plg(ipl)%root_frac * pl_mass(j)%tot(ipl)%m return end subroutine pl_root_gro \ No newline at end of file diff --git a/src/pl_rootfr.f90 b/src/pl_rootfr.f90 index 6ee7e8e..03b780d 100644 --- a/src/pl_rootfr.f90 +++ b/src/pl_rootfr.f90 @@ -1,7 +1,7 @@ - subroutine pl_rootfr - !! This subroutine distributes dead root mass through the soil profile - !! code developed by Armen R. Kemanian in 2008 - !! March, 2009 further adjustments expected + subroutine pl_rootfr + !! This subroutine distributes dead root mass through the soil profile + !! code developed by Armen R. Kemanian in 2008 + !! March, 2009 further adjustments expected use hru_module, only : ihru use soil_module @@ -9,13 +9,13 @@ subroutine pl_rootfr implicit none - real :: sol_thick(soil(ihru)%nly) ! | - real :: cum_rd = 0. ! | + real :: sol_thick(soil(ihru)%nly) ! | + real :: cum_rd = 0. ! | real :: cum_d = 0. ! | real :: cum_rf = 0. ! | real :: x1 = 0. ! | real :: x2 = 0. ! | - integer :: k = 0 ! | + integer :: k = 0 ! | integer :: l = 0 !none |number of soil layer that manure applied integer :: jj = 0 !none |counter real :: a = 0. ! | @@ -26,61 +26,61 @@ subroutine pl_rootfr real :: xx1 = 0. ! | real :: xx2 = 0. ! | real :: xx = 0. ! | - - jj = ihru + + jj = ihru if (pcom(jj)%plg(1)%root_dep < 1.e-6) then soil(jj)%ly(1)%rtfr = 1 return endif - ! Normalized Root Density = 1.15*exp[-11.7*NRD] + 0.022, where NRD = normalized rooting depth - ! Parameters of Normalized Root Density Function from Dwyer et al 19xx - a = 1.15 - b = 11.7 - c = 0.022 - d = 0.12029 ! Integral of Normalized Root Distribution Function - ! from 0 to 1 (normalized depth) = 0.12029 + ! Normalized Root Density = 1.15*exp[-11.7*NRD] + 0.022, where NRD = normalized rooting depth + ! Parameters of Normalized Root Density Function from Dwyer et al 19xx + a = 1.15 + b = 11.7 + c = 0.022 + d = 0.12029 ! Integral of Normalized Root Distribution Function + ! from 0 to 1 (normalized depth) = 0.12029 - l = 0 - k = 0 - cum_d = 0. - cum_rf = 0. + l = 0 + k = 0 + cum_d = 0. + cum_rf = 0. sol_thick(:) = 0. rtfr = 0. - do l = 1, soil(jj)%nly - if (l == 1) then - sol_thick(l) = soil(jj)%phys(l)%d - else - sol_thick(l) = soil(jj)%phys(l)%d - soil(jj)%phys(l-1)%d - end if - - cum_d = cum_d + sol_thick(l) - if (cum_d >= pcom(jj)%plg(1)%root_dep) cum_rd = pcom(jj)%plg(1)%root_dep - if (cum_d < pcom(jj)%plg(1)%root_dep) cum_rd = cum_d - x1 = (cum_rd - sol_thick(l)) / pcom(jj)%plg(1)%root_dep - x2 = cum_rd / pcom(jj)%plg(1)%root_dep + do l = 1, soil(jj)%nly + if (l == 1) then + sol_thick(l) = soil(jj)%phys(l)%d + else + sol_thick(l) = soil(jj)%phys(l)%d - soil(jj)%phys(l-1)%d + end if + + cum_d = cum_d + sol_thick(l) + if (cum_d >= pcom(jj)%plg(1)%root_dep) cum_rd = pcom(jj)%plg(1)%root_dep + if (cum_d < pcom(jj)%plg(1)%root_dep) cum_rd = cum_d + x1 = (cum_rd - sol_thick(l)) / pcom(jj)%plg(1)%root_dep + x2 = cum_rd / pcom(jj)%plg(1)%root_dep xx1 = -b * x1 - if (xx1 > 20.) xx1 = 20. + if (xx1 > 20.) xx1 = 20. xx2 = -b * x2 if (xx2 > 20.) xx2 = 20. - soil(jj)%ly(l)%rtfr = (a/b*(Exp(xx1) - Exp(xx2)) + c *(x2 - x1))/d + soil(jj)%ly(l)%rtfr = (a/b*(Exp(xx1) - Exp(xx2)) + c *(x2 - x1))/d xx = cum_rf - cum_rf = cum_rf + soil(jj)%ly(l)%rtfr + cum_rf = cum_rf + soil(jj)%ly(l)%rtfr if (cum_rf > 1.) then - soil(jj)%ly(l)%rtfr = 1. - xx + soil(jj)%ly(l)%rtfr = 1. - xx cum_rf = 1.0 end if - k = l - if (cum_rd >= pcom(jj)%plg(1)%root_dep) Exit - - end do + k = l + if (cum_rd >= pcom(jj)%plg(1)%root_dep) Exit + + end do - !! ensures that cumulative fractional root distribution = 1 - do l = 1, soil(jj)%nly - soil(jj)%ly(l)%rtfr = soil(jj)%ly(l)%rtfr / cum_rf - If (l == k) Exit ! exits loop on the same layer as the previous loop + !! ensures that cumulative fractional root distribution = 1 + do l = 1, soil(jj)%nly + soil(jj)%ly(l)%rtfr = soil(jj)%ly(l)%rtfr / cum_rf + If (l == k) Exit ! exits loop on the same layer as the previous loop end do return diff --git a/src/plant_all_init.f90 b/src/plant_all_init.f90 index f2f490f..2fd8741 100644 --- a/src/plant_all_init.f90 +++ b/src/plant_all_init.f90 @@ -15,6 +15,8 @@ subroutine plant_all_init integer :: num_plts_cur = 0 !none |temporary counter for number of different plants in basin allocate (plts_bsn(db_mx%plantparm)) + allocate (bsn_crop_yld(db_mx%plantparm)) + allocate (bsn_crop_yld_aa(db_mx%plantparm)) !!assign land use pointers for the hru !!allocate and initialize land use and management @@ -32,7 +34,7 @@ subroutine plant_all_init if (basin_plants == 0) then plts_bsn(1) = pcom(iihru)%pl(ipl) basin_plants = 1 - end if + else num_plts_cur = basin_plants do iplt = 1, num_plts_cur if (pcom(iihru)%pl(ipl) == plts_bsn(iplt)) exit @@ -41,26 +43,20 @@ subroutine plant_all_init basin_plants = basin_plants + 1 end if end do + end if end do end do - !! set all plants simulated in the basin - allocate (plants_bsn(basin_plants)) - allocate (bsn_crop_yld(basin_plants)) - allocate (bsn_crop_yld_aa(basin_plants)) - !! zero basin crop yields and harvested areas do ipl_bsn = 1, basin_plants bsn_crop_yld(ipl_bsn) = bsn_crop_yld_z bsn_crop_yld_aa(ipl_bsn) = bsn_crop_yld_z end do - plants_bsn = plts_bsn(1:basin_plants) - deallocate (plts_bsn) do iihru = 1, sp_ob%hru do ipl = 1, pcom(iihru)%npl do ipl_bsn = 1, basin_plants - if (pcom(iihru)%pl(ipl) == plants_bsn(ipl_bsn)) then + if (pcom(iihru)%pl(ipl) == plts_bsn(ipl_bsn)) then pcom(iihru)%plcur(ipl)%bsn_num = ipl_bsn exit end if diff --git a/src/plant_data_module.f90 b/src/plant_data_module.f90 index fa5f0c9..08b8d40 100644 --- a/src/plant_data_module.f90 +++ b/src/plant_data_module.f90 @@ -2,8 +2,7 @@ module plant_data_module implicit none - character(len=16), dimension (:), allocatable :: plts_bsn !none |plant names simulated in current run - character(len=16), dimension (:), allocatable :: plants_bsn !none |plant names simulated in current run - final + character(len=40), dimension (:), allocatable :: plts_bsn !none |plant names simulated in current run type plant_db character(len=40) :: plantnm = "" !none |crop name diff --git a/src/plant_init.f90 b/src/plant_init.f90 index 7520748..0030535 100644 --- a/src/plant_init.f90 +++ b/src/plant_init.f90 @@ -78,6 +78,9 @@ subroutine plant_init (init, iihru) deallocate (pcom(j)%plstr) deallocate (pcom(j)%plcur) deallocate (rsd1(j)%tot) + deallocate (rsd1(j)%meta) + deallocate (rsd1(j)%str) + deallocate (rsd1(j)%lignin) end if pcom(j)%npl = pcomdb(icom)%plants_com @@ -325,7 +328,7 @@ subroutine plant_init (init, iihru) if (pcom(j)%plcur(ipl)%gro == "y") then call pl_root_gro(j) call pl_seed_gro(j) - call pl_partition(j) + call pl_partition(j, 1) end if end do ! ipl loop diff --git a/src/plant_module.f90 b/src/plant_module.f90 index 05bbe64..5109822 100644 --- a/src/plant_module.f90 +++ b/src/plant_module.f90 @@ -92,7 +92,7 @@ module plant_module type fertilize_future !! set to the fert_fut action in the lum.dtl character(len=35) :: name = "" !! name of the fertilizer operation (from the dtbl) integer :: num = 0 !! number of the future fertilizer application (from the dtbl) - character(len=35) :: fertname = "" !! fertilizer name in fertilizer.frt + character(len=40) :: fertname = "" !! fertilizer name in fertilizer.frt integer :: fertnum = 0 !! fertilizer number in fertilizer.frt integer :: day_fert = 0 !! future julian day to apply fert (must be within a year of test) real :: fert_kg = 0. !! kg/ha - amount of fertilzer applied @@ -101,15 +101,15 @@ module plant_module end type fertilize_future type plant_community - character(len=35) :: name = "" + character(len=40) :: name = "" integer :: npl = 0 !! number of plants in community - character(len=16), dimension(:), allocatable :: pl !! N/A |plant name + character(len=40), dimension(:), allocatable :: pl !! N/A |plant name integer :: pcomdb = 0 !! current plant community database number integer :: rot_yr = 1 !! rotation year integer :: days_plant = 0 !! |days since last planting - for conditional scheduling planting integer :: days_harv = 0 !! |days since last harvest - for conditional scheduling planting integer :: days_irr = 0 !! |days since last irrigation - for conditional scheduling planting - character(len=16) :: last_kill = ""!! |name of last plant killed + character(len=40) :: last_kill = ""!! |name of last plant killed real :: cht_mx = 0. !! m |height of tallest plant in community for pet calculation real :: lai_sum = 0. !! m/m |sum of lai for each plant real :: laimx_sum = 0. !! m/m |sum of maximum lai for each plant - for canopy interception diff --git a/src/plantparm_init.f90 b/src/plantparm_init.f90 index 88e4ff5..87f1c55 100644 --- a/src/plantparm_init.f90 +++ b/src/plantparm_init.f90 @@ -22,11 +22,11 @@ subroutine plantparm_init if (pldb(ic)%usle_c >= 1.0) pldb(ic)%usle_c = 1.0 if (pldb(ic)%blai <= 0.0) pldb(ic)%blai = 0.0 if (pldb(ic)%blai >= 10.0) pldb(ic)%blai = 10.0 - if (pldb(ic)%rsr1 <= 0.0) pldb(ic)%rsr1 = 0.4 - if (pldb(ic)%rsr2 <= 0.0) pldb(ic)%rsr2 = 0.2 + if (pldb(ic)%rsr1 <= 0.0) pldb(ic)%rsr1 = 0.4 + if (pldb(ic)%rsr2 <= 0.0) pldb(ic)%rsr2 = 0.2 if (pldb(ic)%aeration <= 0.0) pldb(ic)%aeration = 0.2 - if (pldb(ic)%rsd_pctcov <= 0.0) pldb(ic)%rsd_pctcov = 0.4 - if (pldb(ic)%rsd_covfac <= 0.0) pldb(ic)%rsd_covfac = 0.04 + if (pldb(ic)%rsd_pctcov <= 0.0) pldb(ic)%rsd_pctcov = 0.4 + if (pldb(ic)%rsd_covfac <= 0.0) pldb(ic)%rsd_covfac = 0.04 !! check if tuber, root to total biomass ratio = 0.7 if (pldb(ic)%typ == "warm_annual_tuber" .or. pldb(ic)%typ == "cold_annual_tuber") then diff --git a/src/proc_bsn.f90 b/src/proc_bsn.f90 index c50336a..3b4491b 100644 --- a/src/proc_bsn.f90 +++ b/src/proc_bsn.f90 @@ -12,7 +12,7 @@ subroutine proc_bsn write (9001,*) "DIAGNOSTICS.OUT FILE" !!! open drainage areas output file open (9004,file="area_calc.out", recl=8000) - + call basin_read_cc call basin_read_objs call time_read diff --git a/src/rec_read_elements.f90 b/src/rec_read_elements.f90 index 3b8f363..a9e56c7 100644 --- a/src/rec_read_elements.f90 +++ b/src/rec_read_elements.f90 @@ -72,7 +72,7 @@ subroutine rec_read_elements db_mx%rec_out = mreg end do - end if + end if !! setting up regions for recall soft cal and/or output by type inquire (file=in_regs%def_psc_reg, exist=i_exist) @@ -116,7 +116,7 @@ subroutine rec_read_elements db_mx%rec_reg = mreg end do - end if + end if !! if no regions are input, don"t need elements if (mreg > 0) then diff --git a/src/recall_nut.f90 b/src/recall_nut.f90 index 5b290b2..6a3379f 100644 --- a/src/recall_nut.f90 +++ b/src/recall_nut.f90 @@ -84,7 +84,7 @@ subroutine recall_nut(irec) endif -100 format(i8,i8,100e16.8) +!*** tu Wunused-label: 100 format(i8,i8,100e16.8) return end subroutine recall_nut \ No newline at end of file diff --git a/src/recall_read.f90 b/src/recall_read.f90 index b1649c5..ba4f4c3 100644 --- a/src/recall_read.f90 +++ b/src/recall_read.f90 @@ -161,6 +161,8 @@ subroutine recall_read case (2) !! monthly read (108,*,iostat=eof) jday, mo, day_mo, iyr, ob_typ, ob_name, & recall(i)%hd(mo1,iyrs) + write (10108,*) jday, mo, day_mo, iyr, ob_typ, ob_name, & + recall(i)%hd(mo1,iyrs) case (3) !! annual read (108,*,iostat=eof) jday, mo, day_mo, iyr, ob_typ, ob_name, ht1 recall(i)%hd(1,iyrs) = ht1 diff --git a/src/recall_salt.f90 b/src/recall_salt.f90 index c33f25a..594bd3a 100644 --- a/src/recall_salt.f90 +++ b/src/recall_salt.f90 @@ -81,7 +81,7 @@ subroutine recall_salt(irec) enddo if(rec_salt(irec)%pts_type.eq.1) then do isalt=1,cs_db%num_salts - recsaltb_d(irec)%salt(isalt) = rec_salt(irec)%hd_salt(1,time%yrs)%salt(isalt) + recsaltb_d(irec)%salt(isalt) = rec_salt(irec)%hd_salt(1,time%yrs)%salt(isalt) enddo else do isalt=1,cs_db%num_salts diff --git a/src/reg_read_elements.f90 b/src/reg_read_elements.f90 index d228675..d83f1e4 100644 --- a/src/reg_read_elements.f90 +++ b/src/reg_read_elements.f90 @@ -122,7 +122,7 @@ subroutine reg_read_elements end do ! i = 1, mreg end do - end if + end if !!read data for each element in all landscape cataloging units inquire (file=in_regs%ele_reg, exist=i_exist) diff --git a/src/res_control.f90 b/src/res_control.f90 index d04c488..18e78d6 100644 --- a/src/res_control.f90 +++ b/src/res_control.f90 @@ -76,8 +76,8 @@ subroutine res_control (jres) res_ob(jres)%prev_flo = ht2%flo call res_sediment - else - ictbl = res_dat(idat)%release !! Osvaldo + else + ictbl = res_dat(idat)%release !! Osvaldo call res_rel_conds (ictbl, res(jres)%flo, ht1%flo, 0.) endif diff --git a/src/res_cs.f90 b/src/res_cs.f90 index ff43035..569264d 100644 --- a/src/res_cs.f90 +++ b/src/res_cs.f90 @@ -24,7 +24,7 @@ subroutine res_cs(jres, icon, iob) !rtb cs real :: cs_conc = 0. !concentration of constituent in reservoir water (g/m3 = mg/L) integer :: icmd = 0 !none real :: k_react = 0. !1/day - first-order rate constant, affected by temperature - real :: v_settle = 0. !m/day - settling rate + real :: v_settle = 0. !m/day - settling rate real :: cs_mass_beg = 0. real :: cs_conc_beg = 0. real :: cs_mass_end = 0. @@ -87,11 +87,11 @@ subroutine res_cs(jres, icon, iob) !rtb cs !constituent mass settling to bottom of reservoir if(ics == 1) then v_settle = res_cs_data(icon)%v_seo4 - elseif(ics == 2) then + elseif(ics == 2) then v_settle = res_cs_data(icon)%v_seo3 - elseif(ics == 3) then + elseif(ics == 3) then v_settle = res_cs_data(icon)%v_born - endif + endif cs_settle = (cs_conc_beg/1000.) * v_settle * (res_wat_d(jres)%area_ha*10000.) !kg if(cs_settle > mass_avail) then cs_settle = mass_avail !take remaining diff --git a/src/res_cs_module.f90 b/src/res_cs_module.f90 index a0323bc..b6e8478 100644 --- a/src/res_cs_module.f90 +++ b/src/res_cs_module.f90 @@ -28,7 +28,7 @@ module res_cs_module !rtb cs type (res_cs_output), dimension(:), allocatable, save :: rescs_m type (res_cs_output), dimension(:), allocatable, save :: rescs_y type (res_cs_output), dimension(:), allocatable, save :: rescs_a - + !arrays for wetland mass balance output type (res_cs_output), dimension(:), allocatable, save :: wetcs_d type (res_cs_output), dimension(:), allocatable, save :: wetcs_m diff --git a/src/res_hydro.f90 b/src/res_hydro.f90 index c5a97a2..1aa25e0 100644 --- a/src/res_hydro.f90 +++ b/src/res_hydro.f90 @@ -21,23 +21,32 @@ subroutine res_hydro (jres, id, pvol_m3, evol_m3) integer :: tstep = 0 !none |hru number integer :: iac = 0 !none |counter integer :: ic = 0 !none |counter + !integer :: weir_flg=0 !none |counter integer, intent (in) :: id !none |hru number integer :: ial = 0 !none |counter integer :: irel = 0 ! | integer :: iob = 0 !none |hru or wro number real :: vol = 0. ! | + real :: vol_above = 0. ! | real :: b_lo = 0. ! | character(len=1) :: action = ""! | real :: res_h = 0. !m |water depth real :: demand = 0. !m3 |irrigation demand by hru or wro real :: wsa1 = 0. !m2 |water surface area + real :: qout = 0. !m3 |weir discharge during short time step + real :: hgt = 0. !m |height of bottom of weir above bottom of impoundment real :: hgt_above = 0. !m |height of water above the above bottom of weir - real :: alpha_e = 0. + real :: sto_max = 0. !m3 |maximum storage volume at the bank top !! store initial values vol = wbody%flo nstep = 1 wsa1 = wbody_wb%area_ha * 10000. !m2 + if (time%step>0) then !Jaehak 2024 + nstep = time%step + else + nstep = 1 + end if do tstep = 1, nstep @@ -90,6 +99,8 @@ subroutine res_hydro (jres, id, pvol_m3, evol_m3) end select ht2%flo = ht2%flo + (wbody%flo - b_lo) / d_tbl%act(iac)%const / nstep ht2%flo = max(0.,ht2%flo) + !wbody%flo = max(0.,wbody%flo - ht2%flo) + vol = wbody%flo case ("dyrt") !! release based on drawdown days + percentage of principal volume @@ -157,8 +168,32 @@ subroutine res_hydro (jres, id, pvol_m3, evol_m3) case ("weir") !! release based on weir equation - res_h = vol / (wbody_wb%area_ha * 10000.) !m + iweir = d_tbl%act_typ(iac) + res_h = vol / wsa1 !m hgt_above = max(0., res_h - wet_ob(jres)%weir_hgt) !m + if (nstep>24) then !hourly interval + ht2%flo = res_weir(iweir)%c * res_weir(iweir)%w * hgt_above ** res_weir(iweir)%k !m3/s + ht2%flo = max(0.,86400. / nstep * ht2%flo) !m3 + vol = vol - ht2%flo + else + do ic = 1, 24 + vol_above = hgt_above * wsa1 !m3 water volume above weir height + qout = res_weir(iweir)%c * res_weir(iweir)%w * hgt_above ** res_weir(iweir)%k !m3/s + qout = 3600. * qout !m3 + if (qout > vol_above) then + ht2%flo = ht2%flo + vol_above !weir discharge volume for the day, m3 + vol = vol - vol_above + else + ht2%flo = ht2%flo + qout + vol = vol - qout + end if + res_h = vol / wsa1 !m + hgt_above = max(0.,res_h - wet_ob(jres)%weir_hgt) !m Jaehak 2022 + if (vol_above<=0.001.or.hgt_above<=0.0001) exit + end do + endif + res_h = vol / wsa1 !m + wbody%flo = vol !m3 iweir = d_tbl%act_typ(iac) ht2%flo = ht2%flo + res_weir(iweir)%c * res_weir(iweir)%w * hgt_above ** res_weir(iweir)%k / nstep !m3/s ht2%flo = ht2%flo + max(0.,ht2%flo) diff --git a/src/res_nutrient.f90 b/src/res_nutrient.f90 index cf009e1..6e4bd00 100644 --- a/src/res_nutrient.f90 +++ b/src/res_nutrient.f90 @@ -89,13 +89,13 @@ subroutine res_nutrient (iob) ht2%no2 = wbody%no2 * ht2%flo / (wbody%flo + ht2%flo) !! remove nutrients leaving reservoir - wbody%no3 = wbody%no3 - ht2%no3 - wbody%orgn = wbody%orgn - ht2%orgn - wbody%sedp = wbody%sedp - ht2%sedp - wbody%solp = wbody%solp - ht2%solp - wbody%chla = wbody%chla - ht2%chla - wbody%nh3 = wbody%nh3 - ht2%nh3 - wbody%no2 = wbody%no2 - ht2%no2 + wbody%no3 = max(0.,wbody%no3 - ht2%no3) !No less than zero, Jaehak 2024 + wbody%orgn = max(0.,wbody%orgn - ht2%orgn) + wbody%sedp = max(0.,wbody%sedp - ht2%sedp) + wbody%solp = max(0.,wbody%solp - ht2%solp) + wbody%chla = max(0.,wbody%chla - ht2%chla) + wbody%nh3 = max(0.,wbody%nh3 - ht2%nh3) + wbody%no2 = max(0.,wbody%no2 - ht2%no2) return end subroutine res_nutrient \ No newline at end of file diff --git a/src/res_read.f90 b/src/res_read.f90 index d75d649..80fb3b4 100644 --- a/src/res_read.f90 +++ b/src/res_read.f90 @@ -109,6 +109,7 @@ subroutine res_read 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 @@ -134,6 +135,9 @@ subroutine res_read 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 @@ -141,6 +145,7 @@ subroutine res_read 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 diff --git a/src/res_salt_module.f90 b/src/res_salt_module.f90 index b30142b..cfb020c 100644 --- a/src/res_salt_module.f90 +++ b/src/res_salt_module.f90 @@ -24,7 +24,7 @@ module res_salt_module !rtb salt type (res_salt_output), dimension(:), allocatable, save :: ressalt_m type (res_salt_output), dimension(:), allocatable, save :: ressalt_y type (res_salt_output), dimension(:), allocatable, save :: ressalt_a - + !arrays for wetland mass balance output type (res_salt_output), dimension(:), allocatable, save :: wetsalt_d type (res_salt_output), dimension(:), allocatable, save :: wetsalt_m diff --git a/src/res_sediment.f90 b/src/res_sediment.f90 index 35d0575..6f59e06 100644 --- a/src/res_sediment.f90 +++ b/src/res_sediment.f90 @@ -21,54 +21,33 @@ subroutine res_sediment wbody = hz else - !! compute new sediment concentration in reservoir - if (ht1%sed < 1.e-6) ht1%sed = 0.0 - !! velsetl = 1.35 for clay particle m/d - if (wbody_wb%area_ha > 1.e-6) then - velofl = (ht1%flo / wbody_wb%area_ha) / 10000. ! m3/d / ha * 10000. = m/d - if (velofl > 1.e-6) then - trapres = wbody_prm%sed%velsetlr / velofl - else - trapres = 1. - end if - if (trapres > 1.) trapres = 1. - else - trapres = 1. - end if - !wbody%sed = wbody%sed - (ht1%sed * trapres) - !wbody%sil = wbody%sil - (ht1%sil * trapres) - !wbody%cla = wbody%cla - (ht1%cla * trapres) - !! compute concentrations - if (wbody%flo > 0.) then + if (wbody%flo > 0.) then sed_ppm = 1000000. * wbody%sed / wbody%flo sed_ppm = Max(1.e-6, sed_ppm) sil_ppm = 1000000. * wbody%sil / wbody%flo sil_ppm = Max(1.e-6, sil_ppm) cla_ppm = 1000000. * wbody%cla / wbody%flo cla_ppm = Max(1.e-6, cla_ppm) - else + else sed_ppm = 1.e-6 sil_ppm = 1.e-6 cla_ppm = 1.e-6 - endif + endif !! compute change in sediment concentration due to settling if (sed_ppm > wbody_prm%sed%nsed) then - wbody_prm%sed%sed_stlr = exp(-wbody_prm%sed%sed_stlr) - sed_ppm = (sed_ppm - wbody_prm%sed%nsed) * wbody_prm%sed%sed_stlr + wbody_prm%sed%nsed + sed_ppm = (sed_ppm - wbody_prm%sed%nsed) * wbody_prm%sed_stlr_co + wbody_prm%sed%nsed sed_ppm = Max (sed_ppm, wbody_prm%sed%nsed) - !wbody%sed = sed_ppm * wbody%flo / 1000000. ! ppm -> t + !! update wetland sediment after settling + wbody%sed = sed_ppm * wbody%flo / 1000000. + !! calculate sediment in the outflow and subtract from wetland ht2%sed = sed_ppm * ht2%flo / 1000000. - wbody%sed = wbody%sed - ht2%sed + wbody%sed = Max(0.,wbody%sed - ht2%sed) - sil_ppm = (sil_ppm - wbody_prm%sed%nsed) * wbody_prm%sed%sed_stlr + wbody_prm%sed%nsed - wbody%sil = sil_ppm * wbody%flo / 1000000. ! ppm -> t - - cla_ppm = (cla_ppm - wbody_prm%sed%nsed) * wbody_prm%sed%sed_stlr + wbody_prm%sed%nsed - wbody%cla = cla_ppm * wbody%flo / 1000000. ! ppm -> t - !! assume all sand aggregates and gravel settles + wbody%sil = 0. + wbody%cla = 0. wbody%san = 0. wbody%sag = 0. wbody%lag = 0. @@ -78,10 +57,6 @@ subroutine res_sediment !! compute sediment leaving reservoir - ppm -> t ht2%sed = sed_ppm * ht2%flo / 1000000. wbody%sed = wbody%sed - ht2%sed - ht2%sil = sil_ppm * ht2%flo / 1000000. - wbody%sil = wbody%sil - ht2%sil - ht2%cla = cla_ppm * ht2%flo / 1000000. - wbody%cla = wbody%cla - ht2%cla end if diff --git a/src/res_weir_release.f90 b/src/res_weir_release.f90 index d72cb8e..3e30e45 100644 --- a/src/res_weir_release.f90 +++ b/src/res_weir_release.f90 @@ -31,11 +31,13 @@ subroutine res_weir_release (jres, id, ihyd, evol_m3, dep, weir_hgt) real :: wsa1 = 0. !m2 |water surface area real :: qout = 0. !m3 |weir discharge during short time step real :: hgt_above = 0. !m |height of water above the above bottom of weir + real :: vol_above = 0. !m3 |water volume above the bottom of weir !Jaehak 2024 !! store initial values vol = wbody%flo nstep = 1 - iweir = bsn_cc%cn + iweir = wet_ob(jres)%iweir + vol_above = 0 !water storage above weir height if (wet_hyd(ihyd)%name=='paddy') then !paddy @@ -54,15 +56,17 @@ subroutine res_weir_release (jres, id, ihyd, evol_m3, dep, weir_hgt) !endif !write(*,'(10f10.1)') w%precip,vol/wsa1*1000,ht2%flo/wsa1*1000,hru(jres)%water_seep,soil(jres)%sw !! check if reservoir decision table has a weir discharge command - do iac = 1, dtbl_res(id)%acts - if (dtbl_res(id)%act(iac)%option == "weir") then - weir_flg = 1 - exit - endif - end do + ! do iac = 1, dtbl_res(id)%acts + ! if (dtbl_res(id)%act(iac)%option == "weir") then + ! weir_flg = 1 + ! exit + ! endif + ! end do do tstep = 1, nstep + !! calculate weir discharge from scheduled management + if (hgt_above > 0 .and. iweir > 0) then !emergency spillway discharge Jaehak 2023 if (vol>evol_m3) then ht2%flo = ht2%flo + (wbody%flo - evol_m3) @@ -71,31 +75,36 @@ subroutine res_weir_release (jres, id, ihyd, evol_m3, dep, weir_hgt) res_h = vol / wsa1 !m hgt_above = max(0.,res_h - weir_hgt) !m endif + vol_above = hgt_above * wsa1 !m3 if (nstep>1) then !revised by Jaehak 2023 qout = res_weir(iweir)%c * res_weir(iweir)%w * hgt_above ** res_weir(iweir)%k !m3/s qout = max(0.,86400. / nstep * qout) !m3 - if (qout > vol) then - ht2%flo = ht2%flo + vol !weir discharge volume for the day, m3 - vol = 0. + if (qout > vol_above) then + ht2%flo = ht2%flo + vol_above !weir discharge volume for the day, m3 + vol = vol - vol_above + vol_above = 0. else ht2%flo = ht2%flo + qout vol = vol - qout + vol_above = vol_above - qout end if res_h = vol / wsa1 !m hgt_above = max(0.,res_h - weir_hgt) !m Jaehak 2022 - if (vol==0.or.hgt_above==0) exit + if (vol_above<=0.001.or.hgt_above<=0.0001) exit else do ic = 1, 24 qout = res_weir(iweir)%c * res_weir(iweir)%w * hgt_above ** res_weir(iweir)%k !m3/s qout = 3600. * qout !m3 - if (qout > vol) then - ht2%flo = ht2%flo + vol !weir discharge volume for the day, m3 - vol = 0. + if (qout > vol_above) then + ht2%flo = ht2%flo + vol_above !weir discharge volume for the day, m3 + vol = vol - vol_above + vol_above = 0. else ht2%flo = ht2%flo + qout vol = vol - qout + vol_above = vol_above - qout end if if (wsa1 > 1.e-6) then @@ -104,9 +113,13 @@ subroutine res_weir_release (jres, id, ihyd, evol_m3, dep, weir_hgt) res_h = 0. end if hgt_above = max(0.,res_h - weir_hgt) !m Jaehak 2022 - if (vol==0.or.hgt_above==0) exit + if (vol_above<=0.001.or.hgt_above<=0.0001) exit end do endif + else + ht2%flo = 0. + endif + wbody%flo = vol !m3 end do return diff --git a/src/reservoir_data_module.f90 b/src/reservoir_data_module.f90 index fa3b706..b49c55d 100644 --- a/src/reservoir_data_module.f90 +++ b/src/reservoir_data_module.f90 @@ -98,7 +98,7 @@ module reservoir_data_module type reservoir_sed_data character(len=25) :: name = "" real :: nsed = 0. !kg/L |normal amt of sed in res (read in as mg/L and convert to kg/L) - real :: d50 = 0. !mm |median particle size of suspended and benthic sediment + real :: d50 = 0. !um |median particle size of suspended and benthic sediment real :: carbon = 0. !% |organic carbon in suspended and benthic sediment real :: bd = 0. !t/m^3 |bulk density of benthic sediment real :: sed_stlr = 0. !none |sediment settling rate @@ -126,6 +126,7 @@ module reservoir_data_module type water_body_data_parameters type (reservoir_sed_data) :: sed type (reservoir_nut_data) :: nut + real :: sed_stlr_co = 0. !none | end type water_body_data_parameters type (water_body_data_parameters), dimension(:), allocatable, target :: res_prm type (water_body_data_parameters), dimension(:), allocatable, target :: wet_prm diff --git a/src/rsd_decomp.f90 b/src/rsd_decomp.f90 new file mode 100644 index 0000000..329aa81 --- /dev/null +++ b/src/rsd_decomp.f90 @@ -0,0 +1,171 @@ + subroutine rsd_decomp + +!! ~ ~ ~ PURPOSE ~ ~ ~ +!! this subroutine estimates daily nitrogen and phosphorus +!! mineralization and immobilization considering fresh organic +!! material (plant residue) and active and stable humus material + +!! ~ ~ ~ INCOMING VARIABLES ~ ~ ~ +!! name |units |definition +!! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ +!! ihru |none |HRU number +!! rsdco_pl(:) |none |plant residue decomposition coefficient. The +!! |fraction of residue which will decompose in +!! |a day assuming optimal moisture, +!! |temperature, C:N ratio, and C:P ratio +!!! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ + +!! ~ ~ ~ OUTGOING VARIABLES ~ ~ ~ +!! name |units |definition +!! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ + +!! ~ ~ ~ LOCAL DEFINITIONS ~ ~ ~ +!! name |units |definition +!! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ +!! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ + +!! ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~ +!! Intrinsic: Max, Exp, Sqrt, Min, Abs + +!! ~ ~ ~ ~ ~ ~ END SPECIFICATIONS ~ ~ ~ ~ ~ ~ + + use plant_data_module + use basin_module + use organic_mineral_mass_module + use hru_module, only : rsdco_plcom, i_sep, ihru, ipl, isep + use soil_module + use plant_module + use output_landscape_module, only : hnb_d + use carbon_module, only : hrc_d + + implicit none + + integer :: j = 0 !none |HRU number + integer :: k = 0 !none |counter (soil layer) + integer :: kk = 0 !none |soil layer used to compute soil water and + ! |soil temperature factors + integer :: idp = 0 + real :: rmn1 = 0. !kg N/ha |amount of nitrogen moving from fresh organic + ! |to nitrate(80%) and active organic(20%) + ! |pools in layer + real :: rmp = 0. ! |to labile(80%) and organic(20%) pools in layer + real :: xx = 0. !varies |variable to hold intermediate calculation result + real :: csf = 0. !none |combined temperature/soil water factor + real :: cnr = 0. ! |carbon nitrogen ratio + real :: cnrf = 0. ! |carbon nitrogen ratio factor + real :: cpr = 0. ! |carbon phosphorus ratio + real :: cprf = 0. ! |carbon phosphorus ratio factor + real :: ca = 0. ! | + real :: decr = 0. ! | + real :: rdc = 0. ! | + real :: cdg = 0. !none |soil temperature factor + real :: sut = 0. !none |soil water factor + + j = ihru + + !zero transformations for summing layers + hnb_d(j)%rsd_nitorg_n = 0. + hnb_d(j)%rsd_laborg_p = 0. + + !! mineralization can occur only if temp above 0 deg + if (soil(j)%phys(1)%tmp > 0.) then + rsd1(j)%tot_com = orgz + if (bsn_cc%cswat == 2) then + rsd1(j)%tot_meta = orgz + rsd1(j)%tot_str = orgz + rsd1(j)%tot_lignin = orgz + end if + + !! compute residue decomp and mineralization of fresh organic n and p of flat residue + do ipl = 1, pcom(j)%npl !! we need to decompose each plant + rmn1 = 0. + rmp = 0. + if (rsd1(j)%tot(ipl)%n > 1.e-4) then + cnr = rsd1(j)%tot(ipl)%c / rsd1(j)%tot(ipl)%n + if (cnr > 500.) cnr = 500. + cnrf = Exp(-.693 * (cnr - 25.) / 25.) + else + cnrf = 1. + end if + + if (rsd1(j)%tot(ipl)%p > 1.e-4) then + cpr = rsd1(j)%tot(ipl)%c / rsd1(j)%tot(ipl)%p + if (cpr > 5000.) cpr = 5000. + cprf = Exp(-.693 * (cpr - 200.) / 200.) + else + cprf = 1. + end if + + !! compute soil water factor + if (soil(j)%phys(1)%st < 0.) soil(j)%phys(1)%st = .0000001 + sut = .1 + .9 * Sqrt(soil(j)%phys(1)%st / soil(j)%phys(1)%fc) + sut = Max(.05, sut) + + !!compute soil temperature factor + xx = soil(j)%phys(1)%tmp + cdg = .9 * xx / (xx + Exp(9.93 - .312 * xx)) + .1 + cdg = Max(.1, cdg) + + !! compute combined factor + xx = cdg * sut + if (xx < 0.) xx = 0. + if (xx > 1.e6) xx = 1.e6 + csf = Sqrt(xx) + ca = Min(cnrf, cprf, 1.) + !! compute residue decomp and mineralization for each plant + if (pcom(j)%npl > 0) then + idp = pcom(j)%plcur(ipl)%idplt + decr = pldb(idp)%rsdco_pl * ca * csf + else + decr = 0.05 * ca * csf + end if + decr = Max(bsn_prm%decr_min, decr) + decr = Min(decr, 1.) + + !! mineralization of mass and carbon + rsd1(j)%tot(ipl)%m = Max(1.e-6, rsd1(j)%tot(ipl)%m) + rdc = decr * rsd1(j)%tot(ipl)%m + rsd1(j)%tot(ipl)%m = rsd1(j)%tot(ipl)%m - rdc + if (rsd1(j)%tot(ipl)%m < 0.) rsd1(j)%tot(ipl)%m = 0. + + !! apply decay to total carbon pool + rsd1(j)%tot(ipl)%c = (1. - decr) * rsd1(j)%tot(ipl)%c + if (rsd1(j)%tot(ipl)%c < 0.) rsd1(j)%tot(ipl)%c = 0. + soil1(j)%hact(1)%c = soil1(j)%hact(1)%c + decr * rsd1(j)%tot(ipl)%c + + !! apply decay to all carbon pools + if (bsn_cc%cswat == 2) then + rsd1(j)%meta(ipl) = (1. - decr) * rsd1(j)%meta(ipl) + rsd1(j)%str(ipl) = (1. - decr) * rsd1(j)%str(ipl) + rsd1(j)%lignin(ipl) = (1. - decr) * rsd1(j)%lignin(ipl) + end if + + !! mineralization of residue n and p + rmn1 = decr * rsd1(j)%tot(ipl)%n + rsd1(j)%tot(ipl)%n = Max(1.e-6, rsd1(j)%tot(ipl)%n) + rsd1(j)%tot(ipl)%n = rsd1(j)%tot(ipl)%n - rmn1 + soil1(j)%mn(1)%no3 = soil1(j)%mn(1)%no3 + .8 * rmn1 + soil1(j)%hact(1)%n = soil1(j)%hact(1)%n + .2 * rmn1 + + rsd1(j)%tot(ipl)%p = Max(1.e-6, rsd1(j)%tot(ipl)%p) + rmp = decr * rsd1(j)%tot(ipl)%p + rsd1(j)%tot(ipl)%p = rsd1(j)%tot(ipl)%p - rmp + soil1(j)%mp(1)%lab = soil1(j)%mp(1)%lab + .8 * rmp + soil1(j)%hact(1)%p = soil1(j)%hact(1)%p + .2 * rmp + + hnb_d(j)%rsd_nitorg_n = hnb_d(j)%rsd_nitorg_n + .8 * rmn1 + hnb_d(j)%rsd_laborg_p = hnb_d(j)%rsd_laborg_p + .8 * rmp + + !! sum total residue pools + rsd1(j)%tot_com = rsd1(j)%tot_com + rsd1(j)%tot(ipl) + if (bsn_cc%cswat == 2) then + rsd1(j)%tot_meta = rsd1(j)%tot_meta + rsd1(j)%meta(ipl) + rsd1(j)%tot_str = rsd1(j)%tot_str + rsd1(j)%str(ipl) + rsd1(j)%tot_lignin = rsd1(j)%tot_lignin + rsd1(j)%lignin(ipl) + end if + + end do ! ipl = 1, pcom(j)%npl + end if ! soil temperature > 0. + + return + end subroutine rsd_decomp \ No newline at end of file diff --git a/src/ru_cs_output.f90 b/src/ru_cs_output.f90 index 0e43ba1..7792664 100644 --- a/src/ru_cs_output.f90 +++ b/src/ru_cs_output.f90 @@ -10,7 +10,7 @@ subroutine ru_cs_output(iru) !rtb cs integer, intent (in) :: iru ! | integer :: iob = 0 ! | - integer :: ics = 0 ! |constituent counter + integer :: ics = 0 ! |constituent counter integer :: ihyd = 0 ! |hydrograph counter !! ~ ~ ~ PURPOSE ~ ~ ~ @@ -64,7 +64,7 @@ subroutine ru_cs_output(iru) !rtb cs (ru_hru_csb_d(iru)%cs(ics)%sorb,ics=1,cs_db%num_cs) if (pco%csvout == "y") then write (6071,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iru, ob(iob)%gis_id, & - (rucsb_d(iru)%hd(1)%cs(ics),ics=1,cs_db%num_cs), & !total out + (rucsb_d(iru)%hd(1)%cs(ics),ics=1,cs_db%num_cs), & !total out (rucsb_d(iru)%hd(2)%cs(ics),ics=1,cs_db%num_cs), & !percolation (rucsb_d(iru)%hd(3)%cs(ics),ics=1,cs_db%num_cs), & !surface runoff (rucsb_d(iru)%hd(4)%cs(ics),ics=1,cs_db%num_cs), & !soil lateral flow diff --git a/src/ru_output.f90 b/src/ru_output.f90 index 3184522..48e7da1 100644 --- a/src/ru_output.f90 +++ b/src/ru_output.f90 @@ -60,7 +60,7 @@ subroutine ru_output (iru) return -100 format (4i6,2i8,25f15.3) -102 format (4i6,2i8,25f15.3) +!*** tu Wunused-label: 100 format (4i6,2i8,25f15.3) +!*** tu Wunused-label: 102 format (4i6,2i8,25f15.3) end subroutine ru_output \ No newline at end of file diff --git a/src/ru_salt_output.f90 b/src/ru_salt_output.f90 index 5156c34..9265186 100644 --- a/src/ru_salt_output.f90 +++ b/src/ru_salt_output.f90 @@ -64,7 +64,7 @@ subroutine ru_salt_output(iru) !rtb salt ru_hru_saltb_d(iru)%salt(1)%diss if (pco%csvout == "y") then write (5071,'(*(G0.3,:","))') time%day, time%mo, time%day_mo, time%yrc, iru, ob(iob)%gis_id, & - (rusaltb_d(iru)%hd(1)%salt(isalt),isalt=1,cs_db%num_salts), & + (rusaltb_d(iru)%hd(1)%salt(isalt),isalt=1,cs_db%num_salts), & (rusaltb_d(iru)%hd(2)%salt(isalt),isalt=1,cs_db%num_salts), & (rusaltb_d(iru)%hd(3)%salt(isalt),isalt=1,cs_db%num_salts), & (rusaltb_d(iru)%hd(4)%salt(isalt),isalt=1,cs_db%num_salts), & @@ -299,7 +299,7 @@ subroutine ru_salt_output(iru) !rtb salt (ru_hru_saltb_a(iru)%salt(isalt)%rain,isalt=1,cs_db%num_salts), & (ru_hru_saltb_a(iru)%salt(isalt)%dryd,isalt=1,cs_db%num_salts), & (ru_hru_saltb_a(iru)%salt(isalt)%road,isalt=1,cs_db%num_salts), & - (ru_hru_saltb_a(iru)%salt(isalt)%fert,isalt=1,cs_db%num_salts), & + (ru_hru_saltb_a(iru)%salt(isalt)%fert,isalt=1,cs_db%num_salts), & (ru_hru_saltb_a(iru)%salt(isalt)%amnd,isalt=1,cs_db%num_salts), & (ru_hru_saltb_a(iru)%salt(isalt)%uptk,isalt=1,cs_db%num_salts), & ru_hru_saltb_a(iru)%salt(1)%diss diff --git a/src/salt_balance.f90 b/src/salt_balance.f90 index 637396b..08f3792 100644 --- a/src/salt_balance.f90 +++ b/src/salt_balance.f90 @@ -499,14 +499,14 @@ subroutine salt_balance gwsol_ss(i)%solute(2+m)%rcti = 0. gwsol_ss(i)%solute(2+m)%rcto = 0. gwsol_ss(i)%solute(2+m)%minl = 0. - enddo + enddo enddo endif endif 7000 format(i8,i8,i8,35e16.8) -7001 format(20e16.8) +!*** tu Wunused-label: 7001 format(20e16.8) return end \ No newline at end of file diff --git a/src/salt_chem_hru.f90 b/src/salt_chem_hru.f90 index 757a110..0281bce 100644 --- a/src/salt_chem_hru.f90 +++ b/src/salt_chem_hru.f90 @@ -198,29 +198,29 @@ subroutine salt_chem_hru if(K_ADJ1.gt.0.) then salt_K1 = Ksp11/K_ADJ1 - else + else salt_K1 = 0. - endif + endif if(K_ADJ2.gt.0.) then salt_K2 = Ksp21/K_ADJ2 - else + else salt_K2 = 0. - endif + endif if(K_ADJ3.gt.0.) then salt_K3 = Ksp31/K_ADJ3 - else + else salt_K3 = 0. - endif + endif if(K_ADJ4.gt.0.) then salt_K4 = Ksp41/K_ADJ4 - else + else salt_K4 = 0. - endif + endif if(K_ADJ5.gt.0.) then salt_K5 = Ksp51/K_ADJ5 - else + else salt_K5 = 0. - endif + endif errorTotal = 1 @@ -365,7 +365,7 @@ subroutine salt_chem_hru mass_after = mass_after / hru(j)%area_ha !kg/ha hsaltb_d(j)%salt(1)%diss = mass_after - mass_before -101 format(i8,i8,i8,i8,50(e13.4)) +!*** tu Wunused-label: 101 format(i8,i8,i8,i8,50(e13.4)) return end diff --git a/src/salt_chem_soil_single.f90 b/src/salt_chem_soil_single.f90 index a578c97..a52ed13 100644 --- a/src/salt_chem_soil_single.f90 +++ b/src/salt_chem_soil_single.f90 @@ -112,29 +112,29 @@ subroutine salt_chem_soil_single(hru_num,lay_num,waterC) !rtb salt if(K_ADJ1.gt.0.) then salt_K1 = Ksp11/K_ADJ1 - else + else salt_K1 = 0. - endif + endif if(K_ADJ2.gt.0.) then salt_K2 = Ksp21/K_ADJ2 - else + else salt_K2 = 0. - endif + endif if(K_ADJ3.gt.0.) then salt_K3 = Ksp31/K_ADJ3 - else + else salt_K3 = 0. - endif + endif if(K_ADJ4.gt.0.) then salt_K4 = Ksp41/K_ADJ4 - else + else salt_K4 = 0. - endif + endif if(K_ADJ5.gt.0.) then salt_K5 = Ksp51/K_ADJ5 - else + else salt_K5 = 0. - endif + endif errorTotal = 1 diff --git a/src/sd_channel_control.f90 b/src/sd_channel_control.f90 index 974b763..ba30c3b 100644 --- a/src/sd_channel_control.f90 +++ b/src/sd_channel_control.f90 @@ -44,8 +44,10 @@ subroutine sd_channel_control real :: washld = 0. !tons |wash load real :: bedld = 0. !tons |bed load real :: dep = 0. !tons |deposition - real :: hc_sed = 0. !tons |headcut erosion - real :: chside = 0. !none |change in horizontal distance per unit + real :: sedp_dep = 0. !kg |Particulate P deposition MJW + real :: orgn_dep = 0. !kg |Particulate N deposition MJW + real :: hc_sed !tons |headcut erosion + real :: chside !none |change in horizontal distance per unit ! |change in vertical distance on channel side ! |slopes; always set to 2 (slope=1/2) real :: a = 0. !m^2 |cross-sectional area of channel @@ -232,7 +234,7 @@ subroutine sd_channel_control if(bsn_cc%gwflow.eq.1) then flood_freq(ich) = 1 !flag to indicate the water is in the floodplain call gwflow_fpln(ich) - endif + endif sd_ch(ich)%overbank = "ob" rcharea = sd_ch_vel(ich)%area @@ -413,7 +415,7 @@ subroutine sd_channel_control !! Peters latest channel erosion model !!vel = 1.37 * (sd_ch(ich)%chs ** 0.31) * (12. * sd_ch(ich)%chw) ** 0.32 !annual ave for SWIFT !! mean daily to peak ratio developed from GARDAY - THE STUDY OF MOST PROBABLE MEAN DAILY BANKFULL RUNOFF VOLUMES - !! IN SMALL WATERSHEDS DOMINATED BY CONVECTIVE/FRONTAL CHANNEL FORMING EVENTS AND THE CO-INCIDENT INNER BERM CHANNELS � PART I. + !! IN SMALL WATERSHEDS DOMINATED BY CONVECTIVE/FRONTAL CHANNEL FORMING EVENTS AND THE CO-INCIDENT INNER BERM CHANNELS – PART I. !! Another eq from Peter - Qmax=Qmean*(1+2.66*Drainage Area^-.3) pk_rto = 0.2 + 0.5 / 250. * ob(icmd)%area_ha pk_rto = amin1 (1., pk_rto) @@ -473,7 +475,7 @@ subroutine sd_channel_control shear_btm = 9800. * rcurv%dep * sd_ch(ich)%chs !! Pa = N/m^2 * m * m/m !! if bottom shear > d50 -> downcut - widen to maintain width depth ratio if (shear_btm > shear_btm_cr) then - ebtm_m = sd_ch(ich)%cherod * (shear_btm - shear_btm_cr) !! cm = hr * cm/hr/Pa * Pa + !ebtm_m = sd_ch(ich)%cherod * (shear_btm - shear_btm_cr) !! cm = hr * cm/hr/Pa * Pa !! calc mass of sediment eroded -> t = cm * m/100cm * width (m) * length (km) * 1000 m/km * bd (t/m3) ebtm_t = 10. * ebtm_m * sd_ch(ich)%chw * sd_ch(ich)%chl * sd_ch(ich)%ch_bd end if @@ -490,7 +492,10 @@ subroutine sd_channel_control !sd_ch(ich)%bankfull_flo = 1.0 !***jga bf_flow = sd_ch(ich)%bankfull_flo * ch_rcurv(ich)%elev(2)%flo_rate if (peakrate > bf_flow) then - dep = sd_ch(ich)%chseq * ht1%sed !((peakrate - bf_flow) / peakrate) * ht1%sed + !dep = sd_ch(ich)%chseq * ht1%sed !((peakrate - bf_flow) / peakrate) * ht1%sed + !! deposit Particulate P and N in the floodplain + !sedp_dep = sd_ch(ich)%chseq * ht1%sedp !MJW 2024 May need to include a enrichment factor for transported sediment + !orgn_dep = sd_ch(ich)%chseq * ht1%orgn !MJW 2024 end if !! compute sediment leaving the channel - washload only @@ -537,10 +542,13 @@ subroutine sd_channel_control !! reset sed to tons ht2%sed = sedout - !! add nutrients from bank erosion - t *ppm (1/1,000,000) * 1000. kg/t - ht2%orgn = ht2%orgn + ebank_t * sd_ch(ich)%n_conc * 1000. - ht2%sedp = ht2%sedp + ebank_t * sd_ch(ich)%p_conc * 1000. - ht2%solp = ht2%solp + ebank_t * sd_ch(ich)%p_bio * 1000. + !! subtract nutrients deposited in floodplain + ht2%sedp = ht2%sedp - sedp_dep !MJW 2024 + ht2%orgn = ht2%orgn - orgn_dep !MJW 2024 + !! add nutrients from bank erosion - t * mg/kg (ppm) * kg/1000 mg * 1000 kg/t = kg + ht2%orgn = ht2%orgn + ebank_t * sd_ch(ich)%n_conc + ht2%sedp = ht2%sedp + ebank_t * sd_ch(ich)%p_conc + ht2%solp = ht2%solp + ebank_t * sd_ch(ich)%p_bio !! route constituents call ch_rtpest diff --git a/src/sd_channel_control3.f90 b/src/sd_channel_control3.f90 index ca119e3..68faffd 100644 --- a/src/sd_channel_control3.f90 +++ b/src/sd_channel_control3.f90 @@ -40,7 +40,7 @@ subroutine sd_channel_control3 real :: erode_bank_cut = 0. !cm |widening caused by downcutting (both sides) real :: ebtm_t = 0. !tons |bottom erosion real :: ebank_t = 0. !tons |bank erosion - real :: sedout = 0. !mg |sediment out of waterway channel + real :: sedout = 0. !mg |sediment out of waterway channel real :: washld = 0. !tons |wash load real :: bedld = 0. !tons |bed load real :: dep = 0. !tons |deposition @@ -310,7 +310,9 @@ subroutine sd_channel_control3 end if ! ht1%flo > 0. !rtb hydrograph separation - if (rttime > det) then ! ht1 = incoming + storage + if (rttime > time%dtm / 60.) then ! travel time > routing time step (hours) + !! Variable Storage Coefficent method - sc=2*dt/(2*ttime+dt) - ttime=(in2+out1)/2 + scoef = 24. / (ch_rcurv(jrch)%in2%ttime + ch_rcurv(jrch)%out1%ttime + 24.) !! travel time > timestep -- then all incoming is stored and frac of stored is routed hdsep2%flo_surq = scoef * ch_stor_hdsep(ich)%flo_surq hdsep2%flo_latq = scoef * ch_stor_hdsep(ich)%flo_latq diff --git a/src/sd_channel_module.f90 b/src/sd_channel_module.f90 index 9662066..d6bd53d 100644 --- a/src/sd_channel_module.f90 +++ b/src/sd_channel_module.f90 @@ -24,10 +24,10 @@ module sd_channel_module real :: chl = 0. !km |channel length real :: chn = 0. ! |channel Manning's n real :: chk = 0. !mm/h |channel bottom conductivity - real :: cherod = 0. ! |channel erodibility + real :: bank_exp = 0. ! |bank erosion exponent real :: cov = 0. !0-1 |channel cover factor real :: sinu = 0. !none |sinuousity - ratio of channel length and straight line length - real :: chseq = 0. !m/m |equilibrium channel slope + real :: vcr_coef = 0. ! |critical velocity coefficient real :: d50 = 0. !mm |channel median sediment size real :: ch_clay = 0. !% |clay percent of bank and bed real :: carbon = 0. !% |carbon percent of bank and bed @@ -54,7 +54,7 @@ module sd_channel_module real :: n_dep_enr = 0.5 ! |enrichment of N in remaining water - deposition = 1/enrichment ratio real :: p_dep_enr = 0.5 ! |enrichment of P in remaining water - deposition = 1/enrichment ratio real :: arc_len_fr = 1.2 !frac |fraction of arc length where bank erosion occurs - real :: part_size = 0.002 !mm |particle size of channel washload + real :: bed_exp = 1.5 ! |bed erosion exponential coefficient real :: wash_bed_fr = 0.1 !frac |fraction of bank erosion that is washload end type swatdeg_sednut_data type (swatdeg_sednut_data), dimension (:), allocatable :: sd_chd1 @@ -172,7 +172,7 @@ module sd_channel_module real :: chk = 0. !mm/h |channel bottom conductivity real :: cov = 0. !0-1 |channel cover factor real :: sinu = 0. !none |sinuousity - ratio of channel length and straight line length - real :: chseq = 0. !m/m |equilibrium channel slope + real :: vcr_coef = 0. !m/m |critical velocity coefficient real :: d50 = 0. real :: ch_clay = 0. real :: carbon = 0. @@ -193,12 +193,12 @@ module sd_channel_module real :: n_dep_enr = 0.5 ! |enrichment of N in remaining water - deposition = 1/enrichment ratio real :: p_dep_enr = 0.5 ! |enrichment of P in remaining water - deposition = 1/enrichment ratio real :: arc_len_fr = 1.2 !frac |fraction of arc length where bank erosion occurs - real :: part_size = 0.002 !mm |particle size of channel washload + real :: bed_exp = 1.5 !mm |bed erosion exponent real :: wash_bed_fr = 0.2 !frac |fraction of bank erosion that is washload real :: hc_kh = 0. real :: hc_hgt = 0. !m |headcut height real :: hc_ini = 0. - real :: cherod = 0. ! |channel erodibility + real :: bank_exp = 0. ! |bank erosion exponent real :: shear_bnk = 0. !0-1 |bank shear coefficient - fraction of bottom shear real :: hc_erod = 0. ! |headcut erodibility real :: hc_co = 0. !m/m |proportionality coefficient for head cut diff --git a/src/sd_channel_sediment.f90 b/src/sd_channel_sediment.f90 index ed7048c..233cc5b 100644 --- a/src/sd_channel_sediment.f90 +++ b/src/sd_channel_sediment.f90 @@ -115,7 +115,7 @@ subroutine sd_channel_sediment (ts_int) shear_bank_cr = 0.493 * 10. ** (.0182 * sd_ch(ich)%ch_clay) e_bank = 0. if (shear_bank_adj > shear_bank_cr) then - e_bank = ts_hr * sd_ch(ich)%cherod * (shear_bank_adj - shear_bank_cr) !! cm = hr * cm/hr/Pa * Pa + !e_bank = ts_hr * sd_ch(ich)%cherod * (shear_bank_adj - shear_bank_cr) !! cm = hr * cm/hr/Pa * Pa erode_bank = erode_bank + e_bank !! calc mass of sediment eroded -> t = cm * m/100cm * width (m) * length (km) * 1000 m/km * bd (t/m3) !! apply to only one side (perim_bank / 2.) @@ -128,7 +128,7 @@ subroutine sd_channel_sediment (ts_int) if (sd_ch(ich)%chs > 0.000001) then ! sd_ch(ich)%chseq) then !! if bottom shear > d50 -> downcut - widen to maintain width depth ratio if (shear_btm > shear_btm_cr) then - e_btm = ts_hr * sd_ch(ich)%cherod * (shear_btm - shear_btm_cr) !! cm = hr * cm/hr/Pa * Pa + !e_btm = ts_hr * sd_ch(ich)%cherod * (shear_btm - shear_btm_cr) !! cm = hr * cm/hr/Pa * Pa !! if downcutting - check width depth ratio to see if widens !if (sd_ch(ich)%chw / sd_ch(ich)%chd < sd_ch(ich)%wd_rto) then ! erode_bank_cut = e_btm * sd_ch(ich)%wd_rto @@ -165,7 +165,7 @@ subroutine sd_channel_sediment (ts_int) !! compute flood plain deposition bf_flow = sd_ch(ich)%bankfull_flo * ch_rcurv(ich)%elev(2)%flo_rate if (peakrate > bf_flow) then - dep = sd_ch(ich)%chseq * ht1%sed !((peakrate - bf_flow) / peakrate) * ht1%sed + !dep = sd_ch(ich)%chseq * ht1%sed !((peakrate - bf_flow) / peakrate) * ht1%sed end if !! output channel morphology @@ -187,7 +187,7 @@ subroutine sd_channel_sediment (ts_int) chsd_d(ich)%hc_m = hc !! compute sediment leaving the channel - washload only - bottom deg is bedload - sedout = ht1%sed - dep + hc_sed + erode_bank ! + ebtm_t + sedout = ht1%sed - dep + hc_sed + erode_bank ! + ebtm_t ht2%sed = sedout diff --git a/src/sd_channel_sediment3.f90 b/src/sd_channel_sediment3.f90 index a6ea481..e94d4ad 100644 --- a/src/sd_channel_sediment3.f90 +++ b/src/sd_channel_sediment3.f90 @@ -2,6 +2,7 @@ subroutine sd_channel_sediment3 use climate_module use sd_channel_module + use channel_module use hydrograph_module use time_module use hru_module, only : hru @@ -22,18 +23,20 @@ subroutine sd_channel_sediment3 real :: vel_fall = 0. !m/s |fall velocity of sediment particles in channel real :: dep_fall = 0. !m |fall depth of sediment particles in channel real :: del_rto = 0. !frac |fraction of sediment deposited in channel - real :: conc_chng = 0. ! |change in concentration (and mass) in channel sol and org N and P real :: ebtm_m = 0. !m |erosion of bottom of channel real :: ebank_m = 0. !m |meander cut on one side real :: ebtm_t = 0. !tons |bottom erosion real :: ebank_t = 0. !tons |bank erosion real :: shear_btm_cr = 0. ! | real :: shear_btm = 0. ! | + real :: inflo = 0. !m^3 |inflow water volume + real :: inflo_rate = 0. !m^3/s |inflow rate + real :: flo_time = 0. !s |estimate of total flow time through the channel real :: bf_flow = 0. !m3/s |bankfull flow rate * adjustment factor real :: pk_rto = 0. !ratio |peak to mean flow rate ratio real :: bd_fac = 0. ! |bulk density factor for critical velocity calculation real :: cohes_fac = 0. ! |cohesion factor for critical velocity calculation - !real :: qman !m^3/s or m/s |flow rate or flow velocity + real :: florate !m^3/s |flow rate below the triangle for flow lasting more than a day real :: vel = 0. real :: veg = 0. real :: vel_cr = 0. @@ -49,7 +52,7 @@ subroutine sd_channel_sediment3 real :: precip = 0. real :: flovol_ob = 0. real :: wet_fill = 0. - + ich = isdch iob = sp_ob1%chandeg + jrch - 1 @@ -67,35 +70,16 @@ subroutine sd_channel_sediment3 !! calculate channel sed and nutrient processes if inflow > 0 if (ht1%flo > 1.e-6) then - !! Another eq from Peter - Qmax=Qmean*(1+2.66*Drainage Area^-.3) - pk_rto = 0.2 + 0.5 / 250. * ob(icmd)%area_ha - pk_rto = Max (1., pk_rto) - pk_rto = 1. + 2.66 * (ob(icmd)%area_ha / 100.) ** (-.3) - !pk_rto = 1. + 1.33 * (ob(icmd)%area_ha / 100.) ** (-.3) - !pk_rto = 1. + 2. * (ob(icmd)%area_ha / 100.) ** (-.3) - !pk_rto = Min (2., pk_rto) - !pk_rto = 1.5 - peakrate = pk_rto * ht1%flo / 86400. !m3/s + !! calculate peak daily flow + peakrate = sd_ch(ich)%pk_rto * ht1%flo / 86400. !m3/s !! interpolate rating curve using peak rate call rcurv_interp_flo (ich, peakrate) !! use peakrate as flow rate h_rad = rcurv%xsec_area / rcurv%wet_perim - sd_ch(ich)%chn = 0.39 * sd_ch(ich)%chs ** 0.38 * h_rad ** (-0.16) - sd_ch(ich)%chn = 0.5 + 0.2 * (ob(icmd)%area_ha / 100.) ** (-.3) - if (ob(icmd)%area_ha <= 5.) then - sd_ch(ich)%chn = 0.13 - end if - if (ob(icmd)%area_ha >= 2500.) then - sd_ch(ich)%chn = 0.03 - end if - if (ob(icmd)%area_ha > 5. .and. ob(icmd)%area_ha >= 2500.) then - sd_ch(ich)%chn = 0.2 / log(ob(icmd)%area_ha / 100.) - end if - sd_ch(ich)%chn = Min (0.15, sd_ch(ich)%chn) - sd_ch(ich)%chn = Max (0.02, sd_ch(ich)%chn) vel = h_rad ** .6666 * Sqrt(sd_ch(ich)%chs) / (sd_ch(ich)%chn + .001) !vel = peakrate / rcurv%xsec_area + rttime = sd_ch(ich)%chl / (3.6 * vel) !! add precip to inflow - km * m * 1000 m/km * ha/10000 m2 = ha ch_wat_d(ich)%area_ha = sd_ch(ich)%chl * sd_ch(ich)%chw / 10. @@ -107,14 +91,24 @@ subroutine sd_channel_sediment3 ht1%flo = ht1%flo + precip !! compute flood plain deposition + !sd_ch(ich)%bankfull_flo = 2. bf_flow = sd_ch(ich)%bankfull_flo * ch_rcurv(ich)%elev(2)%flo_rate florate_ob = peakrate - bf_flow - flovol_ob = florate_ob * 86400. - flovol_ob = Min (flovol_ob, ht1%flo) - if (flovol_ob > 0.) then - trap_eff = 0.05 * log(sd_ch(ich)%fp_inun_days) + 0.1 + if (florate_ob > 0.) then + flo_time = 2. * ht1%flo / peakrate + !! assume a triangular distribution + if (flo_time < 86400.) then + !! flow is over within the day + flovol_ob = ht1%flo * (((peakrate - bf_flow) / peakrate) ** 2) + else + !! flow continues over the day - florate is the rate under the triangle + florate = 2. * ht1%flo - peakrate + flovol_ob = ht1%flo * (((peakrate - bf_flow) / (peakrate - florate)) ** 2) + end if + !trap_eff = 0.05 * log(sd_ch(ich)%fp_inun_days) + 0.1 + !! trap efficiency from Dynamic SedNet Component Model Reference Guide: Update 2017 fp_m2 = 3. * sd_ch(ich)%chw * sd_ch(ich)%chl * 1000. - exp_co = 0.00001 * fp_m2 / florate_ob + exp_co = 0.0007 * fp_m2 / florate_ob trap_eff = sd_ch(ich)%fp_inun_days * (florate_ob / peakrate) * (1. - exp(-exp_co)) trap_eff = Min (1., trap_eff) fp_dep%sed = trap_eff * ht1%sed @@ -123,8 +117,8 @@ subroutine sd_channel_sediment3 fp_dep%orgn = trap_eff * sd_ch(ich)%n_dep_enr * ht1%orgn fp_dep%sedp = trap_eff * sd_ch(ich)%p_dep_enr * ht1%sedp !! trap nitrate and sol P in flood plain - when not simulating flood plain interactions? - fp_dep%no3 = trap_eff * ht1%no3 - fp_dep%solp = trap_eff * ht1%solp + fp_dep%no3 = 0. !trap_eff * ht1%no3 + fp_dep%solp = 0. !trap_eff * ht1%solp ht1 = ht1 - fp_dep !! if flood plain link - fill wetlands to emergency @@ -144,6 +138,7 @@ subroutine sd_channel_sediment3 rto = Min (1., rto) if (rto > 1.e-6) then wet(iihru) = wet(iihru) + rto * ht1 + wet_in_d(iihru) = wet_in_d(iihru) + rto * ht1 hru(iihru)%wet_obank_in = (rto * ht1%flo) / (10. * hru(iihru)%area_ha) rto1 = 1. - rto ob(icmd)%tsin(:) = rto1 * ob(icmd)%tsin(:) @@ -156,25 +151,7 @@ subroutine sd_channel_sediment3 !! add sediment deposition to calculate mm of deposition over the flood plain later ch_morph(ich)%fp_mm = ch_morph(ich)%fp_mm + fp_dep%sed - - !! calculate channel deposition based on fall velocity - SWRRB book - !! assume particle size = 0.03 mm -- median silt size - vel_fall = 411. * sd_ch(ich)%part_size ** 2 ! m/h - dep_fall = vel_fall * rcurv%ttime - !! assume bankfull flow depth - if (dep_fall < sd_ch(ich)%chd) then - del_rto = 1. - .5 * dep_fall / sd_ch(ich)%chd - else - del_rto = .5 * sd_ch(ich)%chd / dep_fall - end if - ch_dep%sed = (1. - del_rto) * ht1%sed - ch_dep%orgn = sd_ch(ich)%n_dep_enr * (1. - del_rto) * ht1%orgn - ch_dep%sedp = sd_ch(ich)%p_dep_enr * (1. - del_rto) * ht1%sedp - rto = ch_dep%flo / ht1%flo - ob(icmd)%tsin(:) = (1. - rto) * ob(icmd)%tsin(:) - ht1 = ht1 - ch_dep - !! calc bank erosion cohesion = (-87.1 + (42.82 * sd_ch(ich)%ch_clay) - (0.261 * sd_ch(ich)%ch_clay ** 2.) & + (0.029 * sd_ch(ich)%ch_clay ** 3.)) @@ -183,64 +160,73 @@ subroutine sd_channel_sediment3 bd_fac = Max (0.001, 0.03924 * sd_ch(ich)%ch_bd * 1000. - 1000.) cohes_fac = 0.021 * cohesion + veg vel_cr = log10 (2200. * sd_ch(ich)%chd) * (0.0004 * (bd_fac + cohes_fac)) ** 0.5 - - !cohesion = (15. / (15.3 - 0.438 * sd_ch(ich)%ch_clay + 0.0044 * sd_ch(ich)%ch_clay ** 2.)) * 1000. - !veg = exp (-5. * sd_ch(ich)%chd) * cha1(icha)%dat%cov !function of cover factor - !vel_cr = log10 (8.8 * sd_ch(ich)%chd / 0.004) * (0.0004 * ((sd_ch(ich)%ch_bd * & - ! 1000. - 1000.) * 9.81 * 0.004 + 0.021 * cohesion + veg)) ** 0.5 + !sd_ch(ich)%vcr_coef = 1. + vel_cr = sd_ch(ich)%vcr_coef * vel_cr !! calculate radius of curvature - rad_curv = ((12. * sd_ch(ich)%chw) * sd_ch(ich)%sinu ** 1.5) / (13. * (sd_ch(ich)%sinu -1.) ** 0.5) + rad_curv = ((12. * sd_ch(ich)%chw) * sd_ch(ich)%sinu ** 1.5) / & + (13. * (sd_ch(ich)%sinu -1.) ** 0.5) vel_bend = vel * (1. / rad_curv + 1.) vel_rch = 0.33 * vel_bend + 0.66 * vel b_exp = 12.3 / sqrt (sd_ch(ich)%ch_clay + 1.) b_exp = min (3.5, b_exp) - if (vel_rch > vel_cr) then ! .and. rcurv%dep / sd_ch(ich)%chd > 0.1) then - ebank_m = 0.0024 * (vel_rch / vel_cr) ** b_exp !bank erosion m/yr + !sd_ch(ich)%bank_exp = 2. + if (vel_rch > vel_cr) then + !! bank erosion m/yr + ebank_m = 0.0024 * (vel_rch / vel_cr) ** sd_ch(ich)%bank_exp else ebank_m = 0. end if ch_morph(ich)%w_yr = ch_morph(ich)%w_yr + ebank_m !! calc mass of sediment eroded -> t = bankcut (m) * depth (m) * lengthcut (m) * bd (t/m3) - !! arc length = 0.33 * meander wavelength * sinuosity -> protected length - arc_len = 0.33 * (12. * sd_ch(ich)%chw) * sd_ch(ich)%sinu + !! arc length = 0.33 * meander wavelength * sinuosity + arc_len = 0.66 * (12. * sd_ch(ich)%chw) * sd_ch(ich)%sinu prot_len = arc_len * sd_ch(ich)%arc_len_fr - prot_len = 0.2 * sd_ch(ich)%chl * 1000. - !rad_curv = (12. * sd_ch(ich)%chw * sd_ch(ich)%sinu ** 1.5) / & - ! (13. * (sd_ch(ich)%sinu - 0.999) ** 0.5) - !cutbank_adj = 2.57 - 0.36 * log(rad_curv / sd_ch(ich)%chw) - !ebank_t = ebank_m * sd_ch(ich)%chd * sd_ch(ich)%arc_len_fr * prot_len * sd_ch(ich)%ch_bd - !ebank_t = 0.8 * ebank_t !assume 80% wash load and 20% bed deposition - !ebank_t = max (0., ebank_t) - !ebank_t = 1000. * (vel_rch * sd_ch(ich)%chs) ** 2. * (1. - sd_ch(ich)%cov) * (sd_ch(ich)%ch_clay + 1.) - !sd_ch(ich)%pk_rto = 500. - ebank_t = (1000. * sd_ch(ich)%pk_rto * vel_rch * sd_ch(ich)%chs) ** 2. * & - (1. - sd_ch(ich)%ch_clay / 100.) - prot_len = 0.2 * sd_ch(ich)%chl - ebank_t = ebank_t * prot_len + ebank_t = ebank_m * sd_ch(ich)%chd * sd_ch(ich)%arc_len_fr * prot_len * sd_ch(ich)%ch_bd bank_ero%sed = ebank_t !! calculate associated nutrients - bank_ero%orgn = bank_ero%sed * sd_ch(ich)%n_conc - bank_ero%sedp = (1. - sd_ch(ich)%p_bio) * bank_ero%sed * sd_ch(ich)%p_conc + bank_ero%orgn = bank_ero%sed * sd_ch(ich)%n_conc / 1000. + bank_ero%sedp = (1. - sd_ch(ich)%p_bio) * bank_ero%sed * sd_ch(ich)%p_conc / 1000. bank_ero%no3 = 0. - bank_ero%solp = sd_ch(ich)%p_bio * bank_ero%sed * sd_ch(ich)%p_conc + bank_ero%solp = sd_ch(ich)%p_bio * bank_ero%sed * sd_ch(ich)%p_conc / 1000. bank_ero%no2 = 0. rto = bank_ero%flo / ht1%flo ob(icmd)%tsin(:) = (1. - rto) * ob(icmd)%tsin(:) ht1 = ht1 + bank_ero + !! calculate channel deposition based on fall velocity - SWRRB book + !! assume particle size = 0.03 mm -- median silt size + !vel_fall = 411. * sd_ch(ich)%part_size ** 2 ! m/h + !dep_fall = vel_fall * rcurv%ttime + !! assume bankfull flow depth + !if (dep_fall < sd_ch(ich)%chd) then + ! del_rto = 1. - .5 * dep_fall / sd_ch(ich)%chd + !else + ! del_rto = .5 * sd_ch(ich)%chd / dep_fall + !end if + !ch_dep%sed = (1. - del_rto) * ht1%sed + !ch_dep%orgn = sd_ch(ich)%n_dep_enr * (1. - del_rto) * ht1%orgn + !ch_dep%sedp = sd_ch(ich)%p_dep_enr * (1. - del_rto) * ht1%sedp + !rto = ch_dep%flo / ht1%flo + !ob(icmd)%tsin(:) = (1. - rto) * ob(icmd)%tsin(:) + !ht1 = ht1 - ch_dep + !! calculate channel deposition as the bedload fraction of bank erosion + ch_dep%sed = sd_ch(ich)%wash_bed_fr * bank_ero%sed + ch_dep%orgn = sd_ch(ich)%n_dep_enr * sd_ch(ich)%wash_bed_fr * bank_ero%orgn + ch_dep%sedp = sd_ch(ich)%p_dep_enr * sd_ch(ich)%wash_bed_fr * bank_ero%sedp + ht1 = ht1 - ch_dep !! calculate bed erosion !! no downcutting below equilibrium slope - if (sd_ch(ich)%chs > 0.000001) then !sd_ch(ich)%chseq) then + if (sd_ch(ich)%chs > 0.000001) then !! calc critical shear and shear on bottom of channel shear_btm_cr = sd_ch(ich)%d50 shear_btm = 9800. * rcurv%dep * sd_ch(ich)%chs !! Pa = N/m^2 * m * m/m !! critical shear function of d50 vel_cr = 0.293 * (sd_ch(ich)%d50) ** 0.5 - vel_cr = 1. if (vel > vel_cr) then - ebtm_m = 0.0001 * (vel_rch / vel_cr) ** 1.5 !bed erosion m/yr + !! bed erosion m/yr + ebtm_m = 0.0001 * (vel_rch / vel_cr) ** sd_ch(ich)%bed_exp end if !! calc mass of sediment eroded -> t = m * width (m) * length (km) * 1000 m/km * bd (t/m3) ebtm_t = 1000. * ebtm_m * sd_ch(ich)%chw * sd_ch(ich)%chl * sd_ch(ich)%ch_bd @@ -255,8 +241,8 @@ subroutine sd_channel_sediment3 bed_ero%solp = sd_ch(ich)%p_bio * bed_ero%sed * sd_ch(ich)%p_conc bed_ero%no2 = 0. rto = bed_ero%flo / ht1%flo - ob(icmd)%tsin(:) = (1. - rto) * ob(icmd)%tsin(:) - ht1 = ht1 + bed_ero + !ob(icmd)%tsin(:) = (1. - rto) * ob(icmd)%tsin(:) + !ht1 = ht1 + bed_ero end if ! inflow>0 diff --git a/src/sd_hydsed_init.f90 b/src/sd_hydsed_init.f90 index 9bc7cff..5832299 100644 --- a/src/sd_hydsed_init.f90 +++ b/src/sd_hydsed_init.f90 @@ -79,12 +79,11 @@ subroutine sd_hydsed_init sd_ch(i)%chn = sd_chd(idb)%chn if (sd_ch(i)%chn < .05) sd_ch(i)%chn = .05 !***jga sd_ch(i)%chk = sd_chd(idb)%chk - sd_ch(i)%cherod = sd_chd(idb)%cherod + sd_ch(i)%bank_exp = sd_chd(idb)%bank_exp sd_ch(i)%cov = sd_chd(idb)%cov sd_ch(i)%sinu = sd_chd(idb)%sinu if (sd_ch(i)%sinu < 1.05) sd_ch(i)%sinu = 1.05 - sd_ch(i)%chseq = sd_chd(idb)%chseq - if (sd_ch(i)%chseq < 1.e-6) sd_ch(i)%chseq = 0.5 + sd_ch(i)%vcr_coef = sd_chd(idb)%vcr_coef sd_ch(i)%d50 = sd_chd(idb)%d50 sd_ch(i)%ch_clay = sd_chd(idb)%ch_clay sd_ch(i)%carbon = sd_chd(idb)%carbon @@ -111,7 +110,7 @@ subroutine sd_hydsed_init sd_ch(i)%n_dep_enr = sd_chd1(idb1)%n_dep_enr sd_ch(i)%p_dep_enr = sd_chd1(idb1)%p_dep_enr sd_ch(i)%arc_len_fr = sd_chd1(idb1)%arc_len_fr - sd_ch(i)%part_size = sd_chd1(idb1)%part_size + sd_ch(i)%bed_exp = sd_chd1(idb1)%bed_exp sd_ch(i)%wash_bed_fr = sd_chd1(idb1)%wash_bed_fr !! compute headcut parameters @@ -165,8 +164,8 @@ subroutine sd_hydsed_init end do !! Compute storage time constant for reach (msk_co1 + msk_co2 = 1.) - msk1 = bsn_prm%msk_co1 / (bsn_prm%msk_co1 + bsn_prm%msk_co2) - msk2 = bsn_prm%msk_co2 / (bsn_prm%msk_co1 + bsn_prm%msk_co2) + msk1 = bsn_prm%msk_co1 / (bsn_prm%msk_co1 + bsn_prm%msk_co2) + msk2 = bsn_prm%msk_co2 / (bsn_prm%msk_co1 + bsn_prm%msk_co2) xkm = sd_ch(i)%stor_dis_bf * msk1 + sd_ch(i)%stor_dis_01bf * msk2 !! Muskingum numerical stability -Jaehak Jeong, 2011 @@ -305,7 +304,7 @@ subroutine sd_hydsed_init ch_water(ich)%cs(ics) = (cs_cha_ini(ics_ini)%conc(ics)/1000.) * tot_stor(ich)%flo !kg enddo enddo - endif + endif return end subroutine sd_hydsed_init \ No newline at end of file diff --git a/src/sep_biozone.f90 b/src/sep_biozone.f90 index 7a299f4..4fd91fa 100644 --- a/src/sep_biozone.f90 +++ b/src/sep_biozone.f90 @@ -1,5 +1,5 @@ subroutine sep_biozone - + !! ~ ~ ~ PURPOSE ~ ~ ~ !! This subroutine conducts biophysical processes occuring !! in the biozone layer of a septic HRU. @@ -45,18 +45,18 @@ subroutine sep_biozone use soil_module use time_module - implicit none + implicit none integer :: bz_lyr = 0 !none |soil layer where biozone exists integer :: isp = 0 !none |type of septic system for current hru integer :: j = 0 !none |hru integer :: nly = 0 ! | - real*8 :: bz_vol = 0.d0 !m^3 |volume of biozone + real*8 :: bz_vol = 0.d0 !m^3 |volume of biozone real*8 :: rtrate = 0.d0 ! | real*8 :: qin = 0.d0 !m^3 H2O |water in reach during time step real*8 :: qout = 0.d0 ! | real*8 :: rplqm = 0.d0 !kg/ha |daily change in plaque - real*8 :: ntr_rt = 0.d0 !1/day |nitrification reaction rate + real*8 :: ntr_rt = 0.d0 !1/day |nitrification reaction rate real*8 :: dentr_rt = 0.d0 !1/day |denitrification reaction rate real*8 :: bod_rt = 0.d0 !1/day |BOD reaction rate real*8 :: fcoli_rt = 0.d0 !1/day |fecal coliform reaction rate @@ -68,30 +68,30 @@ subroutine sep_biozone ! |value needed in later equations real*8 :: bodi = 0.d0 ! | real*8 :: bode = 0.d0 ! | - real*8 :: rnit = 0.d0 !kg/ha |nitrification during the day + real*8 :: rnit = 0.d0 !kg/ha |nitrification during the day real*8 :: rdenit = 0.d0 !kg/ha |denitrification during the day real*8 :: rmort = 0.d0 !kg/ha |daily mortality of bacteria real*8 :: rrsp = 0.d0 !kg/ha |daily resparation of bacteria real*8 :: rslg = 0.d0 !kg/ha |daily slough-off bacteria real*8 :: rbod = 0.d0 !mg/l |daily change in bod concentration real*8 :: rfcoli = 0.d0 !cfu/100ml |daily change in fecal coliform - real*8 :: nh3_begin = 0.d0 ! | + real*8 :: nh3_begin = 0.d0 ! | real*8 :: nh3_end = 0.d0 ! | real*8 :: nh3_inflw_ste = 0.d0! | real*8 :: no3_begin = 0.d0 ! | real*8 :: no3_end = 0.d0 ! | - real*8 :: no3_inflow_ste = 0.d0! | + real*8 :: no3_inflow_ste = 0.d0! | real*8 :: bza = 0.d0 ! | real*8 :: qi = 0.d0 ! | real*8 :: nperc = 0.d0 ! | - real*8 :: nh3_init = 0.d0 ! | + real*8 :: nh3_init = 0.d0 ! | real*8 :: no3_init = 0.d0 ! | real*8 :: hvol = 0.d0 ! | real*8 :: solpconc = 0.d0 ! | real*8 :: solpsorb = 0.d0 ! | real*8 :: qlyr = 0.d0 ! | real*8 :: qsrf = 0.d0 ! | - real*8 :: solp_init = 0.d0 ! | + real*8 :: solp_init = 0.d0 ! | real*8 :: solp_begin = 0.d0 ! | real*8 :: solp_end = 0.d0 ! | real*8 :: svolp = 0.d0 ! | @@ -99,75 +99,75 @@ subroutine sep_biozone real*8 :: ctmp = 0.d0 ! | real*8 :: percp = 0.d0 ! | - j = ihru - nly = soil(j)%nly + j = ihru + nly = soil(j)%nly isep = iseptic(j) - isp = sep(isep)%typ !! J.Jeong 3/09/09 + isp = sep(isep)%typ !! J.Jeong 3/09/09 bz_lyr = i_sep(j) - bza = hru(j)%area_ha - bz_vol = sep(isep)%thk * bza * 10. !m^3 - qlyr = qstemm(j) - qsrf = 0 - - !temperature correction factor for bacteria growth/dieoff (Eppley, 1972) + bza = hru(j)%area_ha + bz_vol = sep(isep)%thk * bza * 10. !m^3 + qlyr = qstemm(j) + qsrf = 0 + + !temperature correction factor for bacteria growth/dieoff (Eppley, 1972) !ibac = 1 !there should be a loop for all pathogens in this hru - !ctmp = path_db(ibac)%t_adj ** (soil(j)%phys(bz_lyr)%tmp- 20.) + !ctmp = path_db(ibac)%t_adj ** (soil(j)%phys(bz_lyr)%tmp- 20.) ctmp = 1. - ! initial water volume - qi = (soil(j)%phys(bz_lyr)%st + soil(j)%ly(bz_lyr-1)%prk + qstemm(j)) * & + ! initial water volume + qi = (soil(j)%phys(bz_lyr)%st + soil(j)%ly(bz_lyr-1)%prk + qstemm(j)) * & bza * 10. !m3 ! STE volume - qin = qstemm(j) * bza * 10. ! m^3 - ! leaching to septic layer - qout = bz_perc(j) * bza * 10. !m3/d - ! final volume - hvol = soil(j)%phys(bz_lyr)%st * bza * 10. - rtof = 0.5 + qin = qstemm(j) * bza * 10. ! m^3 + ! leaching to septic layer + qout = bz_perc(j) * bza * 10. !m3/d + ! final volume + hvol = soil(j)%phys(bz_lyr)%st * bza * 10. + rtof = 0.5 - nh3_init = soil1(j)%mn(bz_lyr)%nh4 - no3_init = soil1(j)%mn(bz_lyr)%no3 - solp_init = soil1(j)%mp(bz_lyr)%lab + nh3_init = soil1(j)%mn(bz_lyr)%nh4 + no3_init = soil1(j)%mn(bz_lyr)%no3 + solp_init = soil1(j)%mp(bz_lyr)%lab - !! Failing system: STE saturates upper soil layers - if (sep(isep)%opt == 2) then - - ! increment the number of failing days - if(sep_tsincefail(j)>0) sep_tsincefail(j) = sep_tsincefail(j) + 1 + !! Failing system: STE saturates upper soil layers + if (sep(isep)%opt == 2) then + + ! increment the number of failing days + if(sep_tsincefail(j)>0) sep_tsincefail(j) = sep_tsincefail(j) + 1 ! convert the failing system into an active system if duration of failing ends - if (sep_tsincefail(j) >= sep(isep)%tfail) then - sep(isep)%opt = 1 + if (sep_tsincefail(j) >= sep(isep)%tfail) then + sep(isep)%opt = 1 soil(j)%phys(bz_lyr)%ul=sep(isep)%thk * & (soil(j)%phys(bz_lyr)%por - soil(j)%phys(bz_lyr)%wp) soil(j)%phys(bz_lyr)%fc=sep(isep)%thk*(soil(j)%phys(bz_lyr)%up- & soil(j)%phys(bz_lyr)%wp) - soil1(j)%mn(bz_lyr)%nh4 = 0 - soil1(j)%mn(bz_lyr)%no3 = 0 - soil1(j)%hsta(bz_lyr)%n = 0 - soil1(j)%hsta(bz_lyr)%p = 0 - soil1(j)%tot(bz_lyr)%p = 0 - soil1(j)%mp(bz_lyr)%lab = 0 + soil1(j)%mn(bz_lyr)%nh4 = 0 + soil1(j)%mn(bz_lyr)%no3 = 0 + soil1(j)%hsta(bz_lyr)%n = 0 + soil1(j)%hsta(bz_lyr)%p = 0 + soil1(j)%tot(bz_lyr)%p = 0 + soil1(j)%mp(bz_lyr)%lab = 0 soil1(j)%mp(bz_lyr)%act = 0 - biom(j) = 0 + biom(j) = 0 plqm(j) = 0 - bio_bod(j) = 0 - fcoli(j) = 0 - sep_tsincefail(j) = 0 - end if + bio_bod(j) = 0 + fcoli(j) = 0 + sep_tsincefail(j) = 0 + end if - return - endif + return + endif - !! Active system + !! Active system !! Water content(eqn 4-12), biozone hydraulic conductivity(eqn 4-9), - !! and percolation (eqn 4-8,10,11) are computed in percmain/percmicro + !! and percolation (eqn 4-8,10,11) are computed in percmain/percmicro - ! Add STE nutrients to appropriate soil pools in mass unit - xx = qin / bza / 1000. ! used for unit conversion: mg/l -> kg/ha + ! Add STE nutrients to appropriate soil pools in mass unit + xx = qin / bza / 1000. ! used for unit conversion: mg/l -> kg/ha soil1(j)%mn(bz_lyr)%no3 = soil1(j)%mn(bz_lyr)%no3 + xx * & (sepdb(sep(isep)%typ)%no3concs + & sepdb(sep(isep)%typ)%no2concs) @@ -188,93 +188,93 @@ subroutine sep_biozone bodi = bio_bod(j) * bza / qi * 1000. !mg/l - !! Field capacity in the biozone Eq. 4-6 ! + !! Field capacity in the biozone Eq. 4-6 ! soil(j)%phys(bz_lyr)%fc = soil(j)%phys(bz_lyr)%fc + sep(isep)%fc1 & * (soil(j)%phys(bz_lyr)%ul - soil(j)%phys(bz_lyr)%fc) ** & sep(isep)%fc2 * rbiom(j) / (sep(isep)%bd * 10) - !! Saturated water content in the biozone - Eq. 4-7 - ! mm = mm - kg/ha / (kg/m^3 * 10) + !! Saturated water content in the biozone - Eq. 4-7 + ! mm = mm - kg/ha / (kg/m^3 * 10) soil(j)%phys(bz_lyr)%ul = soil(j)%phys(bz_lyr)%por * & sep(isep)%thk-plqm(j) /(sep(isep)%bd*10.) - if(soil(j)%phys(bz_lyr)%ul.le.soil(j)%phys(bz_lyr)%fc) then - soil(j)%phys(bz_lyr)%ul = soil(j)%phys(bz_lyr)%fc - sep(isep)%opt = 2 - endif + if(soil(j)%phys(bz_lyr)%ul.le.soil(j)%phys(bz_lyr)%fc) then + soil(j)%phys(bz_lyr)%ul = soil(j)%phys(bz_lyr)%fc + sep(isep)%opt = 2 + endif - !! Respiration rate(kg/ha) Eq. 4-2 - rrsp = ctmp * sep(isep)%rsp * biom(j) + !! Respiration rate(kg/ha) Eq. 4-2 + rrsp = ctmp * sep(isep)%rsp * biom(j) - !! Mortality rate(kg/ha) Eq. 4-3 - rmort = ctmp * sep(isep)%mrt * biom(j) + !! Mortality rate(kg/ha) Eq. 4-3 + rmort = ctmp * sep(isep)%mrt * biom(j) - !! Slough-off rate(kg/ha) - rslg = sep(isep)%slg1 * bz_perc(j) ** sep(isep)%slg2 * biom(j) - - - !! Build up of plqm(kg/ha) Eq.4-5 - ! kg/ha (perday) = kg/ha + dimensionless * m^3/d * mg/l / (1000*ha) + !! Slough-off rate(kg/ha) + rslg = sep(isep)%slg1 * bz_perc(j) ** sep(isep)%slg2 * biom(j) + + + !! Build up of plqm(kg/ha) Eq.4-5 + ! kg/ha (perday) = kg/ha + dimensionless * m^3/d * mg/l / (1000*ha) rplqm = (rmort - rslg) + sep(isep)%plq * qin * & sepdb(sep(isep)%typ)%tssconcs / (1000. * bza) - rplqm = max(0.,rplqm) + rplqm = max(0.,rplqm) - !! Add build up to plqm ! kg/ha = kg/ha + kg/ha + !! Add build up to plqm ! kg/ha = kg/ha + kg/ha plqm(j) = plqm(j) + rplqm - - nh3_inflw_ste = xx * sepdb(sep(isep)%typ)%nh4concs - no3_inflow_ste = xx*(sepdb(sep(isep)%typ)%no3concs + & + + nh3_inflw_ste = xx * sepdb(sep(isep)%typ)%nh4concs + no3_inflow_ste = xx*(sepdb(sep(isep)%typ)%no3concs + & sepdb(sep(isep)%typ)%no2concs) - nh3_begin = soil1(j)%mn(bz_lyr)%nh4 - no3_begin = soil1(j)%mn(bz_lyr)%no3 - solp_begin = soil1(j)%mp(bz_lyr)%lab + nh3_begin = soil1(j)%mn(bz_lyr)%nh4 + no3_begin = soil1(j)%mn(bz_lyr)%no3 + solp_begin = soil1(j)%mp(bz_lyr)%lab - !! Add STE f.coli concentration by volumetric averaging + !! Add STE f.coli concentration by volumetric averaging xx = 10.* soil(j)%phys(bz_lyr)%st * bza / (qin & + 10.* soil(j)%phys(bz_lyr)%st * bza) - fcoli(j) = fcoli(j) * xx + sepdb(sep(isep)%typ)%fcolis * (1.- xx) ! J.Jeong 3/09/09 - - !! nutrients reaction rate (Equation 4-13) - rtrate = biom(j) * bza / (bz_vol * soil(j)%phys(bz_lyr)%por) - - !! BOD (kg/ha) 4-14 ! - bod_rt = max(0.,sep(isep)%bod_dc * rtrate) !bod + fcoli(j) = fcoli(j) * xx + sepdb(sep(isep)%typ)%fcolis * (1.- xx) ! J.Jeong 3/09/09 + + !! nutrients reaction rate (Equation 4-13) + rtrate = biom(j) * bza / (bz_vol * soil(j)%phys(bz_lyr)%por) + + !! BOD (kg/ha) 4-14 ! + bod_rt = max(0.,sep(isep)%bod_dc * rtrate) !bod if (bod_rt>4) bod_rt=4 - rbod = bodi * (1.- Exp(-bod_rt)) - bode = bodi - rbod !mg/l - bio_bod(j) = bode * (soil(j)%phys(bz_lyr)%st * 10)/1000. !kg/ha + rbod = bodi * (1.- Exp(-bod_rt)) + bode = bodi - rbod !mg/l + bio_bod(j) = bode * (soil(j)%phys(bz_lyr)%st * 10)/1000. !kg/ha - !! Fecal coliform(cfu/100ml) Eq 4-14, J.Jeong 3/09/09 - fcoli_rt = max(0.,sep(isep)%fecal * rtrate) !fecal coliform - rfcoli = fcoli(j) * (1.- exp(-fcoli_rt)) - fcoli(j) = fcoli(j) - rfcoli + !! Fecal coliform(cfu/100ml) Eq 4-14, J.Jeong 3/09/09 + fcoli_rt = max(0.,sep(isep)%fecal * rtrate) !fecal coliform + rfcoli = fcoli(j) * (1.- exp(-fcoli_rt)) + fcoli(j) = fcoli(j) - rfcoli - !! change in nh3 & no3 in soil pools due to nitrification(kg/ha) Eq.4-13, 4-14 - ntr_rt = max(0.,sep(isep)%nitr * rtrate) !nitrification - rnit = soil1(j)%mn(bz_lyr)%nh4 * (1. - Exp(-ntr_rt)) !! J.Jeong 4/03/09 - soil1(j)%mn(bz_lyr)%nh4 = soil1(j)%mn(bz_lyr)%nh4 - rnit !J.Jeong 3/09/09 - soil1(j)%mn(bz_lyr)%no3 = soil1(j)%mn(bz_lyr)%no3 + rnit !J.Jeong 3/09/09 - - !ammonium percolation - nperc = 0.2 * qout / qi * soil1(j)%mn(bz_lyr)%nh4 - nperc = min(nperc,0.5 * soil1(j)%mn(bz_lyr)%nh4) - soil1(j)%mn(bz_lyr)%nh4 = soil1(j)%mn(bz_lyr)%nh4 - nperc - soil1(j)%mn(bz_lyr+1)%nh4 = soil1(j)%mn(bz_lyr+1)%nh4 + nperc + !! change in nh3 & no3 in soil pools due to nitrification(kg/ha) Eq.4-13, 4-14 + ntr_rt = max(0.,sep(isep)%nitr * rtrate) !nitrification + rnit = soil1(j)%mn(bz_lyr)%nh4 * (1. - Exp(-ntr_rt)) !! J.Jeong 4/03/09 + soil1(j)%mn(bz_lyr)%nh4 = soil1(j)%mn(bz_lyr)%nh4 - rnit !J.Jeong 3/09/09 + soil1(j)%mn(bz_lyr)%no3 = soil1(j)%mn(bz_lyr)%no3 + rnit !J.Jeong 3/09/09 + + !ammonium percolation + nperc = 0.2 * qout / qi * soil1(j)%mn(bz_lyr)%nh4 + nperc = min(nperc,0.5 * soil1(j)%mn(bz_lyr)%nh4) + soil1(j)%mn(bz_lyr)%nh4 = soil1(j)%mn(bz_lyr)%nh4 - nperc + soil1(j)%mn(bz_lyr+1)%nh4 = soil1(j)%mn(bz_lyr+1)%nh4 + nperc - !! denitrification,(kg/ha) Eq 4-14 - dentr_rt = max(0.,sep(isep)%denitr * rtrate) !denitrification - rdenit = soil1(j)%mn(bz_lyr)%no3 * (1. - Exp(-dentr_rt)) !J.Jeong 3/09/09 - soil1(j)%mn(bz_lyr)%no3 = soil1(j)%mn(bz_lyr)%no3 - rdenit !J.Jeong 3/09/09 + !! denitrification,(kg/ha) Eq 4-14 + dentr_rt = max(0.,sep(isep)%denitr * rtrate) !denitrification + rdenit = soil1(j)%mn(bz_lyr)%no3 * (1. - Exp(-dentr_rt)) !J.Jeong 3/09/09 + soil1(j)%mn(bz_lyr)%no3 = soil1(j)%mn(bz_lyr)%no3 - rdenit !J.Jeong 3/09/09 - !soil volume for sorption: soil thickness below biozone + !soil volume for sorption: soil thickness below biozone svolp = (soil(j)%phys(nly)%d - sep(isep)%z) * bza * 10. !m3, !max adsorption amnt: linear isotherm, McCray 2005 solpconc = soil1(j)%mp(bz_lyr)%lab * bza / qi * 1000. !mg/l - solpsorb = min(sep(isep)%pdistrb * solpconc,sep(isep)%psorpmax) !mgP/kgSoil - solpsorb = 1.6 * 1.e-3 * solpsorb * svolp * & - (1-soil(j)%phys(bz_lyr)%por) !kgP sorption potential + solpsorb = min(sep(isep)%pdistrb * solpconc,sep(isep)%psorpmax) !mgP/kgSoil + solpsorb = 1.6 * 1.e-3 * solpsorb * svolp * & + (1-soil(j)%phys(bz_lyr)%por) !kgP sorption potential !check if max. P sorption is reached if(soil1(j)%mp(bz_lyr)%lab * bza .0001) then + if (surfq(j) > .0001) then !! vfs comnposed of two sections one with more concentrated flow than the other !! Calculate drainage area of vfs 1 2 3 in ha - drain_vfs1 = (1. - hru(j)%lumv%vfscon)* hru(j)%area_ha - drain_vfs2 = ((1. - hru(j)%lumv%vfsch) * hru(j)%lumv%vfscon)* hru(j)%area_ha - drain_vfs3 = hru(j)%lumv%vfscon * hru(j)%lumv%vfsch * hru(j)%area_ha + drain_vfs1 = (1. - hru(j)%lumv%vfscon)* hru(j)%area_ha + drain_vfs2 = ((1. - hru(j)%lumv%vfsch) * hru(j)%lumv%vfscon)* hru(j)%area_ha + drain_vfs3 = hru(j)%lumv%vfscon * hru(j)%lumv%vfsch * hru(j)%area_ha !! Calculate area of vfs 1 and 2 in ha - area_vfs1 = hru(j)%area_ha * 0.9 / hru(j)%lumv%vfsratio - area_vfs2 = hru(j)%area_ha * 0.1 / hru(j)%lumv%vfsratio + area_vfs1 = hru(j)%area_ha * 0.9 / hru(j)%lumv%vfsratio + area_vfs2 = hru(j)%area_ha * 0.1 / hru(j)%lumv%vfsratio - !! Calculate drainage area to vfs area ratio (unitless) - vfs_ratio1 = drain_vfs1/area_vfs1 - vfs_ratio2 = drain_vfs2/area_vfs2 + !! Calculate drainage area to vfs area ratio (unitless) + vfs_ratio1 = drain_vfs1/area_vfs1 + vfs_ratio2 = drain_vfs2/area_vfs2 !! calculate runoff depth over buffer area in mm - vfs_depth1 = vfs_ratio1 * surfq(j) - vfs_depth2 = vfs_ratio2 * surfq(j) + vfs_depth1 = vfs_ratio1 * surfq(j) + vfs_depth2 = vfs_ratio2 * surfq(j) !! calculate sediment loading over buffer area in kg/m^2 - vfs_sed1 = (sedyld(j) / hru(j)%area_ha * 1000. * drain_vfs1) / (area_vfs1 * 10000.) - vfs_sed2 = (sedyld(j) / hru(j)%area_ha * 1000. * drain_vfs2) / (area_vfs2 * 10000.) + vfs_sed1 = (sedyld(j) / hru(j)%area_ha * 1000. * drain_vfs1) / (area_vfs1 * 10000.) + vfs_sed2 = (sedyld(j) / hru(j)%area_ha * 1000. * drain_vfs2) / (area_vfs2 * 10000.) !! calculate Runoff Removal by vfs (used for nutrient removal estimation only) based on runoff depth and ksat !! Based on vfsmod simulations surq_remove1 = 75.8-10.8 * Log(vfs_depth1) + 25.9 * Log(soil(j)%phys(1)%k) - if (surq_remove1 > 100.) surq_remove1 = 100. - if (surq_remove1 < 0.) surq_remove1 = 0. + if (surq_remove1 > 100.) surq_remove1 = 100. + if (surq_remove1 < 0.) surq_remove1 = 0. surq_remove2 = 75.8-10.8 * Log(vfs_depth2) + 25.9 * Log(soil(j)%phys(1)%k) - if (surq_remove2 > 100.) surq_remove2 = 100. - if (surq_remove2 < 0.) surq_remove2 = 0. + if (surq_remove2 > 100.) surq_remove2 = 100. + if (surq_remove2 < 0.) surq_remove2 = 0. - surq_remove = (surq_remove1 * drain_vfs1 + surq_remove2 * drain_vfs2)/hru(j)%area_ha + surq_remove = (surq_remove1 * drain_vfs1 + surq_remove2 * drain_vfs2)/hru(j)%area_ha !! calculate sediment Removal - Based on measured data from literature - sed_remove1 = 79.0 - 1.04 * vfs_sed1 + 0.213 * surq_remove1 - if (sed_remove1 > 100.) sed_remove1 = 100. - if (sed_remove1 < 0.) sed_remove1 = 0. + sed_remove1 = 79.0 - 1.04 * vfs_sed1 + 0.213 * surq_remove1 + if (sed_remove1 > 100.) sed_remove1 = 100. + if (sed_remove1 < 0.) sed_remove1 = 0. - sed_remove2 = 79.0 - 1.04 * vfs_sed2 + 0.213 * surq_remove1 - if (sed_remove2 > 100.) sed_remove2 = 100. - if (sed_remove2 < 0.) sed_remove2 = 0. + sed_remove2 = 79.0 - 1.04 * vfs_sed2 + 0.213 * surq_remove1 + if (sed_remove2 > 100.) sed_remove2 = 100. + if (sed_remove2 < 0.) sed_remove2 = 0. - sed_remove = (sed_remove1 * drain_vfs1 + sed_remove2 * drain_vfs2) / hru(j)%area_ha - - sedyld(j) = sedyld(j) * (1. - sed_remove / 100.) + sed_remove = (sed_remove1 * drain_vfs1 + sed_remove2 * drain_vfs2) / hru(j)%area_ha + + sedyld(j) = sedyld(j) * (1. - sed_remove / 100.) sedyld(j) = Max(0., sedyld(j)) - sedtrap = sedyld(j) * sed_remove / 100. - xrem = 0. + sedtrap = sedyld(j) * sed_remove / 100. + xrem = 0. if (sedtrap <= lagyld(j)) then lagyld(j) = lagyld(j) - sedtrap @@ -174,59 +174,59 @@ subroutine smp_filter !! Calculate Organic Nitrogen Removal !! Based on measured data from literature - remove1 = 0.036 * sed_remove1 ** 1.69 - if (remove1 > 100.) remove1 = 100. - if (remove1 < 0.) remove1 = 0. + remove1 = 0.036 * sed_remove1 ** 1.69 + if (remove1 > 100.) remove1 = 100. + if (remove1 < 0.) remove1 = 0. - remove2 = 0.036 * sed_remove2 ** 1.69 - if (remove2 > 100.) remove2 = 100. - if (remove2 < 0.) remove2 = 0. - - orgn_remove = (remove1 * drain_vfs1 + remove2 * drain_vfs2)/hru(j)%area_ha - sedorgn(j) = sedorgn(j) * (1. - orgn_remove / 100.) + remove2 = 0.036 * sed_remove2 ** 1.69 + if (remove2 > 100.) remove2 = 100. + if (remove2 < 0.) remove2 = 0. + + orgn_remove = (remove1 * drain_vfs1 + remove2 * drain_vfs2)/hru(j)%area_ha + sedorgn(j) = sedorgn(j) * (1. - orgn_remove / 100.) !! calculate Nitrate removal from surface runoff !! Based on measured data from literature - - remove1 = 39.4 + 0.584 * surq_remove1 - if (remove1 > 100.) remove1 = 100. - if (remove1 < 0.) remove1 = 0. + + remove1 = 39.4 + 0.584 * surq_remove1 + if (remove1 > 100.) remove1 = 100. + if (remove1 < 0.) remove1 = 0. - remove2 = 39.4 + 0.584 * surq_remove2 - if (remove2 > 100.) remove2 = 100. + remove2 = 39.4 + 0.584 * surq_remove2 + if (remove2 > 100.) remove2 = 100. if (remove2 < 0.) remove2 = 0. surqno3_remove = (remove1 * drain_vfs1 + remove2 * drain_vfs2)/hru(j)%area_ha - surqno3(j) = surqno3(j) * (1. - surqno3_remove / 100.) + surqno3(j) = surqno3(j) * (1. - surqno3_remove / 100.) !! calculate Particulate P removal from surface runoff !!Based on measured data from literature - remove1 = 0.903 * sed_remove1 - if (remove1 > 100.) remove1 = 100. - if (remove1 < 0.) remove1 = 0. - - remove2 = 0.903 * sed_remove2 - if (remove2 > 100.) remove2 = 100. - if (remove2 < 0.) remove2 = 0. + remove1 = 0.903 * sed_remove1 + if (remove1 > 100.) remove1 = 100. + if (remove1 < 0.) remove1 = 0. + + remove2 = 0.903 * sed_remove2 + if (remove2 > 100.) remove2 = 100. + if (remove2 < 0.) remove2 = 0. - partP_remove = (remove1 * drain_vfs1 + remove2 * drain_vfs2)/hru(j)%area_ha - sedminpa(j) = sedminpa(j) * (1. - partP_remove / 100.) - sedminps(j) = sedminps(j) * (1. - partP_remove / 100.) - sedorgp(j) = sedorgp(j) * (1. - partP_remove / 100.) + partP_remove = (remove1 * drain_vfs1 + remove2 * drain_vfs2)/hru(j)%area_ha + sedminpa(j) = sedminpa(j) * (1. - partP_remove / 100.) + sedminps(j) = sedminps(j) * (1. - partP_remove / 100.) + sedorgp(j) = sedorgp(j) * (1. - partP_remove / 100.) !! Calculate Soluble P removal from surface runoff !! DP% = - 6.14 + 1.13 Runoff% - remove1 = 29.3 + 0.51 * surq_remove1 - if (remove1 > 100.) remove1 = 100. - if (remove1 < 0.) remove1 = 0. - - remove21 = 29.3 + 0.51 * surq_remove2 - if (remove2 > 100.) remove2 = 100. - if (remove2 < 0.) remove2 = 0. + remove1 = 29.3 + 0.51 * surq_remove1 + if (remove1 > 100.) remove1 = 100. + if (remove1 < 0.) remove1 = 0. + + remove21 = 29.3 + 0.51 * surq_remove2 + if (remove2 > 100.) remove2 = 100. + if (remove2 < 0.) remove2 = 0. - solp_remove = (remove1 * drain_vfs1 + remove2 * drain_vfs2)/hru(j)%area_ha - surqsolp(j) = surqsolp(j) * (1. - solp_remove / 100.) + solp_remove = (remove1 * drain_vfs1 + remove2 * drain_vfs2)/hru(j)%area_ha + surqsolp(j) = surqsolp(j) * (1. - solp_remove / 100.) !! Calculate pesticide removal !! based on the sediment and runoff removal only @@ -235,7 +235,7 @@ subroutine smp_filter hpestb_d(j)%pest(k)%sed = hpestb_d(j)%pest(k)%sed * (1. - sed_remove / 100.) end do - end if ! if (surfq(j) > .0001) + end if ! if (surfq(j) > .0001) return end subroutine smp_filter \ No newline at end of file diff --git a/src/smp_grass_wway.f90 b/src/smp_grass_wway.f90 index 44c011d..930ef0b 100644 --- a/src/smp_grass_wway.f90 +++ b/src/smp_grass_wway.f90 @@ -6,12 +6,12 @@ subroutine smp_grass_wway !! name |units |definition !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! ihru |none |HRU number -!! surfq(:) |mm H2O |amount of water in surface runoff generated -!! grwat_l(:) |km |Length of Grass Waterway -!! grwat_w(:) |none |Width of grass waterway -!! grwat_s(:) |m/m |Slope of grass waterway -!! grwat_spcon(:) |none |sediment transport coefficant defined by user -!! tc_gwat(:) |none |Time of concentration for Grassed waterway and its drainage area +!! surfq(:) |mm H2O |amount of water in surface runoff generated +!! grwat_l(:) |km |Length of Grass Waterway +!! grwat_w(:) |none |Width of grass waterway +!! grwat_s(:) |m/m |Slope of grass waterway +!! grwat_spcon(:) |none |sediment transport coefficant defined by user +!! tc_gwat(:) |none |Time of concentration for Grassed waterway and its drainage area !! surfq(:) |mm H2O |surface runoff generated on day in HRU !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! ~ ~ ~ OUTGOING VARIABLES ~ ~ ~ @@ -22,7 +22,7 @@ subroutine smp_grass_wway !! name |units |definition !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! qp_cms |m^3/s |peak runoff rate for the day -!! rcharea |m^2 |cross-sectional area of flow +!! rcharea |m^2 |cross-sectional area of flow !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~ @@ -42,15 +42,15 @@ subroutine smp_grass_wway real :: sed_remove = 0. !% |percent of sediment capture in VFS real :: sf_sed = 0. !kg/m^2 |sediment loads on sides of waterway real :: vc = 0. !m/s |flow velocity in reach - real :: chflow_day = 0. !m^3/day |Runoff + real :: chflow_day = 0. !m^3/day |Runoff integer :: j = 0 !none |HRU number real :: rchdep = 0. !m |depth of flow on day real :: p = 0. ! | real :: rh = 0. !m |hydraulic radius real :: qman !m^3/s or m/s |flow rate or flow velocity - real :: sedin = 0. !mg |Sediment in waterway + real :: sedin = 0. !mg |Sediment in waterway real :: sf_depth = 0. ! | - real :: sedint = 0. !mg |Sediment into waterway channel + real :: sedint = 0. !mg |Sediment into waterway channel real :: cyin = 0. ! | real :: cych = 0. ! | real :: rcharea = 0. @@ -58,23 +58,23 @@ subroutine smp_grass_wway real :: deg = 0. !metric tons |sediment reentrained in water by channel ! |degradation real :: dep = 0. ! | - real :: sedout = 0. !mg | Sediment out of waterway channel + real :: sedout = 0. !mg | Sediment out of waterway channel real :: sed_frac = 0. ! | real :: surq_frac = 0. ! | real :: sedtrap = 0. ! | real :: xrem = 0. ! | integer :: k = 0 !m^3/s |Total number of HRUs plus this HRU number -!! set variables +!! set variables j = ihru -!! do this only if there is surface runoff this day +!! do this only if there is surface runoff this day if (surfq(j) > 0.001) then !! compute channel peak rate using SCS triangular unit hydrograph -!! Calculate average flow based on 3 hours of runoff - chflow_day = 1000. * surfq(j) * hru(ihru)%km +!! Calculate average flow based on 3 hours of runoff + chflow_day = 1000. * surfq(j) * hru(ihru)%km chflow_m3 = chflow_day/10800 qp_cms = 2. * chflow_m3 / (1.5 * tc_gwat(j)) @@ -100,40 +100,40 @@ subroutine smp_grass_wway !! Sediment yield (kg) from fraction of area drained by waterway - sedin = sedyld(ihru) * hru(ihru)%km + sedin = sedyld(ihru) * hru(ihru)%km !! Calculate sediment losses in sheetflow at waterway sides !! calculate area of sheeflow in m^2 assumne *:1 side slope 8.06 = (8^2+1^2)^.5 - sf_area = (hru(j)%lumv%grwat_d - rchdep) * 8.06 * hru(j)%lumv%grwat_l * 1000 + sf_area = (hru(j)%lumv%grwat_d - rchdep) * 8.06 * hru(j)%lumv%grwat_l * 1000 !! Adjust Area to account for flow nonuniformities White and Arnold 2009 found half of flow in VFS !!handled by 10% of VFS area. Waterways likely even more concentrated Assume only 20% of sideslope acts as filters if (sf_area > 1.e-6) then - sf_area = sf_area * 0.20 + sf_area = sf_area * 0.20 !! calculate runoff depth over sheetflow area in mm - sf_depth=surfq(j) * hru(ihru)%km * 1000000/sf_area + sf_depth=surfq(j) * hru(ihru)%km * 1000000/sf_area !! Calculate sediment load on sheetflow area kg/ha - sf_sed = sedin * 1000 / sf_area + sf_sed = sedin * 1000 / sf_area !! Calculate runoff and sediment losses taken from mostly from filter.f end if - if (sf_area > 0.) then -!! surq_remove = 75.8 - 10.8 * Log(sf_depth) + 25.9 + if (sf_area > 0.) then +!! surq_remove = 75.8 - 10.8 * Log(sf_depth) + 25.9 !! & * Log(sol_k(1,j)) - !! Simpler form derived from vfsmod simulations. r2 = 0.57 Publication pending white and arnold 2008 + !! Simpler form derived from vfsmod simulations. r2 = 0.57 Publication pending white and arnold 2008 - surq_remove = 95.6 - 10.79 * Log(sf_depth) - if (surq_remove > 100.) surq_remove = 100. - if (surq_remove < 0.) surq_remove = 0. + surq_remove = 95.6 - 10.79 * Log(sf_depth) + if (surq_remove > 100.) surq_remove = 100. + if (surq_remove < 0.) surq_remove = 0. - sed_remove = 79.0 - 1.04 * sf_sed + 0.213 * surq_remove - if (sed_remove > 100.) sed_remove = 100. - if (sed_remove < 0.) sed_remove = 0. + sed_remove = 79.0 - 1.04 * sf_sed + 0.213 * surq_remove + if (sed_remove > 100.) sed_remove = 100. + if (sed_remove < 0.) sed_remove = 0. - Else - sed_remove = 0 - surq_remove = 0 - endif - sedint = sedin * (1. - sed_remove / 100.) + Else + sed_remove = 0 + surq_remove = 0 + endif + sedint = sedin * (1. - sed_remove / 100.) !! calculate flow velocity vc = 0.001 @@ -157,59 +157,59 @@ subroutine smp_grass_wway !! Calculate deposition in mg depnet = chflow_day * (cyin - cych) if (depnet < 0.) depnet = 0 - if (depnet > sedint) depnet = sedint + if (depnet > sedint) depnet = sedint endif !! Calculate sediment out of waterway channel - sedout = sedint - depnet + sedout = sedint - depnet !! Calculate total fraction of sediment and surface runoff transported if (sedyld(j) < .0001) sedyld(j) = .0001 - sed_frac = sedout/sedyld(j) + sed_frac = sedout/sedyld(j) - surq_frac = 1 - surq_remove/100 + surq_frac = 1 - surq_remove/100 !! Subtract reductions from sediment, nutrients, bacteria, and pesticides NOT SURFACE RUNOFF to protect water balance sedtrap = sedyld(j) * (1. - sed_frac) - sedyld(j) = sedyld(j) * sed_frac - sedminpa(j) = sedminpa(j) * sed_frac - sedminps(j) = sedminps(j) * sed_frac - sedorgp(j) = sedorgp(j) * sed_frac - surqsolp(j) = surqsolp(j) * surq_frac - sedorgn(j) = sedorgn(j) * sed_frac - surqno3(j) = surqno3(j) * surq_frac + sedyld(j) = sedyld(j) * sed_frac + sedminpa(j) = sedminpa(j) * sed_frac + sedminps(j) = sedminps(j) * sed_frac + sedorgp(j) = sedorgp(j) * sed_frac + surqsolp(j) = surqsolp(j) * surq_frac + sedorgn(j) = sedorgn(j) * sed_frac + surqno3(j) = surqno3(j) * surq_frac xrem = 0. - if (sedtrap <= lagyld(j)) then - lagyld(j) = lagyld(j) - sedtrap - else - xrem = sedtrap - lagyld(j) - lagyld(j) = 0. - if (xrem <= sanyld(j)) then - sanyld(j) = sanyld(j) - xrem - else - xrem = xrem - sanyld(j) - sanyld(j) = 0. - if (xrem <= sagyld(j)) then - sagyld(j) = sagyld(j) - xrem - else - xrem = xrem - sagyld(j) - sagyld(j) = 0. - if (xrem <= silyld(j)) then - silyld(j) = silyld(j) - xrem - else - xrem = xrem - silyld(j) - silyld(j) = 0. - if (xrem <= clayld(j)) then - clayld(j) = clayld(j) - xrem - else - xrem = xrem - clayld(j) - clayld(j) = 0. - end if - end if - end if - end if - end if + if (sedtrap <= lagyld(j)) then + lagyld(j) = lagyld(j) - sedtrap + else + xrem = sedtrap - lagyld(j) + lagyld(j) = 0. + if (xrem <= sanyld(j)) then + sanyld(j) = sanyld(j) - xrem + else + xrem = xrem - sanyld(j) + sanyld(j) = 0. + if (xrem <= sagyld(j)) then + sagyld(j) = sagyld(j) - xrem + else + xrem = xrem - sagyld(j) + sagyld(j) = 0. + if (xrem <= silyld(j)) then + silyld(j) = silyld(j) - xrem + else + xrem = xrem - silyld(j) + silyld(j) = 0. + if (xrem <= clayld(j)) then + clayld(j) = clayld(j) - xrem + else + xrem = xrem - clayld(j) + clayld(j) = 0. + end if + end if + end if + end if + end if sanyld(j) = Max(0., sanyld(j)) silyld(j) = Max(0., silyld(j)) clayld(j) = Max(0., clayld(j)) diff --git a/src/soil_data_module.f90 b/src/soil_data_module.f90 index c57f907..5d6f077 100644 --- a/src/soil_data_module.f90 +++ b/src/soil_data_module.f90 @@ -12,7 +12,7 @@ module soil_data_module type soiltest_db character(len=16) :: name = "default" - real :: exp_co = .001 ! |depth coefficient to adjust concentrations for depth + real :: exp_co = .001 ! |depth coefficient to adjust concentrations for depth real :: lab_p = 5. !ppm |labile P in soil surface real :: nitrate = 7. !ppm |nitrate N in soil surface real :: fr_hum_act = .02 !0-1 |fraction of soil humus that is active @@ -29,7 +29,7 @@ module soil_data_module !!!!!! OLD type type soiltest_db_old character(len=16) :: name = "default" - real :: exp_co = .001 ! |depth coefficient to adjust concentrations for depth + real :: exp_co = .001 ! |depth coefficient to adjust concentrations for depth real :: totaln = 13. !ppm |total N in soil real :: inorgn = 6. !ppm |inorganic N in soil surface real :: orgn = 3. !ppm |organic N in soil surface diff --git a/src/soil_module.f90 b/src/soil_module.f90 index 45895f5..845e995 100644 --- a/src/soil_module.f90 +++ b/src/soil_module.f90 @@ -50,7 +50,7 @@ module soil_module type (soil_physical_properties),dimension (:), allocatable:: phys1 type soil_profile - character(len=16) :: snam = "" !! NA soil series name + character(len=20) :: snam = "" !! NA soil series name character(len=16) :: hydgrp = "" !! NA hydrologic soil group character(len=16) :: texture = "" integer :: nly = 0 !! none number of soil layers diff --git a/src/soil_nutcarb_init.f90 b/src/soil_nutcarb_init.f90 index 1cf8db1..b08ee50 100644 --- a/src/soil_nutcarb_init.f90 +++ b/src/soil_nutcarb_init.f90 @@ -34,11 +34,19 @@ subroutine soil_nutcarb_init (isol) isolt = sol_plt_ini(isol_pl)%nut ! isolt = 0 = default in type !! set soil carbon - soil1(ihru)%cbn(1) = max(.001, soildb(isol)%ly(1)%cbn) !! assume 0.001% carbon if zero + soil1(ihru)%cbn(1) = max(0.001, soildb(isol)%ly(1)%cbn) !! assume 0.001% carbon if zero !! calculate percent carbon for lower layers using exponential decrease + !do ly = 2, nly + !dep_frac = Exp(-solt_db(isolt)%exp_co * soil(ihru)%phys(ly)%d) + !soil1(ihru)%cbn(ly) = soil1(ihru)%cbn(1) * dep_frac + !end do + !! use carbon content in the soils database do ly = 2, nly - dep_frac = Exp(-solt_db(isolt)%exp_co * soil(ihru)%phys(ly)%d) - soil1(ihru)%cbn(ly) = soil1(ihru)%cbn(1) * dep_frac + if (ly - 1 <= soildb(isol)%s%nly) then + soil1(ihru)%cbn(ly) = soildb(isol)%ly(ly-1)%cbn + else + soil1(ihru)%cbn(ly) = soildb(isol)%ly(soildb(isol)%s%nly)%cbn + end if end do !! calculate initial nutrient contents of layers, profile and @@ -67,15 +75,15 @@ subroutine soil_nutcarb_init (isol) soil1(ihru)%mp(ly)%lab = soil1(ihru)%mp(ly)%lab * wt1 !! mg/kg => kg/ha !! set active mineral P pool based on dynamic PSP MJW - if (bsn_cc%sol_P_model == 1) then - !! Allow Dynamic PSP Ratio + if (bsn_cc%sol_P_model == 1) then + !! Allow Dynamic PSP Ratio !! convert to concentration solp = soil1(ihru)%mp(ly)%lab / wt1 - !! PSP = -0.045*log (% clay) + 0.001*(Solution P, mg kg-1) - 0.035*(% Organic C) + 0.43 - if (soil(ihru)%phys(ly)%clay > 0.) then + !! PSP = -0.045*log (% clay) + 0.001*(Solution P, mg kg-1) - 0.035*(% Organic C) + 0.43 + if (soil(ihru)%phys(ly)%clay > 0.) then psp = -0.045 * log(soil(ihru)%phys(ly)%clay) + (0.001 * solp) psp = psp - (0.035 * soil1(ihru)%cbn(ly)) + 0.43 - endif + endif !! Limit PSP range if (psp < .10) then psp = 0.10 @@ -88,24 +96,24 @@ subroutine soil_nutcarb_init (isol) soil1(ihru)%mp(ly)%act = soil1(ihru)%mp(ly)%lab * (1. - psp) / psp !! Set Stable pool based on dynamic coefficient - if (bsn_cc%sol_P_model == 1) then !! From White et al 2009 + if (bsn_cc%sol_P_model == 1) then !! From White et al 2009 !! convert to concentration for ssp calculation - actp = soil1(ihru)%mp(ly)%act / wt1 - solp = soil1(ihru)%mp(ly)%lab / wt1 + actp = soil1(ihru)%mp(ly)%act / wt1 + solp = soil1(ihru)%mp(ly)%lab / wt1 !! estimate Total Mineral P in this soil based on data from sharpley 2004 - ssp = 25.044 * (actp + solp)** (-0.3833) - !!limit SSP Range - if (ssp > 7.) ssp = 7. - if (ssp < 1.) ssp = 1. - soil1(ihru)%mp(ly)%sta = ssp * (soil1(ihru)%mp(ly)%act + soil1(ihru)%mp(ly)%lab) + ssp = 25.044 * (actp + solp)** (-0.3833) + !!limit SSP Range + if (ssp > 7.) ssp = 7. + if (ssp < 1.) ssp = 1. + soil1(ihru)%mp(ly)%sta = ssp * (soil1(ihru)%mp(ly)%act + soil1(ihru)%mp(ly)%lab) else - !! the original code - soil1(ihru)%mp(ly)%sta = 4. * soil1(ihru)%mp(ly)%act - end if + !! the original code + soil1(ihru)%mp(ly)%sta = 4. * soil1(ihru)%mp(ly)%act + end if end do !! set initial organic pools - originally by Zhang - do ly = 1, nly + do ly = 1, nly !initialize total soil organic pool - no litter !kg/ha = mm * t/m3 * m/1,000 mm * 1,000 kg/t * 10,000 m2/ha @@ -184,7 +192,7 @@ subroutine soil_nutcarb_init (isol) !soil1(ihru)%water(ly)%n = !soil1(ihru)%water(ly)%p = - end do + end do return end subroutine soil_nutcarb_init \ No newline at end of file diff --git a/src/soil_nutcarb_write.f90 b/src/soil_nutcarb_write.f90 index ce214c5..3c746de 100644 --- a/src/soil_nutcarb_write.f90 +++ b/src/soil_nutcarb_write.f90 @@ -50,6 +50,15 @@ subroutine soil_nutcarb_write soil1(j)%tot_org = soil_org_z soil_prof_hact = soil_org_z soil_prof_hsta = soil_org_z + soil_prof_hsta = soil_org_z + soil_prof_str = soil_org_z + soil_prof_lig = soil_org_z + soil_prof_meta = soil_org_z + soil_prof_man = soil_org_z + soil_prof_hs = soil_org_z + soil_prof_hp = soil_org_z + soil_prof_microb = soil_org_z + soil_prof_water = soil_org_z do ly = 1, soil(j)%nly soil_prof_hact = soil_prof_hact + soil1(j)%hact(ly) soil_prof_hsta = soil_prof_hsta + soil1(j)%hsta(ly) @@ -62,7 +71,9 @@ subroutine soil_nutcarb_write soil_prof_microb = soil_prof_microb + soil1(j)%microb(ly) soil_prof_water = soil_prof_water + soil1(j)%water(ly) end do - soil1(j)%tot_org = soil_prof_hact + soil_prof_hsta + soil_prof_microb + ! soil1(j)%tot_org = soil_prof_hact + soil_prof_hsta + soil_prof_microb + soil1(j)%tot_org = soil_prof_hs + soil_prof_hp + soil_prof_microb + soil_prof_meta + & + soil_prof_str + soil_prof_lig !write all organic carbon for the plant community write (4560,*) time%day, time%mo, time%day_mo, time%yrc, j, ob(iob)%gis_id, ob(iob)%name, & diff --git a/src/soil_phys_init.f90 b/src/soil_phys_init.f90 index 8c9ab4b..d8f89cb 100644 --- a/src/soil_phys_init.f90 +++ b/src/soil_phys_init.f90 @@ -62,13 +62,13 @@ subroutine soil_phys_init (isol) if (sol(isol)%phys(j)%k <= 0.0) then if (sol(isol)%s%hydgrp == "A") then sol(isol)%phys(j)%k = a - else + else if (sol(isol)%s%hydgrp == "B") then sol(isol)%phys(j)%k = b - else + else if (sol(isol)%s%hydgrp == "C") then sol(isol)%phys(j)%k = c - else + else if (sol(isol)%s%hydgrp == "D") then sol(isol)%phys(j)%k = d !Claire 12/2/09 else @@ -131,15 +131,15 @@ subroutine soil_phys_init (isol) sol(isol)%s%det_lag = 1. - sol(isol)%s%det_san - & sol(isol)%s%det_sil - sol(isol)%s%det_cla - sol(isol)%s%det_sag !! Large Aggregate fraction -!! Error check. May happen for soils with more sand +!! Error check. May happen for soils with more sand !! Soil not typical of mid-western USA !! The fraction wont add upto 1.0 - if (sol(isol)%s%det_lag < 0.) then - sol(isol)%s%det_san = sol(isol)%s%det_san/(1 - sol(isol)%s%det_lag) - sol(isol)%s%det_sil = sol(isol)%s%det_sil/(1 - sol(isol)%s%det_lag) - sol(isol)%s%det_cla = sol(isol)%s%det_cla/(1 - sol(isol)%s%det_lag) - sol(isol)%s%det_sag = sol(isol)%s%det_sag/(1 - sol(isol)%s%det_lag) - sol(isol)%s%det_lag = 0. + if (sol(isol)%s%det_lag < 0.) then + sol(isol)%s%det_san = sol(isol)%s%det_san/(1 - sol(isol)%s%det_lag) + sol(isol)%s%det_sil = sol(isol)%s%det_sil/(1 - sol(isol)%s%det_lag) + sol(isol)%s%det_cla = sol(isol)%s%det_cla/(1 - sol(isol)%s%det_lag) + sol(isol)%s%det_sag = sol(isol)%s%det_sag/(1 - sol(isol)%s%det_lag) + sol(isol)%s%det_lag = 0. end if !! initialize water/drainage coefs for each soil layer diff --git a/src/soil_text_init.f90 b/src/soil_text_init.f90 index 87f0672..8c474d5 100644 --- a/src/soil_text_init.f90 +++ b/src/soil_text_init.f90 @@ -55,12 +55,12 @@ subroutine soil_text_init (isol) !! Error check. May happen for soils with more sand !! Soil not typical of mid-western USA The fraction wont add upto 1.0 - if (soil(isol)%det_lag < 0.) then - soil(isol)%det_san = soil(isol)%det_san/(1 - soil(isol)%det_lag) - soil(isol)%det_sil = soil(isol)%det_sil/(1 - soil(isol)%det_lag) - soil(isol)%det_cla = soil(isol)%det_cla/(1 - soil(isol)%det_lag) - soil(isol)%det_sag = soil(isol)%det_sag/(1 - soil(isol)%det_lag) - soil(isol)%det_lag = 0. + if (soil(isol)%det_lag < 0.) then + soil(isol)%det_san = soil(isol)%det_san/(1 - soil(isol)%det_lag) + soil(isol)%det_sil = soil(isol)%det_sil/(1 - soil(isol)%det_lag) + soil(isol)%det_cla = soil(isol)%det_cla/(1 - soil(isol)%det_lag) + soil(isol)%det_sag = soil(isol)%det_sag/(1 - soil(isol)%det_lag) + soil(isol)%det_lag = 0. end if return diff --git a/src/soils_init.f90 b/src/soils_init.f90 index b2ca507..30894f5 100644 --- a/src/soils_init.f90 +++ b/src/soils_init.f90 @@ -134,7 +134,7 @@ subroutine soils_init if (sep(isep)%opt /= 0) then dep_new1 = 0. dep_new2 = 0. - if (sep(isep)%z + sep(isep)%thk > soil(ihru)%phys(nly)%d) then + if (sep(isep)%z + sep(isep)%thk > soil(ihru)%phys(nly)%d) then i_sep(ihru) = nly + 1 dep_new1 = sep(isep)%z - sep(isep)%thk dep_new2 = 0. @@ -200,6 +200,7 @@ subroutine soils_init allocate (soil1_init(ihru)%man(nly)) allocate (soil1_init(ihru)%water(nly)) + call soil_nutcarb_init(isol) !! initialize soil nutrient/carbon parameters Jaehak 2024 end do return diff --git a/src/sq_canopyint.f90 b/src/sq_canopyint.f90 index 1368e81..cf8d3ec 100644 --- a/src/sq_canopyint.f90 +++ b/src/sq_canopyint.f90 @@ -87,7 +87,7 @@ subroutine sq_canopyint precip_eff = precip_eff - (canmxl - canstor(j)) canstor(j) = canmxl endif - end if + end if ! time%step > 1 return end subroutine sq_canopyint \ No newline at end of file diff --git a/src/sq_greenampt.f90 b/src/sq_greenampt.f90 index 3883bf3..c93e7e8 100644 --- a/src/sq_greenampt.f90 +++ b/src/sq_greenampt.f90 @@ -179,14 +179,14 @@ subroutine sq_greenampt end if return - 5000 format(//,"Excess rainfall calculation for day ",i3," of year ", & - i4," for sub-basin",i4,".",/) - 5001 format(t2,"Time",t9,"Incremental",t22,"Cumulative",t35,"Rainfall", & - t45,"Infiltration",t59,"Cumulative",t71,"Cumulative",t82, & - "Incremental",/,t2,"Step",t10,"Rainfall",t23,"Rainfall", & - t35,"Intensity",t49,"Rate",t58,"Infiltration",t73,"Runoff", & - t84,"Runoff",/,t12,"(mm)",t25,"(mm)",t36,"(mm/h)",t48, & - "(mm/h)",t62,"(mm)",t74,"(mm)",t85,"(mm)",/) - 5002 format(i5,t12,f5.2,t24,f6.2,t36,f6.2,t47,f7.2,t61,f6.2,t73,f6.2, & - t84,f6.2) +!*** tu Wunused-label: 5000 format(//,"Excess rainfall calculation for day ",i3," of year ", & + !i4," for sub-basin",i4,".",/) +!*** tu Wunused-label: 5001 format(t2,"Time",t9,"Incremental",t22,"Cumulative",t35,"Rainfall", & + !t45,"Infiltration",t59,"Cumulative",t71,"Cumulative",t82, & + !"Incremental",/,t2,"Step",t10,"Rainfall",t23,"Rainfall", & + !t35,"Intensity",t49,"Rate",t58,"Infiltration",t73,"Runoff", & + !t84,"Runoff",/,t12,"(mm)",t25,"(mm)",t36,"(mm/h)",t48, & + !"(mm/h)",t62,"(mm)",t74,"(mm)",t85,"(mm)",/) +!*** tu Wunused-label: 5002 format(i5,t12,f5.2,t24,f6.2,t36,f6.2,t47,f7.2,t61,f6.2,t73,f6.2, & + !t84,f6.2) end subroutine sq_greenampt \ No newline at end of file diff --git a/src/sq_surfst.f90 b/src/sq_surfst.f90 index 594ff55..1478e77 100644 --- a/src/sq_surfst.f90 +++ b/src/sq_surfst.f90 @@ -42,29 +42,29 @@ subroutine sq_surfst j = ihru - if (bsn_cc%gampt == 0) then + if (bsn_cc%gampt == 0) then bsprev = surf_bs(1,j) - surf_bs(1,j) = Max(1.e-6, surf_bs(1,j) + surfq(j)) + surf_bs(1,j) = Max(1.e-6, surf_bs(1,j) + surfq(j)) qday = surf_bs(1,j) * brt(j) surf_bs(1,j) = surf_bs(1,j) - qday - else - bsprev = hhsurf_bs(1,j,time%step) ! lag from previous day J.Jeong 4/06/2009 + else + bsprev = hhsurf_bs(1,j,time%step) ! lag from previous day J.Jeong 4/06/2009 qday = 0. - do k=1,time%step - !! Left-over (previous timestep) + inflow (current timestep) + do k=1,time%step + !! Left-over (previous timestep) + inflow (current timestep) hhsurf_bs(1,j,k) = Max(0., bsprev + hhsurfq(j,k)) - - !! new estimation of runoff and sediment reaching the main channel - hhsurfq(j,k) = hhsurf_bs(1,j,k) * brt(j) - hhsurf_bs(1,j,k) = hhsurf_bs(1,j,k) - hhsurfq(j,k) - - !! lagged at the end of time step - bsprev = hhsurf_bs(1,j,k) + + !! new estimation of runoff and sediment reaching the main channel + hhsurfq(j,k) = hhsurf_bs(1,j,k) * brt(j) + hhsurf_bs(1,j,k) = hhsurf_bs(1,j,k) - hhsurfq(j,k) + + !! lagged at the end of time step + bsprev = hhsurf_bs(1,j,k) !! daily total yield from the HRU - qday = qday + hhsurfq(j,k) - end do - end if + qday = qday + hhsurfq(j,k) + end do + end if return end subroutine sq_surfst \ No newline at end of file diff --git a/src/stmp_solt.f90 b/src/stmp_solt.f90 index 9d4746c..e4f75e3 100644 --- a/src/stmp_solt.f90 +++ b/src/stmp_solt.f90 @@ -132,10 +132,10 @@ subroutine stmp_solt isep = iseptic(j) if (sep(isep)%opt /= 0 .and. time%yrc >= sep(isep)%yr .and. k >= & i_sep(j)) then - if (soil(j)%phys(k)%tmp < 10.) then - soil(j)%phys(k)%tmp = 10. - (10. - soil(j)%phys(k)%tmp) * 0.1 - end if - endif + if (soil(j)%phys(k)%tmp < 10.) then + soil(j)%phys(k)%tmp = 10. - (10. - soil(j)%phys(k)%tmp) * 0.1 + end if + endif end do diff --git a/src/stor_surfstor.f90 b/src/stor_surfstor.f90 index 8c44398..e886367 100644 --- a/src/stor_surfstor.f90 +++ b/src/stor_surfstor.f90 @@ -98,23 +98,23 @@ subroutine stor_surfstor surf_bs(2,j) = surf_bs(2,j) - sedyld(j) else !subdaily time steps, Jaehak Jeong 2011 - sedprev = hhsurf_bs(2,j,time%step) + sedprev = hhsurf_bs(2,j,time%step) - do k=1,time%step - !! Left-over (previous timestep) + inflow (current timestep) + do k=1,time%step + !! Left-over (previous timestep) + inflow (current timestep) hhsurf_bs(2,j,k) = Max(0., sedprev + hhsedy(j,k)) - - !! new estimation of sediment reaching the main channel + + !! new estimation of sediment reaching the main channel hhsedy(j,k) = hhsurf_bs(2,j,k) * brt(j)! tons hhsurf_bs(2,j,k) = hhsurf_bs(2,j,k) - hhsedy(j,k) - - !! lagged at the end of time step - sedprev = hhsurf_bs(2,j,k) + + !! lagged at the end of time step + sedprev = hhsurf_bs(2,j,k) surf_bs(2,j) = Max(1.e-9, surf_bs(2,j) + sedyld(j)) - end do + end do - !! daily total sediment yield from the HRU - sedyld(j) = sum(hhsedy(j,:)) + !! daily total sediment yield from the HRU + sedyld(j) = sum(hhsedy(j,:)) endif surf_bs(13,j) = Max(1.e-6, surf_bs(13,j) + sanyld(j)) @@ -179,7 +179,7 @@ subroutine stor_surfstor surf_bs(53,j) = surf_bs(53,j) + wetqcs(j,1) !seo4 surf_bs(54,j) = surf_bs(54,j) + wetqcs(j,2) !seo3 surf_bs(55,j) = surf_bs(55,j) + wetqcs(j,3) !born - endif + endif !! sedyld(j) = surf_bs(2,j) * brt(j) <--line of code in x 2. fixes sedyld low prob diff --git a/src/structure_set_parms.f90 b/src/structure_set_parms.f90 index 6a9c030..fe0b89c 100644 --- a/src/structure_set_parms.f90 +++ b/src/structure_set_parms.f90 @@ -63,7 +63,7 @@ subroutine structure_set_parms (str_name, istr, j) case ("grassww") hru(j)%lumv%ngrwat = istr if (istr > 0) then - hru(j)%lumv%grwat_i = grwaterway_db(istr)%grwat_i + hru(j)%lumv%grwat_i = 1 hru(j)%lumv%grwat_n = grwaterway_db(istr)%grwat_n hru(j)%lumv%grwat_spcon = grwaterway_db(istr)%grwat_spcon hru(j)%lumv%grwat_d = grwaterway_db(istr)%grwat_d diff --git a/src/surface.f90 b/src/surface.f90 index f7a09be..bc824f9 100644 --- a/src/surface.f90 +++ b/src/surface.f90 @@ -68,8 +68,8 @@ subroutine surface if (qday > 1.e-6 .and. qp_cms > 1.e-6) then call ero_eiusle - !! calculate sediment erosion by rainfall and overland flow - call ero_ovrsed + !! calculate sediment erosion by rainfall and overland flow + call ero_ovrsed end if call ero_cfactor @@ -77,6 +77,6 @@ subroutine surface if (qday < 0.) qday = 0. -1010 format (2(i4,1x),a5,a4,1x,10f8.3) +!*** tu Wunused-label: 1010 format (2(i4,1x),a5,a4,1x,10f8.3) return end subroutine surface \ No newline at end of file diff --git a/src/swift_output.f90 b/src/swift_output.f90 index c42e667..8740586 100644 --- a/src/swift_output.f90 +++ b/src/swift_output.f90 @@ -32,7 +32,7 @@ subroutine swift_output logical :: i_exist ! SWIFT file formats - 201 format (A8,12xA8,46X,*(A16,F2.0,A4,1xA16,F2.0,A4)) ! format of precip.swf headers + 201 format (A8,12xA8,46X,*(A16,F5.1,A4,1xA16,F5.1,A4)) ! format of precip.swf headers 301 format (I8,1xA64,F16.4,8xF16.4) ! format of precip.swf 202 format (A8,30xA8,18X,A8,36xA8,4xA8,218x1A8,6x1A8) ! format of hru_dat.swf headers 302 format (1I8,1x2A48, G16.4 ,1x*(G16.4)) ! format of hru_dat.swf @@ -42,7 +42,7 @@ subroutine swift_output 205 format (7xA16, A16, 10x,*(A16)) ! format of chan_dat.swf headers 305 format (I8, 1x, A16, A16,*(F16.4)) ! format of chan_dat.swf 206 format (4xA8, 1xA8, 20x,*(A16)) ! format of chan_dr.swf headers - 306 format (I8,4xA16, 10xA16,*(F16.4)) ! format of chan_dr.swf +!*** tu Wunused-label: 306 format (I8,4xA16, 10xA16,*(F16.4)) ! format of chan_dr.swf 207 format (A16,1x*(A16)) ! format of aqu_dr.swf headers 208 format (6xA8, 1xA8, 16x,*(A8,6x)) ! format of res_dat.swf headers !209 format (6xA8, 1xA8, 16x,*(A8,6x)) ! format of res_dr.swf headers diff --git a/src/swr_depstor.f90 b/src/swr_depstor.f90 index e39f95d..8762628 100644 --- a/src/swr_depstor.f90 +++ b/src/swr_depstor.f90 @@ -1,4 +1,4 @@ - subroutine swr_depstor + subroutine swr_depstor !! ~ ~ ~ PURPOSE ~ ~ ~ !! this subroutine computes maximum surface depressional storage depth based on @@ -10,22 +10,22 @@ subroutine swr_depstor !! iop(:,:,:) |julian date |date of tillage operation !! mgt_op |none |operation code number !! ranrns_hru(:)|mm |random roughness for a given HRU -!! sol_ori(:) |mm |oriented roughness (ridges) at time of a given tillage operation +!! sol_ori(:) |mm |oriented roughness (ridges) at time of a given tillage operation !! usle_ei |100(ft-tn in)/(acre-hr)|USLE rainfall erosion index !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! ~ ~ ~ OUTGOING VARIABLES ~ ~ ~ !! name |units |definition !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ -!! stmaxd(:) |mm |maximum surface depressional storage for day in a given HRU +!! stmaxd(:) |mm |maximum surface depressional storage for day in a given HRU !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! ~ ~ ~ LOCAL DEFINITIONS ~ ~ ~ !! name |units |definition !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ -!! cumei(:) |Mj*mm/ha*hr |cumulative USLE rainfall erosion index since last -!! |tillage operation -!! cumrt(:) |mm H2O |cumulative rainfall since last tillage operation +!! cumei(:) |Mj*mm/ha*hr |cumulative USLE rainfall erosion index since last +!! |tillage operation +!! cumrt(:) |mm H2O |cumulative rainfall since last tillage operation !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! ~ ~ ~ SUBROUTINES/FUNCTIONS CALLED ~ ~ ~ @@ -42,28 +42,28 @@ subroutine swr_depstor implicit none integer :: j = 0 !none |HRU number - real:: df = 0. !none |oriented and random roughness decay factor - based + real:: df = 0. !none |oriented and random roughness decay factor - based ! |on cumulative EI and cumulative precip_eff - real:: hru_slpp = 0. !% |average percent slope steepness - real:: sol_orgm = 0. !% |percent organic matter content in soil material - !real:: sol_orr !cm |oriented roughness (ridges) after a rain event - real:: sol_rrr = 0. !cm |random roughness after a rain event + real:: hru_slpp = 0. !% |average percent slope steepness + real:: sol_orgm = 0. !% |percent organic matter content in soil material + !real:: sol_orr !cm |oriented roughness (ridges) after a rain event + real:: sol_rrr = 0. !cm |random roughness after a rain event real:: ei = 0. !Mj*mm/ha*hr |USLE rainfall erosion index real :: xx = 0. ! | j = ihru !! Calculate current cummulative erosivity and rainfall - ei = usle_ei*18.7633 - if (itill(j) ==1)then - cumeira(j) = cumeira(j) + ei - cumei(j) = cumeira(j) - ei - cumrai(j) = cumrai(j) + precip_eff - cumrt(j) = cumrai(j) - precip_eff + ei = usle_ei*18.7633 + if (itill(j) ==1)then + cumeira(j) = cumeira(j) + ei + cumei(j) = cumeira(j) - ei + cumrai(j) = cumrai(j) + precip_eff + cumrt(j) = cumrai(j) - precip_eff end if !! Calculate the decay factor df based on %clay and %organic matter or %organic carbon - sol_orgm = soil1(j)%tot(1)%c / 0.58 - xx = (0.943 - 0.07 * soil(j)%phys(1)%clay + 0.0011 * & + sol_orgm = soil1(j)%tot(1)%c / 0.58 + xx = (0.943 - 0.07 * soil(j)%phys(1)%clay + 0.0011 * & soil(j)%phys(1)%clay**2 - 0.67 * sol_orgm + 0.12 * sol_orgm**2) if (xx > 1.) then df = 1. @@ -75,20 +75,20 @@ subroutine swr_depstor !! Determine the current random and oriented roughness using cumei and cumrt and initial !! random and oriented roughness values - sol_rrr = 0.1 * ranrns_hru(j) & - * exp(df*(-0.0009*cumei(j)-0.0007 * cumrt(j))) - -! sol_orr = 0.1*sol_ori(j)* -! & exp(df*(-0.025*(cumei(j)**0.31)-0.0085*(cumrt(j)**0.567))) + sol_rrr = 0.1 * ranrns_hru(j) & + * exp(df*(-0.0009*cumei(j)-0.0007 * cumrt(j))) + +! sol_orr = 0.1*sol_ori(j)* +! & exp(df*(-0.025*(cumei(j)**0.31)-0.0085*(cumrt(j)**0.567))) !! Compute the current maximum depressional storage using percent slope steepness !! and current random and oriented roughness values determined above - hru_slpp = hru(j)%topo%slope*100 -! if(irk=0) then !irk=0 for random rough, and irk=1, for oriented roughness - stmaxd(j)= 0.112*sol_rrr+0.031*sol_rrr**2-0.012*sol_rrr*hru_slpp -! else -! stmaxd(j)= 0.112*sol_orr+0.031*sol_orr**2-0.012*sol_orr*hru_slpp -! endif + hru_slpp = hru(j)%topo%slope*100 +! if(irk=0) then !irk=0 for random rough, and irk=1, for oriented roughness + stmaxd(j)= 0.112*sol_rrr+0.031*sol_rrr**2-0.012*sol_rrr*hru_slpp +! else +! stmaxd(j)= 0.112*sol_orr+0.031*sol_orr**2-0.012*sol_orr*hru_slpp +! endif - return + return end subroutine swr_depstor \ No newline at end of file diff --git a/src/swr_drains.f90 b/src/swr_drains.f90 index e81fb33..636fa8d 100644 --- a/src/swr_drains.f90 +++ b/src/swr_drains.f90 @@ -1,4 +1,4 @@ - subroutine swr_drains + subroutine swr_drains !! ~ ~ ~ PURPOSE ~ ~ ~ !! this subroutine finds the effective lateral hydraulic conductivity @@ -8,7 +8,7 @@ subroutine swr_drains !! name |units |definition !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! drain_co(:) |mm/day |drainage coefficient -!! ddrain(:) |mm |depth of drain tube from the soil surface +!! ddrain(:) |mm |depth of drain tube from the soil surface !! latksatf(:) |none |multiplication factor to determine conk(j1,j) from sol_k(j1,j) for HRU !! pc(:) |mm/hr |pump capacity (default pump capacity = 1.042mm/hr or 25mm/day) !! sdrain(:) |mm |distance between two drain tubes or tiles @@ -105,11 +105,11 @@ subroutine swr_drains if(y1 > soil(j)%phys(j1)%d) then wnan(j1) = 0. else - wnan(j1) = soil(j)%phys(j1)%d - y1 - x = soil(j)%phys(j1)%d - above + wnan(j1) = soil(j)%phys(j1)%d - y1 + x = soil(j)%phys(j1)%d - above if(wnan(j1) > x) wnan(j1) = x - end if - above = soil(j)%phys(j1)%d + end if + above = soil(j)%phys(j1)%d end do sum = 0. deep = 0. @@ -122,27 +122,27 @@ subroutine swr_drains sum = 0. deep = 0.001 do j1=1,soil(j)%nly - sum = sum + soil(j)%ly(j1)%conk * soil(j)%phys(j1)%thick !Daniel 10/09/07 - deep = deep + dg !Daniel 10/09/07 + sum = sum + soil(j)%ly(j1)%conk * soil(j)%phys(j1)%thick !Daniel 10/09/07 + deep = deep + dg !Daniel 10/09/07 end do - cone=sum/deep - else - cone=sum/deep + cone=sum/deep + else + cone=sum/deep end if - !! calculate parameters hdrain and gee1 + !! calculate parameters hdrain and gee1 ad = soil(j)%zmx - hru(j)%lumv%sdr_dep ad = Max (10., ad) - ap = 3.55 - ((1.6 * ad) / hru(j)%sdr%dist) + 2 * & + ap = 3.55 - ((1.6 * ad) / hru(j)%sdr%dist) + 2 * & ((2 / hru(j)%sdr%dist)**2) - if (ad / hru(j)%sdr%dist < 0.3) then + if (ad / hru(j)%sdr%dist < 0.3) then hdrain= ad / (1 + ((ad / hru(j)%sdr%dist) * (((8 / pi) * & - Log(ad / hru(j)%sdr%radius) - ap)))) + Log(ad / hru(j)%sdr%radius) - ap)))) else hdrain = ad !hdrain = (hru(j)%sdr%dist * pi) / (8 * ((log(hru(j)%sdr%dist / & ! hru(j)%sdr%radius)/ log(e)) - 1.15)) - end if + end if !! calculate Kirkham G-Factor, gee k2 = tan((pi * ((2. * ad) - hru(j)%sdr%radius)) / (4. * soil(j)%zmx)) k3 = tan((pi * hru(j)%sdr%radius) / (4. * soil(j)%zmx)) @@ -164,11 +164,11 @@ subroutine swr_drains if (gee > 12.) gee = 12. !! calculate drainage and subirrigation flux section - ! drainage flux for ponded surface + ! drainage flux for ponded surface depth = hru(j)%lumv%sdr_dep + hdrain hdmin = depth - hru(j)%lumv%sdr_dep call swr_depstor ! dynamic stmaxd(j): compute current HRU stmaxd based - ! on cumulative rainfall and cum. intensity + ! on cumulative rainfall and cum. intensity storro = 0.2 * stmaxd(j) !surface storage that must be filled before surface !water can move to the tile drain tube !! Determine surface storage for the day in a given HRU (stor) @@ -187,7 +187,7 @@ subroutine swr_drains dflux= (12.56637 * 24.0 * cone* (depth - hdrain + stor)) / (gee * hru(j)%sdr%dist) !eq.10 if (dflux > hru(j)%sdr%drain_co) dflux = hru(j)%sdr%drain_co !eq.11 else -! subirrigation flux +! subirrigation flux em = depth - y1 - hdrain if(em < -1.0) then !! ddranp=ddrain(j)-1.0 @@ -198,15 +198,15 @@ subroutine swr_drains if (abs(dflux) > hru(j)%sdr%pumpcap) then dflux = - hru(j)%sdr%pumpcap * 24.0 end if -! drainage flux - for WT below the surface and for ponded depths < storro (S1) +! drainage flux - for WT below the surface and for ponded depths < storro (S1) else dflux = 4.0 * 24.0 * cone * em * (2.0 * hdrain + em) / hru(j)%sdr%dist**2 !eq.5 if(dflux > hru(j)%sdr%drain_co) dflux = hru(j)%sdr%drain_co !eq.11 if(dflux < 0.) dflux=0. if(em < 0.) dflux=0. end if - end if - qtile = dflux + end if + qtile = dflux return end subroutine swr_drains \ No newline at end of file diff --git a/src/swr_percmain.f90 b/src/swr_percmain.f90 index 4f8b17f..8089384 100644 --- a/src/swr_percmain.f90 +++ b/src/swr_percmain.f90 @@ -9,15 +9,15 @@ subroutine swr_percmain !! name |units |definition !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ !! new water table depth equations 01/2009 -!! c |none |a factor used to convert airvol to wtd +!! c |none |a factor used to convert airvol to wtd !! dg |mm |soil layer thickness in HRU !! new water table depth equations 01/2009 !! latq(:) |mm H2O |total lateral flow in soil profile for the !! |day in HRU !! lyrtile |mm H2O |drainage tile flow in soil layer for day !! new water table depth equations 01/2009 -!! ne_p |mm/hr |effective porosity in HRU for all soil profile layers -!! ne_w |mm/hr |effective porosity in HRU for soil layers above wtd +!! ne_p |mm/hr |effective porosity in HRU for all soil profile layers +!! ne_w |mm/hr |effective porosity in HRU for soil layers above wtd !! new water table depth equations 01/2009 !! qtile |mm H2O |drainage tile flow in soil profile for the day !! sepday |mm H2O |micropore percolation from soil layer @@ -29,8 +29,8 @@ subroutine swr_percmain !! new water table depth equations 01/2009 !! wt_shall |mm H2O |shallow water table height above bottom of soil profile !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ -!! w2 |mm | -!! y1 |mm |dummy variable for wat +!! w2 |mm | +!! y1 |mm |dummy variable for wat !! ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ use hru_module, only : hru, ihru, i_sep, inflpcp, isep, latlyr, latq, lyrtile, qstemm, sepbtm, sepcrktot, sepday, & @@ -68,7 +68,7 @@ subroutine swr_percmain !! initialize water entering first soil layer !! ht1%flo is infiltration from overland flow routing if (ires==0) then - sepday = inflpcp + irrig(j)%applied + ht1%flo !mm + sepday = inflpcp + irrig(j)%applied + ht1%flo / (hru(j)%area_ha * 10.) else sepday = inflpcp + ht1%flo / (hru(j)%area_ha * 10.) endif @@ -77,9 +77,9 @@ subroutine swr_percmain !! calculate crack flow if (bsn_cc%crk == 1) then - call swr_percmacro - sepday = sepday - sepcrktot - endif + call swr_percmacro + sepday = sepday - sepcrktot + endif !back to 4 mm slug for soil routing- keeps moisture above fc slug = 1000. !4. !1000. !this should be an input in parameters.bsn @@ -92,11 +92,11 @@ subroutine swr_percmain !! add water moving into soil layer from overlying layer soil(j)%phys(j1)%st = soil(j)%phys(j1)%st + sepday - !! septic tank inflow to biozone layer J.Jeong - ! STE added to the biozone layer if soil temp is above zero. - if (j1 == i_sep(j) .and. soil(j)%phys(j1)%tmp > 0. .and. & + !! septic tank inflow to biozone layer J.Jeong + ! STE added to the biozone layer if soil temp is above zero. + if (j1 == i_sep(j) .and. soil(j)%phys(j1)%tmp > 0. .and. & sep(isep)%opt /= 0) then - soil(j)%phys(j1)%st = soil(j)%phys(j1)%st + qstemm(j) ! in mm + soil(j)%phys(j1)%st = soil(j)%phys(j1)%st + qstemm(j) ! in mm end if !! determine gravity drained water in layer @@ -124,7 +124,7 @@ subroutine swr_percmain qtile = qtile + lyrtile soil(j)%ly(j1)%flat = latlyr + lyrtile soil(j)%ly(j1)%prk = soil(j)%ly(j1)%prk + sepday - if (latq(j) < 1.e-6) latq(j) = 0. + if (latq(j) < 1.e-6) latq(j) = 0. if (qtile < 1.e-6) qtile = 0. if (soil(j)%ly(j1)%flat < 1.e-6) soil(j)%ly(j1)%flat = 0. end do @@ -157,8 +157,8 @@ subroutine swr_percmain xx = (soil(j)%sw - soil(j)%sumfc) / (yy - soil(j)%sumfc) if (xx > 1.) xx = 1. wt_shall = xx * soil(j)%zmx - wat = soil(j)%zmx - wt_shall - if(wat > soil(j)%zmx) wat = soil(j)%zmx + wat = soil(j)%zmx - wt_shall + if(wat > soil(j)%zmx) wat = soil(j)%zmx end if else !compute water table depth using Daniel"s modifications @@ -167,12 +167,12 @@ subroutine swr_percmain sw_del = soil(j)%swpwt - soil(j)%sw wt_del = sw_del * soil(j)%ly(j1)%vwt soil(j)%wat_tbl = soil(j)%wat_tbl + wt_del - if(soil(j)%wat_tbl > soil(j)%zmx) soil(j)%wat_tbl = soil(j)%zmx - wt_shall = soil(j)%zmx - soil(j)%wat_tbl - soil(j)%swpwt = soil(j)%sw - exit - end if - end do + if(soil(j)%wat_tbl > soil(j)%zmx) soil(j)%wat_tbl = soil(j)%zmx + wt_shall = soil(j)%zmx - soil(j)%wat_tbl + soil(j)%swpwt = soil(j)%sw + exit + end if + end do end if !! drainmod wt_shall equations 10/23/2006 diff --git a/src/swr_percmicro.f90 b/src/swr_percmicro.f90 index 11f1fd4..714b437 100644 --- a/src/swr_percmicro.f90 +++ b/src/swr_percmicro.f90 @@ -92,10 +92,10 @@ subroutine swr_percmicro(ly1) sepday = Max(0., sepday) !! limit maximum seepage from biozone layer below potential perc amount - if(ly1 == i_sep(j).and.sep(isep)%opt ==1) then - sepday = min(sepday,sol_k_sep *24.) - bz_perc(j) = sepday - end if + if(ly1 == i_sep(j).and.sep(isep)%opt ==1) then + sepday = min(sepday,sol_k_sep *24.) + bz_perc(j) = sepday + end if !! switched to linear relationship for dep_imp and seepage if (ly1 == soil(j)%nly) then diff --git a/src/tiles_data_module.f90 b/src/tiles_data_module.f90 index d298177..3ee3fc7 100644 --- a/src/tiles_data_module.f90 +++ b/src/tiles_data_module.f90 @@ -7,7 +7,7 @@ module tiles_data_module real :: depth = 0. !! |mm |depth of drain tube from the soil surface real :: time = 0. !! |hrs |time to drain soil to field capacity real :: lag = 0. !! |hours |drain tile lag time - real :: radius =0. !! |mm effective radius of drains + real :: radius =0. !! |mm effective radius of drains real :: dist = 0. !! |mm |distance between two drain tubes or tiles real :: drain_co = 0. !! |mm/day |drainage coefficient real :: pumpcap = 0. !! |mm/hr |pump capacity (default pump capacity = 1.042mm/hr or 25mm/day) diff --git a/src/time_conc_init.f90 b/src/time_conc_init.f90 index 4488a4d..09e5784 100644 --- a/src/time_conc_init.f90 +++ b/src/time_conc_init.f90 @@ -69,7 +69,7 @@ subroutine time_conc_init !! compute fraction of surface runoff that is reaching the main channel if (time%step > 1) then brt(ihru) = 1.-Exp(-bsn_prm%surlag / (tconc(ihru) / & - (time%dtm / 60.))) !! urban modeling by J.Jeong + (time%dtm / 60.))) !! urban modeling by J.Jeong else brt(ihru) = 1. - Exp(-bsn_prm%surlag / tconc(ihru)) endif diff --git a/src/time_control.f90 b/src/time_control.f90 index c722016..623fccb 100644 --- a/src/time_control.f90 +++ b/src/time_control.f90 @@ -228,13 +228,18 @@ subroutine time_control call conditions (j, id) call actions (j, iob, id) end if - !! have to check every hru for land use change + !! check every hru for land use change if (upd_cond(iupd)%typ == "lu_change") then do j = 1, sp_ob%hru call conditions (j, id) call actions (j, iob, id) end do end if + !! change the land use that is specified + if (upd_cond(iupd)%typ == "lu_change1") then + call conditions (j, id) + call actions (j, iob, id) + end if !end if end do @@ -285,7 +290,7 @@ subroutine time_control if (sp_ob%hru > 0) then do iplt = 1, basin_plants crop_yld_t_ha = bsn_crop_yld(iplt)%yield / (bsn_crop_yld(iplt)%area_ha + 1.e-6) - write (5100,*) time%yrc, iplt, plants_bsn(iplt), bsn_crop_yld(iplt)%area_ha, & + write (5100,*) time%yrc, iplt, plts_bsn(iplt), bsn_crop_yld(iplt)%area_ha, & bsn_crop_yld(iplt)%yield, crop_yld_t_ha bsn_crop_yld_aa(iplt)%area_ha = bsn_crop_yld_aa(iplt)%area_ha + bsn_crop_yld(iplt)%area_ha bsn_crop_yld_aa(iplt)%yield = bsn_crop_yld_aa(iplt)%yield + bsn_crop_yld(iplt)%yield @@ -294,7 +299,7 @@ subroutine time_control crop_yld_t_ha = bsn_crop_yld_aa(iplt)%yield / (bsn_crop_yld_aa(iplt)%area_ha + 1.e-6) bsn_crop_yld_aa(iplt)%area_ha = bsn_crop_yld_aa(iplt)%area_ha / time%yrs_prt bsn_crop_yld_aa(iplt)%yield = bsn_crop_yld_aa(iplt)%yield / time%yrs_prt - write (5101,*) time%yrc, iplt, plants_bsn(iplt), bsn_crop_yld_aa(iplt)%area_ha, & + write (5101,*) time%yrc, iplt, plts_bsn(iplt), bsn_crop_yld_aa(iplt)%area_ha, & bsn_crop_yld_aa(iplt)%yield, crop_yld_t_ha bsn_crop_yld_aa(iplt) = bsn_crop_yld_z end if diff --git a/src/time_module.f90 b/src/time_module.f90 index 5d14317..e8f6df8 100644 --- a/src/time_module.f90 +++ b/src/time_module.f90 @@ -3,7 +3,7 @@ module time_module implicit none !integer :: int_print = 1 !! current interval between daily prints - character (len=25) :: cal_sim = " Original Simulation" + character (len=29) :: cal_sim = " Original Simulation" real :: cal_adj = 0.0 real :: yrs_print = 0. integer, dimension (13) :: ndays = (/0,31,60,91,121,152,182,213,244,274,305,335,366/) diff --git a/src/topography_data_module.f90 b/src/topography_data_module.f90 index d2f0e50..771080d 100644 --- a/src/topography_data_module.f90 +++ b/src/topography_data_module.f90 @@ -4,7 +4,7 @@ module topography_data_module type topography_db character(len=16) :: name = "default" - real :: slope = .02 !! hru_slp(:) |m/m |average slope steepness in HRU + real :: slope = .02 !! hru_slp(:) |m/m |average slope steepness in HRU real :: slope_len = 50. !! slsubbsn(:) |m |average slope length for erosion real :: lat_len = 50. !! slsoil(:) |m |slope length for lateral subsurface flow real :: dis_stream = 100. !! dis_stream(:) |m |average distance to stream diff --git a/src/varinit.f90 b/src/varinit.f90 index b0b340d..46c787e 100644 --- a/src/varinit.f90 +++ b/src/varinit.f90 @@ -120,10 +120,10 @@ subroutine varinit vpd = 0. voltot = 0. - !! urban modeling by J.Jeong - sedprev = 0. - ubnrunoff = 0. - irmmdt = 0. + !! urban modeling by J.Jeong + sedprev = 0. + ubnrunoff = 0. + irmmdt = 0. hhsedy = 0. ubntss = 0. wet_seep_day(j)%no3 = 0 diff --git a/src/wallo_demand.f90 b/src/wallo_demand.f90 index dfd40b6..633ee69 100644 --- a/src/wallo_demand.f90 +++ b/src/wallo_demand.f90 @@ -75,7 +75,11 @@ subroutine wallo_demand (iwallo, idmd) j = wallo(iwallo)%dmd(idmd)%ob_num !! if there is demand, use amount from water allocation file if (irrig(j)%demand > 0.) then + if (hru(j)%irr_hmax > 0.) then + wallod_out(iwallo)%dmd(idmd)%dmd_tot = irrig(j)%demand !m3 Irrigation demand based on paddy/wetland target ponding depth Jaehak 2023 + else wallod_out(iwallo)%dmd(idmd)%dmd_tot = wallo(iwallo)%dmd(idmd)%amount * hru(j)%area_ha * 10. !m3 = mm * ha * 10. + endif else wallod_out(iwallo)%dmd(idmd)%dmd_tot = 0. end if diff --git a/src/wallo_withdraw.f90 b/src/wallo_withdraw.f90 index 437230f..0ecc0d3 100644 --- a/src/wallo_withdraw.f90 +++ b/src/wallo_withdraw.f90 @@ -24,7 +24,7 @@ subroutine wallo_withdraw (iwallo, idmd, isrc) real :: avail = 0. !m3 |water available to withdraw from an aquifer real :: extracted = 0. !m3 |water extracted from the aquifer object (gwflow - rtb) real :: dmd_unmet = 0. !m3 |demand that is unmet (gwflow - rtb) - real :: hru_demand = 0. !m3 |demand (copy to pass into gwflow subroutine - rtb) + real :: hru_demand = 0. !m3 |demand (copy to pass into gwflow subroutine - rtb) real :: withdraw = 0. !m3 real :: unmet = 0. !m3 real :: total_dmd = 0. !m3 diff --git a/src/water_allocation_module.f90 b/src/water_allocation_module.f90 index da8ace1..0f8093f 100644 --- a/src/water_allocation_module.f90 +++ b/src/water_allocation_module.f90 @@ -103,29 +103,29 @@ module water_allocation_module type (water_allocation_output), dimension(:), allocatable :: walloa_out !dimension by demand objects type wallo_header - character(len=6) :: day = " jday" - character(len=6) :: mo = " mon" - character(len=6) :: day_mo = " day " - character(len=6) :: yrc = " yr " - character(len=8) :: idmd = " unit " - character(len=16) :: dmd_typ = "dmd_typ " - character(len=16) :: dmd_num = " dmd_num " - character(len=16) :: rcv_typ = "drcv_typ " - character(len=16) :: rcv_num = " rcv_num " + character(len=6) :: day = " jday" + character(len=6) :: mo = " mon" + character(len=6) :: day_mo = " day " + character(len=6) :: yrc = " yr " + character(len=8) :: idmd = " unit " + character(len=16) :: dmd_typ = "dmd_typ " + character(len=16) :: dmd_num = " dmd_num " + character(len=17) :: rcv_typ = "drcv_typ " + character(len=16) :: rcv_num = " rcv_num " character(len=12) :: src1_obj = " src1_obj " - character(len=12) :: src1_typ = " src1_typ " - character(len=12) :: src1_num = " src1_num " - character(len=15) :: dmd1 = " demand " !! ha-m |demand - muni or irrigation + character(len=12) :: src1_typ = " src1_typ " + character(len=12) :: src1_num = " src1_num " + character(len=15) :: dmd1 = " demand " !! ha-m |demand - muni or irrigation character(len=15) :: s1out = "src1_withdraw " !! ha-m |withdrawal from source 1 character(len=12) :: s1un = " src1_unmet" !! ha-m |unmet from source 1 - character(len=12) :: src2_typ = " src2_typ " - character(len=12) :: src2_num = " src2_num " - character(len=15) :: dmd2 = " demand " !! ha-m |demand - muni or irrigation + character(len=12) :: src2_typ = " src2_typ " + character(len=12) :: src2_num = " src2_num " + character(len=15) :: dmd2 = " demand " !! ha-m |demand - muni or irrigation character(len=15) :: s2out = "src2_withdraw " !! ha-m |withdrawal from source 2 character(len=12) :: s2un = " src2_unmet" !! ha-m |unmet from source 2 - character(len=12) :: src3_typ = " src3_typ " - character(len=12) :: src3_num = " src3_num " - character(len=15) :: dmd3 = " demand " !! ha-m |demand - muni or irrigation + character(len=12) :: src3_typ = " src3_typ " + character(len=12) :: src3_num = " src3_num " + character(len=15) :: dmd3 = " demand " !! ha-m |demand - muni or irrigation character(len=15) :: s3out = "src3_withdraw " !! ha-m |withdrawal from source 3 character(len=12) :: s3un = " src3_unmet" !! ha-m |unmet from source 3 @@ -133,31 +133,31 @@ module water_allocation_module type (wallo_header) :: wallo_hdr type wallo_header_units - character (len=8) :: day = " " - character (len=8) :: mo = " " - character (len=8) :: day_mo = " " - character (len=8) :: yrc = " " - character (len=8) :: idmd = " " - character (len=16) :: dmd_typ = " " - character (len=16) :: dmd_num = " " - character (len=16) :: rcv_typ = " " - character (len=16) :: rcv_num = " " + character (len=8) :: day = " " + character (len=8) :: mo = " " + character (len=8) :: day_mo = " " + character (len=8) :: yrc = " " + character (len=8) :: idmd = " " + character (len=16) :: dmd_typ = " " + character (len=16) :: dmd_num = " " + character (len=16) :: rcv_typ = " " + character (len=16) :: rcv_num = " " character (len=12) :: src1_obj = " " - character (len=12) :: src1_typ = " " - character (len=8) :: src1_num = " " + character (len=12) :: src1_typ = " " + character (len=8) :: src1_num = " " character (len=15) :: dmd1 = "m^3 " !! ha-m |demand - muni or irrigation - character (len=15) :: s1out = "m^3 " !! ha-m |withdrawal from source 1 + character (len=15) :: s1out = "m^3 " !! ha-m |withdrawal from source 1 character (len=9) :: s1un = "m^3 " !! ha-m |unmet from source 1 - character (len=15) :: src2_typ = " " - character (len=15) :: src2_num = " " + character (len=15) :: src2_typ = " " + character (len=15) :: src2_num = " " character (len=15) :: dmd2 = "m^3 " !! ha-m |demand - muni or irrigation - character (len=15) :: s2out = "m^3 " !! ha-m |withdrawal from source 2 - character (len=10) :: s2un = "m^3 " !! ha-m |unmet from source 2 - character (len=15) :: src3_typ = " " - character (len=15) :: src3_num = " " + character (len=15) :: s2out = "m^3 " !! ha-m |withdrawal from source 2 + character (len=15) :: s2un = "m^3 " !! ha-m |unmet from source 2 + character (len=15) :: src3_typ = " " + character (len=15) :: src3_num = " " character (len=15) :: dmd3 = "m^3 " !! ha-m |demand - muni or irrigation - character (len=15) :: s3out = "m^3 " !! ha-m |withdrawal from source 3 - character (len=10) :: s3un = "m^3 " !! ha-m |unmet from source 3 + character (len=15) :: s3out = "m^3 " !! ha-m |withdrawal from source 3 + character (len=15) :: s3un = "m^3 " !! ha-m |unmet from source 3 end type wallo_header_units type (wallo_header_units) :: wallo_hdr_units diff --git a/src/water_allocation_read.f90 b/src/water_allocation_read.f90 index 56a80a5..fd4b442 100644 --- a/src/water_allocation_read.f90 +++ b/src/water_allocation_read.f90 @@ -116,7 +116,7 @@ subroutine water_allocation_read allocate (walloy_out(iwro)%dmd(i)%src(num_objs)) allocate (walloa_out(iwro)%dmd(i)%src(num_objs)) - !! for hru irrigtion, need to xwalk with irrigation demand decision table + !! for hru irrigation, need to xwalk with irrigation demand decision table if (wallo(iwro)%dmd(i)%ob_typ == "hru") then !! xwalk with lum decision table do idb = 1, db_mx%dtbl_lum diff --git a/src/wet_cs.f90 b/src/wet_cs.f90 index 0b5258f..b959b7c 100644 --- a/src/wet_cs.f90 +++ b/src/wet_cs.f90 @@ -87,11 +87,11 @@ subroutine wet_cs(icmd, icon, ihru) !rtb cs !constituent mass settling to bottom of wetland if(ics == 1) then v_settle = res_cs_data(icon)%v_seo4 - elseif(ics == 2) then + elseif(ics == 2) then v_settle = res_cs_data(icon)%v_seo3 - elseif(ics == 3) then + elseif(ics == 3) then v_settle = res_cs_data(icon)%v_born - endif + endif cs_settle = (cs_conc_beg/1000.) * v_settle * (wet_wat_d(ihru)%area_ha*10000.) !kg if(cs_settle > mass_avail) then cs_settle = mass_avail !take remaining diff --git a/src/wet_initial.f90 b/src/wet_initial.f90 index 01d13b7..6d41cba 100644 --- a/src/wet_initial.f90 +++ b/src/wet_initial.f90 @@ -31,15 +31,14 @@ subroutine wet_initial (iihru) iweir = wet_ob(iihru)%iweir if (iprop > 0) then - ihyd = wet_dat(iprop)%hyd - !if (wet_hyd(ihyd)%k > 0.) then - hru(iihru)%wet_hc = wet_hyd(ihyd)%k !mm/hr + !if (wet_hyd(iihru)%k > 0.) then + hru(iihru)%wet_hc = wet_hyd(iihru)%k !mm/hr !else ! hru(iihru)%wet_hc = soil(iihru)%phys(1)%k !endif !! ha*mm*10. => m**3 - assume entire hru is wet and don't use fractional inputs (for simplicity) - wet_ob(iihru)%evol = hru(iihru)%area_ha * wet_hyd(iihru)%edep * 10. ! * wet_hyd(ihyd)%esa - wet_ob(iihru)%pvol = hru(iihru)%area_ha * wet_hyd(iihru)%pdep * 10. ! * wet_hyd(ihyd)%psa + wet_ob(iihru)%evol = hru(iihru)%area_ha * wet_hyd(iihru)%edep * 10. ! * wet_hyd(iihru)%esa + wet_ob(iihru)%pvol = hru(iihru)%area_ha * wet_hyd(iihru)%pdep * 10. ! * wet_hyd(iihru)%psa wet_ob(iihru)%psa = wet_hyd(iihru)%psa * hru(iihru)%area_ha wet_ob(iihru)%esa = wet_hyd(iihru)%esa * hru(iihru)%area_ha !! set initial weir height to principal depth - m @@ -47,7 +46,7 @@ subroutine wet_initial (iihru) wet_ob(iihru)%weir_hgt = res_weir(iweir)%h !m weir height wet_ob(iihru)%weir_wid = res_weir(iweir)%w !m, weir width !update pvol/evol according to weir height for paddy weir discharge. Jaehak 2023 - wet_ob(iihru)%pvol = hru(iihru)%area_ha * wet_ob(iihru)%weir_hgt * 10.**4 ! m3 + wet_ob(iihru)%pvol = hru(iihru)%area_ha * res_weir(iweir)%h * 10.**4 ! m3 if (wet_ob(iihru)%evol < wet_ob(iihru)%pvol*1.2) then wet_ob(iihru)%evol = wet_ob(iihru)%pvol * 1.2 endif @@ -111,16 +110,16 @@ subroutine wet_initial (iihru) !! wetland on hru - solve quadratic to find new depth wet_wat_d(iihru)%area_ha = 0. if (wet(iihru)%flo > 0.) then - x1 = wet_hyd(ihyd)%bcoef ** 2 + 4. * wet_hyd(ihyd)%ccoef * (1. - wet(iihru)%flo / wet_ob(iihru)%pvol) + x1 = wet_hyd(iihru)%bcoef ** 2 + 4. * wet_hyd(iihru)%ccoef * (1. - wet(iihru)%flo / wet_ob(iihru)%pvol) if (x1 < 1.e-6) then wet_h = 0. else - wet_h1 = (-wet_hyd(ihyd)%bcoef - sqrt(x1)) / (2. * wet_hyd(ihyd)%ccoef) - wet_h = wet_h1 + wet_hyd(ihyd)%bcoef + wet_h1 = (-wet_hyd(iihru)%bcoef - sqrt(x1)) / (2. * wet_hyd(iihru)%ccoef) + wet_h = wet_h1 + wet_hyd(iihru)%bcoef end if - wet_fr = (1. + wet_hyd(ihyd)%acoef * wet_h) + wet_fr = (1. + wet_hyd(iihru)%acoef * wet_h) wet_fr = min(wet_fr,1.) - wet_wat_d(iihru)%area_ha = hru(iihru)%area_ha * wet_hyd(ihyd)%psa * wet_fr + wet_wat_d(iihru)%area_ha = hru(iihru)%area_ha * wet_hyd(iihru)%psa * wet_fr end if end if diff --git a/src/wet_irrp.f90 b/src/wet_irrp.f90 index bb0e2c8..10c263a 100644 --- a/src/wet_irrp.f90 +++ b/src/wet_irrp.f90 @@ -9,6 +9,7 @@ subroutine wet_irrp() use aquifer_module use mgt_operations_module use hru_module, only : hru, ihru + use climate_module implicit none @@ -24,7 +25,7 @@ subroutine wet_irrp() wsa1 = hru(j)%area_ha * 10. !! store initial values - irrig(j)%demand = max(0., hru(j)%irr_hmax - wet_ob(j)%depth*1000.) * wsa1 !m3 + irrig(j)%demand = max(0., hru(j)%irr_hmax - wet_ob(j)%depth*1000. - w%precip) * wsa1 !m3 rto = 0. if (.not. allocated(ob(j)%ru)) then @@ -89,7 +90,8 @@ subroutine wet_irrp() if (aqu_d(isrc)%stor > 0.001) then rto = min(0.99, irrig(j)%demand / aqu_d(isrc)%stor) ! ratio of water removed from aquifer volume end if - irrig(j)%water%flo = rto * aqu_d(isrc)%flo ! organics in irrigation water + ! irrig(j)%water%flo = rto * aqu_d(isrc)%flo ! organics in irrigation water + irrig(j)%water%flo = rto * aqu_d(isrc)%stor ! organics in irrigation water Jaehak 2024 cs_irr(isrc) = rto * cs_aqu(isrc) ! constituents in irrigation water aqu_d(isrc)%stor = (1. - rto) * aqu_d(isrc)%stor ! remainder stays in aquifer cs_aqu(isrc) = (1. - rto) * cs_aqu(isrc) diff --git a/src/wet_read.f90 b/src/wet_read.f90 index 6ddbc4a..efc1c49 100644 --- a/src/wet_read.f90 +++ b/src/wet_read.f90 @@ -132,6 +132,8 @@ subroutine wet_read do ised = 1, db_mx%res_sed if (res_sed(ised)%name == wet_dat_c(isstor)%sed) then wet_prm(i)%sed = res_sed(ised) + !! d50 -micro meters + wet_prm(i)%sed_stlr_co = exp(-0.184 * wet_prm(i)%sed%d50) wet_dat(isstor)%sed = ised exit end if diff --git a/src/wetland_control.f90 b/src/wetland_control.f90 index a4a0e58..0c674f7 100644 --- a/src/wetland_control.f90 +++ b/src/wetland_control.f90 @@ -31,6 +31,8 @@ subroutine wetland_control integer :: ires = 0 integer :: j1 = 0 integer :: ii = 0 !none |sub daily time step counter + integer :: ihyd = 0 !none |counter !Jaehak 2024 + integer :: isched = 0 !none |counter !Jaehak 2024 real :: wet_fr = 0. real :: pvol_m3 = 0. real :: evol_m3 = 0. @@ -47,9 +49,12 @@ subroutine wetland_control real :: swst(20) = 0. j = ihru ires = hru(j)%dbs%surf_stor + ihyd = wet_dat(ires)%hyd ised = wet_dat(ires)%sed irel = wet_dat(ires)%release wsa1 = hru(j)%area_ha * 10. + isched = hru(j)%mgt_ops + wet_wat_d(j)%area_ha = hru(j)%area_ha !! zero outgoing flow ht2 = resz @@ -73,7 +78,7 @@ subroutine wetland_control !! add irrigation water to the paddy/wetland storage wet(j)%flo = wet(j)%flo + irrig(j)%applied * wsa1 !m3 - + wet(j)%no3 = wet(j)%no3 + irrig(j)%no3 * irrig(j)%applied * wsa1 * 0.001 !kg wet_wat_d(j)%area_ha = 0. if (wet(j)%flo > 0.) then !paddy is assumed flat !! update wetland surface area - solve quadratic to find new depth @@ -123,17 +128,21 @@ subroutine wetland_control swst(j1) = swst(j1) - volex !update soil water endif end do - + !update seepage volume wet_wat_d(j)%seep = max(0., wet_wat_d(j)%seep - volex * wsa1) !m3 - endif - + endif + wet(j)%flo = wet(j)%flo - wet_wat_d(j)%seep wet_wat_d(j)%area_ha = hru(j)%area_ha hru(j)%water_seep = wet_wat_d(j)%seep / wsa1 !mm=m3/(10*ha) ! calculate dissolved nutrient infiltration Jaehak 2022 - seep_rto = wet_wat_d(j)%seep / (wet_wat_d(j)%seep + wet(j)%flo) + if (wet_wat_d(j)%seep + wet(j)%flo > 0.01)then + seep_rto = wet_wat_d(j)%seep / (wet_wat_d(j)%seep + wet(j)%flo) + else + seep_rto = 0. + endif soil1(j)%mn(1)%no3 = soil1(j)%mn(1)%no3 + wet(j)%no3 * seep_rto / hru(j)%area_ha !kg/ha soil1(j)%mn(1)%nh4 = soil1(j)%mn(1)%nh4 + wet(j)%nh3 * seep_rto / hru(j)%area_ha !kg/ha soil1(j)%mp(1)%act = soil1(j)%mp(1)%act + wet(j)%solp * seep_rto / hru(j)%area_ha !kg/ha @@ -159,6 +168,8 @@ subroutine wetland_control !if (hru(j)%wet_fp == "n") then !! calc release from decision table d_tbl => dtbl_res(irel) + wbody => wet(j) + wbody_wb => wet_wat_d(j) pvol_m3 = wet_ob(j)%pvol evol_m3 = wet_ob(j)%evol !if (wet_ob(j)%area_ha > 1.e-6) then @@ -193,21 +204,22 @@ subroutine wetland_control end do end if - !end if wet_ob(j)%depth = wet(j)%flo / wsa1 / 1000. !m !! compute sediment deposition call res_sediment - !!! subtract sediment leaving from reservoir - !wet(j)%sed = wet(j)%sed - ht2%sed - !wet(j)%sil = wet(j)%sil - ht2%sil - !wet(j)%cla = wet(j)%cla - ht2%cla + wet(j)%sed = wbody%sed !t !! perform reservoir nutrient balance call res_nutrient (j) + wet(j)%no3 = wbody%no3 + wet(j)%nh3 = wbody%nh3 + wet(j)%orgn =wbody%orgn + wet(j)%sedp = wbody%sedp + wet(j)%solp = wbody%solp !! perform salt ion constituent balance call wet_salt(icmd,j) @@ -236,10 +248,6 @@ subroutine wetland_control - !write(100100,'(3(I6,","),11(f10.1,","))') time%yrc,time%mo,time%day_mo,w%precip,irrig(j)%applied,hru(j)%water_seep,& - ! weir_hgt*1000,wet(j)%flo/wsa1,ht2%flo/wsa1,soil(j)%sw,wet(j)%sed*1000,ht2%sed*1000,no3ppm,ht2%no3 - !write(*,'(3(I6),11(f10.1))') time%yrc,time%mo,time%day_mo,w%precip,irrig(j)%applied,hru(j)%water_seep,& - ! weir_hgt*1000,wet(j)%flo/wsa1,ht2%flo/wsa1,soil(j)%sw,wet(j)%sed*1000,ht2%sed*1000,wet(j)%no3,ht2%no3 !! perform reservoir pesticide transformations !call res_pest (ires) @@ -267,10 +275,8 @@ subroutine wetland_control !! set inflow and outflow variables for reservoir_output if (time%yrs > pco%nyskip) then - wet_in_d(j) = ht1 + wet_in_d(j) = wet_in_d(j) + ht1 wet_out_d(j) = ht2 - !wet_in_d(j)%flo = wet(j)%flo / 10000. !m^3 -> ha-m - !wet_out_d(j)%flo = wet(j)%flo / 10000. !m^3 -> ha-m end if return diff --git a/src/wetland_output.f90 b/src/wetland_output.f90 index e43828b..af92a79 100644 --- a/src/wetland_output.f90 +++ b/src/wetland_output.f90 @@ -90,6 +90,6 @@ subroutine wetland_output(j) return -100 format (4i6,2i10,2x,a,63e15.4) +100 format (4i6,2i10,2x,a,64e15.4) end subroutine wetland_output \ No newline at end of file