This program implements the approach detailed in:
Wernette, P., C. Houser, and M.P. Bishop. (2016) An automated approach for extracting barrier island morphology from digital elevation models. Geomorphology, 262(1), 1-7. http://doi.org/10.1016/j.geomorph.2016.02.024.
If compiling this program on a linux OS or unix OS, you do not need to include the ".exe" suffix at the end of the output program name and can compile the program using either of the following options:
g++ *.cpp -lm -O2 -o programname
g++ *.cpp -lm -O2 -static -o programname
If compiling this program on a Windows OS, make sure to include the ".exe" suffix at the end of the output program name. For example, programname.exe
.
g++ *.cpp -lm -O2 -o programname.exe
g++ *.cpp -lm -O2 -static -o programname.exe
Including the -static
flag during compilation will ensure that everything required for the program is wrapped into a single executable that can be moved from one computer to another and still function properly. If this flag is not included, then the resulting executable may not function properly or at all when moving computers.
NOTE: Compiling with relative_relief.cpp
will not work since data_structures.cpp is not also compiled in the process.
To run the program:
- Make sure you have successfully compiled the program. If you are on a Windows OS, you will need to specify the executable as a .exe file during compilation. Otherwise, with unix and linux systems, the ".exe" suffix is not required.
- Place a copy of the
params_rr.ini
file in the same directory on your local machine as the ENVI format rasters you wish to analyze. - Update the
params_rr.ini
file with the correct information (i.e. filename, initial kernel size, thresholds, desired output products and format, etc) for analysis. - Open a terminal window and mavigate to the directory with your .ini file and rasters.
- Run the executable you created when you compiled the program.
The program draws all input information (including input file name and thresholds) from the params_rr.ini
file. This .ini file includes the following information:
- iFile [default: rr_example]: The default input DEM file name (without file extension).
- iWindowSize [default: 21] Size of the kernel in picxels used to compute relative relief. Two additional scales of relative relief will also be computed by adding 2 to this user-specified window/kernel size.
- oProduct [default: all] Specify the output products
all
: Computes relative relief and all landform parameters.rr
: Compute the relative relief only. (ONLY OUTPUTS ENVI FORMAT RASTERS)landforms
: Writes out all landform metrics information.shoreline
: Writes out only the shoreline information.dunetoe
: Writes out only the dune toe information.dunecrest
: Writes out only the dune crest information.duneheel
: Writes out only the dune heel information.backbarrier
: Writes out only the backbarrier shoreline information.
- oFormat [default: both]: Output file format(s).
ascii
: Write out only ascii landform metrics.envi
: Only output ENVI format rasters.both
: Write ascii landform metrics AND ENVI format rasters.
- tShoreline [default: 0.2]: Elevation threshold used to define the shoreline position.
- tDT [default: 0.22]: Relative relief threshold used to define the dune toe position.
- tDC [default: 0.75]: Relative relief threshold used to define the dune crest position.
- tDH [default: 0.4]: Relative relief threshold used to define the dune heel position.
- tBB [default: 1.0]: Elevation threshold used to define the backbarrier shoreline position.
- tDuneDistMin [default: 15]: Minimum distance between the shoreline and dune toe.
- tDuneDistMax [default: 100]: Maximum distance between the shoreline and dune toe.
- tCrestDistMin [default: 1]: Minimum distance between the dune toe and dune crest.
- tCrestDistMax [default: 20]: Maximum distance between the dune toe and dune crest.
- tHeelDistMin [default: 1]: Minimum distance between the dune crest and dune heel.
- tHeelDistMax [default: 20]: Maximum distance between the dune crest and dune heel.
- transect_direction [default: W] Direction to extract landforms in. For example, "W" indicates that the program will start reading the raster from East to West in search of the shoreline, dune toe, dune crest, dune heel, and backbarrier shoreline (in that order). If 'rr' is specified in the
oProduct
field, then this option does not apply since no landform metrics are computed.
The default thresholds are as follows:
Shoreline: 0.02 masl
Dune Toe: 0.2 (relative relief value)
Dune Crest: 0.8 (relative relief value)
Dune Heel: 0.4 (relative relief value)
Backbarrier Shoreline: 1.0 masl
Any of the default values can be changed by altering the params_rr.ini
file that accompanies this program.
This program functions by (1) importing an ENVI format DEM (.dat and .h file), (2) computing relative relief across 3 spatial scales, and (3) (OPTIONAL) extracting beach, dune, and island landscape features, and computing landform morphometrics (i.e. height, width, volume) from these landscape features.
Relative relief (RR) of every pixel in the input DEM is first computed *using a 2D moving window*, where the window size is specified by the params_rr.ini
file.
The 2D window size will significant affect the ability to extract different landform morphometrics and subsequent landforms.
Landform morphometrics (i.e. dune toe, dune crest, dune heel, and all additional derivatives) are extracted along transects of the 2D computed relative relief values.
This program was developed by Phillipe Wernette as part of his PhD Thesis from 2017 ("Assessing the Role of Framework Geology on Barrier Island Geomorphology") and Geomorphology paper from 2016 (Wernette, P., C. Houser, and M.P. Bishop. (2016) An automated approach for extracting barrier island morphology from digital elevation models. Geomorphology, 262(1), 1-7. http://doi.org/10.1016/j.geomorph.2016.02.024.)
For questions related to this program, please contact:
Phil Wernette [email protected]