Watershed Module overview

From Tygron Support wiki
Jump to navigation Jump to search


  • Watershed introduction.png

The watershed module calculates watersheds for rainfall based on a DTM or a calculated flow direction result of a Water Overlay. The watershed overlay can provide an indication into which waterway or -body rainfall will end up. Users can assign and group waterways and -bodies using discharge areas as input data. Additionally, culverts that connect waterways and bodies can be taken into account, which enables connected waterways and -bodies to be automatically assigned to the prioritized client-provided discharge areas. The general concept is:

  1. Rainfall simulation is done and generates a directional result.
  2. Discharge areas indicate the locations where rainfall will conceptually be discharged out of the system. Each discharge area will result in a watershed.
  3. Discharge areas are expanded along the waterways and culvert connections.
  4. Based on the direction the rainfall has moved in, the watersheds are gradually backtracked starting from the discharge areas. This is done for each watershed in parallel.
  5. On locations where the watersheds meet, the backtracking stops.
  6. The end result will be an overlay with unique id numbers corresponding to a watershed based on the initial discharge area.

This is the general concept, but there are variations on this concept:

  • Terrain height can be used instead of a rainfall simulation. However, this approach suffers more from local mini and oversegmentation.
  • Discharge areas are advised but not required. Optionally, each waterway and waterbody can be identified as a unique discharge area, in turn resulting into unique watersheds.


Historically, the calculation of watersheds for rainfall was done based on the gradient of the terrain. Issues occur when the terrain is near flat; it is not known where the rain water will flow and the direction will be assigned arbitrarily based on the used algorithm. Secondly, the terrain often contains a lot of local minimas, which results in the creation of too many unique watersheds (oversegmentation). To solve this, one would often apply filters to the terrain to remove these local minimas, but this required a lot of user judgement.

Fortunately, instead of using only the gradient of the terrain directly, we can also simulate rainfall using our Rainfall (Overlay) and use the Average Direction result to have a better idea of where the rain drops will end up based on momentum. Given that the rainfall is sufficiently large, this will remove local minima and solve most issues of unknown flow direction on flat surfaces.

Discharge Areas

In a water system model, the waterways generally catch the rainfall and transport it elsewhere, often out of the system. These waterways can be considered the end point of a rain drops travel overland and we could call them discharge waterways.

Expert users often have grouped multiple waterways together to make it easier for analysis and discussion. The Tygron Platform allows to import these groups as areas, which we conceptually call Discharge areas. Each discharge area will then result into a unique watershed.

In practice, the provided Discharge areas do not fully cover the waterways geometrically. We therefore added an initialization step in which water cells that are not yet assigned to any discharge area be automatically assigned to one when they are connected as a neighbour or by a culvert.

In absence of, or in addition to, discharge areas, users can also choose to automatically add discharge areas for each individual waterway and waterbody. However, when these waterways or bodies are still connected to a provided Discharge area, they can still be overwritten by this prioritized discharge area.


Since the propagation of discharge areas to neighboring waterways heavily relies on the connectivity of water system, culverts are important. Optionally, we could even restrict this propagation based on the direction of the flow through this culvert, allowing only the propagation from A to B when B flows to A.

Unfortunately, the available Geo data on the locations of culverts is often incomplete, containing mostly the most important culverts but missing the minor ones. We have therefore added a Water Connection Generator tool to automatically add culverts based on configured parameters. In general it deals with concepts such as:

  • culvert generally do not cross major roads, but can cross driveways on private plots;
  • culverts generally connect waterways, and not large water bodies;
  • culverts generally do not connect waterways of distinctly different heights or waterlevels;


Also note that culverts can now be generated using the Water Connection Generator.


  • Discharge remaining water: Create additional discharge areas for waterways and bodies that are not connected by culverts to discharge areas.
  • Minimal area: Only waterways and bodies with the required minimum size can become an additional discharge areas.
  • Discharge method:
    • Height minima: Restricted to height map input data
    • Water terrains: Restricted to directional data. Each water body is a separate discharge area.
    • Specific areas: Restricted to directional data. Provided discharge areas are prioritized and set as input for watersheds. Water bodies that are connected by culverts to discharge area water bodies are assigned to that discharge area as well. Depending on the option "Discharge remaining water", the remaining water bodies are stored as a separate discharge area.
  • Fill distance: unmatched cells are assigned to nearest watershed when within the provided distance.
  • Culvert flow direction: When active, a water body is only connected to an other water body when the first flows to the second.
  • Limit road: When active, the operation that assigns unmatched cells to the nearest watershed within the provided distance locally stops on cells that are roads.

Result Types

  • Watershed Overlay.png
  • Discharge areas result.jpg
  • Direction result type (Watershed Overlay).jpeg
  • Watershed base types.jpeg