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

Sunday, December 29, 2024

SWMM5 Delphi GUI Fraph.pas Summary

 Below is a high-level overview of Fgraph.pas, a Delphi unit from SWMM 5.2 that defines a form (TGraphForm) for displaying simulation results as either a time series plot or a scatter plot.


1. Purpose and Context

SWMM can display simulation results in various plot types. Fgraph.pas implements the TGraphForm (an MDI child form) that renders these plots (time series or scatter plots) using Delphi’s TeeChart library. It relies on routines in Ugraph.pas to handle the details of chart creation, styling, and data retrieval from SWMM’s binary output file.


2. The TGraphForm Class

2.1 Key Fields

  1. Chart1 (TChart):

    • The main TeeChart component.
    • Houses a set of data series used for plotting.
  2. Graph (TReportSelection record):

    • Stores selections (like object/variable, time range, plot type, etc.).
  3. TimeFactor, StartDate, EndDate:

    • Used for time series plots, to manage whether times appear in elapsed hours, days, or actual date/time format.
  4. OptionPage:

    • Determines which tab of a graph options dialog will initially show.
  5. XvarIndex, YvarIndex:

    • Indices in SWMM’s binary output data for the chosen variables (X and Y in a scatter plot).
  6. StartPeriod, EndPeriod, TotalPeriods:

    • Determine which range of simulation time steps to display.

2.2 Main Features

  1. Time Series Plot

    • Each object/variable combination is displayed as a separate series on Chart1.
    • X-axis can be actual dates/times or elapsed time.
    • The user can optionally show observed/calibration data if only one object is being plotted.
  2. Scatter Plot

    • Plots one variable vs. another for a single range of time steps.
    • A single data series is created, containing points of (Xvariable, Yvariable) for each time period.
  3. Creation and Refresh

    • CreateGraph is called once to set up the chart based on selected items:
      • For time series: creates multiple line or area series, one per object.
      • For scatter plot: creates a single point series.
    • RefreshGraph is called to retrieve new data after e.g. a re-run of the simulation.
    • Data are fetched from the SWMM binary output via Uoutput routines (like GetValue).
  4. Graph Options

    • Right-clicking on the chart calls SetGraphOptions, opening a Graph Options dialog (in Ugraph.pas) to change display styles.
    • Standard functionality for copying to clipboard or file, or printing, is available via CopyTo and Print.
  5. Mouse/Keyboard Interactions

    • Pressing Shift + left mouse button zooms in. Right-click triggers graph options.
    • Pressing Esc or close button frees the form.
    • A “lock” button toggles whether the plot auto-refreshes data after a new simulation.

2.3 Key Methods

  1. CreateGraph (Main entry point):

    • Takes a TReportSelection describing what to plot.
    • Decides if it’s a time series or scatter plot.
    • Builds the chart’s data series accordingly.
  2. RefreshGraph:

    • Re-fetches data from the simulation results if not locked.
    • For time series: calls RefreshTimeSeriesPlot.
    • For scatter: calls RefreshScatterPlot.
  3. RefreshTimeSeriesPlot:

    • Clears each data series, then loops over time periods from start to end, calling GetValue for each.
    • Optionally adds calibration data for observed vs. computed comparisons.
  4. RefreshScatterPlot:

    • Clears the single scatter series, again fetching X and Y values over time from the binary output.
  5. SetGraphOptions:

    • Launches a Graph Options dialog, letting the user change colors, grid style, fonts, axis scaling, etc.
  6. CopyTo and Print:

    • Provide ways to save or print the chart.

3. Summary

In Fgraph.pas, the TGraphForm is the specialized form for showing SWMM’s results as a time series or scatter plot. It integrates with SWMM’s output file reading, receives user’s plot selections from a TReportSelection, and displays the resulting chart with help from Ugraph.pas. By calling CreateGraph, RefreshGraph, SetGraphOptions, CopyTo, or Print, the rest of SWMM’s GUI manages how and when a chart is built, updated, exported, or printed.

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