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

Monday, December 30, 2024

SWMM5 Delphi GUI Uupdate.pas Summary

 Below is a high-level summary of the Uupdate.pas unit, which is responsible for updating references to changed SWMM project data in the user interface (UI) and in SWMM’s underlying data structures.


1. Purpose & Overview

Uupdate.pas ensures that when certain SWMM data elements (like nodes, subcatchments, pollutants, etc.) change names, or when configuration changes occur (like infiltration model or link offset conventions), all references to those elements remain consistent across the entire project. If an element is renamed or removed, Uupdate.pas finds all its occurrences in other objects’ properties (e.g., a subcatchment’s outlet, a node’s inflow pollutant, etc.) and adjusts them accordingly.

Core Responsibilities:

  1. Remove references to deleted object names.
  2. Rename references to objects that changed names.
  3. Synchronize property changes across subcatchments, nodes, links, and specialized objects (LIDs, controls, etc.).
  4. Convert link offsets from “Depth Offsets” to “Elevation Offsets” (or vice versa) and update all link objects accordingly.
  5. Manage changes in infiltration models and default project options.

2. Key Procedures and Functions

Name/Reference Updates

  1. RemoveName(ObjType, OldName)

    • Removes all references to an object whose name has been deleted.
    • Example: If a node “Node1” is removed, it also removes “Node1” from any links or subcatchments that referenced it.
  2. UpdateXYZName(OldName, NewName) (e.g., UpdatePollutName, UpdateRainGageName, UpdateNodeName, etc.)

    • Searches the entire project data for occurrences of OldName (e.g., in inflows, subcatchment loadings, or link references) and replaces them with NewName.
    • If NewName is blank, the references are effectively set to “*” or removed.
  3. UpdateAllLengths, UpdateObjectLength

    • Recompute lengths and areas if the “AutoLength” option is enabled or if geometry changes (like a node reference is updated).
  4. UpdateOffsets, ComputeDepthOffsets, ComputeElevationOffsets

    • Convert link offsets from “Elevation” to “Depth” or vice versa.
    • Iterates through all links of type conduit, orifice, weir, or outlet, computing new offset values.
  5. UpdateInfilModel, UpdateDefOptions

    • If the default infiltration model changes (e.g., from Horton to Green-Ampt), optionally updates all subcatchments still using the old model to the new one.
    • Synchronizes global default options if something like FLOW_UNITS or LINK_OFFSETS changes.
  6. UpdateLinkNode, UpdateSubcatchOutlet, UpdateLabelAnchor

    • Adjusts references for the endpoints or anchors of various objects (links, subcatchments, labels) to a new name while validating that the references make sense (i.e., a link cannot connect a node to itself).
  7. UpdateLinkHints, UpdateUnits, UpdateMapUnits

    • Refreshes UI hints displayed for link offsets if the user toggles between “Depth” vs. “Elevation” offset conventions.
    • Updates displayed units if the project’s flow units or infiltration model changes.

3. Typical Use Cases

  1. Renaming a Node

    • The user edits a node's ID from NodeA to NodeB. UpdateNodeName replaces NodeA everywhere it’s used as an outfall, inflow reference, or subcatchment outlet.
  2. Removing a Pollutant

    • The user deletes “TSS” from the pollutant list. RemoveName calls UpdatePollutName(... , ""), which sets or removes “TSS” from land uses, nodes’ inflows, or LID removal references.
  3. Switching Offsets

    • The user changes link offsets from “Depth” to “Elevation.” UpdateOffsets calls ComputeElevationOffsets for each conduit, weir, orifice, and outlet, adjusting offset numbers so the DB remains consistent.
  4. Changing Infiltration Model

    • The user changes the default infiltration option from “Green-Ampt” to “Horton.” UpdateInfilModel optionally updates all subcatchments that were using the old infiltration method to the new one.

4. Integration with the SWMM GUI

  • Uupdate.pas works in tandem with the Uglobals and Uproject modules:
    • Uglobals holds the global flags (e.g., AutoLength, UnitSystem, etc.).
    • Uproject stores all objects (subcatchments, nodes, links, pollutants, landuses, etc.).
  • The UI (e.g., Fmain, Fmap, Ubrowser) calls these update routines in response to user edits or preference changes.

5. Conclusion

Uupdate.pas is essentially a “cleanup and synchronization” module. Whenever an object is renamed or a project-wide setting is changed, it ensures that all references, geometry computations, or label anchors remain valid and consistent throughout the EPA SWMM data environment. This prevents orphan references or outdated settings after user actions.

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...