Structure Class |
Namespace: DHI.Mike1D.StructureModule
public abstract class Structure : IStructure, IDoubleProxy, IQuantityProxy, IDisposable, IExtensibleDataObject
The Structure type exposes the following members.
Name | Description | |
---|---|---|
dDischargedDownStreamWaterLevel |
Calculated Discharge derivative with DownStreamWaterLevel. Downstream is relative to the direction of chainage.
The value is calculated by SetWaterLevels.
Unit: [m^2/s]
| |
dDischargedUpStreamWaterLevel |
Calculated Discharge derivative with UpStreamWaterLevel. Upstream is relative to the direction of chainage.
The value is calculated by SetWaterLevels.
Unit: [m^2/s]
| |
Discharge |
Calculated Discharge. The value is calculated by SetWaterLevels.
Unit: [m^3/s]
| |
DownstreamWaterLevel |
Downstream water level.Downstream refers to the direction of chainage. The water level is set by use of
SetWaterLevels
Unit: [m]
| |
ExtensionData |
Property used by (de)serializer, when it can not find proper target for
a data field. Support of forward compatible data contracts.
| |
FlowArea |
Flow area through structure. Used by most (but not all) structures.
| |
ID |
Structure ID
| |
IDInUserUnit |
Used to get a consistent description of the structure. The ID comes in user units. Used e.g. when
reporting errors, warnings and hints.
| |
Implicit |
Flag to control if the structure is implicit or explicit. If the structure is explicit
(Implicit == false) then the derivatives of the dicharge are always zero.
Default value: true
| |
InvertLevelDownstream |
Invert level down stream
| |
InvertLevelUpstream |
Invert level up stream
| |
Length |
Length of the structure.
Unit: [m]
Default value: 0m
| |
Location |
Location property.
| |
RunTimeDiagnostics |
The getter is used to get a list of errors.
| |
SideStructureBank |
Bank side that side-structure is located on
If side structure contains reservoir, and has the Coordinate set, this is not used (and should be set to Undefined). | |
SideStructureReservoir |
Reservoir at end of side structure. Null if not side structure, or no reservoir is defined
| |
StructureType |
Type of structure
| |
TopoID |
String used to identified cross sections
| |
Type |
Structure type, unique for each type structure.
| |
UpstreamWaterLevel |
Upstream water level. Upstream refers to the direction of chainage. The water level is set by use of
SetWaterLevels
Unit: [m]
|
Name | Description | |
---|---|---|
Accepts |
List of data types that is accepted, i.e., that you can get a ValueSetter for.
| |
Description |
Return a string that describes this structure. Includes structure type and ID
| |
Dispose |
Frees the licenses held.
| |
Equals | Determines whether the specified object is equal to the current object. (Inherited from Object.) | |
ExplicitStructureSupport |
DEBUG: This method is called from Validate() if _implitcit == false to check if
the structure supports being Explicit.
Once all structures support explicit operation this method can be deleted.
| |
Finalize | Allows an object to try to free resources and perform other cleanup operations before it is reclaimed by garbage collection. (Inherited from Object.) | |
GetCrossSections |
Find upstream and downstream cross section from crossSectionData
at location.
If none exists, create an return a GetVeryLargeCrossSection | |
GetFlowCoefficient |
Calculation of fractions of the different flow types
| |
GetHashCode | Serves as a hash function for a particular type. (Inherited from Object.) | |
GetType | Gets the Type of the current instance. (Inherited from Object.) | |
Initialize(IStructureCollection, CrossSectionData, Boolean, IDiagnostics) |
Set up structure and set runtime diagnostics object
| |
Initialize(IStructureCollection, IBoundaryData, CrossSectionData, Boolean, IDiagnostics) |
Set up structure and set runtime diagnostics object
| |
Linearisation |
Makes linearisation for heads smaller than delH.
Note that it is assumed that the flow is positive
so this should be called before taking flow direction into account.
| |
MemberwiseClone | Creates a shallow copy of the current Object. (Inherited from Object.) | |
Offers |
A list of quantities available from this structure
| |
Prepare(HDParameterData, IDiagnostics) |
Set up structure and set runtime diagnostics object
| |
Prepare(DateTime, HDParameterData, IDiagnostics) |
Set up structure and set runtime diagnostics object
| |
SetControlStrategyId |
Set control strategy ID manually.
| |
SetInputWaterLevels | ||
SetWaterLevels(Double, Double) |
Sets up- and down- stream water level and forces the calculation of the discharge and its derivatives.
Override in extending classes to do something usefull. | |
SetWaterLevels(Double, Double, DateTime) | ||
SetZeroFlow |
Sets the conditions for zero flow
| |
SwitchFlowDirection |
Switches sign and derivatives. Should be used when flow direction is against increasing chainage
| |
ToString | Returns a string that represents the current object. (Inherited from Object.) | |
UpdatedWaterLevels |
After a time step (or iteration) has finished, update the discharge to the actual value, based
on the final water levels and the discharge derivatives.
| |
Validate |
Writes errors, warnings and hints into their respective member classes. The member objects are initially cleared.
| |
ValueFractionGetter |
Get value fraction setter for the specified data quantity
| |
ValueGetter |
Get value setter for the specified data quantity
| |
ValueGetterBoxed |
Get value setter for the specified data quantity
| |
ValueSetter |
Get value setter for the specified data type
| |
ValueSetterBoxed |
Get value setter for the specified data type
|
Name | Description | |
---|---|---|
_accepts |
List of quantities that are accepted
| |
_controlStategyId |
If the structure is being controlled, then _controlStategyId contains the ID of the
active control strategy
| |
_downstreamWaterLevel |
Downstream water level, as set by SetWaterLevels(Double, Double)
Unit: [m]
| |
_dqdhDownstream |
The derivative of flow through the structure with downstream water level. The flow is
calculated in the derived classes when the SetWaterLevels method is called.
Unit: [m2/sec]
| |
_dqdhUpstream |
The derivative of flow through the structure with upstream water level. The flow is
calculated in the derived classes when the SetWaterLevels method is called.
Unit: [m2/sec]
| |
_flowArea |
Flow area through structure. Used by most (but not all) structures.
| |
_flowDir |
FlowDir is used to determine which parameters to use for the flow calculations.
Derived by the SetWaterLevels(Double, Double).
| |
_id |
Identification name of the structure
| |
_implicit |
If _implicit == false, then the derivatives are always zero.
Default value: true.
| |
_location |
Location in the network
| |
_offers |
List of quantities that are offered
| |
_q |
Flow through the structure. The flow is calculated in the derived classes when the
SetWaterLevels method is called.
Unit: [m3/sec]
| |
_runTimeDiagnostics |
Diagnostics are written into this Diagnostics during calculations.
Set during [!:Initialize(DHI.Mike1D.CrossSectionModule.CrossSectionData,bool,DHI.Mike1D.Generic.IDiagnostics)] | |
_topoID |
Identification used to find referenced cross sections
| |
_upstreamWaterLevel |
Upstream water level, as set by SetWaterLevels(Double, Double)
Unit: [m]
| |
ZeroWaterLevelDifference |
The constant is used to define the lower limit for which we will try to calculate the flow and typically
more problematic the flow derivatives.
|
Name | Description | |
---|---|---|
Description |
Returns the description of the structure, if it is an Structure,
otherwise id + type
(Defined by StructureExtensions.) | |
Getter | From the proxy, return an IDoubleGetter for the specified quantity. It returns the first quantity of that type that is offered, and null if the quantity is not offered. | |
Getters |
Returns a set of IDoubleGetter for the quantity.
We can return several quantities with the same id (usually they will differ in their description).
If the quantity is not offerent, an empty list is returned.
(Defined by ProxyExtensions.) | |
GettersFraction |
Returns a set of IDoubleGetter for the quantity.
We can return several quantities with the same id (usually they will differ in their description).
If the quantity is not offerent, an empty list is returned.
(Defined by ProxyExtensions.) | |
GetterUnboxed | From the proxy, return an IDoubleGetter for the specified quantity. It returns the first quantity of that type that is offered, and null if the quantity is not offered. | |
Initialize(CrossSectionData, Boolean, IDiagnostics) | Overloaded.
Helper function for some unit tests. Do not use.
(Defined by StructureExtensions.) | |
Initialize(BoundaryData, CrossSectionData, Boolean, IDiagnostics) | Overloaded.
Helper function for some unit tests. Do not use.
(Defined by StructureExtensions.) | |
IsSideStructure |
Returns true if the structure is a side structure
(Defined by StructureExtensions.) | |
Setter | From the proxy, return an IDoubleGetSet for the specified quantity. It returns the first quantity of that type that is accepted, and null if the quantity is not accepted. |