-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathrve_costdistance.py
83 lines (69 loc) · 2.87 KB
/
rve_costdistance.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
""" Title:
River valley bottom delineation using cost distance accumulation
Author:
Gasper Sechu (gasper.sechu@gmail.com)
Aarhus University, Denmark
"""
# Import modules
import arcpy
import os
from pathlib import Path
import datetime
from slope import slope
from valleycostdistance import valley
from costdistance import costdist
# Starting script
start = datetime.datetime.now()
print("Script started at %s" % start)
arcpy.AddMessage ("Script started started at %s" % start)
arcpy.AddMessage ("\n")
# Check out spatial extention
arcpy.CheckOutExtension("Spatial")
# Environments
arcpy.env.overwriteOutput = True
# Python inputs
#riv = r"Path" # river network as a shapefile
#cat = r"Path" # catchments as a shapefile
#dem = r"Path" # elevation model as a raster
#wet = r"Path" # measured valley bottom, wetlands or any wet signature in low areas as shapefile
#pth = r"Path" # path to output folder (scratch and cost distance folders)
#outval = r"Path" # path to output river valley bottom shapefile
# ArcGIS inputs
riv = arcpy.GetParameterAsText(0) # river network as a shapefile
cat = arcpy.GetParameterAsText(1) # catchments as a shapefile
dem = arcpy.GetParameterAsText(2) # elevation model as a raster
wet = arcpy.GetParameterAsText(3) # measured river valley
pth = arcpy.GetParameterAsText(4) # path to outputs (scratch and cost distance folders)
outval = arcpy.GetParameterAsText(5) # path to output river valley
# Check to see if scratch geodatabase exists
s = Path(os.path.join(pth, "outputs.gdb"))
if s.exists() == False:
scrg = arcpy.CreateFileGDB_management(pth, "outputs")
scr = scrg.getOutput(0) # scratch folder
else:
scr = os.path.join(pth, "outputs.gdb") #scr = r"in_memory" (if you want to store in memory)
# Check to see if cost dist folder exists (use code in comments if you want results in a folder instead of gdb)
c = Path(os.path.join(pth, "costdist.gdb")) # Path(os.path.join(pth, "costdist"))
if c.exists() == False:
cstg = arcpy.CreateFileGDB_management(pth, "costdist") # arcpy.CreateFolder_management(pth, "costdist")
cst = cstg.getOutput(0) # cost distance folder
else:
cst = os.path.join(pth, "costdist.gdb") # os.path.join(pth, "costdist")
# Calculate slope and replace 0 slopes with small value
slope(riv, cat, dem, scr)
# Cost distance calculation
costdist(riv, cat, os.path.join(scr, "con_slope"), cst, scr)
# Extract valley
valley(riv, wet, cst, scr, outval)
# Ending script
end = datetime.datetime.now()
print("Script ended at %s" % end)
arcpy.AddMessage ("Script ended at %s" % end)
arcpy.AddMessage ("\n")
time_elapsed = end - start
print("Time elapsed %s" % (time_elapsed))
arcpy.AddMessage ("Time elapsed %s" % time_elapsed)
arcpy.AddMessage ("\n")
print(".........................................................")
arcpy.AddMessage (".........................................................")
arcpy.AddMessage ("\n")