Showing posts with label SWMM5 Delphi GUI Dinlet.pas Summary. Show all posts
Showing posts with label SWMM5 Delphi GUI Dinlet.pas Summary. Show all posts

Sunday, December 29, 2024

SWMM5 Delphi GUI Dinlet.pas Summary

 Below is an overview of Dinlet.pas, a Delphi unit from SWMM 5.2 that provides a form (TInletEditorForm) for specifying a particular street inlet design. SWMM uses inlets to model surface flow interception (capture) from gutters into the drainage network.


1. Purpose and Context

This unit defines the Inlet Editor dialog, which lets the user create or modify the design details of a street inlet. SWMM supports several types of inlets (grate, curb opening, etc.), each with its own set of parameters determining how flows are intercepted from street gutters.


2. TInletEditorForm at a Glance

TInletEditorForm is the main form class that contains:

  1. A Combo Box (InletTypeCombo) listing inlet types (e.g., Grate, Curb, Combo, Slotted Drain, Custom).
  2. Pages (TPageControl with multiple TTabSheets) to display different inlet parameter sets, depending on the type:
    • TabSheet1: Grate Inlet
    • TabSheet2: Curb Opening Inlet
    • TabSheet3: Slotted Drain Inlet
    • TabSheet4: Custom Inlet
  3. Several TNumEdit Controls (NumEdit1, NumEdit2, etc.) for numeric input:
    • E.g., grate length/width, curb opening length, depths, and other geometrical or capacity parameters.
  4. Combo Boxes for sub-type selection:
    • GrateTypeCombo: e.g., “Vane,” “Generic,” “Herringbone,” etc.
    • ThroatTypeCombo: e.g., “Depressed,” “Setback,” etc.
    • CurveCombo: reference to a Custom Inlet’s rating or diversion curve name.
  5. Radio Buttons (DiversionRB, RatingRB) to specify which type of custom capture curve is used (Diversion curve vs. Rating curve).
  6. An Image (Image1), updated dynamically to show an icon representing the chosen inlet type.

When the user picks an inlet type in InletTypeCombo, the form displays the relevant tab pages and hides the others.


3. Key Data Structures and Properties

3.1 TInlet Object

SWMM organizes inlets under a special object class TInlet. Each TInlet:

  • Has an integer InletType index (matching the order in InletTypes[], e.g. GRATE_INLET = 0, CURB_INLET = 1, etc.).
  • Stores parameters in an array of strings, Data[ ], indexed by symbolic constants (e.g., GRATE_INLET_TYPE, CURB_INLET_THROAT, etc.).
  • For a Custom inlet type, the relevant capture curve name is placed into the string array at a specific index (e.g., CUSTOM_INLET_DIVRSN_CURVE or CUSTOM_INLET_RATING_CURVE).

3.2 Controls and Indices

  • NameEdit: The unique name of the inlet.
  • InletTypeCombo: Index corresponds to the inlet’s type.
  • NumEdit#: Each numeric edit (1..9) updates aInlet.Data[#]. For example:
    • NumEdit1 might be Grate Width
    • NumEdit2 might be Grate Length
    • … etc.
  • GrateTypeCombo and ThroatTypeCombo: Stored as strings in aInlet.Data[GRATE_INLET_TYPE] or [CURB_INLET_THROAT].

4. Form Lifecycle and Event Handlers

4.1 FormCreate

  • Initializes unit labels (feet or meters) based on Uglobals.UnitSystem.
  • Populates InletTypeCombo with the strings in InletTypes[].
  • Populates GrateTypeCombo and ThroatTypeCombo with strings from GrateTypes[] and ThroatTypes[].
  • Sets default content for CurveCombo (e.g., all diversion curves).
  • Assigns a glyph (icon) to the CurveBtn from the main form’s image list.

4.2 SetData

procedure SetData(const I: Integer; const S: String; aInlet: TInlet);

  1. Stores local references (InletName, InletIndex, and InletType) from the passed-in aInlet.
  2. Fills the form controls from aInlet.Data.
    • GrateTypeCombo.Text := aInlet.Data[GRATE_INLET_TYPE]
    • NumEdit# controls get numeric values from aInlet.Data[#]
    • ThroatTypeCombo.Text := aInlet.Data[CURB_INLET_THROAT]
    • If it’s a Custom inlet, picks which radio button (Diversion vs. Rating) based on the known curve type in the project data.
  3. Shows/hides the relevant tab sheets via InletTypeComboClick.
  4. Sets Modified := False.

4.3 GetData

procedure GetData(var S: String; aInlet: TInlet);

  1. Retrieves the edited name into S.
  2. Sets aInlet.InletType := InletTypeCombo.ItemIndex.
  3. Copies each NumEdit# control back into aInlet.Data[#].
  4. If it’s a Custom inlet, stores the curve name in either CUSTOM_INLET_DIVRSN_CURVE or CUSTOM_INLET_RATING_CURVE based on which radio button is selected.
  5. Checks if anything has changed compared to the original inlet data. If so, sets Modified := True.

4.4 InletTypeComboClick

When the user picks an inlet type:

  • Updates the displayed image (Image1.Picture.Icon) to match the chosen type.
  • Shows or hides the tab sheets (TabSheet1..TabSheet4) relevant to that inlet type. For example:
    • Grate => TabSheet1
    • Curb => TabSheet2
    • Combo => TabSheet1 + TabSheet2
    • Slotted => TabSheet3
    • Drop Grate => TabSheet1 (again, different style)
    • Drop Curb => TabSheet2 (no throat combo)
    • Custom => TabSheet4
  • Labels each tab appropriately (e.g., “Grate Inlet,” “Curb Opening Inlet,” etc.).

4.5 GrateTypeComboChange

If the user selects a “GENERIC” grate, additional controls become visible (NumEdit3, NumEdit4) for e.g. grate coefficient data.

4.6 OkBtnClick

  • Checks that NameEdit is not empty.
  • Verifies that no other inlet shares this name (unless editing the same inlet).
  • If Custom inlet type, checks that a valid curve name was supplied in CurveCombo (either Diversion or Rating).
    • If the project already has a curve of the correct type, fine; if not, the user can still provide a new name (which might be defined later).
  • If these validations pass, the form ends with ModalResult := mrOK.

4.7 CurveBtnClick

  • Edits or adds a curve in the Diversion or Rating curve list, as chosen by the user.
  • Upon returning from the curve editor, updates CurveCombo text if a new or renamed curve was created.

4.8 HelpBtnClick

Opens a help topic. The code picks a help context ID depending on which tab is active.


5. Summary of Operation

  1. Initialization
    The form is created, populating combos and setting up the user interface based on the SWMM unit system (US or SI).

  2. Data Loading
    SetData populates the form from an existing TInlet object. It also determines which tabs to show or hide.

  3. User Editing
    The user modifies the inlet type, geometry (length, width, opening dimensions), optionally picks or edits a capture curve for a Custom inlet, etc.

  4. Validation
    When the user clicks OK, the form ensures the inlet name is valid and unique, and checks for a valid curve name (when needed).

  5. Data Saving
    GetData copies values back into the TInlet object. The calling code can then store it in the SWMM project database.

By controlling which tabs and fields appear for each inlet type, Dinlet.pas provides an organized approach to editing potentially complex inlet geometry and capture properties. This modular design allows SWMM to handle everything from simple grates to custom rating-curve-based inlets in a single dialog.

Banach-Tarski paradox and SWMM5 modeling.

Banach-Tarski paradox and SWMM5 modeling.  Let's elaborate on how the principles underlying Banach-Tarski could inspire practical hydrau...