Below is an extended summary of this code, focusing on its structure, purpose, and how each class fits into managing LID (Low Impact Development) layers in a SWMM model via PySWMM.
Overview
This module defines layer-specific classes that represent the different components of a Low Impact Development (LID) unit in SWMM (e.g., surface, soil, storage, pavement, drain, drain mat). Each class exposes properties that allow reading (and, in some cases, modifying) the physical or hydraulic parameters of the respective layer. These classes work in conjunction with PySWMM’s lower-level API (pyswmm.toolkitapi
) to interface with SWMM’s C data structures.
Key Themes
-
Layer Abstraction
Each LID layer (e.g., Surface, Soil, Storage) is encapsulated in its own class. This allows for a clean, modular approach where each set of parameters is logically grouped. -
Property-Based Interface
Parameters are generally accessed and modified through Pythonic properties. For example:lid_control_surface.roughness # get the current roughness lid_control_surface.roughness = 0.45 # set a new value
-
Setters Before vs. During Simulation
The docstrings and tables indicate that some parameters can only be changed before the simulation starts (e.g., thickness, porosity), while others can be changed at runtime (e.g., roughness for certain layers, or the underdrain properties). This distinction is crucial for real-time simulation control and is enforced at a deeper level by SWMM or PySWMM. -
Integration with
LidControls
In a typical workflow, a user would retrieve aLidControls
object (e.g.,lid_control = LidControls(sim)["LID_C1"]
) and then access one of these layer classes (lid_control.surface
,lid_control.soil
, etc.). The classes here rely on_lidcontrolid
to locate and update the correct LID in the SWMM model.
Classes and Their Roles
1. Surface
- Represents the topmost (surface) layer of an LID (e.g., a bioretention cell or green roof surface).
- Key Properties:
thickness
(ponding or surface layer depth),void_fraction
(storage availability in the surface layer),roughness
(surface Manning’s n),slope
,side_slope
(geometric slopes),alpha
(additional swale-flow parameter).
- Setter Availability:
- Most parameters can only be set before simulation except for
roughness
, which can also be changed during the simulation.
- Most parameters can only be set before simulation except for
2. Soil
- Corresponds to the soil layer in LIDs such as bioretention or vegetative infiltration practices.
- Key Properties:
thickness
,porosity
(void volume fraction),field_capacity
,wilting_point
,k_saturated
(saturated hydraulic conductivity),k_slope
(slope of log(k) vs. moisture content curve),suction_head
.
- Setter Availability:
- Typically, soil parameters are only adjustable before a simulation starts.
3. Storage
- Represents a storage or reservoir layer (e.g., gravel layer beneath soil, or a storage zone in a permeable pavement design).
- Key Properties:
thickness
,void_fraction
,k_saturated
(hydraulic conductivity in the storage zone),clog_factor
(captures deterioration or clogging over time).
- Setter Availability:
clog_factor
can be adjusted before or during the simulation. Other parameters are typically set before simulation.
4. Pavement
- Used for permeable pavement-related attributes.
- Key Properties:
thickness
,void_fraction
,impervious_fraction
,k_saturated
(permeability),clog_factor
,regeneration
,regeneration_degree
(represent how often and effectively the pavement is maintained or unclogged).
- Setter Availability:
- As with most layers, structural parameters (e.g.,
thickness
) are set before the simulation;clog_factor
is an exception that can be updated during runtime.
- As with most layers, structural parameters (e.g.,
5. Drain
- Models the underdrain or outlet of an LID, often found in rain barrels or bioretention cells with sub-surface drainage.
- Key Properties:
coefficient
,exponent
(determine flow rate from underdrain),offset
(height of the drain above the bottom),delay
(rain barrel drain delay time),open_head
/close_head
(head level triggers for opening or closing).
- Setter Availability:
- Underdrain parameters can typically be changed both before and during the simulation, enabling real-time control strategies.
6. DrainMat
- Represents a drainage mat layer, such as in green roofs, which can be placed beneath soil to provide a drainage path.
- Key Properties:
thickness
,void_fraction
,roughness
(akin to surface Manning’s n in the mat),alpha
(flow adjustment factor).
- Setter Availability:
- Similar to the other classes, with certain parameters (e.g.,
roughness
) potentially modifiable during runtime, while others (e.g.,thickness
,void_fraction
) must be set beforehand.
- Similar to the other classes, with certain parameters (e.g.,
Typical Usage
A standard workflow might look like this:
from pyswmm import Simulation, LidControls
with Simulation('example_lid_model.inp') as sim:
# Access a specific LID control by its name/ID
lid_control = LidControls(sim)['MyGreenRoof']
# Retrieve layer-specific handlers
surface_layer = lid_control.surface
soil_layer = lid_control.soil
drain_mat_layer = lid_control.drain_mat
# Inspect or change parameters:
print("Current surface roughness:", surface_layer.roughness)
surface_layer.roughness = 0.05
print("Soil porosity:", soil_layer.porosity)
soil_layer.porosity = 0.6
# Step through simulation to see if changes are recognized
for step in sim:
# Potentially update drain coefficients at runtime
pass
- Obtain
lid_control
fromLidControls(sim)
. - Access individual layers via properties like
lid_control.surface
orlid_control.soil
. - Get or set the desired property.
- If the property is allowed to change during the simulation, you can do so within the simulation loop.
Key Takeaways
- Layer-Specific Encapsulation: Each class (Surface, Soil, Storage, Pavement, Drain, DrainMat) isolates the parameters relevant to that part of the LID, making code more organized and readable.
- Property Getters/Setters: Provide a straightforward, Pythonic way to inspect and modify layer parameters without dealing with raw SWMM data structures.
- Pre-Simulation vs. Runtime Edits: Some parameters (e.g., thickness) can only be changed before the model runs, while others (e.g., drain coefficients) can also be changed during the simulation—an important distinction for real-time control or scenario testing.
- Deeper Integration: Used in tandem with
LidControls
andSimulation
classes, these layers form the backbone of how PySWMM manages LIDs, facilitating both design-time configuration and on-the-fly adjustments.
In short, these classes provide a powerful, granular interface to SWMM’s LID modeling capabilities, enabling a wide range of hydraulic/hydrologic and real-time control workflows in Python.