2.0.0b10
catchment modelling framework
Loading...
Searching...
No Matches
RectangularReach Class Reference

Describes a IChannel with a rectangular crosssection. More...

+ Inheritance diagram for RectangularReach:
+ Collaboration diagram for RectangularReach:

Detailed Description

Describes a IChannel with a rectangular crosssection.

Public Member Functions

 RectangularReach (double l, double width)
 Creates a new rectangular reach type with width [m].
 
virtual double A (double V) const
 Returns the area of the surface for a given volume.
 
virtual double get_channel_width (double depth) const
 Returns the width of the stream at a given depth.
 
virtual double get_depth (double area) const
 Returns the depth at a given crossection area.
 
virtual double get_flux_crossection (double depth) const
 Returns the crossection area at a given depth.
 
double get_length () const
 Length of the reach.
 
virtual double get_wetted_perimeter (double depth) const
 Returns the wetted perimeter at a given depth.
 
virtual double h (double V) const
 Returns the depth of a given volume.
 
virtual double qManning (double A, double slope) const
 Calculates the flow rate from a given water volume in the reach.
 

Member Function Documentation

◆ get_channel_width()

virtual double get_channel_width ( double depth) const
virtual

Returns the width of the stream at a given depth.

\begin{eqnarray*} w &=& const \end{eqnarray*}

Implements IChannel.

◆ get_depth()

virtual double get_depth ( double area) const
virtual

Returns the depth at a given crossection area.

\begin{eqnarray*} d &=& \frac A w \end{eqnarray*}

Implements IChannel.

◆ get_flux_crossection()

virtual double get_flux_crossection ( double depth) const
virtual

Returns the crossection area at a given depth.

\begin{eqnarray*} A &=& d w \end{eqnarray*}

Implements IChannel.

◆ get_wetted_perimeter()

virtual double get_wetted_perimeter ( double depth) const
virtual

Returns the wetted perimeter at a given depth.

\begin{eqnarray*} P &=& 2 d + w \end{eqnarray*}

Implements IChannel.

◆ qManning()

virtual double qManning ( double A,
double slope ) const
virtualinherited

Calculates the flow rate from a given water volume in the reach.

\begin{eqnarray*} q_{Manning}&=& A R^{\frac 2 3} \sqrt{\frac {\Delta_z} n} \\ A &=& \frac V l \mbox{, (Crosssectional area of the wetted crossection, Volume per length)} \\ R &=& \frac A {P(d)} \\ P(d) &=& \mbox{ the perimeter of the wetted crosssection, a function of reach depth} \\ d(V) &=& \mbox{ the depth of the reach a function of the volume} \\ \Delta_z &=& \frac{z_{max} - z_{min}}{l} \mbox{ Slope of the reach} \end{eqnarray*}

Returns
Flow rate [m3/s]
Parameters
AThe area of the cross section [m2]
slopeThe slope of the reach [m/m]