forked from mheberger/delineator
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathconfig.py
126 lines (96 loc) · 5.17 KB
/
config.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
"""
Configuration / Settings for delineator.py
Edit this file carefully before running delineator.py
See README for more information about the options and for instructions
on how to download the input data for delineating watersheds in areas
outside of the sample data provided for Iceland.
"""
# Path to your CSV file with the watershed outlet data
OUTLETS_CSV = 'outlets_sample.csv'
# Set to True for "higher resolution" mode or False for "lower resolution."
HIGH_RES = True
# Directory containing the merged, basin-scale MERIT-Hydro flow direction rasters (.tif)
# Download from https://mghydro.com/watersheds/rasters
# For all paths, do not include a trailing slash.
MERIT_FDIR_DIR = "data/raster/flowdir_basins"
# Directory containing the merged, basin-scale MERIT-Hydro flow accumulation rasters (.tif)
# Download from https://mghydro.com/watersheds/rasters
MERIT_ACCUM_DIR = "data/raster/accum_basins"
# Set to True if you want the script to write status messages to the console
VERBOSE = True
# Set to True to make a bunch of plots of each watershed.
# (Just for debugging. Slows down the script a lot.)
PLOTS = True
# Folder where you have stored the Merit-BASINS catchment shapefiles.
# These files need to be downloaded from: https://www.reachhydro.org/home/params/merit-basins
HIGHRES_CATCHMENTS_DIR = "data/shp/merit_catchments"
# Location of simplified unit catchment boundaries vector data (shapefiles)
# Download from: https://mghydro.org/watersheds/share/catchments_simplified.zip
LOWRES_CATCHMENTS_DIR = "data/shp/catchments_simplified"
# Folder where you have stored the MERIT-Basins River flowline shapefiles
# Download from: https://www.reachhydro.org/home/params/merit-basins
RIVERS_DIR = "C:/Data/GIS/MERITBasins/rivers"
# Folder where the script will write the output GeoJSON files or shapefiles
OUTPUT_DIR = "output"
# The file extension will determine the types of geodata files the script creates.
# "gpkg" for GeoPackage (recommended)
# "geojson" for GeoJSON files
# "shp" for shapefile
# Use a blank string "" if you DO NOT want any geodata files (for example,
# you are only making the interactive map and don't need geodata).
# Other file formats are available;
# see: https://geopandas.org/en/stable/docs/user_guide/io.html#writing-spatial-data
OUTPUT_EXT = "gpkg"
# Set to True to ouput a summary of the delineation in OUTPUT.CSV
OUTPUT_CSV = True
# Directory to store Python pickle files. Because it can be slow for Python to
# read shapefiles and create a GeoDataFrame. Once you have done this once, you
# can save time in the future by storing the GeoDataFrame as a .pkl file.
# Enter a blank string, '' if you do NOT want the script to create .pkl files.
# Please note that these files can be large! (Up to around 1 GB for large basins.)
PICKLE_DIR = 'pkl'
# Threshold for watershed size in km² above which the script will revert to
# low-resolution mode
LOW_RES_THRESHOLD = 50000
# If the requested watershed outlet is not inside a catchment, how far away
# from the point should we look for the nearest catchment (in degrees). 0.025 recommended
SEARCH_DIST = 0
# Watersheds created with Merit-Hydro data tend to have many "donut holes"
# ranging from one or two pixels to much larger.
FILL = True
# If FILL = True, you many choose to to fill donut holes that are below a
# certain size. This is the number of pixels, on the 3 arcsecond grid.
# Set to 0 to fill ALL holes.
FILL_THRESHOLD = 100
# Simplify the watershed boundary? This will remove some vertices
# from the watershed boundary and output smaller files.
SIMPLIFY = False
# If SIMPLIFY is True, set SIMPLIFY_TOLERANCE to a value in decimal degrees.
SIMPLIFY_TOLERANCE = 0.0008
# Set to TRUE if you want the script to create a local web page where you
# can review the results.
MAKE_MAP = True
# Folder where the script should put the map files. (MAKE sure it exists!)
# The mapping routine will make _viewer.html and .js files for every watershed
MAP_FOLDER = "map"
# On the map, do you also want to include the rivers?
MAP_RIVERS = True
# On the web page map, if MAP_RIVERS is True, how many stream orders shall we display?
# I recommend 4 or less. More than this and the browser may not display all the rivers in a large watershed.
NUM_STREAM_ORDERS = 3
# Set to True to use the experimental match areas feature.
# You must include the field `area` in your outlets CSV file to use this feature (in km²)
MATCH_AREAS = False
# If you set MATCH_AREAS = True, how close of a match should the script look for?
# Enter 0.25 for 25%. If you set MATCH_AREAS to False you can ignore this parameter.
AREA_MATCHING_THRESHOLD = 0.25
# If you set MATCH_AREAS = True, how far away from the original outlet point should the script look
# for a river reach that is a better match in terms of upstream area?
# Units are decimal degrees (sorry, not a proper distance measurement, this feature could be improved!)
# 0.1° is about 11 km near the equator, and about 8 km near at a latitude of 45°
MAX_DIST = 0.075
# Threshold for number of upstream pixels that defines a stream
# These values worked will in my testing, but you might try changing if the
# outlet is not getting snapped to a river centerline properly
THRESHOLD_SINGLE = 500
THRESHOLD_MULTIPLE = 5000