From 8e3a1717bdc30a111ab652809b90766d7f6ca308 Mon Sep 17 00:00:00 2001 From: karosc Date: Mon, 27 Mar 2023 13:16:02 -0400 Subject: [PATCH] add initial inlet control api functions --- src/solver/include/toolkit.h | 30 ++ src/solver/include/toolkit_enums.h | 16 + src/solver/include/toolkit_error.h | 1 + src/solver/include/toolkit_errors.txt | 1 + src/solver/inlet.c | 33 +- src/solver/inlet.h | 35 ++ src/solver/toolkit.c | 142 +++++++ tests/solver/CMakeLists.txt | 1 + tests/solver/data/test_inlet_drains.inp | 502 ++++++++++++++++++++++++ tests/solver/test_inlets_and_drains.cpp | 120 ++++++ tests/solver/test_solver.hpp | 13 + 11 files changed, 862 insertions(+), 32 deletions(-) create mode 100644 tests/solver/data/test_inlet_drains.inp create mode 100644 tests/solver/test_inlets_and_drains.cpp diff --git a/src/solver/include/toolkit.h b/src/solver/include/toolkit.h index ad2bdcdeb..339dbd09a 100644 --- a/src/solver/include/toolkit.h +++ b/src/solver/include/toolkit.h @@ -25,6 +25,7 @@ #include "../enums.h" #include "../datetime.h" #include "../lid.h" +#include "../inlet.h" #ifdef __cplusplus extern "C" { @@ -312,6 +313,24 @@ EXPORT_TOOLKIT int swmm_getLinkParam(int index, SM_LinkProperty param, double *v */ EXPORT_TOOLKIT int swmm_setLinkParam(int index, SM_LinkProperty param, double value); +/** + @brief Get a property value for the inlets of a specified link. + @param index The index of a link + @param Param The property type code (See @ref SM_InletProperty) + @param[out] value The value of the inlet's property + @return Error code +*/ +EXPORT_TOOLKIT int swmm_getInletParam(int index, SM_InletProperty param, double *value); + +/** + @brief Set a property value for the inlets of a specified link. + @param index The index of a link + @param Param The property type code (See @ref SM_InletProperty) + @param value The new value of the inlet's property + @return Error code +*/ +EXPORT_TOOLKIT int swmm_setInletParam(int index, SM_InletProperty param, double value); + /** @brief Get a property value for specified subcatchment. @param index The index of a subcatchment @@ -421,6 +440,17 @@ EXPORT_TOOLKIT int swmm_setLinkPollut(int index, SM_LinkPollut type, int polluta */ EXPORT_TOOLKIT int swmm_getLinkResult(int index, SM_LinkResult type, double *result); +/** + @brief Gets results for the inlets of a specified link. + @param index The index of a link with inlets + @param type The result type code (See @ref SM_InletResult) + @param result Pollutant index to set + @param[out] result The result of the inlet's property + @return Error code +*/ +EXPORT_TOOLKIT int swmm_getInletResult(int index, SM_InletResult type, double *result); + + /** @brief Gets pollutant values for a specified link. @param index The index of a link diff --git a/src/solver/include/toolkit_enums.h b/src/solver/include/toolkit_enums.h index 9b54f7b2d..651743b37 100644 --- a/src/solver/include/toolkit_enums.h +++ b/src/solver/include/toolkit_enums.h @@ -275,5 +275,21 @@ typedef enum { SM_STORAGEDRAIN = 29, /**< Underdrain flow rate layer */ } SM_LidResult; +typedef enum { + SM_INLETNUMINLETS = 0, + SM_INLETCLOGFACTOR = 1, + SM_INLETFLOWLIMIT = 2, + SM_INLETLOCALDEPRESS = 3, + SM_INLETLOCALWIDTH = 4 +} SM_InletProperty; + +typedef enum { + SM_INLETFLOWFACTOR = 0, + SM_INLETFLOWCAPTURE = 1, + SM_INLETBACKFLOW = 2, + SM_INLETBACKFLOWRATIO = 3, + +} SM_InletResult; + #endif /* TOOLKIT_ENUMS_H_ */ diff --git a/src/solver/include/toolkit_error.h b/src/solver/include/toolkit_error.h index 2081edefd..3f58128ec 100644 --- a/src/solver/include/toolkit_error.h +++ b/src/solver/include/toolkit_error.h @@ -13,6 +13,7 @@ enum ToolkitErrorType { ERR_TKAPI_LIDUNIT_INDEX = 2009, ERR_TKAPI_UNDEFINED_LID = 2010, ERR_TKAPI_MEMORY = 2011, + ERR_TKAPI_NO_INLET = 2012, TKMAXERRMSG = 3000 }; diff --git a/src/solver/include/toolkit_errors.txt b/src/solver/include/toolkit_errors.txt index 3a5b9782e..4a9dd1f8e 100644 --- a/src/solver/include/toolkit_errors.txt +++ b/src/solver/include/toolkit_errors.txt @@ -12,3 +12,4 @@ ERR(2008, "\n API Key Error: Invalid Pattern Index") ERR(2009, "\n API Key Error: Invalid Lid Unit Index") ERR(2010, "\n API Key Error: Undefined Subcatchment Lid") ERR(2011, "\n API Key Error: No memory allocated for return value") +ERR(2012, "\n API Key Error: Specified link is not assigned an inlet") diff --git a/src/solver/inlet.c b/src/solver/inlet.c index 4defe127e..c44ae9fcb 100644 --- a/src/solver/inlet.c +++ b/src/solver/inlet.c @@ -70,38 +70,7 @@ typedef struct } TInletDesign; -// Inlet performance statistics -typedef struct -{ - int flowPeriods; // # periods with approach flow - int capturePeriods; // # periods with captured flow - int backflowPeriods; // # periods with backflow - double peakFlow; // peak flow seen by inlet (cfs) - double peakFlowCapture; // capture efficiency at peak flow - double avgFlowCapture; // average capture efficiency - double bypassFreq; // frequency of bypass flow -} TInletStats; - -// Inlet list object -struct TInlet -{ - int linkIndex; // index of conduit link with the inlet - int designIndex; // index of inlet's design - int nodeIndex; // index of node receiving captured flow - int numInlets; // # inlets on each side of street or in channel - int placement; // whether inlet is on-grade or on-sag - double clogFactor; // fractional degree of inlet clogging - double flowLimit; // inlet flow restriction (cfs) - double localDepress; // local gutter depression (ft) - double localWidth; // local depression width (ft) - - double flowFactor; // flow = flowFactor * (flow spread)^2.67 - double flowCapture; // captured flow rate (cfs) - double backflow; // backflow from capture node (cfs) - double backflowRatio; // inlet backflow / capture node overflow - TInletStats stats; // inlet performance statistics - TInlet * nextInlet; // next inlet in list -}; +// OWA EDIT - TInlet and TInletStats struct defs moved to inlet.h to be shared by toolkit.c // Shared inlet variables TInletDesign * InletDesigns; // array of available inlet designs diff --git a/src/solver/inlet.h b/src/solver/inlet.h index ca7830725..52b6dcb54 100644 --- a/src/solver/inlet.h +++ b/src/solver/inlet.h @@ -27,4 +27,39 @@ void inlet_adjustQualOutflows(); void inlet_writeStatsReport(); double inlet_capturedFlow(int link); +// OWA EDIT ################################################################################## +// TInlet and TInletStats struct defs moved to inlet.h to be shared by toolkit.c +typedef struct +{ + int flowPeriods; // # periods with approach flow + int capturePeriods; // # periods with captured flow + int backflowPeriods; // # periods with backflow + double peakFlow; // peak flow seen by inlet (cfs) + double peakFlowCapture; // capture efficiency at peak flow + double avgFlowCapture; // average capture efficiency + double bypassFreq; // frequency of bypass flow +} TInletStats; + +// Inlet list object +struct TInlet +{ + int linkIndex; // index of conduit link with the inlet + int designIndex; // index of inlet's design + int nodeIndex; // index of node receiving captured flow + int numInlets; // # inlets on each side of street or in channel + int placement; // whether inlet is on-grade or on-sag + double clogFactor; // fractional degree of inlet clogging + double flowLimit; // inlet flow restriction (cfs) + double localDepress; // local gutter depression (ft) + double localWidth; // local depression width (ft) + + double flowFactor; // flow = flowFactor * (flow spread)^2.67 + double flowCapture; // captured flow rate (cfs) + double backflow; // backflow from capture node (cfs) + double backflowRatio; // inlet backflow / capture node overflow + TInletStats stats; // inlet performance statistics + TInlet * nextInlet; // next inlet in list +}; +// ########################################################################################### + #endif diff --git a/src/solver/toolkit.c b/src/solver/toolkit.c index fff5f4998..83571a97e 100644 --- a/src/solver/toolkit.c +++ b/src/solver/toolkit.c @@ -806,6 +806,148 @@ EXPORT_TOOLKIT int swmm_setLinkParam(int index, SM_LinkProperty param, double va return error_code; } +EXPORT_TOOLKIT int swmm_getInletParam(int index, SM_InletProperty param, double *value) +/// +/// Input: index = Index of the link with desired inlet +/// param = Parameter desired (Based on enum SM_InletProperty) +/// Output: value = value to be output +/// Return: API Error +/// Purpose: Gets Link Parameter +{ + int error_code = 0; + *value = 0; + TInlet* inlet; + + // Check if Open + if(swmm_IsOpenFlag() == FALSE) + { + error_code = ERR_TKAPI_INPUTNOTOPEN; + } + // Check if object index is within bounds + else if (index < 0 || index >= Nobjects[LINK]) + { + error_code = ERR_TKAPI_OBJECT_INDEX; + } + else + { + inlet = Link[index].inlet; + if (inlet) + { + switch(param) + { + case SM_INLETNUMINLETS: + *value = (double)inlet->numInlets; break; + case SM_INLETCLOGFACTOR: + *value = (1 - inlet->clogFactor) * 100; break; + case SM_INLETFLOWLIMIT: + *value = inlet->flowLimit * UCF(FLOW); break; + case SM_INLETLOCALDEPRESS: + *value = inlet->localDepress * UCF(LENGTH); break; + case SM_INLETLOCALWIDTH: + *value = inlet->localWidth * UCF(LENGTH); break; + default: error_code = ERR_TKAPI_OUTBOUNDS; break; + } + } + + else + { + error_code = ERR_TKAPI_NO_INLET; + } + } + return error_code; +}; + +EXPORT_TOOLKIT int swmm_setInletParam(int index, SM_InletProperty param, double value) +/// +/// Input: index = Index of link with desired inlets +/// param = Parameter desired (Based on enum SM_InletProperty) +/// value = value to be assigned +/// Return: API Error +/// Purpose: Sets Inlet Parameter +{ + int error_code = 0; + TInlet* inlet; + // Check if Open + if(swmm_IsOpenFlag() == FALSE) + { + error_code = ERR_TKAPI_INPUTNOTOPEN; + } + // Check if object index is within bounds + else if (index < 0 || index >= Nobjects[LINK]) + { + error_code = ERR_TKAPI_OBJECT_INDEX; + } + else + { + inlet = Link[index].inlet; + if (inlet) + { + switch(param) + { + case SM_INLETCLOGFACTOR: + inlet->clogFactor = 1.0 - (value / 100.); break; + case SM_INLETFLOWLIMIT: + inlet->flowLimit = value / UCF(FLOW); break; + default: error_code = ERR_TKAPI_OUTBOUNDS; break; + } + } + + else + { + error_code = ERR_TKAPI_NO_INLET; + } + } + return error_code; +} + +EXPORT_TOOLKIT int swmm_getInletResult(int index, SM_InletResult type, double *result) +/// +/// Input: index = Index of the link with desired inlet +/// param = Parameter desired (Based on enum SM_InletProperty) +/// Output: value = value to be output +/// Return: API Error +/// Purpose: Gets Link Parameter +{ + int error_code = 0; + *result = 0; + TInlet* inlet; + + // Check if Open + if(swmm_IsOpenFlag() == FALSE) + { + error_code = ERR_TKAPI_INPUTNOTOPEN; + } + // Check if object index is within bounds + else if (index < 0 || index >= Nobjects[LINK]) + { + error_code = ERR_TKAPI_OBJECT_INDEX; + } + else + { + inlet = Link[index].inlet; + if (inlet) + { + switch(type) + { + case SM_INLETFLOWFACTOR: + *result = inlet->flowFactor; break; + case SM_INLETFLOWCAPTURE: + *result = inlet->flowCapture * UCF(FLOW); break; + case SM_INLETBACKFLOW: + *result = inlet->backflow * UCF(FLOW); break; + case SM_INLETBACKFLOWRATIO: + *result = inlet->backflowRatio; break; + default: error_code = ERR_TKAPI_OUTBOUNDS; break; + } + } + + else + { + error_code = ERR_TKAPI_NO_INLET; + } + } + return error_code; +}; EXPORT_TOOLKIT int swmm_getSubcatchParam(int index, SM_SubcProperty param, double *value) /// diff --git a/tests/solver/CMakeLists.txt b/tests/solver/CMakeLists.txt index da8a5d375..021832fbb 100644 --- a/tests/solver/CMakeLists.txt +++ b/tests/solver/CMakeLists.txt @@ -37,6 +37,7 @@ set(solver_test_srcs test_toolkit.cpp test_solver.cpp test_stats.cpp + test_inlets_and_drains.cpp # ADD NEW TEST SUITES TO EXISTING TOOLKIT TEST MODULE ) diff --git a/tests/solver/data/test_inlet_drains.inp b/tests/solver/data/test_inlet_drains.inp new file mode 100644 index 000000000..a60d798aa --- /dev/null +++ b/tests/solver/data/test_inlet_drains.inp @@ -0,0 +1,502 @@ +[TITLE] +;;Project Title/Notes +A dual drainage model with street inlets. +See Inlet_Drains_Model.txt for more details. + +[OPTIONS] +;;Option Value +FLOW_UNITS CFS +INFILTRATION HORTON +FLOW_ROUTING DYNWAVE +LINK_OFFSETS DEPTH +MIN_SLOPE 0 +ALLOW_PONDING NO +SKIP_STEADY_STATE NO + +START_DATE 01/01/2007 +START_TIME 00:00:00 +REPORT_START_DATE 01/01/2007 +REPORT_START_TIME 00:00:00 +END_DATE 01/01/2007 +END_TIME 06:00:00 +SWEEP_START 01/01 +SWEEP_END 12/31 +DRY_DAYS 0 +REPORT_STEP 00:01:00 +WET_STEP 00:01:00 +DRY_STEP 01:00:00 +ROUTING_STEP 0:00:15 +RULE_STEP 00:00:00 + +INERTIAL_DAMPING PARTIAL +NORMAL_FLOW_LIMITED SLOPE +FORCE_MAIN_EQUATION H-W +VARIABLE_STEP 0.75 +LENGTHENING_STEP 0 +MIN_SURFAREA 12.566 +MAX_TRIALS 8 +HEAD_TOLERANCE 0.005 +SYS_FLOW_TOL 5 +LAT_FLOW_TOL 5 +MINIMUM_STEP 0.5 +THREADS 1 + +[EVAPORATION] +;;Data Source Parameters +;;-------------- ---------------- +CONSTANT 0.0 +DRY_ONLY NO + +[RAINGAGES] +;;Name Format Interval SCF Source +;;-------------- --------- ------ ------ ---------- +RainGage INTENSITY 0:05 1.0 TIMESERIES 2-yr + +[SUBCATCHMENTS] +;;Name Rain Gage Outlet Area %Imperv Width %Slope CurbLen SnowPack +;;-------------- ---------------- ---------------- -------- -------- -------- -------- -------- ---------------- +S1 RainGage Aux1 4.55 56.8 1587 2 0 +S2 RainGage Aux4 4.74 63.0 1653 2 0 +S3 RainGage Aux3 3.74 39.5 1456 3.1 0 +S4 RainGage J7 6.79 49.9 2331 3.1 0 +S5 RainGage J10 4.79 87.7 1670 2 0 +S6 RainGage J11 1.98 95.0 690 2 0 +S7 RainGage J10 2.33 0.0 907 3.1 0 + +[SUBAREAS] +;;Subcatchment N-Imperv N-Perv S-Imperv S-Perv PctZero RouteTo PctRouted +;;-------------- ---------- ---------- ---------- ---------- ---------- ---------- ---------- +S1 0.015 0.24 0.06 0.3 25 OUTLET +S2 0.015 0.24 0.06 0.3 25 OUTLET +S3 0.015 0.24 0.06 0.3 25 OUTLET +S4 0.015 0.24 0.06 0.3 25 OUTLET +S5 0.015 0.24 0.06 0.3 25 OUTLET +S6 0.015 0.24 0.06 0.3 25 OUTLET +S7 0.015 0.24 0.06 0.3 25 OUTLET + +[INFILTRATION] +;;Subcatchment Param1 Param2 Param3 Param4 Param5 +;;-------------- ---------- ---------- ---------- ---------- ---------- +S1 4.5 0.2 6.5 7 0 +S2 4.5 0.2 6.5 7 0 +S3 4.5 0.2 6.5 7 0 +S4 4.5 0.2 6.5 7 0 +S5 4.5 0.2 6.5 7 0 +S6 4.5 0.2 6.5 7 0 +S7 4.5 0.2 6.5 7 0 + +[JUNCTIONS] +;;Name Elevation MaxDepth InitDepth SurDepth Aponded +;;-------------- ---------- ---------- ---------- ---------- ---------- +Aux1 4975 0 0 0 0 +Aux2 4973 0 0 0 0 +Aux3 4968.5 0 0 0 0 +Aux4 4971.8 0 0 0 0 +Aux5 4970.7 0 0 0 0 +Aux6 4969 0 0 0 0 +Aux7 4963 0 0 0 0 +J1 4969 4 0 0 0 +J10 4957.8 0 0 0 0 +J11 4957 0 0 0 0 +J2 4965 4 0 0 0 +J2a 4966.7 4 0 0 0 +J3 4973 0 0 0 0 +J4 4965 0 0 0 0 +J5 4965.8 0 0 0 0 +J6 4969 0 0 0 0 +J7 4963.5 0 0 0 0 +J8 4966.5 0 0 0 0 +J9 4964.8 0 0 0 0 + +[OUTFALLS] +;;Name Elevation Type Stage Data Gated Route To +;;-------------- ---------- ---------- ---------------- -------- ---------------- +O1 4956 FREE NO + +[CONDUITS] +;;Name From Node To Node Length Roughness InOffset OutOffset InitFlow MaxFlow +;;-------------- ---------------- ---------------- ---------- ---------- ---------- ---------- ---------- ---------- +Street1 Aux1 Aux2 377.31 0.016 0 0 0 0 +Street2 Aux2 Aux4 286.06 0.016 0 0 0 0 +Street3 Aux4 Aux5 239.41 0.016 0 0 0 0 +Street4 Aux5 Aux6 157.48 0.016 0 0 0 0 +Street5 Aux6 Aux7 526.0 0.016 0 0 0 0 +C3 J3 J4 109.0 0.016 0 6 0 0 +C4 J4 J5 133.0 0.05 6 4 0 0 +C5 J5 J6 207.0 0.05 4 0 0 0 +C6 J7 J6 140.0 0.05 8 0 0 0 +C7 J6 J8 95.0 0.016 0 0 0 0 +C8 J8 J9 166.0 0.05 0 0 0 0 +C9 J9 J10 320.0 0.05 0 6 0 0 +C10 J10 J11 145.0 0.05 6 6 0 0 +C11 J11 O1 89.0 0.016 0 0 0 0 +C_Aux3 Aux3 J3 444.75 0.05 6 0 0 0 +P1 J1 J5 185.39 0.016 0 0 0 0 +P2 J2a J2 157.48 0.016 0 0 0 0 +P3 J2 J11 529.22 0.016 0 0 0 0 +P4 Aux3 J4 567.19 0.016 0 0 0 0 +P5 J5 J4 125.98 0.016 0 0 0 0 +P6 J4 J7 360.39 0.016 0 0 0 0 +P7 J7 J10 507.76 0.016 0 0 0 0 +P8 J10 J11 144.50 0.016 0 0 0 0 + +[XSECTIONS] +;;Link Shape Geom1 Geom2 Geom3 Geom4 Barrels Culvert +;;-------------- ------------ ---------------- ---------- ---------- ---------- ---------- ---------- +Street1 STREET FullStreet +Street2 STREET FullStreet +Street3 STREET FullStreet +Street4 STREET HalfStreet +Street5 STREET HalfStreet +C3 CIRCULAR 2.25 0 0 0 1 +C4 TRAPEZOIDAL 3 5 5 5 1 +C5 TRAPEZOIDAL 3 5 5 5 1 +C6 TRAPEZOIDAL 3 5 5 5 1 +C7 CIRCULAR 3.5 0 0 0 1 +C8 TRAPEZOIDAL 3 5 5 5 1 +C9 TRAPEZOIDAL 3 5 5 5 1 +C10 TRAPEZOIDAL 3 5 5 5 1 +C11 CIRCULAR 4.75 0 0 0 1 +C_Aux3 TRAPEZOIDAL 3 5 5 5 1 +P1 CIRCULAR 0.5 0 0 0 1 +P2 CIRCULAR 1.5 0 0 0 1 +P3 CIRCULAR 1.5 0 0 0 1 +P4 CIRCULAR 1.67 0 0 0 1 +P5 CIRCULAR 1.83 0 0 0 1 +P6 CIRCULAR 2 0 0 0 1 +P7 CIRCULAR 2 0 0 0 1 +P8 CIRCULAR 3.17 0 0 0 1 + +[STREETS] +;;Name Tcrown Hcurb Sx nRoad a W Sides Tback Sback nBack +;;-------------- -------- -------- -------- -------- -------- -------- -------- -------- -------- -------- +HalfStreet 20 0.5 4 0.016 0 0 1 20 4 0.016 +FullStreet 20 0.5 4 0.016 0 0 2 20 4 0.016 + +[INLETS] +;;Name Type Parameters: +;;-------------- ---------------- ----------- +ComboInlet GRATE 2 2 P_BAR-50 +ComboInlet CURB 2 0.5 HORIZONTAL + +[INLET_USAGE] +;;Conduit Inlet Node Number %Clogged Qmax aLocal wLocal Placement +;;-------------- ---------------- ---------------- --------- --------- --------- --------- --------- --------- --------- +Street1 ComboInlet J1 1 50 2.2 0.5 2 +Street3 ComboInlet J2a 1 0 0 0 0 +Street4 ComboInlet J2 1 0 0 0 0 +Street5 ComboInlet J11 2 0 0 0 0 + +[TIMESERIES] +;;Name Date Time Value +;;-------------- ---------- ---------- ---------- +2-yr 0:00 0.29 +2-yr 0:05 0.33 +2-yr 0:10 0.38 +2-yr 0:15 0.64 +2-yr 0:20 0.81 +2-yr 0:25 1.57 +2-yr 0:30 2.85 +2-yr 0:35 1.18 +2-yr 0:40 0.71 +2-yr 0:45 0.42 +2-yr 0:50 0.35 +2-yr 0:55 0.3 +2-yr 1:00 0.2 +2-yr 1:05 0.19 +2-yr 1:10 0.18 +2-yr 1:15 0.17 +2-yr 1:20 0.17 +2-yr 1:25 0.16 +2-yr 1:30 0.15 +2-yr 1:35 0.15 +2-yr 1:40 0.14 +2-yr 1:45 0.14 +2-yr 1:50 0.13 +2-yr 1:55 0.13 +; +10-yr 0:00 0.49 +10-yr 0:05 0.56 +10-yr 0:10 0.65 +10-yr 0:15 1.09 +10-yr 0:20 1.39 +10-yr 0:25 2.69 +10-yr 0:30 4.87 +10-yr 0:35 2.02 +10-yr 0:40 1.21 +10-yr 0:45 0.71 +10-yr 0:50 0.6 +10-yr 0:55 0.52 +10-yr 1:00 0.39 +10-yr 1:05 0.37 +10-yr 1:10 0.35 +10-yr 1:15 0.34 +10-yr 1:20 0.32 +10-yr 1:25 0.31 +10-yr 1:30 0.3 +10-yr 1:35 0.29 +10-yr 1:40 0.28 +10-yr 1:45 0.27 +10-yr 1:50 0.26 +10-yr 1:55 0.25 + +[REPORT] +;;Reporting Options +INPUT YES +SUBCATCHMENTS ALL +NODES ALL +LINKS ALL + +[TAGS] +Link Street1 Full_Street +Link Street2 Full_Street +Link Street3 Full_Street +Link Street4 Half_Street +Link Street5 Half_Street +Link C3 Culvert +Link C4 Swale +Link C5 Swale +Link C6 Swale +Link C7 Culvert +Link C8 Swale +Link C9 Swale +Link C10 Swale +Link C11 Culvert +Link C_Aux3 Swale + +[MAP] +DIMENSIONS -255.206 -70.199 1490.833 1514.231 +Units Feet + +[COORDINATES] +;;Node X-Coord Y-Coord +;;-------------- ------------------ ------------------ +Aux1 293.152 1161.023 +Aux2 653.046 1052.180 +Aux3 122.363 696.959 +Aux4 914.142 1058.025 +Aux5 1175.238 1120.376 +Aux6 1260.972 956.704 +Aux7 1381.777 514.399 +J1 647.200 1022.952 +J10 1254.058 640.029 +J11 1270.714 491.017 +J2 1218.105 950.859 +J2a 1159.651 1069.716 +J3 405.287 905.702 +J4 505.345 862.573 +J5 631.281 859.123 +J6 803.079 869.022 +J7 831.398 709.035 +J8 915.930 840.146 +J9 1072.918 867.749 +O1 1411.468 477.401 + +[VERTICES] +;;Link X-Coord Y-Coord +;;-------------- ------------------ ------------------ +Street1 382.860 1112.719 +Street1 514.703 1061.922 +Street2 806.976 1042.437 +Street3 1062.227 1091.149 +Street4 1210.311 1061.922 +Street5 1338.911 781.341 +Street5 1387.623 662.483 +Street5 1393.468 586.493 +C4 559.710 846.393 +C5 672.684 850.497 +C5 712.363 829.795 +C5 743.415 805.643 +C5 768.006 833.950 +C6 791.719 734.912 +C6 798.620 784.942 +C8 965.959 838.421 +C8 995.287 831.520 +C8 1038.415 850.497 +C9 1102.246 867.749 +C9 1131.573 852.222 +C9 1147.099 829.795 +C9 1162.626 809.094 +C9 1198.854 779.766 +C9 1219.556 757.339 +C9 1233.357 721.111 +C9 1238.532 715.936 +C9 1235.082 674.532 +C9 1247.158 646.930 +C_Aux3 163.003 699.992 +C_Aux3 208.620 726.287 +C_Aux3 239.673 793.567 +C_Aux3 251.749 876.374 +C_Aux3 291.427 912.602 +C_Aux3 355.257 929.854 +P3 1331.117 691.711 +P3 1329.168 590.390 +P4 275.901 572.749 +P4 472.567 824.620 +P7 886.602 800.468 + +[Polygons] +;;Subcatchment X-Coord Y-Coord +;;-------------- ------------------ ------------------ +S1 282.657 1334.810 +S1 111.700 1101.604 +S1 172.525 1062.743 +S1 231.660 1027.262 +S1 306.002 990.092 +S1 370.206 959.679 +S1 409.066 946.163 +S1 444.547 936.025 +S1 493.545 924.198 +S1 532.405 915.750 +S1 569.576 907.302 +S1 610.125 897.165 +S1 655.744 897.165 +S1 684.338 1318.700 +S1 651.043 1321.922 +S1 596.269 1332.662 +S1 551.160 1346.624 +S1 495.312 1367.030 +S1 455.573 1384.214 +S1 410.465 1409.991 +S1 386.836 1427.175 +S1 363.208 1442.211 +S2 678.967 1238.149 +S2 673.584 1152.903 +S2 655.744 897.165 +S2 758.808 893.786 +S2 817.943 895.475 +S2 880.458 898.855 +S2 921.007 905.613 +S2 978.453 920.819 +S2 1042.657 937.715 +S2 1103.482 959.679 +S2 1159.238 985.023 +S2 1225.131 1010.367 +S2 1109.646 1274.665 +S2 1052.723 1400.325 +S2 985.061 1370.252 +S2 924.916 1348.772 +S2 861.549 1331.588 +S2 815.367 1325.144 +S2 762.740 1319.774 +S2 719.780 1316.552 +S2 684.338 1317.626 +S3 109.199 1103.258 +S3 141.754 1081.555 +S3 190.586 1051.713 +S3 247.557 1019.158 +S3 304.528 989.317 +S3 354.716 964.900 +S3 398.123 949.980 +S3 490.166 922.509 +S3 477.743 883.275 +S3 501.993 816.065 +S3 556.059 778.895 +S3 488.476 679.210 +S3 422.582 729.897 +S3 282.348 557.560 +S3 179.734 633.927 +S3 153.962 651.561 +S3 107.843 693.610 +S3 71.218 742.443 +S3 48.159 785.849 +S3 31.881 837.394 +S3 29.168 886.226 +S3 31.881 933.702 +S3 38.664 967.613 +S3 50.872 1001.525 +S3 65.793 1035.436 +S3 87.496 1070.704 +S3 109.199 1103.258 +S4 282.348 559.250 +S4 420.893 729.897 +S4 488.476 680.899 +S4 556.828 779.067 +S4 501.213 814.335 +S4 479.468 885.000 +S4 491.718 922.851 +S4 616.511 898.434 +S4 668.056 897.078 +S4 783.355 895.722 +S4 815.909 898.434 +S4 857.959 899.791 +S4 890.595 897.165 +S4 968.316 915.750 +S4 1042.657 937.715 +S4 1074.759 849.857 +S4 1054.484 773.826 +S4 1020.692 702.864 +S4 963.247 623.454 +S4 689.536 256.816 +S5 1301.482 474.258 +S5 1271.677 445.380 +S5 1232.340 393.835 +S5 1241.835 384.340 +S5 1222.844 366.706 +S5 1233.696 355.854 +S5 1026.159 66.931 +S5 1008.525 56.079 +S5 708.750 275.824 +S5 1023.446 704.462 +S5 1150.644 618.812 +S5 1251.203 640.809 +S5 1328.193 519.824 +S6 1334.478 519.824 +S6 1306.266 488.956 +S6 1293.380 474.205 +S6 1232.340 393.835 +S6 1241.835 381.627 +S6 1222.844 365.350 +S6 1232.340 353.142 +S6 1027.516 65.574 +S6 1012.595 56.079 +S6 707.393 273.111 +S6 688.403 254.121 +S6 739.948 218.853 +S6 788.780 159.169 +S6 806.414 106.268 +S6 813.197 1.821 +S6 994.961 12.673 +S6 1228.270 27.594 +S6 1222.844 115.763 +S6 1228.270 167.308 +S6 1241.835 229.705 +S6 1255.399 254.121 +S6 1279.815 302.953 +S6 1309.657 354.498 +S6 1335.430 401.974 +S6 1359.846 448.093 +S6 1370.616 475.830 +S6 1381.615 491.542 +S7 1122.467 968.970 +S7 1174.012 987.282 +S7 1225.557 1005.594 +S7 1377.480 675.977 +S7 1391.044 642.065 +S7 1396.470 598.659 +S7 1381.615 491.542 +S7 1331.336 519.824 +S7 1249.632 640.809 +S7 1150.644 617.241 +S7 1020.733 704.462 +S7 1054.645 772.285 +S7 1076.796 848.212 +S7 1056.370 900.062 +S7 1040.658 937.772 + +[SYMBOLS] +;;Gage X-Coord Y-Coord +;;-------------- ------------------ ------------------ +RainGage -175.841 1212.778 + +[LABELS] +;;X-Coord Y-Coord Label +145.274 1129.896 "S1" "" "Arial" 14 0 0 +758.404 969.723 "S2" "" "Arial" 14 0 0 +247.369 666.226 "S3" "" "Arial" 14 0 0 +628.971 458.688 "S4" "" "Arial" 14 0 0 +952.552 257.845 "S5" "" "Arial" 14 0 0 +827.947 56.930 "S6" "" "Arial" 14 0 0 +1073.058 780.037 "S7" "" "Arial" 14 0 0 +1385.481 454.225 "Outfall" "" "Arial" 10 1 0 + diff --git a/tests/solver/test_inlets_and_drains.cpp b/tests/solver/test_inlets_and_drains.cpp new file mode 100644 index 000000000..466140c46 --- /dev/null +++ b/tests/solver/test_inlets_and_drains.cpp @@ -0,0 +1,120 @@ +/* + ****************************************************************************** + Project: OWA SWMM + Version: 5.2.3 + Module: test_inlets_and_drains.cpp + Description: tests for SWMM inlets and drains API functions + Authors: see AUTHORS + Copyright: see AUTHORS + License: see LICENSE + Last Updated: 3/27/2023 + ****************************************************************************** +*/ + + #include + + #include "test_solver.hpp" + + +#define ERR_NONE 0 + +BOOST_AUTO_TEST_SUITE(test_toolkitapi_inlets_and_drains) + + +BOOST_FIXTURE_TEST_CASE(getset_inlet_params, FixtureBeforeStep_Inlets){ + int error, link_ind; + double value; + char id[] = "Street1"; + + error = swmm_getObjectIndex(SM_LINK, id, &link_ind); + BOOST_REQUIRE(error == ERR_NONE); + + // test num inlets getter + error = swmm_getInletParam(link_ind, SM_INLETNUMINLETS, &value); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(value - 1.0, 0.0001); + + // test clogging factor getter + error = swmm_getInletParam(link_ind, SM_INLETCLOGFACTOR, &value); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(value - 50.0, 0.0001); + + // test clogging factor setter + error = swmm_setInletParam(link_ind, SM_INLETCLOGFACTOR, 78.0); + BOOST_REQUIRE(error == ERR_NONE); + error = swmm_getInletParam(link_ind, SM_INLETCLOGFACTOR, &value); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(value - 78.0, 0.0001); + + // test flow limit getter + error = swmm_getInletParam(link_ind, SM_INLETFLOWLIMIT, &value); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(value - 2.2, 0.0001); + + // test flow limit setter + error = swmm_setInletParam(link_ind, SM_INLETFLOWLIMIT, 5.8); + BOOST_REQUIRE(error == ERR_NONE); + error = swmm_getInletParam(link_ind, SM_INLETFLOWLIMIT, &value); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(value - 5.8, 0.0001); + + // test local depression height getter + error = swmm_getInletParam(link_ind, SM_INLETLOCALDEPRESS, &value); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(value - 0.5, 0.0001); + + // test local depression width getter + error = swmm_getInletParam(link_ind, SM_INLETLOCALWIDTH, &value); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(value - 2.0, 0.0001); + +} + +BOOST_FIXTURE_TEST_CASE(get_result_during_sim, FixtureBeforeStep_Inlets){ + int error, step_ind; + int lnk_ind; + double val; + double elapsedTime = 0.0; + + char lnkid[] = "Street1"; + + error = swmm_getObjectIndex(SM_LINK, lnkid, &lnk_ind); + BOOST_REQUIRE(error == ERR_NONE); + + step_ind = 0; + + do + { + error = swmm_step(&elapsedTime); + + if (step_ind == 250) // peak flow in Street1 + { + // test inlet flow factor getter + error = swmm_getInletResult(lnk_ind, SM_INLETFLOWFACTOR, &val); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(val - 0.0118, 0.0001); + + // test inlet flow capture getter + error = swmm_getInletResult(lnk_ind, SM_INLETFLOWCAPTURE, &val); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(val - 3.3864, 0.0001); + + // test inlet backflow getter + error = swmm_getInletResult(lnk_ind, SM_INLETBACKFLOW, &val); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(val - 2.5670, 0.0001); + + // test inlet backflow ratio getter + error = swmm_getInletResult(lnk_ind, SM_INLETBACKFLOWRATIO, &val); + BOOST_REQUIRE(error == ERR_NONE); + BOOST_CHECK_SMALL(val - 1.0, 0.0001); + } + + step_ind+=1; + }while (elapsedTime != 0 && !error); + // BOOST_REQUIRE(error == 1); + swmm_end(); +} + + +BOOST_AUTO_TEST_SUITE_END() \ No newline at end of file diff --git a/tests/solver/test_solver.hpp b/tests/solver/test_solver.hpp index c2617ae9b..e45e477b4 100644 --- a/tests/solver/test_solver.hpp +++ b/tests/solver/test_solver.hpp @@ -24,6 +24,7 @@ extern "C" { #define DATA_PATH_INP_POLLUT_NODE "node_constantinflow_constanteffluent.inp" #define DATA_PATH_INP_POLLUT_LINK "link_constantinflow.inp" #define DATA_PATH_INP_LINK_DIR "link_flow_dir.inp" +#define DATA_PATH_INP_INLETS_AND_DRAINS "test_inlet_drains.inp" #define DATA_PATH_RPT "tmp.rpt" #define DATA_PATH_OUT "tmp.out" @@ -103,6 +104,18 @@ struct FixtureBeforeStep_Flow_Dir{ }; +struct FixtureBeforeStep_Inlets{ + FixtureBeforeStep_Inlets() { + swmm_open(DATA_PATH_INP_INLETS_AND_DRAINS, DATA_PATH_RPT, DATA_PATH_OUT); + swmm_start(0); + } + ~FixtureBeforeStep_Inlets() { + swmm_close(); + } +}; + + + // Declare shared test predicates here boost::test_tools::predicate_result check_cdd_double(std::vector& test, std::vector& ref, long cdd_tol);