floodmodeller-api 0.4.2.post1__py3-none-any.whl → 0.4.4__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- floodmodeller_api/__init__.py +8 -9
- floodmodeller_api/_base.py +169 -176
- floodmodeller_api/backup.py +273 -273
- floodmodeller_api/dat.py +889 -831
- floodmodeller_api/diff.py +136 -119
- floodmodeller_api/ied.py +302 -306
- floodmodeller_api/ief.py +553 -637
- floodmodeller_api/ief_flags.py +253 -253
- floodmodeller_api/inp.py +260 -266
- floodmodeller_api/libs/libifcoremd.dll +0 -0
- floodmodeller_api/libs/libifcoremt.so.5 +0 -0
- floodmodeller_api/libs/libifport.so.5 +0 -0
- floodmodeller_api/{libmmd.dll → libs/libimf.so} +0 -0
- floodmodeller_api/libs/libintlc.so.5 +0 -0
- floodmodeller_api/libs/libmmd.dll +0 -0
- floodmodeller_api/libs/libsvml.so +0 -0
- floodmodeller_api/libs/libzzn_read.so +0 -0
- floodmodeller_api/libs/zzn_read.dll +0 -0
- floodmodeller_api/logs/__init__.py +2 -2
- floodmodeller_api/logs/lf.py +364 -312
- floodmodeller_api/logs/lf_helpers.py +354 -352
- floodmodeller_api/logs/lf_params.py +643 -529
- floodmodeller_api/mapping.py +84 -0
- floodmodeller_api/test/__init__.py +4 -4
- floodmodeller_api/test/conftest.py +16 -8
- floodmodeller_api/test/test_backup.py +117 -117
- floodmodeller_api/test/test_conveyance.py +107 -0
- floodmodeller_api/test/test_dat.py +222 -92
- floodmodeller_api/test/test_data/All Units 4_6.DAT +1081 -1081
- floodmodeller_api/test/test_data/All Units 4_6.feb +1081 -1081
- floodmodeller_api/test/test_data/BRIDGE.DAT +926 -926
- floodmodeller_api/test/test_data/Culvert_Inlet_Outlet.dat +36 -36
- floodmodeller_api/test/test_data/Culvert_Inlet_Outlet.feb +36 -36
- floodmodeller_api/test/test_data/DamBreakADI.xml +52 -52
- floodmodeller_api/test/test_data/DamBreakFAST.xml +58 -58
- floodmodeller_api/test/test_data/DamBreakFAST_dy.xml +53 -53
- floodmodeller_api/test/test_data/DamBreakTVD.xml +55 -55
- floodmodeller_api/test/test_data/DefenceBreach.xml +53 -53
- floodmodeller_api/test/test_data/DefenceBreachFAST.xml +60 -60
- floodmodeller_api/test/test_data/DefenceBreachFAST_dy.xml +55 -55
- floodmodeller_api/test/test_data/Domain1+2_QH.xml +76 -76
- floodmodeller_api/test/test_data/Domain1_H.xml +41 -41
- floodmodeller_api/test/test_data/Domain1_Q.xml +41 -41
- floodmodeller_api/test/test_data/Domain1_Q_FAST.xml +48 -48
- floodmodeller_api/test/test_data/Domain1_Q_FAST_dy.xml +48 -48
- floodmodeller_api/test/test_data/Domain1_Q_xml_expected.json +263 -0
- floodmodeller_api/test/test_data/Domain1_W.xml +41 -41
- floodmodeller_api/test/test_data/EX1.DAT +321 -321
- floodmodeller_api/test/test_data/EX1.ext +107 -107
- floodmodeller_api/test/test_data/EX1.feb +320 -320
- floodmodeller_api/test/test_data/EX1.gxy +107 -107
- floodmodeller_api/test/test_data/EX17.DAT +421 -422
- floodmodeller_api/test/test_data/EX17.ext +213 -213
- floodmodeller_api/test/test_data/EX17.feb +422 -422
- floodmodeller_api/test/test_data/EX18.DAT +375 -375
- floodmodeller_api/test/test_data/EX18_DAT_expected.json +3876 -0
- floodmodeller_api/test/test_data/EX2.DAT +302 -302
- floodmodeller_api/test/test_data/EX3.DAT +926 -926
- floodmodeller_api/test/test_data/EX3_DAT_expected.json +16235 -0
- floodmodeller_api/test/test_data/EX3_IEF_expected.json +61 -0
- floodmodeller_api/test/test_data/EX6.DAT +2084 -2084
- floodmodeller_api/test/test_data/EX6.ext +532 -532
- floodmodeller_api/test/test_data/EX6.feb +2084 -2084
- floodmodeller_api/test/test_data/EX6_DAT_expected.json +31647 -0
- floodmodeller_api/test/test_data/Event Data Example.DAT +336 -336
- floodmodeller_api/test/test_data/Event Data Example.ext +107 -107
- floodmodeller_api/test/test_data/Event Data Example.feb +336 -336
- floodmodeller_api/test/test_data/Linked1D2D.xml +52 -52
- floodmodeller_api/test/test_data/Linked1D2DFAST.xml +53 -53
- floodmodeller_api/test/test_data/Linked1D2DFAST_dy.xml +48 -48
- floodmodeller_api/test/test_data/Linked1D2D_xml_expected.json +313 -0
- floodmodeller_api/test/test_data/blockage.dat +50 -50
- floodmodeller_api/test/test_data/blockage.ext +45 -45
- floodmodeller_api/test/test_data/blockage.feb +9 -9
- floodmodeller_api/test/test_data/blockage.gxy +71 -71
- floodmodeller_api/test/test_data/conveyance_test.dat +165 -0
- floodmodeller_api/test/test_data/conveyance_test.feb +116 -0
- floodmodeller_api/test/test_data/conveyance_test.gxy +85 -0
- floodmodeller_api/test/test_data/defaultUnits.dat +127 -127
- floodmodeller_api/test/test_data/defaultUnits.ext +45 -45
- floodmodeller_api/test/test_data/defaultUnits.feb +9 -9
- floodmodeller_api/test/test_data/defaultUnits.fmpx +58 -58
- floodmodeller_api/test/test_data/defaultUnits.gxy +85 -85
- floodmodeller_api/test/test_data/ex3.ief +20 -20
- floodmodeller_api/test/test_data/ex3.lf1 +2800 -2800
- floodmodeller_api/test/test_data/ex4.DAT +1374 -1374
- floodmodeller_api/test/test_data/ex4_changed.DAT +1374 -1374
- floodmodeller_api/test/test_data/example1.inp +329 -329
- floodmodeller_api/test/test_data/example2.inp +158 -158
- floodmodeller_api/test/test_data/example3.inp +297 -297
- floodmodeller_api/test/test_data/example4.inp +388 -388
- floodmodeller_api/test/test_data/example5.inp +147 -147
- floodmodeller_api/test/test_data/example6.inp +154 -154
- floodmodeller_api/test/test_data/expected_conveyance.csv +60 -0
- floodmodeller_api/test/test_data/jump.dat +176 -176
- floodmodeller_api/test/test_data/network.dat +1374 -1374
- floodmodeller_api/test/test_data/network.ext +45 -45
- floodmodeller_api/test/test_data/network.exy +1 -1
- floodmodeller_api/test/test_data/network.feb +45 -45
- floodmodeller_api/test/test_data/network.ied +45 -45
- floodmodeller_api/test/test_data/network.ief +20 -20
- floodmodeller_api/test/test_data/network.inp +147 -147
- floodmodeller_api/test/test_data/network.pxy +57 -57
- floodmodeller_api/test/test_data/network.zzd +122 -122
- floodmodeller_api/test/test_data/network_dat_expected.json +21837 -0
- floodmodeller_api/test/test_data/network_from_tabularCSV.csv +87 -87
- floodmodeller_api/test/test_data/network_ied_expected.json +287 -0
- floodmodeller_api/test/test_data/rnweir.dat +9 -9
- floodmodeller_api/test/test_data/rnweir.ext +45 -45
- floodmodeller_api/test/test_data/rnweir.feb +9 -9
- floodmodeller_api/test/test_data/rnweir.gxy +45 -45
- floodmodeller_api/test/test_data/rnweir_default.dat +74 -74
- floodmodeller_api/test/test_data/rnweir_default.ext +45 -45
- floodmodeller_api/test/test_data/rnweir_default.feb +9 -9
- floodmodeller_api/test/test_data/rnweir_default.fmpx +58 -58
- floodmodeller_api/test/test_data/rnweir_default.gxy +53 -53
- floodmodeller_api/test/test_data/unit checks.dat +16 -16
- floodmodeller_api/test/test_ied.py +29 -29
- floodmodeller_api/test/test_ief.py +136 -24
- floodmodeller_api/test/test_inp.py +47 -48
- floodmodeller_api/test/test_json.py +114 -0
- floodmodeller_api/test/test_logs_lf.py +102 -51
- floodmodeller_api/test/test_tool.py +165 -152
- floodmodeller_api/test/test_toolbox_structure_log.py +234 -239
- floodmodeller_api/test/test_xml2d.py +151 -156
- floodmodeller_api/test/test_zzn.py +36 -34
- floodmodeller_api/to_from_json.py +230 -0
- floodmodeller_api/tool.py +332 -329
- floodmodeller_api/toolbox/__init__.py +5 -5
- floodmodeller_api/toolbox/example_tool.py +45 -45
- floodmodeller_api/toolbox/model_build/__init__.py +2 -2
- floodmodeller_api/toolbox/model_build/add_siltation_definition.py +100 -98
- floodmodeller_api/toolbox/model_build/structure_log/__init__.py +1 -1
- floodmodeller_api/toolbox/model_build/structure_log/structure_log.py +287 -289
- floodmodeller_api/toolbox/model_build/structure_log_definition.py +76 -76
- floodmodeller_api/units/__init__.py +10 -10
- floodmodeller_api/units/_base.py +214 -212
- floodmodeller_api/units/boundaries.py +467 -467
- floodmodeller_api/units/comment.py +52 -55
- floodmodeller_api/units/conduits.py +382 -402
- floodmodeller_api/units/conveyance.py +301 -0
- floodmodeller_api/units/helpers.py +123 -131
- floodmodeller_api/units/iic.py +107 -101
- floodmodeller_api/units/losses.py +305 -306
- floodmodeller_api/units/sections.py +465 -446
- floodmodeller_api/units/structures.py +1690 -1683
- floodmodeller_api/units/units.py +93 -104
- floodmodeller_api/units/unsupported.py +44 -44
- floodmodeller_api/units/variables.py +87 -89
- floodmodeller_api/urban1d/__init__.py +11 -11
- floodmodeller_api/urban1d/_base.py +188 -179
- floodmodeller_api/urban1d/conduits.py +93 -85
- floodmodeller_api/urban1d/general_parameters.py +58 -58
- floodmodeller_api/urban1d/junctions.py +81 -79
- floodmodeller_api/urban1d/losses.py +81 -74
- floodmodeller_api/urban1d/outfalls.py +114 -110
- floodmodeller_api/urban1d/raingauges.py +111 -111
- floodmodeller_api/urban1d/subsections.py +92 -98
- floodmodeller_api/urban1d/xsections.py +147 -144
- floodmodeller_api/util.py +119 -21
- floodmodeller_api/validation/parameters.py +660 -660
- floodmodeller_api/validation/urban_parameters.py +388 -404
- floodmodeller_api/validation/validation.py +110 -108
- floodmodeller_api/version.py +1 -1
- floodmodeller_api/xml2d.py +632 -673
- floodmodeller_api/xml2d_template.py +37 -37
- floodmodeller_api/zzn.py +414 -363
- {floodmodeller_api-0.4.2.post1.dist-info → floodmodeller_api-0.4.4.dist-info}/LICENSE.txt +13 -13
- {floodmodeller_api-0.4.2.post1.dist-info → floodmodeller_api-0.4.4.dist-info}/METADATA +85 -82
- floodmodeller_api-0.4.4.dist-info/RECORD +185 -0
- {floodmodeller_api-0.4.2.post1.dist-info → floodmodeller_api-0.4.4.dist-info}/WHEEL +1 -1
- floodmodeller_api/libifcoremd.dll +0 -0
- floodmodeller_api/test/test_data/EX3.bmp +0 -0
- floodmodeller_api/test/test_data/test_output.csv +0 -87
- floodmodeller_api/zzn_read.dll +0 -0
- floodmodeller_api-0.4.2.post1.dist-info/RECORD +0 -164
- {floodmodeller_api-0.4.2.post1.dist-info → floodmodeller_api-0.4.4.dist-info}/entry_points.txt +0 -0
- {floodmodeller_api-0.4.2.post1.dist-info → floodmodeller_api-0.4.4.dist-info}/top_level.txt +0 -0
|
@@ -1,289 +1,287 @@
|
|
|
1
|
-
import csv
|
|
2
|
-
|
|
3
|
-
from floodmodeller_api import DAT
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
class StructureLogBuilder:
|
|
7
|
-
def __init__(self, input_path, output_path) -> None:
|
|
8
|
-
self.dat_file_path = input_path
|
|
9
|
-
self.csv_output_path = output_path
|
|
10
|
-
|
|
11
|
-
def _add_fields(self):
|
|
12
|
-
field = [
|
|
13
|
-
"Unit Name",
|
|
14
|
-
"Unit Type",
|
|
15
|
-
"Unit Subtype",
|
|
16
|
-
"Comment",
|
|
17
|
-
"Friction",
|
|
18
|
-
"Dimensions (m)",
|
|
19
|
-
"Weir Coefficient",
|
|
20
|
-
"Culvert Inlet/Outlet Loss",
|
|
21
|
-
]
|
|
22
|
-
self._writer.writerow(field)
|
|
23
|
-
|
|
24
|
-
def _conduit_data(self, conduit):
|
|
25
|
-
length = 0.0
|
|
26
|
-
inlet = ""
|
|
27
|
-
outlet = ""
|
|
28
|
-
previous = self._dat.prev(conduit)
|
|
29
|
-
if hasattr(previous, "subtype"):
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
current_conduit
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
next_conduit
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
culvert_loss = f"Ki: {inlet}
|
|
46
|
-
elif
|
|
47
|
-
culvert_loss = f"
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
friction = f"Mannings: {mannings_set.pop()}"
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
conduit.
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
friction = f"Mannings: {mannings_set.pop()}"
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
conduit.
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
friction = f"Mannings: {mannings_set.pop()}"
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
height
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
friction =
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
conduit.
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
friction = f"Mannings: {mannings_set.pop()}"
|
|
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
|
-
conduit.
|
|
176
|
-
conduit.
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
dimensions
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
friction = f"Mannings: {mannings_set.pop()}"
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
elif structure._unit == "
|
|
227
|
-
dimensions = f"Crest Elevation: {structure.
|
|
228
|
-
elif structure._unit == "
|
|
229
|
-
dimensions = f"Crest Elevation: {structure.weir_elevation:.2f} x w: {structure.weir_breadth:.2f}
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
structure.
|
|
244
|
-
structure.
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
self.
|
|
284
|
-
|
|
285
|
-
self.
|
|
286
|
-
|
|
287
|
-
self.
|
|
288
|
-
|
|
289
|
-
self._add_structures()
|
|
1
|
+
import csv
|
|
2
|
+
|
|
3
|
+
from floodmodeller_api import DAT
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
class StructureLogBuilder:
|
|
7
|
+
def __init__(self, input_path, output_path) -> None:
|
|
8
|
+
self.dat_file_path = input_path
|
|
9
|
+
self.csv_output_path = output_path
|
|
10
|
+
|
|
11
|
+
def _add_fields(self):
|
|
12
|
+
field = [
|
|
13
|
+
"Unit Name",
|
|
14
|
+
"Unit Type",
|
|
15
|
+
"Unit Subtype",
|
|
16
|
+
"Comment",
|
|
17
|
+
"Friction",
|
|
18
|
+
"Dimensions (m)",
|
|
19
|
+
"Weir Coefficient",
|
|
20
|
+
"Culvert Inlet/Outlet Loss",
|
|
21
|
+
]
|
|
22
|
+
self._writer.writerow(field)
|
|
23
|
+
|
|
24
|
+
def _conduit_data(self, conduit):
|
|
25
|
+
length = 0.0
|
|
26
|
+
inlet = ""
|
|
27
|
+
outlet = ""
|
|
28
|
+
previous = self._dat.prev(conduit)
|
|
29
|
+
if hasattr(previous, "subtype") and previous.subtype == "INLET":
|
|
30
|
+
inlet = previous.ki
|
|
31
|
+
current_conduit = conduit
|
|
32
|
+
while current_conduit.dist_to_next != 0:
|
|
33
|
+
length += current_conduit.dist_to_next
|
|
34
|
+
current_conduit = self._dat.next(current_conduit)
|
|
35
|
+
next_conduit = self._dat.next(current_conduit)
|
|
36
|
+
if hasattr(next_conduit, "subtype") and next_conduit.subtype == "OUTLET":
|
|
37
|
+
outlet = next_conduit.loss_coefficient
|
|
38
|
+
return [length, inlet, outlet]
|
|
39
|
+
|
|
40
|
+
def _culvert_loss_data(self, inlet, outlet):
|
|
41
|
+
culvert_loss = ""
|
|
42
|
+
if inlet != "" and outlet != "":
|
|
43
|
+
culvert_loss = f"Ki: {inlet}, Ko: {outlet}"
|
|
44
|
+
elif inlet != "":
|
|
45
|
+
culvert_loss = f"Ki: {inlet}"
|
|
46
|
+
elif outlet != "":
|
|
47
|
+
culvert_loss = f"Ko: {outlet}"
|
|
48
|
+
return culvert_loss
|
|
49
|
+
|
|
50
|
+
def _circular_data(self, conduit, length):
|
|
51
|
+
dimensions = f"dia: {conduit.diameter:.2f} x l: {length:.2f}"
|
|
52
|
+
all_mannings = [
|
|
53
|
+
conduit.friction_above_axis,
|
|
54
|
+
conduit.friction_below_axis,
|
|
55
|
+
]
|
|
56
|
+
mannings_set = {min(all_mannings), max(all_mannings)}
|
|
57
|
+
if len(mannings_set) == 1:
|
|
58
|
+
friction = f"Mannings: {mannings_set.pop()}"
|
|
59
|
+
else:
|
|
60
|
+
friction = f"Mannings: [min: {mannings_set.pop()}, max: {mannings_set.pop()}]"
|
|
61
|
+
|
|
62
|
+
return [friction, dimensions]
|
|
63
|
+
|
|
64
|
+
def _sprungarch_data(self, conduit, length):
|
|
65
|
+
dimensions = f"(Springing: {conduit.height_crown:.2f}, Crown: {conduit.height_springing:.2f}) x w: {conduit.width:.2f} x l: {length:.2f}"
|
|
66
|
+
all_mannings = [
|
|
67
|
+
conduit.friction_on_invert,
|
|
68
|
+
conduit.friction_on_soffit,
|
|
69
|
+
conduit.friction_on_walls,
|
|
70
|
+
]
|
|
71
|
+
mannings_set = {min(all_mannings), max(all_mannings)}
|
|
72
|
+
if len(mannings_set) == 1:
|
|
73
|
+
friction = f"Mannings: {mannings_set.pop()}"
|
|
74
|
+
else:
|
|
75
|
+
friction = f"Mannings: [min: {mannings_set.pop()}, max: {mannings_set.pop()}]"
|
|
76
|
+
|
|
77
|
+
return [friction, dimensions]
|
|
78
|
+
|
|
79
|
+
def _rectangular_data(self, conduit, length):
|
|
80
|
+
dimensions = f"h: {conduit.height:.2f} x w: {conduit.width:.2f} x l: {length:.2f}"
|
|
81
|
+
all_mannings = [
|
|
82
|
+
conduit.friction_on_invert,
|
|
83
|
+
conduit.friction_on_soffit,
|
|
84
|
+
conduit.friction_on_walls,
|
|
85
|
+
]
|
|
86
|
+
mannings_set = {min(all_mannings), max(all_mannings)}
|
|
87
|
+
if len(mannings_set) == 1:
|
|
88
|
+
friction = f"Mannings: {mannings_set.pop()}"
|
|
89
|
+
else:
|
|
90
|
+
friction = f"Mannings: [min: {mannings_set.pop()}, max: {mannings_set.pop()}]"
|
|
91
|
+
|
|
92
|
+
return [friction, dimensions]
|
|
93
|
+
|
|
94
|
+
def _section_data(self, conduit, length):
|
|
95
|
+
x_list = conduit.coords.x.tolist()
|
|
96
|
+
width = (max(x_list) - min(x_list)) * 2
|
|
97
|
+
y_list = conduit.coords.y.tolist()
|
|
98
|
+
height = max(y_list) - min(y_list)
|
|
99
|
+
# currently this means that height goes to the top of the spike,
|
|
100
|
+
# it is only meant to go up to the height of the majority of the area
|
|
101
|
+
dimensions = f"h: {height:.2f} x w: {width:.2f} x l: {length:.2f}"
|
|
102
|
+
all_cw_frictions = conduit.coords.cw_friction.tolist()
|
|
103
|
+
cw_frictions_set = {min(all_cw_frictions), max(all_cw_frictions)}
|
|
104
|
+
if len(cw_frictions_set) == 1:
|
|
105
|
+
friction = f"Colebrook-White: {cw_frictions_set.pop()}"
|
|
106
|
+
else:
|
|
107
|
+
friction = (
|
|
108
|
+
f"Colebrook-White: [min: {cw_frictions_set.pop()}, max: {cw_frictions_set.pop()}]"
|
|
109
|
+
)
|
|
110
|
+
|
|
111
|
+
return [friction, dimensions]
|
|
112
|
+
|
|
113
|
+
def _sprung_data(self, conduit, length):
|
|
114
|
+
dimensions = f"(Springing: {conduit.height_crown:.2f}, Crown: {conduit.height_springing:.2f}) x w: {conduit.width:.2f} x l: {length:.2f}"
|
|
115
|
+
all_mannings = [
|
|
116
|
+
conduit.friction_on_invert,
|
|
117
|
+
conduit.friction_on_soffit,
|
|
118
|
+
conduit.friction_on_walls,
|
|
119
|
+
]
|
|
120
|
+
mannings_set = {min(all_mannings), max(all_mannings)}
|
|
121
|
+
if len(mannings_set) == 1:
|
|
122
|
+
friction = f"Mannings: {mannings_set.pop()}"
|
|
123
|
+
else:
|
|
124
|
+
friction = f"Mannings: [min: {mannings_set.pop()}, max: {mannings_set.pop()}]"
|
|
125
|
+
|
|
126
|
+
return [friction, dimensions]
|
|
127
|
+
|
|
128
|
+
def _add_conduits(self):
|
|
129
|
+
for conduit in self._dat.conduits.values():
|
|
130
|
+
if conduit.subtype not in [
|
|
131
|
+
"CIRCULAR",
|
|
132
|
+
"SPRUNGARCH",
|
|
133
|
+
"RECTANGULAR",
|
|
134
|
+
"SECTION",
|
|
135
|
+
"SPRUNG",
|
|
136
|
+
]:
|
|
137
|
+
print(f"Conduit subtype: {conduit.subtype} not currently supported")
|
|
138
|
+
self._write(conduit.name, conduit._unit, conduit.subtype)
|
|
139
|
+
continue
|
|
140
|
+
conduit_data = self._conduit_data(conduit)
|
|
141
|
+
length = conduit_data[0]
|
|
142
|
+
inlet = conduit_data[1]
|
|
143
|
+
outlet = conduit_data[2]
|
|
144
|
+
|
|
145
|
+
if length == 0:
|
|
146
|
+
continue
|
|
147
|
+
|
|
148
|
+
culvert_loss = self._culvert_loss_data(inlet, outlet)
|
|
149
|
+
friction = ""
|
|
150
|
+
dimensions = ""
|
|
151
|
+
if conduit.subtype == "CIRCULAR":
|
|
152
|
+
circular_data = self._circular_data(conduit, length)
|
|
153
|
+
friction = circular_data[0]
|
|
154
|
+
dimensions = circular_data[1]
|
|
155
|
+
elif conduit.subtype == "SPRUNGARCH":
|
|
156
|
+
sprungarch_data = self._sprungarch_data(conduit, length)
|
|
157
|
+
friction = sprungarch_data[0]
|
|
158
|
+
dimensions = sprungarch_data[1]
|
|
159
|
+
elif conduit.subtype == "RECTANGULAR":
|
|
160
|
+
rectangular_data = self._rectangular_data(conduit, length)
|
|
161
|
+
friction = rectangular_data[0]
|
|
162
|
+
dimensions = rectangular_data[1]
|
|
163
|
+
elif conduit.subtype == "SECTION":
|
|
164
|
+
section_data = self._section_data(conduit, length)
|
|
165
|
+
friction = section_data[0]
|
|
166
|
+
dimensions = section_data[1]
|
|
167
|
+
elif conduit.subtype == "SPRUNG":
|
|
168
|
+
sprung_data = self._sprung_data(conduit, length)
|
|
169
|
+
friction = sprung_data[0]
|
|
170
|
+
dimensions = sprung_data[1]
|
|
171
|
+
|
|
172
|
+
self._write(
|
|
173
|
+
conduit.name,
|
|
174
|
+
conduit._unit,
|
|
175
|
+
conduit.subtype,
|
|
176
|
+
conduit.comment,
|
|
177
|
+
friction,
|
|
178
|
+
dimensions,
|
|
179
|
+
"",
|
|
180
|
+
culvert_loss,
|
|
181
|
+
)
|
|
182
|
+
|
|
183
|
+
def _orifice_dimensions(self, structure):
|
|
184
|
+
if structure.shape == "RECTANGLE":
|
|
185
|
+
height = structure.soffit - structure.invert
|
|
186
|
+
width = structure.bore_area / height
|
|
187
|
+
dimensions = f"h: {height:.2f} x w: {width:.2f}"
|
|
188
|
+
elif structure.shape == "CIRCULAR":
|
|
189
|
+
diameter = structure.soffit - structure.invert
|
|
190
|
+
dimensions = f"dia: {diameter:.2f}"
|
|
191
|
+
return dimensions
|
|
192
|
+
|
|
193
|
+
def _spill_data(self, structure):
|
|
194
|
+
elevation = min(structure.data.Y.tolist())
|
|
195
|
+
x_list = structure.data.X.tolist()
|
|
196
|
+
width = max(x_list) - min(x_list)
|
|
197
|
+
dimensions = f"Elevation: {elevation:.2f} x w: {width:.2f}"
|
|
198
|
+
weir_coefficient = structure.weir_coefficient
|
|
199
|
+
return [dimensions, weir_coefficient]
|
|
200
|
+
|
|
201
|
+
def _bridge_data(self, structure):
|
|
202
|
+
all_mannings = structure.section_data["Mannings n"].tolist()
|
|
203
|
+
mannings_set = {min(all_mannings), max(all_mannings)}
|
|
204
|
+
if len(mannings_set) == 1:
|
|
205
|
+
friction = f"Mannings: {mannings_set.pop()}"
|
|
206
|
+
else:
|
|
207
|
+
friction = f"Mannings: [min: {mannings_set.pop()}, max: {mannings_set.pop()}]"
|
|
208
|
+
height = structure.opening_data.values[0][3] - min(structure.section_data.Y.tolist())
|
|
209
|
+
width = structure.opening_data.values[0][1] - structure.opening_data.values[0][0]
|
|
210
|
+
dimensions = f"h: {height:.2f} x w: {width:.2f}"
|
|
211
|
+
return [friction, dimensions]
|
|
212
|
+
|
|
213
|
+
def _add_structures(self):
|
|
214
|
+
for structure in self._dat.structures.values():
|
|
215
|
+
friction = ""
|
|
216
|
+
dimensions = ""
|
|
217
|
+
weir_coefficient = ""
|
|
218
|
+
if structure._unit == "ORIFICE":
|
|
219
|
+
dimensions = self._orifice_dimensions(structure)
|
|
220
|
+
elif structure._unit == "SPILL":
|
|
221
|
+
spill_data = self._spill_data(structure)
|
|
222
|
+
dimensions = spill_data[0]
|
|
223
|
+
weir_coefficient = spill_data[1]
|
|
224
|
+
elif structure._unit == "SLUICE":
|
|
225
|
+
dimensions = f"Crest Elevation: {structure.crest_elevation:.2f} x w: {structure.weir_breadth:.2f} x l: {structure.weir_length:.2f}"
|
|
226
|
+
elif structure._unit == "RNWEIR":
|
|
227
|
+
dimensions = f"Crest Elevation: {structure.weir_elevation:.2f} x w: {structure.weir_breadth:.2f} x l: {structure.weir_length:.2f}"
|
|
228
|
+
elif structure._unit == "WEIR":
|
|
229
|
+
dimensions = f"Crest Elevation: {structure.weir_elevation:.2f} x w: {structure.weir_breadth:.2f}"
|
|
230
|
+
# Need weir coefficient (the velocity attribute??)
|
|
231
|
+
elif structure._unit == "BRIDGE":
|
|
232
|
+
bridge_data = self._bridge_data(structure)
|
|
233
|
+
friction = bridge_data[0]
|
|
234
|
+
dimensions = bridge_data[1]
|
|
235
|
+
else:
|
|
236
|
+
print(f"Structure: {structure._unit} not currently supported in structure log")
|
|
237
|
+
self._write(structure.name, structure._unit, structure.subtype)
|
|
238
|
+
continue
|
|
239
|
+
|
|
240
|
+
self._write(
|
|
241
|
+
structure.name,
|
|
242
|
+
structure._unit,
|
|
243
|
+
structure.subtype,
|
|
244
|
+
structure.comment,
|
|
245
|
+
friction,
|
|
246
|
+
dimensions,
|
|
247
|
+
weir_coefficient,
|
|
248
|
+
"",
|
|
249
|
+
)
|
|
250
|
+
|
|
251
|
+
def _write( # noqa: PLR0913
|
|
252
|
+
self,
|
|
253
|
+
name,
|
|
254
|
+
unit,
|
|
255
|
+
subtype,
|
|
256
|
+
comment="",
|
|
257
|
+
friction="",
|
|
258
|
+
dimensions="",
|
|
259
|
+
weir_coefficient="",
|
|
260
|
+
culvert_loss="",
|
|
261
|
+
):
|
|
262
|
+
self._writer.writerow(
|
|
263
|
+
[
|
|
264
|
+
name,
|
|
265
|
+
unit,
|
|
266
|
+
subtype,
|
|
267
|
+
comment,
|
|
268
|
+
friction,
|
|
269
|
+
dimensions,
|
|
270
|
+
weir_coefficient,
|
|
271
|
+
culvert_loss,
|
|
272
|
+
],
|
|
273
|
+
)
|
|
274
|
+
|
|
275
|
+
def create(self):
|
|
276
|
+
# Read in the .dat file
|
|
277
|
+
self._dat = DAT(self.dat_file_path)
|
|
278
|
+
|
|
279
|
+
# Create a new .csv file
|
|
280
|
+
with open(self.csv_output_path, "w", newline="") as file:
|
|
281
|
+
self._writer = csv.writer(file)
|
|
282
|
+
|
|
283
|
+
self._add_fields()
|
|
284
|
+
|
|
285
|
+
self._add_conduits()
|
|
286
|
+
|
|
287
|
+
self._add_structures()
|