Detailed Expanded Summary of the Dgweqn
Unit (SWMM5)
The Dgweqn
unit, written in the Object Pascal language (often associated with Delphi or Lazarus), contains a form class named TGWEqnForm
designed specifically for editing custom groundwater flow equations in EPA SWMM5. This dialog is part of SWMM5’s user interface code and allows users to create or modify an additional or alternative equation to the default groundwater flow formulas. Below is an in-depth explanation of the code’s structure, purpose, and functionality.
1. Purpose & Context
In EPA SWMM, groundwater flow from a subcatchment can be modeled using a standard built-in equation. However, advanced modelers may wish to add or replace this with a user-defined equation for more control or to represent site-specific conditions. The Dgweqn
unit addresses this need by providing:
- A specialized form (
TGWEqnForm
) that collects, displays, and validates a custom math expression. - Variable placeholders (e.g.,
Hgw
,Theta
,Ks
) which the user can use in the expression, referencing various states of the aquifer, soil moisture, infiltration rate, etc. - Helper text and example usage, displayed in a read-only memo box (
Memo1
), that guide the user on acceptable variable names, usage ofSTEP()
function, and typical flow units.
This form is invoked when the user clicks a button from either the lateral flow or the deep flow equation property in the groundwater editor form (Dgwater.pas
).
2. Key Components
2.1. Form Class: TGWEqnForm
- Inheritance: Inherits from
TForm
, the standard Delphi/Lazarus form for GUI windows. - Design: Contains visual controls (labels, memo fields, and buttons) managed in the form’s
.dfm
file (textual or binary format for Delphi form definitions).
2.2. Visual Controls
Label1
&Label2
: Provide dynamic instructions to the user about the meaning of the expression being edited (i.e., the difference between editing a lateral vs. a deep equation).Memo1
: Read-only multi-line text box offering usage instructions, a list of acceptable variable placeholders, and example code for flow equations.Edit1
: Multi-line text box (the main editor) where the user types or pastes in their custom equation.OkBtn
,CancelBtn
, andHelpBtn
: Standard footer buttons for finalizing, discarding changes, and invoking help, respectively.
2.3. Class Fields and Methods
SetupForm(EqnType: Integer)
This procedure configures the dynamic text inLabel1
,Label2
, andMemo1
depending on whether the user is editing a lateral or deep groundwater flow equation. Two sets of instructions exist, each labeled 0 (lateral) or 1 (deep).SetEqn(Eqn: String)
Allows external code to load an existing expression (e.g., stored previously for a subcatchment) into theEdit1
memo. The user sees and can further modify this expression.GetEqn: String
Returns the final text fromEdit1
(i.e., the user’s custom expression). This is called when the user clicks OK in the form to confirm changes.- Event Handlers:
FormShow(Sender: TObject)
Sets the focus onEdit1
when the form becomes visible.HelpBtnClick(Sender: TObject)
Triggered when the user clicks the Help button, usually opening context-specific instructions or a help file topic.FormKeyDown(Sender: TObject; var Key: Word; Shift: TShiftState)
Detects if the F1 key was pressed, calling the same Help logic as the Help button.
2.4. Variables & Constants
Label1Text
/Label2Text
Arrays of strings that define text forLabel1
andLabel2
for either the “lateral” or “deep” case. The form sets them inSetupForm
.Memo1Text1
,Memo1Text2
,Memo1Text3
Arrays of strings providing usage instructions and examples displayed insideMemo1
. They mention placeholders likeHgw
,Ks
,Phi
, etc., as well as any special function usage likeSTEP()
.EqnType
(0-based) is used to decide which set of text to display.
3. Usage Flow
- Open the Equation Editor: The user, from the main Groundwater editing form (
Dgwater.pas
), clicks a button for either the Lateral or Deep equation property. The code callsTGWEqnForm.Create(...)
and configures the form withSetupForm(EqnType)
. - Populate with Existing Equation: If the subcatchment already has a custom equation, it’s loaded via
SetEqn
. - User Edits: The user modifies or replaces that expression in
Edit1
. - Confirm: Clicking OK calls
GetEqn
to retrieve the user’s final expression. - Validation: Some basic checks happen; if valid, the main UI code updates the subcatchment’s groundwater properties.
4. Implementation Insights
- Flow Equation: The text the user enters could add to or replace the standard SWMM equation for
Hgw
, infiltration, or other terms. If the user wants to wholly override the standard, they might zero out its parameters in the main groundwater form and supply a brand new formula here. - Syntax: By design,
TGWEqnForm
does not parse or validate the expression syntax beyond typical checks. SWMM’s engine attempts to interpret the expression later, possibly generating run-time errors if invalid placeholders or operators are used. - STEP Function: The instructions highlight a
STEP()
function enabling conditional flows. It’s a typical way to do piecewise logic in expressions, e.g., ignoring flow unless the water table is above a threshold.
5. Relation to Other Units
- The
TGWEqnForm
is typically called fromDgwater.pas
(TGroundWaterForm
class) for the specific subcatchment property for lateral or deep flow. - The actual math expression is stored in subcatchment object fields such as
GwLatFlowEqn
orGwDeepFlowEqn
. - Another unit or the SWMM engine interprets the expressions at simulation time.
6. Maintenance & Extendability
- To add new placeholders or advanced logic (e.g., additional math functions), one might expand the help text or internal expression evaluator.
- The code is straightforward and separated from any expression evaluation logic, so modifications remain simple for additional user instructions or placeholders.
Conclusion
Overall, Dgweqn
provides a streamlined approach for specifying custom lateral or deep GW flow equations in SWMM5. It uses a standard Delphi form with minimal logic, focusing on text entry and help text, while relying on other parts of SWMM to parse and apply the expression. This separation offers clarity and maintainability in the codebase.