Detailed Expanded Summary of the Dgwater
Unit (SWMM5)
The Dgwater
unit (Object Pascal) provides a specialized dialog form (named TGroundWaterForm
) that allows the user to view and edit the groundwater flow properties of a subcatchment in the EPA SWMM5 software. These properties describe how water flows between a subcatchment’s aquifer, soil zones, and the node that receives the outflow. Below is a comprehensive analysis of the unit’s functionality, structure, and role within the broader application.
1. Purpose & Scope
In SWMM5, each subcatchment can optionally have a groundwater component describing aquifer properties beneath it, plus equations describing lateral and deep percolation flows. The TGroundWaterForm
dialog centralizes editing of these parameters, which include:
- Aquifer name (links to a named Aquifer object)
- Receiving node for groundwater flow
- Surface elevation plus several flow coefficients, exponents, and threshold parameters
- Optional custom equations for lateral and/or deep groundwater flow, allowing advanced control beyond the standard GW flow formula
Hence, Dgwater.pas
is the code behind a SWMM5 window that displays and updates these fields.
2. Key Components
2.1. Form Class: TGroundWaterForm
- Inheritance: Descends from
TForm
, a Delphi/Lazarus standard for visual windows. - Fields:
SubCatchIndex
: The subcatchment index in SWMM’s data structure (pointing to the current subcatchment whose groundwater data is displayed).GwaterProps
: An array of property descriptors (TPropRecord
) for each editable field, such as “Aquifer Name,” “Surface Elevation,” “Receiving Node,” etc.PropEdit1
: ATPropEdit
control that implements a property-value style grid for editing. Each row corresponds to a property, while columns represent the property’s name and its value.PropList
: A string list containing the actual data values displayed inPropEdit1
.LatFlowEqn
&DeepFlowEqn
: Strings representing optional custom equations for lateral flow and deep flow, respectively, used in addition to or in place of the built-in SWMM groundwater formula.
2.2. Constants & Data Structures
MAX_GW_PROPS
= 14: Number of groundwater properties including two for custom equations (LAT_EQN_INDEX
= 13,DEEP_EQN_INDEX
= 14).Default_GW_Props
: An array that provides default text for each property if no data exist (such as no aquifer name, or zero for flow coefficients).PropNames
&GroundWaterHint
: Arrays of user-facing strings that define the names of each property and hints/tips displayed at the bottom of the form (theHintLabel
) as the user navigates each row inPropEdit1
.
2.3. Form Lifecycle Methods
-
FormCreate(Sender: TObject)
- Instantiates and configures the
PropEdit1
property grid (TPropEdit
). - Sets up
GwaterProps
(oneTPropRecord
for each field). - Creates
PropList
, the string list that stores property values to display. - Initializes
LatFlowEqn
andDeepFlowEqn
as empty strings.
- Instantiates and configures the
-
FormShow(Sender: TObject)
- Loads the property records (
GwaterProps
) plus values fromPropList
intoPropEdit1
. - Tells
PropEdit1
to place the user in edit mode (Edit;
).
- Loads the property records (
-
FormDestroy(Sender: TObject)
- Cleans up the
PropList
andPropEdit1
objects.
- Cleans up the
-
FormKeyDown(Sender: TObject; ...)
- Detects F1 key press to trigger help.
3. User Interaction
3.1. Property Grid (PropEdit1)
Each row of the grid corresponds to a specific groundwater property. The user can:
- Enter text (for numeric or string fields).
- Click a button for the custom equations for lateral or deep flow, leading to a specialized child form (
TGWEqnForm
fromDgweqn.pas
).
3.2. Buttons
- OK / Cancel: Finalize or dismiss changes.
- Help: Show specialized help.
3.3. Event Handlers
ButtonClick(Sender: TObject; Index: Integer; var S: String; var Modified: Boolean)
Triggered when the user clicks the “...” button on a row inPropEdit1
. Specifically forLAT_EQN_INDEX
orDEEP_EQN_INDEX
, it calls upTGWEqnForm
to let the user input a custom equation. The resulting string is stored inLatFlowEqn
orDeepFlowEqn
, andS
is set to “Yes” or “No” to reflect whether an equation is present.ShowPropertyHint(Sender: TObject; aRow: LongInt)
Updates the lowerHintLabel
with a short piece of help text fromGroundWaterHint
.ValidateEntry(Sender: TObject; Index: Integer; var S: String; var Errmsg: String; var IsValid: Boolean)
Currently only checks if the field can remain blank or not.OKBtnClick(Sender: TObject)
EnsuresPropEdit1
fields pass validation. If not, remain in the form. Otherwise close withmrOK
.
4. Data Transfer Methods
4.1. SetData(const Index: Integer)
Given a subcatchment index:
- Loads defaults (
Default_GW_Props
) intoPropList
. - If the subcatchment is valid, it fetches the subcatchment’s
Groundwater
string list, copying each line into the first 13 items. - The custom equations (
GwLatFlowEqn
&GwDeepFlowEqn
) are loaded into local strings (LatFlowEqn
&DeepFlowEqn
). If these are non-empty, the corresponding property’s string inPropList
is “Yes” else “No”.
4.2. GetData(const Index: Integer)
Copies the final set of property values back to the subcatchment:
- Clears the subcatchment’s
Groundwater
list. - If the aquifer name property (index 0) is not blank, it copies the first 13 lines from the local
PropList
intoGroundwater
. - The
LatFlowEqn
&DeepFlowEqn
are assigned toS.GwLatFlowEqn
&S.GwDeepFlowEqn
. - The global
HasChanged
is set ifPropEdit1.Modified
is true.
4.3. Group Data Methods
SetGroupData
Switches the form caption to “Group Groundwater Editor” and changes the last property style to read-only. Also sets the localPropList
to'*'
for each property, meaning “Not editing or default.”GetGroupData(var GWData: array of String)
Copies the form’s property data (except for custom equations) into the passed array. Used to apply these as group edits to multiple subcatchments in a different code flow.
5. Coupling with Other Units
Dgweqn
: The specialized child form for custom flow equations. TheButtonClick
method calls intoDgweqn.pas
’sTGWEqnForm
to handle user editing of advanced math expressions forLatFlowEqn
orDeepFlowEqn
.Uproject
,Uglobals
,Uutils
: Provide references to the subcatchment data, global settings, and utility routines for error messages, numeric parsing, and string handling.
6. Workflow Example
- User Opens Subcatchment’s Groundwater Editor: The main SWMM UI calls
GroundWaterForm.SetData(i)
, passing subcatchment indexi
. - Properties Shown: The form populates the grid with the subcatchment’s existing data (like aquifer name, flow coefficients, etc.).
- User Edits: If the user clicks on the lateral or deep equation row’s “...” button, a separate
TGWEqnForm
opens. The user can add or remove custom code there. The form’s property will become “Yes” or “No.” - Confirm: On OK,
GetData(i)
copies the user’s changes to the subcatchment data structure (S.GwLatFlowEqn
etc.), setsHasChanged
, and closes.
7. Maintenance & Extensibility
- Validation: Currently minimal. Additional checks on numeric ranges or synergy with aquifer references could be added.
- Custom Equation: The usage of “Yes/No” in
PropEdit1
for the custom equation might be expanded to display a short preview if desired. - Group Editing:
SetGroupData
/GetGroupData
supports applying an edit to multiple subcatchments at once, used by a “Group Edit” function from other SWMM UI code.
Conclusion
Dgwater.pas
is a compact, well-structured module enabling an advanced groundwater property UI. It leverages the standard approach in SWMM5’s UI: a property grid for data fields, dynamic memo-based help, and child forms for specialized tasks (like writing custom equations). It keeps all SWMM data in alignment with user changes for a single or multiple subcatchment(s).