An ArcGIS python toolbox and library for analyzing extent of flooding and damage to assets under varying sea level rise and storm surge scenarios.
- ArcGIS: the suite of proprietarty software application licensed by Esri. Includes the ArcMap and ArcCatalog applications.
- ArcGIS session: use of either ArcMap or ArcCatalog.
- prompt or terminal: the Windows interface to its command-line tools.
- Python: an open source, dynamic programming language that Esri bundles with ArcGIS.
- numpy: an open source numerical extension to python that provides the basis for must scientific libraries in python.
- arcpy: a proprietary Python-based interface to some of the geoprocessing functionality of ArcGIS.
- nose: an open source unit test runner for python.
- jupyter: an open source, programming language-agnostic suite tools aimed at facilitating reproducible scientific work. The name stands for "Julia", "Python", and "R", the names of three of the dominating scientific computing languages.
- git: A distributed version control software. See https://git-scm.com/ for more details.
An always current zipped archive of the tool can be downloaded here. Alternatively, you can simply clone this repository through git:
git clone https://github.com/Geosyntec/python-tidegates.git
This library requires the following python-packages to be installed on your system:
- Python 2.7
- arcpy
- numpy
All of these are bundled with modern ArcGIS installations. Additional libraries are required to run the test suite. See the section titled Running the test suite for more information.
This is a pure-python library, so installation from source (even on Windows) is not an issue.
After acquiring and unzipping the source-code in some fashion, open a command window, navigate into the directory, and execute pip install .
.
In total, that looks like this:
::opens new command prompt:: ...
Microsoft Windows [Version 6.3.9600]
(c) 2013 Microsoft Corporation. All rights reserved.
C:\Users\phobson
$ cd C:\Users\phobson\Downloads\python-tidegates-master
C:\Users\phobson\Downloads\python-tidegates-master
$ pip install .
Processing c:\users\phobson\downloads\python-tidegates-master
Building wheels for collected packages: tidegates
Running setup.py bdist_wheel for tidegates
Stored in directory: C:\Users\phobson\AppData\Local\pip\Cache\wheels\bc\1d\a3\fae5dffd5c58635786503464001432a9c5b8e8f5
de28171a77
Successfully built tidegates
Installing collected packages: tidegates
Successfully installed tidegates-0.1
The input data required to run the tool are the following:
- workspace - this is an Esri geodatabase or folder in which the analysis will take place
- DEM - this is a raster dataset of a digitial elevation model
- zones_of_influence - a polygon layer that delineates the zones of influence behind each tidegate of interest
- elevations - the water surface elevation (in feet) at the tidegates
- filename - an optional name of the outputfile where the results will be saved.
This repository contains a very small sample dataset that is used to:
- Run the test suite
- Provide a minimal demonstration of the toolbox
The code base that powers the GIS toolboxes is uses a code QC technique known as unit testing.
In this case, we rely on the python package nose
to find, collect, and execute all of the tests.
To install nose
, execute the following in a command window in any directory:
pip install nose
Aftwards, navigate back to the source directory and execute the nosetests
command.
That entire process looks like this.
Microsoft Windows [Version 6.3.9600]
(c) 2013 Microsoft Corporation. All rights reserved.
C:\Users\phobson
$ cd C:\Users\phobson\Downloads\python-tidegates-master
C:\Users\phobson\Downloads\python-tidegates-master
nosetests
........................................
----------------------------------------------------------------------
Ran 40 tests in 5.634s
Each dot above represents a test that pass.
Alternatively, you can use nosetests --verbose
and the name descriptive of each test will be printed to the terminal.
The main advantage of building python-tidegates
as a python library instead of simply an ArcGIS toolbox, is that it can be used outside of ArcGIS sessions.
One basic way would be to write your own python files, call it "my_analysis.py", and to run that file with:
> python my_analysis.py
As an example, the contents of "my_analysis.py" could be as simple as:
import tidegates
workspace = r"F:\phobson\Tidegates\python-tidegates\tidegates\testing"
dem = r"python-tidegates\tidegates\testing\test_dem.tif "
ZOI = r"python-tidegates\tidegates\testing\test_zones.shp "
col = "GeoID"
elev = 9.5
output = "test01.shp"
with tidegates.utils.WorkSpace(workspace), tidegates.utils.OverwriteState(True):
tidegates.flood_area(dem, ZOI, col, elev, filename=output, verbose=True)
Alternatively, you can use some of the jupyter notebook provided with the source code.
To install jupyter, execute pip install jupyter
in a terminal.
To launch the notebooks bundled with the source code, navigate to the directory and execute jupyter notebook
.
In a newly opened terminal, this looks like:
Microsoft Windows [Version 6.3.9600]
(c) 2013 Microsoft Corporation. All rights reserved.
C:\Users\phobson
$ cd C:\Users\phobson\Downloads\python-tidegates-master\notebooks
$ C:\Users\phobson\Downloads\python-tidegates-master\notebooks
jupyter notebook
...and then a browser window will pop up with a list of example notebooks to run. For best results, use jupyter in a modern browswer like Chrome or Firefox. Unexpected behavior sometimes occurs in Internet Explorer.
For more information on jupyter, see the official documentation
TDB
Released under a BSD license. See the LICENSE file for more informat.