module basin_module implicit none character(len=80) :: prog = "" real :: ban_precip_aa = 0. type basin_inputs character(len=25) :: name = "" real :: area_ls_ha = 0. real :: area_tot_ha = 0. end type basin_inputs type (basin_inputs) :: bsn type basin_control_codes !character(len=16) :: update !! pointer to basin updates in schedule.upd character(len=16) :: petfile =' pet.cli' !! potential et filename character(len=16) :: wwqfile = "" !! watershed stream water quality filename integer :: pet = 0 !! potential ET method code !! 0 = Priestley-Taylor !! 1 = Penman-Monteith !! 2 = Hargreaves method 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 !! peak rate method !! 0 = NRCS dimensionless hydrograph with PRF !! 1 = half hour rainfall intensity method integer :: rte = 0 !! water routing method !! 0 variable storage method !! 1 Muskingum method 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 !! not used integer :: cswat = 0 !! carbon code !! = 0 Static soil carbon (old mineralization routines) !! = 1 C-FARM one carbon pool model !! = 2 Century model integer :: lapse = 0 !! precip and temperature lapse rate control !! 0 = do not adjust for elevation !! 1 = adjust for elevation integer :: uhyd = 1 !! Unit hydrograph method: !! 0 = triangular UH !! 1 = gamma function UH integer :: sed_ch = 0 !! not used integer :: tdrn = 0 !! tile drainage eq code !! 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" !! 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 type basin_parms real :: evlai = 3.0 !! none |leaf area index at which no evap occurs real :: ffcb = 0. !! none |initial soil water cont expressed as a fraction of fc real :: surlag = 4.0 !! days |surface runoff lag time (days) real :: adj_pkr = 1.0 !! none |peak rate adjustment factor in the subbasin real :: prf = 484. !! peak rate factor for peak rate equation real :: spcon = 0.0 !! not used real :: spexp = 0.0 !! not used real :: cmn = 0.003 !! rate factor for mineralization on active org N - 0.0003 -> 0.003 real :: n_updis = 20.0 !! nitrogen uptake dist parm real :: p_updis = 20.0 !! phosphorus uptake dist parm real :: nperco = 0.10 !! nitrate perc coeff (0-1) !! 0 = conc of nitrate in surface runoff is zero !! 1 = perc has same conc of nitrate as surf runoff real :: pperco = 10.0 !! phos perc coeff (0-1) !! 0 = conc of sol P in surf runoff is zero !! 1 = percolate has some conc of sol P as surf runoff real :: phoskd = 175.0 !! phos soil partitioning coef real :: psp = 0.40 !! phos availability index real :: rsdco = 0.05 !! residue decomposition coeff real :: percop = 0.5 !! pestcide perc coeff (0-1) real :: msk_co1 = 0.75 !! calibration coeff to control impact of the storage !! time constant for the reach at bankfull depth real :: msk_co2 = 0.25 !! calibration coefficient used to control impact of the !! storage time constant for low flow (where low flow is when !! river is at 0.1 bankfull depth) upon the Km value calculated !! for the reach real :: msk_x = 0.20 !! weighting factor control relative importance of inflow rate !! and outflow rate in determining storage on reach real :: nperco_lchtile = .5 !! n concentration coeff for tile flow and leach from bottom layer real :: evrch = 0.60 !! reach evaporation adjustment factor real :: scoef = 1.0 !! channel storage coefficient (0-1) real :: cdn = 1.40 !! denitrification expoential rate coefficient real :: sdnco = 1.30 !! denitrification threshold frac of field cap real :: bact_swf = 0.15 !! frac of manure containing active colony forming units real :: tb_adj = 0. !! adjustment factor for subdaily unit hydrograph basetime real :: cn_froz = 0.000862 !! parameter for frozen soil adjustment on infiltraion/runoff real :: dorm_hr = -1. !! time threshold used to define dormant (hrs) real :: plaps = 0. !! mm/km |precipitation lapse rate: mm per km of elevation difference real :: tlaps = 6.5 !! deg C/km |temperature lapse rate: deg C per km of elevation difference real :: nfixmx = 20.0 !! max daily n-fixation (kg/ha) real :: decr_min = 0.01 !! minimum daily residue decay real :: rsd_covco = 0.75 !! residue cover factor for computing frac of cover real :: urb_init_abst = 1. !! maximum initial abstraction for urban areas when using Green and Ampt real :: petco_pmpt = 100.0 !! PET adjustment (%) for Penman-Montieth and Preiestly-Taylor methods real :: uhalpha = 1.0 !! alpha coeff for est unit hydrograph using gamma func real :: eros_spl = 0. !! coeff of splash erosion varing 0.9-3.1 real :: rill_mult = 0. !! rill erosion coefficient real :: eros_expo = 0. !! exponential coeffcient for overland flow real :: c_factor = 0. !! scaling parameter for cover and management factor for !! overland flow erosion real :: ch_d50 = 0. !! median particle diameter of main channel (mm) real :: co2 = 400. !! co2 concentration at start of simulation (ppm) integer :: day_lag_mx = 0 !! max days to lag hydrographs for hru, ru and channels !! non-draining soils integer :: igen = 5 !! random generator code: !! 0 = use default numbers !! 1 = generate new numbers in every simulation end type basin_parms type (basin_parms) :: bsn_prm type print_interval character(len=1) :: d = "n" character(len=1) :: m = "n" character(len=1) :: y = "n" character(len=1) :: a = "n" end type print_interval type basin_print_codes !! PRINT CODES: "avann" = average annual (always print....unless input is "null") !! "year" = yearly !! "mon" = monthly !! "day" = daily character (len=1) :: day_print = "n" character (len=1) :: day_print_over = "n" integer :: nyskip = 0 !! number of years to skip output summarization character (len=1) :: sw_init = "n" !! n=sw not initialized, y=sw intialized for output (when hit nyskip) ! DAILY START/END AND INTERVAL integer :: day_start = 0 !! julian day to start printing output integer :: day_end = 0 !! julian day to end printing output integer :: yrc_start = 0 !! calendar year to start printing output integer :: yrc_end = 0 !! calendar year to end printing output integer :: int_day = 1 !! interval between daily printing integer :: int_day_cur = 1 !! current day since last print ! AVE ANNUAL END YEARS integer :: aa_numint = 0 !! number of print intervals for ave annual output integer, dimension(:), allocatable :: aa_yrs !! end years for ave annual output ! SPECIAL OUTPUTS character(len=1) :: csvout = "n" !! code to print .csv files n=no print; y=print; character(len=1) :: carbout = "n" !! code to print carbon output; d = end of day; m = end of month; y = end of year; a = end of simulation; character(len=1) :: cdfout = "n" !! code to print netcdf (cdf) files n=no print; y=print; ! OTHER OUTPUTS !! nbs character(len=1) :: snutc = " n" !! not used - soils nutrients carbon output (default ave annual-d,m,y,a input) character(len=1) :: crop_yld = "a" !! crop yields - a=average annual; y=yearly; b=both annual and yearly; n=no print character(len=1) :: mgtout = "n" !! management output file (mgt.out) (default ave annual-d,m,y,a input) character(len=1) :: hydcon = "n" !! hydrograph connect output file (hydcon.out) character(len=1) :: fdcout = "n" !! flow duration curve output n=no print; avann=print; NOT ACTIVE ! BASIN type(print_interval) :: wb_bsn !! water balance BASIN output type(print_interval) :: nb_bsn !! nutrient balance BASIN output type(print_interval) :: ls_bsn !! losses BASIN output type(print_interval) :: pw_bsn !! plant weather BASIN output type(print_interval) :: aqu_bsn !! type(print_interval) :: res_bsn !! type(print_interval) :: chan_bsn !! type(print_interval) :: sd_chan_bsn !! type(print_interval) :: recall_bsn !! ! REGION type(print_interval) :: wb_reg !! water balance REGION output type(print_interval) :: nb_reg !! nutrient balance REGION output type(print_interval) :: ls_reg !! losses REGION output type(print_interval) :: pw_reg !! plant weather REGION output type(print_interval) :: aqu_reg !! type(print_interval) :: res_reg !! type(print_interval) :: sd_chan_reg !! type(print_interval) :: recall_reg !! type(print_interval) :: water_allo !! ! LSU type(print_interval) :: wb_lsu !! water balance LSU output type(print_interval) :: nb_lsu !! nutrient balance LSU output type(print_interval) :: ls_lsu !! losses LSU output type(print_interval) :: pw_lsu !! plant weather LSU output ! HRU type(print_interval) :: wb_hru !! water balance HRU output type(print_interval) :: nb_hru !! nutrient balance HRU output type(print_interval) :: ls_hru !! losses HRU output type(print_interval) :: pw_hru !! plant weather HRU output ! HRU-LTE type(print_interval) :: wb_sd !! water balance SWAT-DEG output type(print_interval) :: nb_sd !! nutrient balance SWAT-DEG output type(print_interval) :: ls_sd !! losses SWAT-DEG output type(print_interval) :: pw_sd !! plant weather SWAT-DEG output ! CHANNEL type(print_interval) :: chan !! channel output ! CHANNEL_LTE type(print_interval) :: sd_chan !! swat deg (lte) channel output ! AQUIFER type(print_interval) :: aqu !! aqufier output ! RESERVOIR type(print_interval) :: res !! reservoir output ! RECALL type(print_interval) :: recall !! recall output ! HYDIN AND HYDOUT type(print_interval) :: hyd !! hydin_output and hydout_output type(print_interval) :: ru type(print_interval) :: pest !! all constituents pesticide output files (hru, chan, res, basin_chan, basin_res, !! basin_ls ! SALT (rtb salt) type(print_interval) :: salt_basin !! salt output for the basin type(print_interval) :: salt_hru !! salt output for HRUs type(print_interval) :: salt_ru !! salt output for routing units type(print_interval) :: salt_aqu !! salt output for aquifers type(print_interval) :: salt_chn !! salt output for channels type(print_interval) :: salt_res !! salt output for reservoirs type(print_interval) :: salt_wet !! salt output for reservoirs ! CONSTITUENTS (rtb cs) type(print_interval) :: cs_basin !! constituent output for the basin type(print_interval) :: cs_hru !! constituent output for HRUs type(print_interval) :: cs_ru !! constituent output for routing units type(print_interval) :: cs_aqu !! constituent output for aquifers type(print_interval) :: cs_chn !! constituent output for channels type(print_interval) :: cs_res !! constituent output for reservoirs type(print_interval) :: cs_wet !! constituent output for reservoirs end type basin_print_codes type (basin_print_codes) :: pco type (basin_print_codes) :: pco_init type mgt_header character (len=12) :: hru = " hru" character (len=12) :: year = " year" character (len=12) :: mon = " mon" character (len=11) :: day = " day" character (len=15) :: crop = " crop/fert/pest" character (len=12) :: oper = " operation" character (len=12) :: phub = "phubase" character (len=11) :: phua = " phuplant" character (len=12) :: sw = " soil_water" character (len=17) :: bio = " plant_bioms" character (len=11) :: rsd = " surf_rsd" character (len=15) :: solno3 = " soil_no3" character (len=15) :: solp = " soil_solp" character (len=15) :: op_var = " op_var" character (len=15) :: var1 = " var1" character (len=14) :: var2 = " var2" character (len=17) :: var3 = " var3" character (len=17) :: var4 = " var4" character (len=16) :: var5 = " var5" character (len=16) :: var6 = " var6" character (len=16) :: var7 = " var7" end type mgt_header type (mgt_header) :: mgt_hdr type mgt_header_unit1 character (len=12) :: hru = " --- " character (len=12) :: year = " --- " character (len=12) :: mon = " --- " character (len=12) :: day = " --- " character (len=11) :: crop = " --- " character (len=13) :: oper = " --- " character (len=9) :: phub = " deg_c" character (len=16) :: phua = " deg_c" character (len=12) :: sw = " mm" character (len=17) :: bio = " kg/ha" character (len=11) :: rsd = " kg/ha" character (len=15) :: solno3 = " kg/ha" character (len=15) :: solp = " kg/ha" character (len=15) :: op_var = " --- " character (len=16) :: var1 = " --- " character (len=15) :: var2 = " --- " character (len=16) :: var3 = " ---" character (len=16) :: var4 = " ---" character (len=16) :: var5 = " ---" character (len=16) :: var6 = " ---" character (len=15) :: var7 = " ---" end type mgt_header_unit1 type(mgt_header_unit1) :: mgt_hdr_unt1 ! type snutc_header ! character (len=12) :: day = " jday" ! character (len=12) :: mo = " mon" ! character (len=12) :: day_mo = " day" ! character (len=12) :: yrc = " yr" ! character (len=12) :: isd = " hru" ! character (len=12) :: id = " gis_id" ! character (len=12) :: name = " name " ! character (len=16) :: soil_mn = " soil_mn" ! character (len=16) :: soil_mp = " soil_mp" ! character (len=16) :: soil_orgc = " soil_orgc" ! character (len=16) :: soil_orgn = " soil_orgn" ! character (len=16) :: soil_orgp = " soil_orgp" ! character (len=16) :: pl_orgc = " pl_orgc" ! character (len=16) :: pl_orgn = " pl_orgn" ! character (len=16) :: pl_orgp = " pl_orgp" ! character (len=16) :: res_orgc = " res_orgc" ! character (len=16) :: res_orgn = " res_orgn" ! character (len=16) :: res_orgp = " res_orgp" ! end type snutc_header ! type(snutc_header) :: snutc_hdr ! type snutc_header_unit ! character (len=12) :: day = " " ! character (len=12) :: mo = " " ! character (len=12) :: day_mo= " " ! character (len=12) :: yrc = " " ! character (len=12) :: isd = " " ! character (len=12) :: id = " " ! character (len=12) :: name = " " ! character (len=16) :: soil_mn = " kg/ha" ! character (len=16) :: soil_mp = " kg/ha" ! character (len=16) :: soil_orgc = " kg/ha" ! character (len=16) :: soil_orgn = " kg/ha" ! character (len=16) :: soil_orgp = " kg/ha" ! character (len=16) :: pl_orgc = " kg/ha" ! character (len=16) :: pl_orgn = " kg/ha" ! character (len=16) :: pl_orgp = " kg/ha" ! character (len=16) :: res_orgc = " kg/ha" ! character (len=16) :: res_orgn = " kg/ha" ! character (len=16) :: res_orgp = " kg/ha" ! end type snutc_header_unit ! type(snutc_header_unit) :: snutc_hdr_unit !type snutc_old_header ! character (len=12) :: day = " day" ! character (len=12) :: year = " year" ! character (len=12) :: hru = " hru" ! character (len=14) :: soil_mn_no3 = " soil_mn_no3 " ! character (len=16) :: soil_mn_nh4 = " soil_mn_nh4 " ! character (len=14) :: soil_mp_wsol = " soil_mp_wsol" ! character (len=13) :: soil_mp_lab = " soil_mp_lab" ! character (len=13 ) :: soil_mp_act = " soil_mp_act" ! character (len=15) :: soil_mp_sta = " soil_mp_sta" ! character (len=19) :: soil_tot_m = " soil_tot_m" ! character (len=14) :: soil_tot_c = " soil_tot_c " ! character (len=14) :: soil_tot_n = " soil_tot_n " ! character (len=15) :: soil_tot_p = " soil_tot_p " ! character (len=18) :: soil_str_m = " soil_str_m " ! character (len=14) :: soil_str_c = " soil_str_c " ! character (len=14) :: soil_str_n = " soil_str_n " ! character (len=14) :: soil_str_p = " soil_str_p" ! character (len=16) :: soil_lig_m = " soil_lig_m " ! character (len=14) :: soil_lig_c = " soil_lig_c " ! character (len=14) :: soil_lig_n = " soil_lig_n " ! character (len=14) :: soil_lig_p = " soil_lig_p " ! character (len=14) :: soil_meta_m = " soil_meta_m " ! character (len=14) :: soil_meta_c = " soil_meta_c " ! character (len=14) :: soil_meta_n = " soil_meta_n " ! character (len=14) :: soil_meat_p = " soil_meta_p " ! character (len=14) :: soil_man_m = " soil_man_m " ! character (len=14) :: soil_man_c = " soil_man_c " ! character (len=14) :: soil_man_n = " soil_man_n " ! character (len=14) :: soil_man_p = " soil_man_p " ! character (len=14) :: soil_hs_m = " soil_hs_m " ! character (len=14) :: soil_hs_c = " soil_hs_c " ! character (len=16) :: soil_hs_n = " soil_hs_n " ! character (len=16) :: soil_hs_p = " soil_hs_p " ! character (len=16) :: soil_hp_m = " soil_hp_m " ! character (len=16) :: soil_hp_c = " soil_hp_c " ! character (len=16) :: soil_hp_n = " soil_hp_n " ! character (len=16) :: soil_hp_p = " soil_hp_p " ! character (len=16) :: soil_microb_m = " soil_microb_m " ! character (len=16) :: soil_microb_c = " soil_microb_c " ! character (len=16) :: soil_microb_n = " soil_microb_n " ! character (len=16) :: soil_microb_p =" soil_microb_p " ! character (len=16) :: soil_water_m = " soil_water_m " ! character (len=16) :: soil_water_c = " soil_water_c " ! character (len=16) :: soil_water_n = " soil_water_n " ! character (len=16) :: soil_water_p = " soil_water_p " ! end type snutc_old_header ! type(snutc_old_header) :: snutc_old_hdr type basin_yld_header character (len=11) :: year = " year " character (len=16) :: plant_no = " plant_no" character (len=16) :: plant_name = "plant_name " 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 end module basin_module