-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathLSDFloodplain.hpp
180 lines (154 loc) · 7.02 KB
/
LSDFloodplain.hpp
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
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
//beginning of the LSDFloodplain class
#ifndef LSDFloodplain_H
#define LSDFloodplain_H
#include <vector>
#include <string>
#include <algorithm>
#include "TNT/tnt.h"
#include "LSDFlowInfo.hpp"
#include "LSDRaster.hpp"
#include "LSDIndexRaster.hpp"
#include "LSDJunctionNetwork.hpp"
#include "LSDStatsTools.hpp"
using namespace std;
using namespace TNT;
///@brief Class to store information about floodplains and terraces...
class LSDFloodplain
{
public:
/// @brief create function
///
/// @details This populates the binary array and connected components array for the floodplain
/// given rasters of channel relief and slope and thresholds for both. Each pixel
/// must be below the slope and channel relief threshold to be classified as floodplain.
/// @author FJC
/// 18/10/16
LSDFloodplain(LSDRaster& ChannelRelief, LSDRaster& Slope, LSDJunctionNetwork& ChanNetwork, LSDFlowInfo& FlowInfo, float relief_threshold, float slope_threshold, int min_patch_size, int threshold_SO)
{ create(ChannelRelief, Slope, ChanNetwork, FlowInfo, relief_threshold, slope_threshold, min_patch_size, threshold_SO); }
/// @return Number of rows as an integer.
int get_NRows() const { return NRows; }
/// @return Number of columns as an integer.
int get_NCols() const { return NCols; }
/// @return Minimum X coordinate as an integer.
float get_XMinimum() const { return XMinimum; }
/// @return Minimum Y coordinate as an integer.
float get_YMinimum() const { return YMinimum; }
/// @return Data resolution as an integer.
float get_DataResolution() const { return DataResolution; }
/// @return No Data Value as an integer.
int get_NoDataValue() const { return NoDataValue; }
/// @return Georeferencing information
map<string,string> get_GeoReferencingStrings() const { return GeoReferencingStrings; }
/// @brief This function gets the elevation of the nearest channel reach to each patch
/// @details For each pixel this function finds the nearest channel to a patch greater than a
/// threshold stream order
/// @details Terraces - calculates the mean elevation of a reach defined by this
/// channel and gets the elevation of each pixel compared to this reach. Floodplains - gets the
/// elevation of the nearest channel pixel.
/// @param ChanNetwork LSDJunctionNetwork object
/// @param FlowInfo LSDFlow info object
/// @param ElevationRaster LSDRaster of elevations
/// @param DistFromOutlet LSDRaster of distance from outlet
/// @param threshold_SO threshold stream order
/// @param search_distance search distance for channel reach
/// @author FJC
/// @date 21/10/16
void Get_Relief_of_Nearest_Channel(LSDJunctionNetwork& ChanNetwork, LSDFlowInfo& FlowInfo, LSDRaster& ElevationRaster, LSDRaster& DistFromOutlet, int threshold_SO);
/// @brief This function gets the information about all the floodplain pixels connected to the main stem channel from a junction
/// @details Takes a junction number and generates the main stem channel from this point. THe information about each floodplain or terrace pixel is then calculated relative to the main channel.
/// @param junction_number junction number of interest
/// @param ChanNetwork LSDJunctionNetwork object
/// @param FlowInfo LSDFlow info object
/// @param DistFromOutlet LSDRaster of distances from the outlet
/// @param ElevationRaster LSDRaster of elevations
/// @author FJC
/// @date 26/10/16
void get_distance_upstream_along_main_stem(int junction_number, LSDJunctionNetwork& ChanNetwork, LSDFlowInfo& FlowInfo, LSDRaster& DistFromOutlet);
/// FUNCTIONS TO GENERATE RASTERS
/// @brief This function prints the connected components array to a raster
/// @return ConnectedComponents connected components raster
/// @author FJC
/// @date 20/10/16
LSDIndexRaster print_ConnectedComponents_to_Raster();
/// @brief This function prints a binary raster of floodplain locations
/// @return BinaryRaster binary raster
/// @author FJC
/// @date 24/11/16
LSDIndexRaster print_BinaryRaster();
/// @brief This function prints the channel relief compared to the main stem to a raster
/// @return ChannelRelief LSDRaster of channel relief
/// @author FJC
/// @date 18/10/16
LSDRaster print_ChannelRelief_to_Raster();
/// @brief This function prints the upstream distance compared of the nearest main stem to a raster
/// @return UpstreamDist LSDRaster of upstream distance
/// @author FJC
/// @date 19/10/16
LSDRaster print_UpstreamDistance_to_Raster();
/// @brief This function prints the flow lengths to the nearest main stem to a raster
/// @return Flow Lengths LSDRaster of flow length
/// @author FJC
/// @date 19/10/16
LSDRaster print_FlowLengths_to_Raster();
/// FUNCTIONS TO PRINT TEXT FILES
/// @brief This function prints the upstream distance and channel relief of the floodplain pixels
/// to a text file
/// @author FJC
/// @date 19/10/16
void print_ChannelRelief_to_File(string filename);
/// @brief This function prints the binned upstream distance and channel relief of all the CC
/// pixels to a text file.
/// @details The format is: mean_distance st_dev_distance st_err_distance mean_relief st_dev_relief st_err_relief
/// @author FJC
/// @date 20/10/16
void print_Binned_ChannelRelief_to_File(string filename, float& bin_width, float& bin_lower_limit, float& bin_threshold);
/// @brief This function returns the array of floodplain nodes
/// @author FJC
/// @date 03/05/17
Array2D<int> get_FloodplainArray() const { return FloodplainNodes_array; }
protected:
/// Number of rows
int NRows;
/// Number of columns
int NCols;
/// X minimum
float XMinimum;
/// Y minimum
float YMinimum;
/// Data resolution
float DataResolution;
/// No data value
int NoDataValue;
/// A map of strings for holding georeferencing information
map<string,string> GeoReferencingStrings;
/// Relief threshold
float relief_threshold;
/// Slope threshold
float slope_threshold;
/// The binary array of floodplain data
Array2D<int> BinaryArray;
/// The array of connected components
Array2D<int> ConnectedComponents_Array;
/// Array of nearest channel elevations
Array2D<float> NearestChannelElev_array;
/// Array of nearest channel node indices
Array2D<int> NearestChannelNode_array;
/// Array of relief to the nearest channel
Array2D<float> ChannelRelief_array;
/// Array of distance upstream of nearest channel
Array2D<float> UpstreamDist_array;
/// vectors to separate floodplain and terrace nodes
/// vector of floodplain nodes
vector<int> FloodplainNodes;
Array2D<int> FloodplainNodes_array;
/// Store information for a specified main stem junction
/// vector of nodes on the main stem
vector<int> MainStemNodes;
/// vector of distance upstream for every pixel connected to the main stem
vector<float> UpstreamDist;
/// vector of channel relief for every pixel connected to the main stem
vector<float> ChannelRelief;
private:
void create(LSDRaster& ChannelRelief, LSDRaster& Slope, LSDJunctionNetwork& ChanNetwork, LSDFlowInfo& FlowInfo, float relief_threshold, float slope_threshold, int min_patch_size, int threshold_SO);
};
#endif