From dd03138b59c033bc3fbdcf241e234715e794166e Mon Sep 17 00:00:00 2001 From: David Jansen Date: Mon, 24 Jun 2024 18:58:46 +0000 Subject: [PATCH] Update 'docs' folder with ci_updates and delete old branches. --- docs/ci_updates/syntax/HTML_correct_log.txt | 39676 +++++++++--------- docs/ci_updates/syntax/HTML_error_log.txt | 664 +- 2 files changed, 20170 insertions(+), 20170 deletions(-) diff --git a/docs/ci_updates/syntax/HTML_correct_log.txt b/docs/ci_updates/syntax/HTML_correct_log.txt index 07cc5f90e7..c885fbf58a 100644 --- a/docs/ci_updates/syntax/HTML_correct_log.txt +++ b/docs/ci_updates/syntax/HTML_correct_log.txt @@ -1,1967 +1,1351 @@ ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/GroundTemperatureResponse.mo ---- +---- AixLib/Fluid/FMI/UsersGuide.mo ---- -------- HTML Code -------- -

- This model calculates the ground temperature response to obtain the temperature - at the borehole wall in a geothermal system where heat is being injected into or - extracted from the ground. -

-

- A load-aggregation scheme based on that developed by Claesson and Javed (2012) is - used to calculate the borehole wall temperature response with the temporal superposition - of ground thermal loads. In its base form, the - load-aggregation scheme uses fixed-length aggregation cells to agglomerate - thermal load history together, with more distant cells (denoted with a higher cell and vector index) - representing more distant thermal history. The more distant the thermal load, the - less impactful it is on the borehole wall temperature change at the current time step. - Each cell has an aggregation time associated to it denoted by nu, - which corresponds to the simulation time (since the beginning of heat injection or - extraction) at which the cell will begin shifting its thermal load to more distant - cells. To determine nu, cells have a temporal size rcel - (rcel in this model) - which follows the exponential growth -

-

- \"image\" -

-

- where nCel is the number of consecutive cells which can have the same size. - Decreasing rcel will generally decrease calculation times, at the cost of - precision in the temporal superposition. rcel is expressed in multiples - of the aggregation time resolution (via the parameter tLoaAgg). - Then, nu may be expressed as the sum of all rcel values - (multiplied by the aggregation time resolution) up to and including that cell in question. -

-

- To determine the weighting factors, the borefield's temperature - step response at the borefield wall is determined as -

-

- \"image\" -

-

- where g(·) is the borefield's thermal response factor known as the g-function, - H is the total length of all boreholes and ks is the thermal - conductivity of the soil. The weighting factors kappa (κ in the equation below) - for a given cell i are then expressed as follows. -

-

- \"image\" -

-

- where ν refers to the vector nu in this model and - Tstep0)=0. -

-

- At every aggregation time step, a time event is generated to perform the load aggregation steps. - First, the thermal load is shifted. When shifting between cells of different size, total - energy is conserved. This operation is illustred in the figure below by Cimmino (2014). -

-

- \"image\" -

-

- After the cell-shifting operation is performed, the first aggregation cell has its - value set to the average thermal load since the last aggregation step. - Temporal superposition is then applied by means - of a scalar product between the aggregated thermal loads QAgg_flow and the - weighting factors κ. -

-

- Due to Modelica's variable time steps, the load aggregation scheme is modified by separating - the thermal response between the current aggregation time step and everything preceding it. - This is done according to -

-

- \"image\" -
- \"image\" -

-

- where Tb is the borehole wall temperature, - Tg - is the undisturbed ground temperature, - Q is the ground thermal load per borehole length and h = g/(2 π ks) - is a temperature response factor based on the g-function. tk - is the last discrete aggregation time step, meaning that the current time t - satisfies tk≤t≤tk+1. - Δtagg(=tk+1-tk) is the - parameter tLoaAgg in the present model. -

-

- Thus, - ΔTb*(t) - is the borehole wall temperature change due to the thermal history prior to the current - aggregation step. At every aggregation time step, load aggregation and temporal superposition - are used to calculate its discrete value. Assuming no heat injection or extraction until - tk+1, this term is assumed to have a linear - time derivative, which is given by the difference between ΔTb*(tk+1) - (the temperature change from load history at the next discrete aggregation time step, which - is constant over the duration of the ongoing aggregation time step) and the total - temperature change at the last aggregation time step, ΔTb(t). -

-

- \"image\" -

-

- The second term ΔTb,q(t) concerns the ongoing aggregation time step. - To obtain the time derivative of this term, the thermal response factor h is assumed - to vary linearly over the course of an aggregation time step. Therefore, because - the ongoing aggregation time step always concerns the first aggregation cell, its derivative (denoted - by the parameter dTStepdt in this model) can be calculated as - kappa[1], the first value in the kappa vector, - divided by the aggregation time step Δt. - The derivative of the temperature change at the borehole wall is then expressed - as the multiplication of dTStepdt (which only needs to be - calculated once at the start of the simulation) and the heat flow Q at - the borehole wall. -

-

- \"image\" -

-

- \"image\" -

-

- With the two terms in the expression of ΔTb(t) expressed - as time derivatives, ΔTb(t) can itself also be - expressed as its time derivative and implemented as such directly in the Modelica - equations block with the der() operator. -

-

- \"image\" -
- \"image\" -

-

- This load aggregation scheme is validated in - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.Validation.Analytic_20Years. -

-

References

-

- Cimmino, M. 2014. Développement et validation expérimentale de facteurs de réponse - thermique pour champs de puits géothermiques, - Ph.D. Thesis, École Polytechnique de Montréal. -

-

- Claesson, J. and Javed, S. 2012. A load-aggregation method to calculate extraction temperatures of borehole heat exchangers. ASHRAE Transactions 118(1): 530-539. -

- - - --------- Corrected Code -------- -

- This model calculates the ground temperature response to obtain the - temperature at the borehole wall in a geothermal system where heat is - being injected into or extracted from the ground. -

-

- A load-aggregation scheme based on that developed by Claesson and - Javed (2012) is used to calculate the borehole wall temperature - response with the temporal superposition of ground thermal loads. In - its base form, the load-aggregation scheme uses fixed-length - aggregation cells to agglomerate thermal load history together, with - more distant cells (denoted with a higher cell and vector index) - representing more distant thermal history. The more distant the - thermal load, the less impactful it is on the borehole wall - temperature change at the current time step. Each cell has an - aggregation time associated to it denoted by - nu, which corresponds to the simulation time (since the - beginning of heat injection or extraction) at which the cell will - begin shifting its thermal load to more distant cells. To determine - nu, cells have a temporal size rcel - (rcel in this model) which follows the exponential - growth -

-

- \"image\" -

-

- where nCel is the number of consecutive cells which - can have the same size. Decreasing rcel will - generally decrease calculation times, at the cost of precision in the - temporal superposition. rcel is expressed in multiples - of the aggregation time resolution (via the parameter - tLoaAgg). Then, nu may be expressed as the - sum of all rcel values (multiplied by the aggregation - time resolution) up to and including that cell in question. -

-

- To determine the weighting factors, the borefield's temperature step - response at the borefield wall is determined as -

-

- \"image\" -

-

- where g(·) is the borefield's thermal response factor known as - the g-function, H is the total length of all - boreholes and ks is the thermal conductivity of the - soil. The weighting factors kappa (κ in the - equation below) for a given cell i are then expressed as - follows. -

-

- \"image\" -

-

- where ν refers to the vector nu in this model and - Tstep0)=0. -

-

- At every aggregation time step, a time event is generated to perform - the load aggregation steps. First, the thermal load is shifted. When - shifting between cells of different size, total energy is conserved. - This operation is illustred in the figure below by Cimmino (2014). -

-

- \"image\" -

- After the cell-shifting operation is performed, the first aggregation - cell has its value set to the average thermal load since the last - aggregation step. Temporal superposition is then applied by means of - a scalar product between the aggregated thermal loads - QAgg_flow and the weighting factors κ. +This user's guide describes the FMI package (Wetter et al., 2015). +The FMI package has been implemented to facilitate the export +of thermofluid flow models such as HVAC components, HVAC systems +and thermal zones as Functional Mockup Units (FMUs). +This allows to export thermofluid flow models as FMUs so that they can be +imported in other simulators. +To export thermofluid flow components, a Modelica block is needed +in order for the model to only have input and output signals +rather than fluid connectors, as fluid connectors do not impose any causality +on the signal flow. +This package implements such blocks and its connectors.

- Due to Modelica's variable time steps, the load aggregation scheme is - modified by separating the thermal response between the current - aggregation time step and everything preceding it. This is done - according to -

-

- \"image\"
- - \"image\" +The main packages are as follows:

+ + + + + + + + + + + + + + + + + + + + +
PackageDescription
+ + AixLib.Fluid.FMI.ExportContainers + +

+ Package with blocks to export thermofluid flow components and systems. +

+

+ To export an HVAC component or system with a single inlet and outlet port, instantiate + + AixLib.Fluid.FMI.ExportContainers.ReplaceableTwoPort + with a replaceable model, + or extend from + + AixLib.Fluid.FMI.ExportContainers.PartialTwoPort + and add components.
+ See + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.Fan + and + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ResistanceVolume. +

+

+ To export an HVAC system that serves a single thermal zone, extend from + + AixLib.Fluid.FMI.ExportContainers.HVACZone + and add the HVAC system.
+ See + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone. +

+

+ To export an HVAC system that serves multiple thermal zones, extend from + + AixLib.Fluid.FMI.ExportContainers.HVACZones + and add the HVAC system.
+ See + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones. +

+

+ To export a single thermal zone, extend from + + AixLib.Fluid.FMI.ExportContainers.ThermalZone + and add the thermal zone.
+ See + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone. +

+

+ To export multiple thermal zones, extend from + + AixLib.Fluid.FMI.ExportContainers.ThermalZones + and add the thermal zone models.
+ See + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones. +

+
+ + AixLib.Fluid.FMI.Adaptors + +

+ Package with adaptors to connect models with fluid ports to blocks that + have input and output signals. +

+
+

+ + AixLib.Fluid.FMI.Conversion +

+
+

+ Package with blocks that convert between the signal connectors of + + AixLib.Fluid.FMI.Interfaces + and the real input and output signal connectors of the Modelica Standard Library. +

+
+ + AixLib.Fluid.FMI.Interfaces + +

+ Package with composite connectors that have different input and output + signals. These connectors are used to export FMUs, and they contain + quantities such as mass flow rate, temperature, optional pressure, etc. +

+

- where Tb is the borehole wall temperature, - Tg is the undisturbed ground temperature, Q - is the ground thermal load per borehole length and h = g/(2 π - ks) is a temperature response factor based on the - g-function. tk is the last discrete aggregation - time step, meaning that the current time t satisfies - tk≤t≤tk+1. - Δtagg(=tk+1-tk) is the - parameter tLoaAgg in the present model. +The package + +AixLib.Fluid.FMI.ExportContainers.Examples.FMUs +contains various examples in which HVAC components, HVAC systems +and thermal zones are exported as an FMU.

+

Typical use

- Thus, ΔTb*(t) is the borehole wall temperature - change due to the thermal history prior to the current aggregation - step. At every aggregation time step, load aggregation and temporal - superposition are used to calculate its discrete value. Assuming no - heat injection or extraction until tk+1, this term - is assumed to have a linear time derivative, which is given by the - difference between ΔTb*(tk+1) (the - temperature change from load history at the next discrete aggregation - time step, which is constant over the duration of the ongoing - aggregation time step) and the total temperature change at the last - aggregation time step, ΔTb(t). -

-

- \"image\" +Users who want to export a single thermofluid flow component, or a +subsystem of thermofluid flow components, can use the block + +AixLib.Fluid.FMI.ExportContainers.ReplaceableTwoPort. +This block has a fluid inlet, a fluid outlet, and a replaceable +component that can be replaced with an HVAC component or system that +has an inlet and outlet fluid port.

- The second term ΔTb,q(t) concerns the ongoing - aggregation time step. To obtain the time derivative of this term, - the thermal response factor h is assumed to vary linearly over - the course of an aggregation time step. Therefore, because the - ongoing aggregation time step always concerns the first aggregation - cell, its derivative (denoted by the parameter dTStepdt - in this model) can be calculated as kappa[1], the first - value in the kappa vector, divided by the aggregation - time step Δt. The derivative of the temperature change at the - borehole wall is then expressed as the multiplication of - dTStepdt (which only needs to be calculated once at the - start of the simulation) and the heat flow Q at the borehole - wall. -

-

- \"image\" -

-

- \"image\" +Users who want to export a whole HVAC system that serves a single thermal zone +can do so by extending the partial block + +AixLib.Fluid.FMI.ExportContainers.HVACZone. +The example + +AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone +illustrates how this can be accomplished.
+Similar export containers and examples are implemented for HVAC systems that serve multiple thermal zones.

- With the two terms in the expression of ΔTb(t) - expressed as time derivatives, ΔTb(t) can itself - also be expressed as its time derivative and implemented as such - directly in the Modelica equations block with the der() - operator. +Conversely, to export a thermal zone, users can extend the partial block + +AixLib.Fluid.FMI.ExportContainers.ThermalZone. +The example + +AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone +illustrates how this can be accomplished.
+Similar export containers and examples are implemented for models of multiple thermal zones.

-

- \"image\"
- - \"image\" +

+Each example and validation model has a Dymola script that +either simulates the model, or exports the model as an FMU. +The script can be invoked from the pull +down menu Commands -> Export FMU.

+

Options

- This load aggregation scheme is validated in - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.Validation.Analytic_20Years. +In the +AixLib.Fluid package, +most models have a boolean parameter called allowFlowReversal. +If set to true, then the flow can be in either direction, +otherwise it needs to be from the inlet to the outlet port. +This parameter is also used in the +AixLib.Fluid.FMI package. +The package was designed in such a way that an FMU, +if exported with allowFlowReversal=false +has as input the mass flow rate, +pressure and fluid properties of the inflowing fluid. The outputs +are the outlet mass flow rate, outlet pressure and the fluid +properties of the outflowing medium. This allows simulators +such as Ptolemy II +to evaluate the FMUs in the direction of the mass flow by first +setting all inputs, then evaluating the model equations, +and finally retrieving the +outputs before proceeding the simulation with the next downstream +component. +If allowFlowReversal=true, then the connectors have additional +signals for the properties of the fluid if it flows backwards.

-

- References -

- Cimmino, M. 2014. Développement et validation expérimentale de - facteurs de réponse thermique pour champs de puits géothermiques, - Ph.D. Thesis, École Polytechnique de Montréal. +Most components have a boolean parameter use_p_in. +If use_p_in=true, then the pressure is used from the +connector, and based on the mass flow rate, the outlet pressure +is computed and assigned to the outlet connectors. +If use_p_in=false, then the pressure as declared +by the constant p_default of the medium model is +used, and the component computes no pressure drop. +Setting use_p_in=false therefore leads to fewer +equations, but it requires a component that specifies the mass +flow rate, such as + +AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.IdealSource_m_flow.

+

Notes

- Claesson, J. and Javed, S. 2012. A load-aggregation method to - calculate extraction temperatures of borehole heat exchangers. - ASHRAE Transactions 118(1): 530-539. +Note the following when exporting HVAC component models as an FMU:

- - --------- Errors -------- -line 22 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 37 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 46 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 58 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 73 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 101 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 117 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 120 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 129 column 2 - Warning:

attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource_Erfint.mo ---- --------- HTML Code -------- - -

- This function evaluates the integral of the error function, given by: -

-

- \"image\" -

- - - --------- Corrected Code -------- +
    +
  1. - This function evaluates the integral of the error function, given by: +For models with control volumes, +the mass balance must be configured using +massDynamics=Modelica.Fluid.Types.Dynamics.SteadyState +when used with the media + +AixLib.Media.Air. +Otherwise, the translation stops with the error

    -

    - \"image\" +

    +The model requires derivatives of some inputs as listed below:
    +1 inlet.p
    +
    +

    +The reason is that for + +AixLib.Media.Air, +mass is proportional to pressure and pressure is proportional +to density. Hence, dm/dt requires dp/dt, +but the time derivative of the pressure is not an input to the model. +

    +

    +For +AixLib.Media.Water, this setting is not needed +as the mass is independent of pressure. +

    +
  2. +
  3. +

    +The model + +AixLib.Fluid.Movers.FlowControlled_m_flow +cannot be exported as an FMU. +This is because it assignes the mass flow rate. +However, the input connector + +AixLib.Fluid.FMI.Interfaces.Inlet +already declares the mass flow rate as an input. +Therefore, the mass flow rate is overdetermined. +As a fall back, if a user needs to set the mass flow rate, he/she can +do so by using + +AixLib.Fluid.FMI.Source_T, +which takes as an input signal the mass flow rate. +

    +
  4. +
+

+When connecting fluid flow components in a loop, +be careful to avoid circular assignments for example for the temperature, +as these can of course not be simulated. +An example of such an ill-posed problem is to connect the outlet of + +AixLib.Fluid.FixedResistances.PressureDrop +to its inlet. In this situation, neither pressure, nor mass flow rate or temperature +can be computed. To model such loops, a control volume with a dynamic energy +balance must be presented, and the medium needs to be compressible. +

+

References

+

+Michael Wetter, Marcus Fuchs and Thierry Stephane Nouidui.
+ +Design choices for thermofluid flow components and systems that are exported as Functional Mockup Units.
+Proc. of the 11th International Modelica Conference, + p. 31-41, + Versailles, France, September 2015.

- - --------- Errors -------- -line 5 column 2 - Warning:

attribute "align" not allowed for HTML5 - - ----- AixLib/BoundaryConditions/Validation/BESTEST/WD500.mo ---- --------- HTML Code -------- -

- -

WD500: Time Zone Case

-

Weather data file : WD500.epw

-

Table 1: Site Data for Weather file WD500epw

- - - - - - - - - - - - - - - - -

Latitude

28.567° north

Longitude

77.103° east

Altitude

236.9 m

Time Zone

5.5

- -------- Corrected Code -------- - -

- WD500: Time Zone Case -

- Weather data file : WD500.epw + This user's guide describes the FMI package (Wetter et al., 2015). + The FMI package has been implemented to facilitate the export of + thermofluid flow models such as HVAC components, HVAC systems and + thermal zones as Functional Mockup Units (FMUs). This allows to + export thermofluid flow models as FMUs so that they can be imported + in other simulators. To export thermofluid flow components, a + Modelica block is needed in order for the model to only have input + and output signals rather than fluid connectors, as fluid connectors + do not impose any causality on the signal flow. This package + implements such blocks and its connectors.

- Table 1: Site Data for Weather file WD500epw + The main packages are as follows:

- +
- - + + - - - - - - - - - -
-

- Latitude -

-
-

- 28.567° north -

-
+ Package + + Description +
-

- Longitude -

+ AixLib.Fluid.FMI.ExportContainers

- 77.103° east + Package with blocks to export thermofluid flow components and + systems.

-

- Altitude + To export an HVAC component or system with a single inlet and + outlet port, instantiate + AixLib.Fluid.FMI.ExportContainers.ReplaceableTwoPort with a + replaceable model, or extend from AixLib.Fluid.FMI.ExportContainers.PartialTwoPort + and add components.
+ See + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.Fan and + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ResistanceVolume.

-

- 236.9 m + To export an HVAC system that serves a single thermal zone, + extend from AixLib.Fluid.FMI.ExportContainers.HVACZone + and add the HVAC system.
+ See + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone.

-

- Time Zone + To export an HVAC system that serves multiple thermal zones, + extend from AixLib.Fluid.FMI.ExportContainers.HVACZones + and add the HVAC system.
+ See + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones.

-

- 5.5 + To export a single thermal zone, extend from AixLib.Fluid.FMI.ExportContainers.ThermalZone + and add the thermal zone.
+ See + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone. +

+

+ To export multiple thermal zones, extend from AixLib.Fluid.FMI.ExportContainers.ThermalZones + and add the thermal zone models.
+ See + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones.

-
- --------- Errors -------- -line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/Fluid/Types.mo ---- --------- HTML Code -------- - - -

- Enumeration to define the choice of valve flow coefficient - (to be selected via choices menu): -

- -
- - - - - - - - - - - - - - - -
EnumerationDescription
OpPointflow coefficient defined by ratio m_flow_nominal/sqrt(dp_nominal)
KvKv (metric) flow coefficient
CvCv (US) flow coefficient
AvAv (metric) flow coefficient
- -

- The details of the coefficients are explained in the - - Users Guide. -

- - -

- Enumeration that defines the heat exchanger construction. -

-

- The following heat exchanger configurations are available in this enumeration: -

- - - - - - - - -
EnumerationDescription
ParallelFlowParallel flow
CounterFlowCounter flow
CrossFlowUnmixedCross flow, both streams unmixed
CrossFlowStream1MixedStream2UnmixedCross flow, stream 1 mixed, stream 2 unmixed
CrossFlowStream1UnmixedStream2MixedCross flow, stream 1 unmixed, stream 2 mixed
ConstantTemperaturePhaseChangeConstant temperature phase change in one stream
-

- Note that for a given heat exchanger, the - HeatExchangerConfiguration is fixed. However, if the capacity - flow rates change, then the - - AixLib.Fluid.Types.HeatExchangerFlowRegime may change. For example, - a counter flow heat exchanger has HeatExchangerConfiguration=CounterFlow, - but the - AixLib.Fluid.Types.HeatExchangerFlowRegime can change to parallel flow if one of the two capacity flow rates reverts - its direction. -

- - - -

- Enumeration to define the heat exchanger flow regime. -

-

- This enumeration defines for the current capacity flow rate the kind of - heat transfer relation that will be used to compute the relation between - effectiveness and Number of Transfer Units. -

-

- The following heat exchanger flow regimes are available in this enumeration: -

- - - - - - - - -
EnumerationDescription
ParallelFlowParallel flow
CounterFlowCounter flow
CrossFlowUnmixedCross flow, both streams unmixed
CrossFlowCMinMixedCMaxUnmixedCross flow, CMin mixed, CMax unmixed
CrossFlowCMinUnmixedCMaxMixedCross flow, CMin unmixed, CMax mixed
ConstantTemperaturePhaseChangeConstant temperature phase change in one stream
- - - -

- This type allows defining which type of input should be used for movers. - This can either be -

-
    -
  1. - a constant set point declared by a parameter, -
  2. -
  3. - a series of possible set points that can be switched using an integer input, or -
  4. -
  5. - a continuously variable set point. -
  6. -
- - - -

- This package contains type definitions. -

- --------- Corrected Code -------- -

- Enumeration to define the choice of valve flow coefficient (to be - selected via choices menu): -

- - - - - - - -
- Enumeration - - Description -
- OpPoint - - flow coefficient defined by ratio m_flow_nominal/sqrt(dp_nominal)
- Kv + AixLib.Fluid.FMI.Adaptors - Kv (metric) flow coefficient +

+ Package with adaptors to connect models with fluid ports to + blocks that have input and output signals. +

- Cv +

+ AixLib.Fluid.FMI.Conversion +

- Cv (US) flow coefficient +

+ Package with blocks that convert between the signal connectors + of AixLib.Fluid.FMI.Interfaces + and the real input and output signal connectors of the Modelica + Standard Library. +

- Av + AixLib.Fluid.FMI.Interfaces - Av (metric) flow coefficient +

+ Package with composite connectors that have different input and + output signals. These connectors are used to export FMUs, and + they contain quantities such as mass flow rate, temperature, + optional pressure, etc. +

- The details of the coefficients are explained in the - Users Guide. + The package AixLib.Fluid.FMI.ExportContainers.Examples.FMUs + contains various examples in which HVAC components, HVAC systems and + thermal zones are exported as an FMU.

+

+ Typical use +

- Enumeration that defines the heat exchanger construction. + Users who want to export a single thermofluid flow component, or a + subsystem of thermofluid flow components, can use the block AixLib.Fluid.FMI.ExportContainers.ReplaceableTwoPort. + This block has a fluid inlet, a fluid outlet, and a replaceable + component that can be replaced with an HVAC component or system that + has an inlet and outlet fluid port.

- The following heat exchanger configurations are available in this - enumeration: + Users who want to export a whole HVAC system that serves a single + thermal zone can do so by extending the partial block AixLib.Fluid.FMI.ExportContainers.HVACZone. + The example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone + illustrates how this can be accomplished.
+ Similar export containers and examples are implemented for HVAC + systems that serve multiple thermal zones.

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- Enumeration - - Description -
- ParallelFlow - - Parallel flow -
- CounterFlow - - Counter flow -
- CrossFlowUnmixed - - Cross flow, both streams unmixed -
- CrossFlowStream1MixedStream2Unmixed - - Cross flow, stream 1 mixed, stream 2 unmixed -
- CrossFlowStream1UnmixedStream2Mixed - - Cross flow, stream 1 unmixed, stream 2 mixed -
- ConstantTemperaturePhaseChange - - Constant temperature phase change in one stream -

- Note that for a given heat exchanger, the - HeatExchangerConfiguration is fixed. However, if the - capacity flow rates change, then the AixLib.Fluid.Types.HeatExchangerFlowRegime - may change. For example, a counter flow heat exchanger has - HeatExchangerConfiguration=CounterFlow, but the AixLib.Fluid.Types.HeatExchangerFlowRegime - can change to parallel flow if one of the two capacity flow rates - reverts its direction. + Conversely, to export a thermal zone, users can extend the partial + block AixLib.Fluid.FMI.ExportContainers.ThermalZone. + The example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone + illustrates how this can be accomplished.
+ Similar export containers and examples are implemented for models of + multiple thermal zones.

-

- Enumeration to define the heat exchanger flow regime. + Each example and validation model has a Dymola script that either + simulates the model, or exports the model as an FMU. The script can + be invoked from the pull down menu Commands -> Export + FMU.

+

+ Options +

- This enumeration defines for the current capacity flow rate the kind - of heat transfer relation that will be used to compute the relation - between effectiveness and Number of Transfer Units. + In the AixLib.Fluid package, + most models have a boolean parameter called + allowFlowReversal. If set to true, then the + flow can be in either direction, otherwise it needs to be from the + inlet to the outlet port. This parameter is also used in the AixLib.Fluid.FMI package. The + package was designed in such a way that an FMU, if exported with + allowFlowReversal=false has as input the mass flow rate, + pressure and fluid properties of the inflowing fluid. The outputs are + the outlet mass flow rate, outlet pressure and the fluid properties + of the outflowing medium. This allows simulators such as Ptolemy II + to evaluate the FMUs in the direction of the mass flow by first + setting all inputs, then evaluating the model equations, and finally + retrieving the outputs before proceeding the simulation with the next + downstream component. If allowFlowReversal=true, then + the connectors have additional signals for the properties of the + fluid if it flows backwards.

- The following heat exchanger flow regimes are available in this - enumeration: + Most components have a boolean parameter use_p_in. If + use_p_in=true, then the pressure is used from the + connector, and based on the mass flow rate, the outlet pressure is + computed and assigned to the outlet connectors. If + use_p_in=false, then the pressure as declared by the + constant p_default of the medium model is used, and the + component computes no pressure drop. Setting + use_p_in=false therefore leads to fewer equations, but + it requires a component that specifies the mass flow rate, such as + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.IdealSource_m_flow.

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- Enumeration - - Description -
- ParallelFlow - - Parallel flow -
- CounterFlow - - Counter flow -
- CrossFlowUnmixed - - Cross flow, both streams unmixed -
- CrossFlowCMinMixedCMaxUnmixed - - Cross flow, CMin mixed, CMax unmixed -
- CrossFlowCMinUnmixedCMaxMixed - - Cross flow, CMin unmixed, CMax mixed -
- ConstantTemperaturePhaseChange - - Constant temperature phase change in one stream -
- +

+ Notes +

- This type allows defining which type of input should be used for - movers. This can either be + Note the following when exporting HVAC component models as an FMU:

    -
  1. a constant set point declared by a parameter, -
  2. -
  3. a series of possible set points that can be switched using an - integer input, or +
  4. +

    + For models with control volumes, the mass balance must be + configured using + massDynamics=Modelica.Fluid.Types.Dynamics.SteadyState + when used with the media AixLib.Media.Air. Otherwise, + the translation stops with the error +

    +
    +The model requires derivatives of some inputs as listed below:
    +1 inlet.p
    +
    +

    + The reason is that for AixLib.Media.Air, mass is + proportional to pressure and pressure is proportional to density. + Hence, dm/dt requires dp/dt, but the time + derivative of the pressure is not an input to the model. +

    +

    + For AixLib.Media.Water, this + setting is not needed as the mass is independent of pressure. +

  5. -
  6. a continuously variable set point. +
  7. +

    + The model AixLib.Fluid.Movers.FlowControlled_m_flow + cannot be exported as an FMU. This is because it assignes the + mass flow rate. However, the input connector AixLib.Fluid.FMI.Interfaces.Inlet + already declares the mass flow rate as an input. Therefore, the + mass flow rate is overdetermined. As a fall back, if a user needs + to set the mass flow rate, he/she can do so by using AixLib.Fluid.FMI.Source_T, + which takes as an input signal the mass flow rate. +

-

- This package contains type definitions. -

- --------- Errors -------- -line 8 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - -line 8 column 2 - Warning: The summary attribute on the
element is obsolete in HTML5 - + When connecting fluid flow components in a loop, be careful to avoid + circular assignments for example for the temperature, as these can of + course not be simulated. An example of such an ill-posed problem is + to connect the outlet of AixLib.Fluid.FixedResistances.PressureDrop + to its inlet. In this situation, neither pressure, nor mass flow rate + or temperature can be computed. To model such loops, a control volume + with a dynamic energy balance must be presented, and the medium needs + to be compressible. +

+

+ References +

+

+ Michael Wetter, Marcus Fuchs and Thierry Stephane Nouidui.
+ + Design choices for thermofluid flow components and systems that are + exported as Functional Mockup Units.
+ Proc. of the 11th International Modelica Conference, p. 31-41, + Versailles, France, September 2015. +

-line 13 column 2 - Warning: The summary attribute on the
element is obsolete in HTML5 +-------- Errors -------- +line 18 column 1 - Warning: The summary attribute on the
element is obsolete in HTML5 ----- AixLib/Fluid/Movers/Data/Pumps/Wilo/Stratos25slash1to6.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/infiniteLineSource.mo ---- -------- HTML Code -------- -

Data from - - http://productfinder.wilo.com/en/COM/product/00000018000028040002003a/fc_product_datasheet +

+ This function evaluates the infinite line source solution. This solution gives + the relation between the constant heat transfer rate (per unit length) injected + by a line heat source of infinite length and the temperature raise in the + medium. The infinite line source solution is defined by +

+

+ \"image\"

- The nominal rpm is arbitrarily chosen as the rpm of the pump curve - in the data sheet that has the highest rpm, - without being limited by the maximum power limitation - (see dotted curve on figure below). - Pump curves (H(m_flow) and P(m_flow)) from the data sheets - are digitized using - web plot digitizer. + where ΔT(t,r) is the temperature raise after a time t of + constant heat injection and at a distance r from the line source, + Q' is the heat injection rate per unit length, ks is + the soil thermal conductivity and hILS is the infinite line + source solution.

-

Limitations:

-

- The figure below illustrates a digitized pump curve. + The infinite line source solution is given by the exponential integral

- \"Pump

+ \"image\" +

+

+ where αs is the ground thermal diffusivity. The + exponential integral is implemented in + AixLib.Utilities.Math.Functions.exponentialIntegralE1. +

-------- Corrected Code --------

- Data from - http://productfinder.wilo.com/en/COM/product/00000018000028040002003a/fc_product_datasheet + This function evaluates the infinite line source solution. This + solution gives the relation between the constant heat transfer rate + (per unit length) injected by a line heat source of infinite length + and the temperature raise in the medium. The infinite line source + solution is defined by +

+

+ \"image\"

- The nominal rpm is arbitrarily chosen as the rpm of the pump curve in - the data sheet that has the highest rpm, without being limited by the - maximum power limitation (see dotted curve on figure below). Pump - curves (H(m_flow) and P(m_flow)) from the data sheets are digitized - using web plot - digitizer. + where ΔT(t,r) is the temperature raise after a time t + of constant heat injection and at a distance r from the line + source, Q' is the heat injection rate per unit length, + ks is the soil thermal conductivity and + hILS is the infinite line source solution.

-

- Limitations: -

-

- The figure below illustrates a digitized pump curve. + The infinite line source solution is given by the exponential + integral

- \"Pump + \"image\" +

+

+ where αs is the ground thermal diffusivity. The + exponential integral is implemented in AixLib.Utilities.Math.Functions.exponentialIntegralE1.

-------- Errors -------- -line 27 column 2 - Warning:

attribute "align" not allowed for HTML5 +line 8 column 2 - Warning:

attribute "align" not allowed for HTML5 +line 21 column 2 - Warning:

attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/FourElements.mo ---- +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT.mo ---- -------- HTML Code -------- +

+ The example contains + + experimental data from a real district heating network. + This data is used to validate this library's + + AixLib.Fluid.FixedResistances.PlugFlowPipe in + + AixLib.Fluid.FixedResistances.Validation.PlugFlowPipes.PlugFlowAIT. + This model compares its performance with the original Modelica Standard Library + pipes, using one discretization element per unit length of pipe. + For a coarser discretization, please refer to + + MSLAIT2Nodes. +

+

+ Note that these three models are identical, except for the pipe model that is used: +

+

+ This comparison between different discretization levels and pipe models is made + to check the influence of the discretization and pipe model on computation time + and simulation accuracy. +

+

The pipes' temperatures are not initialized, thus results of outflow + temperature before approximately the first 10000 seconds should not be considered. +

+

Test bench schematic

+

\"Schematic

+

Calibration

+

To calculate the length specific thermal resistance R of the + pipe, the thermal resistance of the surrounding ground is added.

+

+ R=1/(0.208)+1/(2   lambda_g   Modelica.Constants.pi)   log(1/0.18)

+

+ Where the thermal conductivity of the ground lambda_g = 2.4 W/(m K). +

+ + -

- This model adds another element for the roof. Roofs commonly - exhibit the same excitations as exterior walls but have different coefficients - of heat transfer due to their orientation. Adding an extra element for the roof - might lead to a finer resolution of the dynamic behaviour but increases - calculation times. The roof is parameterized via the length of the RC-chain - nRoof, - the vector of capacities CRoof[nRoof], the vector of resistances - RRoof[nRoof] and remaining resistances RRoofRem. -

-

- The image below shows the RC-network of this model. -

-

- \"image\"/ -

- -------- Corrected Code -------- -
+ + + + + + + + + + + + + + + +

Latitude

28.567° north

Longitude

77.103° east

Altitude

236.9 m

Time Zone

5.5

+ -------- Corrected Code -------- -

- This example is identical to AixLib.Fluid.Movers.Validation.PowerSimplified, - except that the performance data for the flow controlled pumps - pump_dp and pump_m_flow contain the - pressure curves and efficiency curves. The plot below shows that this - leads to a computation of the power consumption that is identical to - the one from the speed controlled pump pump_Nrpm. -

-

- \"image\" -

- --------- Errors -------- -line 12 column 2 - Warning:

attribute "align" not allowed for HTML5 - - ----- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/splitFacVal.mo ---- --------- HTML Code -------- - -

Calculates the ratio of the surface areas of a wall to the total wall area, - unless the area is zero. It subtracts the wall area AExt - for first entry in AArray and AWin for - second entry in AArray unless AArray[1] and/or - AArray[2] are not zero. This is done separately for each - orientation. Consequently, the function gives an nRow x nCol - array back as output. Each row stands for one area in - AArray and each column for one orientation in - AExt and AWin. The function is used to - calculate the split factors for - - AixLib.ThermalZones.ReducedOrder.RC.BaseClasses.ThermSplitter.

- For internal gains, the calculation is: -

- SplitFaci = AArray[i] - /ATot -

- whereby ATot is the sum of AArray. To - perform this, - AExt and AWin can just be set to vectors of - zeros with length 1. - For solar radiation through windows, the window and wall area with the same - orientation as the incoming radiation should be subtracted as these areas - cannot be hit by the radiation. This needs to be done separately for each - orientation and for exterior walls and windows only, according to: -

- SplitFaci,k = (AArray[i] - - AExt[k]) - /(ATot - - AExt[k] - -AWin[k]) -

- and -

- SplitFaci,k = (AArray[i] - - AWin[k]) - /(ATot - - AExt[k] - - AWin[k]) -

- respectively. For all other walls, the equation is: -

- SplitFaci,k = AArray[i] - /(ATot - - AExt[k] - - AWin[k]) -

- - - --------- Corrected Code -------- +

+ WD500: Time Zone Case +

- Calculates the ratio of the surface areas of a wall to the total wall - area, unless the area is zero. It subtracts the wall area - AExt for first entry in AArray and - AWin for second entry in AArray unless - AArray[1] and/or AArray[2] are not zero. - This is done separately for each orientation. Consequently, the - function gives an nRow x nCol array back as output. Each - row stands for one area in AArray and each column for - one orientation in AExt and AWin. The - function is used to calculate the split factors for AixLib.ThermalZones.ReducedOrder.RC.BaseClasses.ThermSplitter. -

For internal gains, the calculation is: -

- SplitFaci = AArray[i] /ATot -

whereby ATot is the sum of AArray. To -perform this, AExt and AWin can just be set -to vectors of zeros with length 1. For solar radiation through windows, -the window and wall area with the same orientation as the incoming -radiation should be subtracted as these areas cannot be hit by the -radiation. This needs to be done separately for each orientation and -for exterior walls and windows only, according to: -

- SplitFaci,k = (AArray[i] - AExt[k]) /(ATot - AExt[k] - -AWin[k]) -

and -

- SplitFaci,k = (AArray[i] - AWin[k]) /(ATot - AExt[k] - - AWin[k]) -

respectively. For all other walls, the equation is: -

- SplitFaci,k = AArray[i] /(ATot - AExt[k] - AWin[k]) + Weather data file : WD500.epw

- +

+ Table 1: Site Data for Weather file WD500epw +

+ + + + + + + + + + + + + + + + + +
+

+ Latitude +

+
+

+ 28.567° north +

+
+

+ Longitude +

+
+

+ 77.103° east +

+
+

+ Altitude +

+
+

+ 236.9 m +

+
+

+ Time Zone +

+
+

+ 5.5 +

+
-------- Errors -------- -line 15 column 4 - Warning:

attribute "align" not allowed for HTML5 -line 27 column 4 - Warning:

attribute "align" not allowed for HTML5 -line 35 column 4 - Warning:

attribute "align" not allowed for HTML5 -line 43 column 4 - Warning:

attribute "align" not allowed for HTML5 +line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Media/Water.mo ---- +---- AixLib/Fluid/HeatPumps/Compressors/ReciprocatingCompressor.mo ---- -------- HTML Code --------

- Model with basic thermodynamic properties. -

-

- This base properties model is identical to - - Modelica.Media.Water.ConstantPropertyLiquidWater, - except that the equation - u = cv_const*(T - reference_T) - has been replaced by u=h because - cp_const=cv_const. -

-

- This model provides equation for the following thermodynamic properties: + Model for a reciprocating processor, as detailed in Jin (2002). The rate of heat transferred to the evaporator is given by:

-
- - - - - - - - - - - - - - - - - - - - - - - - - - - -
VariableUnitDescription
TKtemperature
pPaabsolute pressure
dkg/m3density
hJ/kgspecific enthalpy
uJ/kgspecific internal energy
Xi[nXi]kg/kgindependent mass fractions m_i/m
RJ/kg.Kgas constant
Mkg/molmolar mass
- -

- Enthalpy of the water. +

+ Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ).

- - -

- This medium package models liquid water. + The power consumed by the compressor is given by a linear efficiency relation:

-

- The mass density is computed using a constant value of 995.586 kg/s. - For a medium model in which the density is a function of temperature, use - - AixLib.Media.Specialized.Water.TemperatureDependentDensity which may have considerably higher computing time. +

+ P = PTheoretical / η + PLoss,constant.

- For the specific heat capacities at constant pressure and at constant volume, - a constant value of 4184 J/(kg K), which corresponds to 20°C - is used. - The figure below shows the relative error of the specific heat capacity that - is introduced by this simplification. -

-

- \"Relative + Variable speed is acheived by multiplying the full load piston displacement + by the normalized compressor speed. The power and heat transfer rates are forced + to zero if the resulting heat pump state has higher evaporating pressure than + condensing pressure.

+

Assumptions and limitations

- The enthalpy is computed using the convention that h=0 - if T=0 °C. + The compression process is assumed isentropic. The thermal energy + of superheating is ignored in the evaluation of the heat transferred to the refrigerant + in the evaporator. There is no supercooling.

-

Limitations

+

References

- Density, specific heat capacity, thermal conductivity and viscosity are constant. - Water is modeled as an incompressible liquid. - There are no phase changes. + H. Jin. + + Parameter estimation based models of water source heat pumps. + + PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002.

+ +-------- Corrected Code -------- +

+ Model for a reciprocating processor, as detailed in Jin (2002). The + rate of heat transferred to the evaporator is given by: +

+

+ Q̇Eva = ṁref ( + hVap(TEva) - hLiq(TCon) + ). +

+

+ The power consumed by the compressor is given by a linear efficiency + relation: +

+

+ P = PTheoretical / η + PLoss,constant. +

+

+ Variable speed is acheived by multiplying the full load piston + displacement by the normalized compressor speed. The power and heat + transfer rates are forced to zero if the resulting heat pump state + has higher evaporating pressure than condensing pressure. +

+

+ Assumptions and limitations +

+

+ The compression process is assumed isentropic. The thermal energy of + superheating is ignored in the evaluation of the heat transferred to + the refrigerant in the evaporator. There is no supercooling. +

+

+ References +

+

+ H. Jin. Parameter estimation based models of water source heat + pumps. PhD Thesis. Oklahoma State University. Stillwater, + Oklahoma, USA. 2002. +

+ + +-------- Errors -------- +line 5 column 2 - Warning:

attribute "align" not allowed for HTML5 +line 11 column 2 - Warning:

attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Interfaces/PrescribedOutlet.mo ---- +-------- HTML Code -------- + +

+ This model sets the temperature or the water vapor mass fraction + of the medium that leaves port_a + to the value given by the input TSet or X_wSet, + subject to optional limitations on the capacity + for heating and cooling, or limitations on the humidification or dehumidification + moisture mass flow rate. + Also, optionally the model allows to take into account first order dynamics. +

+

+ If the parameters energyDynamics is not equal to + Modelica.Fluid.Types.Dynamics.SteadyState, + the component models the dynamic response using a first order differential equation. + The time constant of the component is equal to the parameter tau. + This time constant is adjusted based on the mass flow rate using +

+

+ τeff = τ |ṁ| ⁄ ṁnom +

+

+ where + τeff is the effective time constant for the given mass flow rate + and + τ is the time constant at the nominal mass flow rate + nom. + This type of dynamics is equal to the dynamics that a completely mixed + control volume would have. +

+

+ This model has no pressure drop. + See + AixLib.Fluid.HeatExchangers.PrescribedOutlet + for a model that instantiates this model and that has a pressure drop. +

+

+ In case of reverse flow, + the fluid that leaves port_a has the same + properties as the fluid that enters port_b. +

+ + -------- Corrected Code --------

- Model with basic thermodynamic properties. + This model sets the temperature or the water vapor mass fraction of + the medium that leaves port_a to the value given by the + input TSet or X_wSet, subject to optional + limitations on the capacity for heating and cooling, or limitations + on the humidification or dehumidification moisture mass flow rate. + Also, optionally the model allows to take into account first order + dynamics.

- This base properties model is identical to Modelica.Media.Water.ConstantPropertyLiquidWater, - except that the equation u = cv_const*(T - reference_T) - has been replaced by u=h because - cp_const=cv_const. + If the parameters energyDynamics is not equal to + Modelica.Fluid.Types.Dynamics.SteadyState, the component + models the dynamic response using a first order differential + equation. The time constant of the component is equal to the + parameter tau. This time constant is adjusted based on + the mass flow rate using +

+

+ τeff = τ |ṁ| ⁄ ṁnom

- This model provides equation for the following thermodynamic - properties: -

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- Variable - - Unit - - Description -
- T - - K - - temperature -
- p - - Pa - - absolute pressure -
- d - - kg/m3 - - density -
- h - - J/kg - - specific enthalpy -
- u - - J/kg - - specific internal energy -
- Xi[nXi] - - kg/kg - - independent mass fractions m_i/m -
- R - - J/kg.K - - gas constant -
- M - - kg/mol - - molar mass -
-

- Enthalpy of the water. -

- -

- This medium package models liquid water. -

-

- The mass density is computed using a constant value of 995.586 - kg/s. For a medium model in which the density is a function of - temperature, use - AixLib.Media.Specialized.Water.TemperatureDependentDensity which - may have considerably higher computing time. -

-

- For the specific heat capacities at constant pressure and at constant - volume, a constant value of 4184 J/(kg K), which corresponds - to 20°C is used. The figure below shows the relative error of - the specific heat capacity that is introduced by this simplification. -

-

- - + where τeff is the effective time constant for the + given mass flow rate and τ is the time constant at + the nominal mass flow rate nom. This type of + dynamics is equal to the dynamics that a completely mixed control + volume would have.

- The enthalpy is computed using the convention that h=0 if - T=0 °C. + This model has no pressure drop. See AixLib.Fluid.HeatExchangers.PrescribedOutlet + for a model that instantiates this model and that has a pressure + drop.

-

- Limitations -

- Density, specific heat capacity, thermal conductivity and viscosity - are constant. Water is modeled as an incompressible liquid. There are - no phase changes. + In case of reverse flow, the fluid that leaves port_a + has the same properties as the fluid that enters port_b.

-------- Errors -------- -line 17 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - line 18 column 2 - Warning:

attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Humidifiers/SteamHumidifier_X.mo ---- +---- AixLib/Fluid/Chillers/BaseClasses/Carnot.mo ---- -------- HTML Code --------

- Model for a steam humidifier with a prescribed outlet water vapor mass fraction - in kg/kg total air. + This is the base class for the Carnot chiller and the Carnot heat pump + whose coefficient of performance COP changes + with temperatures in the same way as the Carnot efficiency changes.

- This model forces the outlet water mass fraction at port_b to be - no lower than the - input signal X_wSet, subject to optional limits on the - maximum water vapor mass flow rate that is added, as - described by the parameter mWatMax_flow. - By default, the model has unlimited capacity. + The model allows to either specify the Carnot effectivness + ηCarnot,0, or + a COP0 + at the nominal conditions, together with + the evaporator temperature Teva,0 and + the condenser temperature Tcon,0, in which + case the model computes the Carnot effectivness as

-

- The output signal mWat_flow ≥ 0 is the moisture added - to the medium if the flow rate is from port_a to port_b. - If the flow is reversed, then mWat_flow = 0. - The outlet specific enthalpy at port_b is increased by - the enthalpy of steam at 100°C times the mass of steam that was added. - Therefore, the temperature of the leaving fluid is slightly above the inlet temperature. +

+ ηCarnot,0 = + COP0 + ⁄ (Tuse,0 ⁄ (Tcon,0-Teva,0)),

- The outlet conditions at port_a are not affected by this model, - other than for a possible pressure difference due to flow friction. + where + Tuse is the temperature of the the useful heat, + e.g., the evaporator temperature for a chiller or the condenser temperature + for a heat pump.

- If the parameter energyDynamics is different from - Modelica.Fluid.Types.Dynamics.SteadyState, - the component models the dynamic response using a first order differential equation. - The time constant of the component is equal to the parameter tau. - This time constant is adjusted based on the mass flow rate using + The COP is computed as the product

- τeff = τ |ṁ| ⁄ ṁnom + COP = ηCarnot,0 COPCarnot ηPL,

- where - τeff is the effective time constant for the given mass flow rate - and - τ is the time constant at the nominal mass flow rate - nom. - This type of dynamics is equal to the dynamics that a completely mixed - control volume would have. + where COPCarnot is the Carnot efficiency and + ηPL is the part load efficiency, expressed using + a polynomial. + This polynomial has the form

-

- Optionally, this model can have a flow resistance. - Set dp_nominal = 0 to disable the flow friction calculation. +

+ ηPL = a1 + a2 y + a3 y2 + ...

- For a model that uses a control signal u ∈ [0, 1] and multiplies - this with the nominal water mass flow rate, use - - AixLib.Fluid.Humidifiers.Humidifier_u - + where y ∈ [0, 1] is + either the part load for cooling in case of a chiller, or the part load of heating in + case of a heat pump, and the coefficients ai + are declared by the parameter a.

-

Limitations

+

Implementation

- This model only adds water vapor for the flow from - port_a to port_b. - The water vapor of the reverse flow is not affected by this model. + To make this base class applicable to chiller or heat pumps, it uses + the boolean constant COP_is_for_cooling. + Depending on its value, the equations for the coefficient of performance + and the part load ratio are set up.

- --------- Corrected Code -------- -

- Model for a steam humidifier with a prescribed outlet water vapor - mass fraction in kg/kg total air. -

-

- This model forces the outlet water mass fraction at - port_b to be no lower than the input signal - X_wSet, subject to optional limits on the maximum water - vapor mass flow rate that is added, as described by the parameter - mWatMax_flow. By default, the model has unlimited - capacity. -

-

- The output signal mWat_flow ≥ 0 is the moisture added to - the medium if the flow rate is from port_a to - port_b. If the flow is reversed, then mWat_flow = - 0. The outlet specific enthalpy at port_b is - increased by the enthalpy of steam at 100°C times the mass of - steam that was added. Therefore, the temperature of the leaving fluid - is slightly above the inlet temperature. -

-

- The outlet conditions at port_a are not affected by this - model, other than for a possible pressure difference due to flow - friction. -

-

- If the parameter energyDynamics is different from - Modelica.Fluid.Types.Dynamics.SteadyState, the component - models the dynamic response using a first order differential - equation. The time constant of the component is equal to the - parameter tau. This time constant is adjusted based on - the mass flow rate using -

-

- τeff = τ |ṁ| ⁄ ṁnom -

-

- where τeff is the effective time constant for the - given mass flow rate and τ is the time constant at - the nominal mass flow rate nom. This type of - dynamics is equal to the dynamics that a completely mixed control - volume would have. -

-

- Optionally, this model can have a flow resistance. Set - dp_nominal = 0 to disable the flow friction calculation. -

-

- For a model that uses a control signal u ∈ [0, 1] and - multiplies this with the nominal water mass flow rate, use AixLib.Fluid.Humidifiers.Humidifier_u -

-

- Limitations -

-

- This model only adds water vapor for the flow from - port_a to port_b. The water vapor of the - reverse flow is not affected by this model. -

- - --------- Errors -------- -line 33 column 2 - Warning:

attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/HeatPumps/Carnot_TCon.mo ---- --------- HTML Code -------- - -

- This is a model of a heat pump whose coefficient of performance COP changes - with temperatures in the same way as the Carnot efficiency changes. - The control input is the setpoint of the condenser leaving temperature, which - is met exactly at steady state if the heat pump has sufficient capacity. -

-

- The model allows to either specify the Carnot effectivness - ηCarnot,0, or - a COP0 - at the nominal conditions, together with - the evaporator temperature Teva,0 and - the condenser temperature Tcon,0, in which - case the model computes the Carnot effectivness as -

-

- ηCarnot,0 = - COP0 - ⁄ (Tcon,0 ⁄ (Tcon,0-Teva,0)). -

-

- The heat pump COP is computed as the product -

-

- COP = ηCarnot,0 COPCarnot ηPL, -

-

- where COPCarnot is the Carnot efficiency and - ηPL is a polynomial in heating part load ratio yPL - that can be used to take into account a change in COP at part load - conditions. - This polynomial has the form -

-

- ηPL = a1 + a2 yPL + a3 yPL2 + ... -

-

- where the coefficients ai - are declared by the parameter a. -

-

- On the Dynamics tag, the model can be parametrized to compute a transient - or steady-state response. - The transient response of the model is computed using a first - order differential equation for the evaporator and condenser fluid volumes. - The heat pump outlet temperatures are equal to the temperatures of these lumped volumes. -

-

Typical use and important parameters

-

- When using this component, make sure that the condenser has sufficient mass flow rate. - Based on the evaporator mass flow rate, temperature difference and the efficiencies, - the model computes how much heat will be removed by to the evaporator. - If the mass flow rate is too small, very low outlet temperatures can result, possibly below freezing. -

-

- The condenser heat flow rate QCon_flow_nominal is used to assign - the default value for the mass flow rates, which are used for the pressure drop - calculations. - It is also used to compute the part load efficiency. - Hence, make sure that QCon_flow_nominal is set to a reasonable value. -

-

- The maximum heating capacity is set by the parameter QCon_flow_max, - which is by default set to infinity. -

-

- The coefficient of performance depends on the - evaporator and condenser leaving temperature - since otherwise the second law of thermodynamics may be violated. -

-

Notes

-

- For a similar model that can be used as a chiller, see - - AixLib.Fluid.Chillers.Examples.Carnot_TEva. -

- - -------- Corrected Code --------

- This is a model of a heat pump whose coefficient of performance COP - changes with temperatures in the same way as the Carnot efficiency - changes. The control input is the setpoint of the condenser leaving - temperature, which is met exactly at steady state if the heat pump - has sufficient capacity. + This is the base class for the Carnot chiller and the Carnot heat + pump whose coefficient of performance COP changes with temperatures + in the same way as the Carnot efficiency changes.

The model allows to either specify the Carnot effectivness @@ -1972,1167 +1356,496 @@ line 33 column 2 - Warning:

attribute "align" not allowed for HTML5 effectivness as

- ηCarnot,0 = COP0 ⁄ (Tcon,0 ⁄ - (Tcon,0-Teva,0)). + ηCarnot,0 = COP0 ⁄ (Tuse,0 ⁄ + (Tcon,0-Teva,0)),

- The heat pump COP is computed as the product + where Tuse is the temperature of the the useful + heat, e.g., the evaporator temperature for a chiller or the condenser + temperature for a heat pump. +

+

+ The COP is computed as the product

COP = ηCarnot,0 COPCarnot ηPL,

where COPCarnot is the Carnot efficiency and - ηPL is a polynomial in heating part load ratio - yPL that can be used to take into account a change - in COP at part load conditions. This polynomial has the form + ηPL is the part load efficiency, expressed using a + polynomial. This polynomial has the form

- ηPL = a1 + a2 yPL + - a3 yPL2 + ... -

-

- where the coefficients ai are declared by the - parameter a. + ηPL = a1 + a2 y + a3 + y2 + ...

- On the Dynamics tag, the model can be parametrized to - compute a transient or steady-state response. The transient response - of the model is computed using a first order differential equation - for the evaporator and condenser fluid volumes. The heat pump outlet - temperatures are equal to the temperatures of these lumped volumes. + where y ∈ [0, 1] is either the part load for cooling in case + of a chiller, or the part load of heating in case of a heat pump, and + the coefficients ai are declared by the parameter + a.

- Typical use and important parameters + Implementation

- When using this component, make sure that the condenser has - sufficient mass flow rate. Based on the evaporator mass flow rate, - temperature difference and the efficiencies, the model computes how - much heat will be removed by to the evaporator. If the mass flow rate - is too small, very low outlet temperatures can result, possibly below - freezing. -

-

- The condenser heat flow rate QCon_flow_nominal is used - to assign the default value for the mass flow rates, which are used - for the pressure drop calculations. It is also used to compute the - part load efficiency. Hence, make sure that - QCon_flow_nominal is set to a reasonable value. -

-

- The maximum heating capacity is set by the parameter - QCon_flow_max, which is by default set to infinity. -

-

- The coefficient of performance depends on the evaporator and - condenser leaving temperature since otherwise the second law of - thermodynamics may be violated. -

-

- Notes -

-

- For a similar model that can be used as a chiller, see AixLib.Fluid.Chillers.Examples.Carnot_TEva. + To make this base class applicable to chiller or heat pumps, it uses + the boolean constant COP_is_for_cooling. Depending on + its value, the equations for the coefficient of performance and the + part load ratio are set up.

-------- Errors -------- -line 17 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 25 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 35 column 2 - Warning:

attribute "align" not allowed for HTML5 +line 16 column 2 - Warning:

attribute "align" not allowed for HTML5 +line 30 column 2 - Warning:

attribute "align" not allowed for HTML5 +line 39 column 2 - Warning:

attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/timeGeometric.mo ---- +---- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/InteriorWall.mo ---- -------- HTML Code -------- -

- This function attemps to build a vector of length nTim with a geometric - expansion of the time variable between dt and t_max. -

-

- If t_max > nTim*dt, then a geometrically expanding vector is built as -

-

- t = [dt, dt*(1-r2)/(1-r), ... , dt*(1-rn)/(1-r), ... , tmax], -

-

- where r is the geometric expansion factor. -

-

- If t_max < nTim*dt, then a linearly expanding vector is built as -

-

- t = [dt, 2*dt, ... , n*dt, ... , nTim*dt] -

- - - +

InteriorWall represents heat storage within walls. It links a + variable number n of thermal resistances and capacities to a + series connection. n thus defines the spatial discretization of + thermal effects within the wall. All effects are considered as one-dimensional + normal to the wall's surface. This model is thought for interior wall + elements that only serve as heat storage elements. The RC-chain is defined via + a vector of capacities CInt[n] and a vector of resistances + RInt[n]. + Resistances and capacities are connected alternately, starting with the first + resistance RInt[1], from heat port_a into the wall. +

+

\"image\"/

+ + + -------- Corrected Code --------

- This function attemps to build a vector of length nTim - with a geometric expansion of the time variable between - dt and t_max. -

-

- If t_max > nTim*dt, then a geometrically expanding - vector is built as -

-

- t = [dt, dt*(1-r2)/(1-r), ... , - dt*(1-rn)/(1-r), ... , tmax], -

-

- where r is the geometric expansion factor. -

-

- If t_max < nTim*dt, then a linearly expanding vector - is built as + InteriorWall represents heat storage within walls. It + links a variable number n of thermal resistances and + capacities to a series connection. n thus defines the + spatial discretization of thermal effects within the wall. All + effects are considered as one-dimensional normal to the wall's + surface. This model is thought for interior wall elements that only + serve as heat storage elements. The RC-chain is defined via a vector + of capacities CInt[n] and a vector of resistances + RInt[n]. Resistances and capacities are connected + alternately, starting with the first resistance RInt[1], + from heat port_a into the wall.

- t = [dt, 2*dt, ... , n*dt, ... , nTim*dt] + \"image\"

-------- Errors -------- -line 9 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 18 column 2 - Warning:

attribute "align" not allowed for HTML5 +line 13 column 4 - Warning:

attribute "align" not allowed for HTML5 ----- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_m_flow.mo ---- +---- AixLib/Fluid/Movers/UsersGuide.mo ---- -------- HTML Code -------- -

- Function that computes the pressure drop of flow elements as -

-

- Δp = sign(m) (m ⁄ k)2 -

-

- with regularization near the origin. - Therefore, the flow coefficient is -

-

- k = m ⁄ √ Δp   -

-

- The input m_flow_turbulent determines the location of the regularization. -

- - - --------- Corrected Code --------

- Function that computes the pressure drop of flow elements as -

-

- Δp = sign(m) (m ⁄ k)2 +This package contains models for fans and pumps. The same models +are used for fans or pumps.

-

- with regularization near the origin. Therefore, the flow coefficient - is -

-

- k = m ⁄ √ Δp -   -

-

- The input m_flow_turbulent determines the location of - the regularization. -

- - --------- Errors -------- -line 5 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 12 column 2 - Warning:

attribute "align" not allowed for HTML5 - ----- AixLib/Fluid/Sensors/SensibleEnthalpyFlowRate.mo ---- --------- HTML Code -------- - -

- This model outputs the sensible enthalphy flow rate of the medium in the flow - between its fluid ports. In particular, if the total enthalpy flow rate is -

-

- Ḣtot = Ḣsen + Ḣlat, -

-

- where - sen = ṁ (1-Xw) cp,air, - then this sensor outputs Ḣ = Ḣsen. -

- -

- If the parameter tau is non-zero, then the measured - specific sensible enthalpy hout that is used to - compute the sensible enthalpy flow rate - sen = ṁ hout - is computed using a first order differential equation. - See - AixLib.Fluid.Sensors.UsersGuide for an explanation. -

- -

- For a sensor that measures - tot, use - - AixLib.Fluid.Sensors.EnthalpyFlowRate.
- For a sensor that measures - lat, use - - AixLib.Fluid.Sensors.LatentEnthalpyFlowRate. -

- -

- The sensor is ideal, i.e., it does not influence the fluid. - The sensor can only be used with medium models that implement the function - enthalpyOfNonCondensingGas(T).

- - - - --------- Corrected Code -------- -

- This model outputs the sensible enthalphy flow rate of the - medium in the flow between its fluid ports. In particular, if the - total enthalpy flow rate is +

Model description

+

A detailed description of the fan and pump models can be +found in +Wetter (2013). +The models are implemented as described in this paper, except +that equation (20) is no longer used. The reason is that +the transition (24) caused the derivative

- Ḣtot = Ḣsen + Ḣlat, -

-

- where sen = ṁ (1-Xw) - cp,air, then this sensor outputs Ḣ = - Ḣsen. + d Δp(r(t), V(t)) ⁄ d r(t)

- If the parameter tau is non-zero, then the measured - specific sensible enthalpy hout that is used to - compute the sensible enthalpy flow rate sen = ṁ - hout is computed using a first order differential - equation. See AixLib.Fluid.Sensors.UsersGuide - for an explanation. +to have an inflection point in the regularization region +r(t) ∈ (δ/2, δ). +This caused some models to not converge. +To correct this, for r(t) < δ, +the term V(t) ⁄ r(t) in (16) +has been modified so that (16) can be used for any +value of r(t).

- For a sensor that measures tot, use AixLib.Fluid.Sensors.EnthalpyFlowRate.
- - For a sensor that measures lat, use AixLib.Fluid.Sensors.LatentEnthalpyFlowRate. +Below, the models are briefly described.

+
Performance data

- The sensor is ideal, i.e., it does not influence the fluid. The - sensor can only be used with medium models that implement the - function enthalpyOfNonCondensingGas(T). +The models use +performance curves that compute pressure rise, +electrical power draw and efficiency as a function +of the volume flow rate and the speed. +The following performance curves are implemented: +

+
+ + + + + + + + + + + + + + + + + + + + + + + + +
Independent variableDependent variableRecord for performance dataFunction
Volume flow ratePressure +flowParameters +pressure
Volume flow rateEfficiency +efficiencyParameters +efficiency
Volume flow ratePower* +powerParameters +power
+

*Note: This record should not be used +(i.e. use_powerCharacteristic should be false) +for the movers that take as a control signal +the mass flow rate or the head, +unless also values for the record pressure are provided. +The reason is that for these movers the record pressure +is required to be able to compute the mover speed, +which is required to be able to compute the electrical power +correctly using similarity laws. +If a Pressure record is not provided, +the model will internally override use_powerCharacteristic=false. +In this case the efficiency records will be used. +Note that in this case an error is still introduced, +but it is smaller than when using the power records. +Compare + +AixLib.Fluid.Movers.Validation.PowerSimplified +with + +AixLib.Fluid.Movers.Validation.PowerExact +for an illustration of this error. +

+

+These performance curves are implemented in + +AixLib.Fluid.Movers.BaseClasses.Characteristics, +and are used in the performance records in the package + +AixLib.Fluid.Movers.Data. +The package + +AixLib.Fluid.Movers.Data +contains different data records. +

+
Models that use performance curves for pressure rise
+

+The models + +AixLib.Fluid.Movers.SpeedControlled_y and + +AixLib.Fluid.Movers.SpeedControlled_Nrpm +take as an input either a control signal between 0 and 1, or the +rotational speed in units of [1/min]. From this input and the current flow rate, +they compute the pressure rise. +This pressure rise is computed using a user-provided list of operating points that +defines the fan or pump curve at full speed. +For other speeds, similarity laws are used to scale the performance curves, as +described in + +AixLib.Fluid.Movers.BaseClasses.Characteristics.pressure.

- - --------- Errors -------- -line 6 column 2 - Warning:

attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Actuators/BaseClasses/exponentialDamper.mo ---- --------- HTML Code -------- -

- This function computes the opening characteristics of an exponential damper. -

- The function is used by the model - - AixLib.Fluid.Actuators.Dampers.Exponential. -

- For yL < y < yU, the damper characteristics is -

-

- kd(y) = exp(a+b (1-y)). -

-

- Outside this range, the damper characteristic is defined by a quadratic polynomial. -

-

- Note that this implementation returns sqrt(kd(y)) instead of kd(y). - This is done for numerical reason since otherwise kd(y) may be an iteration - variable, which may cause a lot of warnings and slower convergence if the solver - attempts kd(y) < 0 during the iterative solution procedure. -

- - - --------- Corrected Code --------

- This function computes the opening characteristics of an exponential - damper. +For example, suppose a pump needs to be modeled whose pressure versus flow relation crosses, at +full speed, the points shown in the table below.

+ + + + + + + + + + + + + + + + + +
Volume flow rate [m3⁄s] Head [Pa]
0.000345000
0.000635000
0.000815000

- The function is used by the model AixLib.Fluid.Actuators.Dampers.Exponential. +Then, a declaration would be

+
+  AixLib.Fluid.Movers.SpeedControlled_y pum(
+    redeclare package Medium = Medium,
+    per.pressure(V_flow={0.0003,0.0006,0.0008},
+                 dp    ={45,35,15}*1000))
+    \"Circulation pump\";
+
+

- For yL < y < yU, the damper characteristics is +This will model the following pump curve for the pump input signal y=1.

-

- kd(y) = exp(a+b (1-y)). +

+\"image\"

+ +
Models that directly control the head or the mass flow rate

- Outside this range, the damper characteristic is defined by a - quadratic polynomial. +The models +AixLib.Fluid.Movers.FlowControlled_dp and + +AixLib.Fluid.Movers.FlowControlled_m_flow +take as an input the pressure difference or the mass flow rate. +This pressure difference or mass flow rate will be provided by the fan or pump, +i.e., the fan or pump has idealized perfect control and infinite capacity. +Using these models that take as an input the head or the mass flow rate often leads +to smaller system of equations compared to using the models that take +as an input the speed.

- Note that this implementation returns sqrt(kd(y)) - instead of kd(y). This is done for numerical reason - since otherwise kd(y) may be an iteration variable, - which may cause a lot of warnings and slower convergence if the - solver attempts kd(y) < 0 during the iterative - solution procedure. +These models can be configured for three different control inputs. +For + +AixLib.Fluid.Movers.FlowControlled_dp, +the head is as follows:

- --------- Errors -------- -line 11 column 2 - Warning:

attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowHeatLoss.mo ---- --------- HTML Code -------- - -

- Component that calculates the heat losses at the end of a plug flow pipe - when the flow goes in the design direction. -

-

Main equations

-

- The governing equations are -

-

- Tout = Tb + (Tin - Tb) - exp((tout - tin)/tauchar) -

-

- with -

-

- tauchar = R C -

-

Assumptions and limitations

-

- This model is based on the following assumptions: -

- -

Implementation

-

- Heat losses are only considered in design flow direction. - For heat loss consideration in both directions, use one of these models at - both ends of a - - AixLib.Fluid.FixedResistances.BaseClasses.PlugFlow model. - The outlet temperature is calculated as in the equation above, - using the inlet temperature at port_a and the instantaneous - time delay and boundary temperature. - The boundary temperature can be either the air temperature - or the undisturbed ground temperature, depending on the definition of the - thermal resistance R. -

-

- This component requires the delay time and the instantaneous ambient temperature - as an input. - This component is to be used in single pipes or in more advanced configurations - where no influence from other pipes is considered.

- - - --------- Corrected Code -------- +
  • - Component that calculates the heat losses at the end of a plug flow - pipe when the flow goes in the design direction. +If the parameter inputType==AixLib.Fluid.Types.InputType.Continuous, +the head is dp=dp_in, where dp_in is an input connector.

    -

    - Main equations -

    +
  • +
  • - The governing equations are -

    -

    - Tout = Tb + (Tin - Tb) - exp((tout - tin)/tauchar) +If the parameter inputType==AixLib.Fluid.Types.InputType.Constant, +the head is dp=constantHead, where constantHead is a parameter.

    +
  • +
  • - with -

    -

    - tauchar = R C +If the parameter inputType==AixLib.Fluid.Types.InputType.Stages, +the head is dp=heads, where heads is a +vectorized parameter. For example, if a mover has +two stages and the head of the first stage should be 60% of the nominal head +and the second stage equal to dp_nominal, set +heads={0.6, 1}*dp_nominal. +Then, the mover will have the following heads:

    -

    - Assumptions and limitations -

    + + + + + + + + + + + + + + + + + +
    input signal stageHead [Pa]
    00
    10.6*dp_nominal
    2dp_nominal
    +
  • +

    - This model is based on the following assumptions: +Similarly, for + +AixLib.Fluid.Movers.FlowControlled_m_flow, +the mass flow rate is as follows:

    -

    - Implementation -

    +
  • - Heat losses are only considered in design flow direction. For heat - loss consideration in both directions, use one of these models at - both ends of a AixLib.Fluid.FixedResistances.BaseClasses.PlugFlow - model. The outlet temperature is calculated as in the equation above, - using the inlet temperature at port_a and the - instantaneous time delay and boundary temperature. The boundary - temperature can be either the air temperature or the undisturbed - ground temperature, depending on the definition of the thermal - resistance R. +If the parameter inputType==AixLib.Fluid.Types.InputType.Continuous, +the mass flow rate is m_flow=m_flow_in, where m_flow_in is an input connector.

    +
  • +
  • - This component requires the delay time and the instantaneous ambient - temperature as an input. This component is to be used in single pipes - or in more advanced configurations where no influence from other - pipes is considered. +If the parameter inputType==AixLib.Fluid.Types.InputType.Constant, +the mass flow rate is m_flow=constantMassFlowRate, where constantMassFlowRate is a parameter.

    - - --------- Errors -------- -line 10 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 17 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Utilities/Math/QuadraticLinear.mo ---- --------- HTML Code -------- - -

    Block for function quadraticLinear, which computes

    -

    y = a1 + a2 x1 + a3 x12 + (a4 + a5 x1 + a6 x12) x2

    - - - --------- Corrected Code -------- +
  • +
  • - Block for function quadraticLinear, which computes -

    -

    - y = a1 + a2 x1 + a3 x12 + (a4 + a5 x1 + a6 x12) x2 +If the parameter inputType==AixLib.Fluid.Types.InputType.Stages, +the mass flow rate is m_flow=massFlowRates, where massFlowRates is a +vectorized parameter. For example, if a mover has +two stages and the mass flow rate of the first stage should be 60% of the nominal mass flow rate +and the second stage equal to m_flow_nominal, set +massFlowRates={0.6, 1}*m_flow_nominal. +Then, the mover will have the following mass flow rates:

    - - --------- Errors -------- -line 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Movers/UsersGuide.mo ---- --------- HTML Code -------- -

    -This package contains models for fans and pumps. The same models -are used for fans or pumps. -

    - -

    Model description

    -

    A detailed description of the fan and pump models can be -found in -Wetter (2013). -The models are implemented as described in this paper, except -that equation (20) is no longer used. The reason is that -the transition (24) caused the derivative -

    -

    - d Δp(r(t), V(t)) ⁄ d r(t) -

    -

    -to have an inflection point in the regularization region -r(t) ∈ (δ/2, δ). -This caused some models to not converge. -To correct this, for r(t) < δ, -the term V(t) ⁄ r(t) in (16) -has been modified so that (16) can be used for any -value of r(t). -

    -

    -Below, the models are briefly described. -

    -
    Performance data
    -

    -The models use -performance curves that compute pressure rise, -electrical power draw and efficiency as a function -of the volume flow rate and the speed. -The following performance curves are implemented: -

    - - - - - - - - - - - - - - - - - - - - - - - - - -
    Independent variableDependent variableRecord for performance dataFunction
    Volume flow ratePressure -flowParameters -pressure
    Volume flow rateEfficiency -efficiencyParameters -efficiency
    Volume flow ratePower* -powerParameters -power
    -

    *Note: This record should not be used -(i.e. use_powerCharacteristic should be false) -for the movers that take as a control signal -the mass flow rate or the head, -unless also values for the record pressure are provided. -The reason is that for these movers the record pressure -is required to be able to compute the mover speed, -which is required to be able to compute the electrical power -correctly using similarity laws. -If a Pressure record is not provided, -the model will internally override use_powerCharacteristic=false. -In this case the efficiency records will be used. -Note that in this case an error is still introduced, -but it is smaller than when using the power records. -Compare - -AixLib.Fluid.Movers.Validation.PowerSimplified -with - -AixLib.Fluid.Movers.Validation.PowerExact -for an illustration of this error. -

    -

    -These performance curves are implemented in - -AixLib.Fluid.Movers.BaseClasses.Characteristics, -and are used in the performance records in the package - -AixLib.Fluid.Movers.Data. -The package - -AixLib.Fluid.Movers.Data -contains different data records. -

    -
    Models that use performance curves for pressure rise
    -

    -The models - -AixLib.Fluid.Movers.SpeedControlled_y and - -AixLib.Fluid.Movers.SpeedControlled_Nrpm -take as an input either a control signal between 0 and 1, or the -rotational speed in units of [1/min]. From this input and the current flow rate, -they compute the pressure rise. -This pressure rise is computed using a user-provided list of operating points that -defines the fan or pump curve at full speed. -For other speeds, similarity laws are used to scale the performance curves, as -described in - -AixLib.Fluid.Movers.BaseClasses.Characteristics.pressure. -

    - -

    -For example, suppose a pump needs to be modeled whose pressure versus flow relation crosses, at -full speed, the points shown in the table below. -

    - - - - - - - - - - - - - - - - - -
    Volume flow rate [m3⁄s] Head [Pa]
    0.000345000
    0.000635000
    0.000815000
    +These two models do not need to use a performance curve for the flow +characteristics. +The reason is that

    +

    -Then, a declaration would be +However, the computation of the electrical power consumption +requires the mover speed to be known +and the computation of the mover speed requires the performance +curves for the flow and efficiency/power characteristics. +Therefore these performance curves do need to be provided +if the user desires a correct electrical power computation. +If the curves are not provided, a simplified computation is used, +where the efficiency curve is used and assumed to be correct for all speeds. +This loss of accuracy has the advantage that it allows to use the +mover models without requiring flow and efficiency/power characteristics.

    -
    -  AixLib.Fluid.Movers.SpeedControlled_y pum(
    -    redeclare package Medium = Medium,
    -    per.pressure(V_flow={0.0003,0.0006,0.0008},
    -                 dp    ={45,35,15}*1000))
    -    \"Circulation pump\";
    -
    -

    -This will model the following pump curve for the pump input signal y=1. -

    -

    -\"image\" +The model +AixLib.Fluid.Movers.FlowControlled_dp +has an option to control the mover such +that the pressure difference set point is obtained +across two remote points in the system. +To use this functionality +parameter prescribeSystemPressure has +to be enabled and a differential pressure measurement +must be connected to +the pump input dpMea. +This functionality is demonstrated in + +AixLib.Fluid.Movers.Validation.FlowControlled_dpSystem.

    - -
    Models that directly control the head or the mass flow rate

    The models AixLib.Fluid.Movers.FlowControlled_dp and AixLib.Fluid.Movers.FlowControlled_m_flow -take as an input the pressure difference or the mass flow rate. -This pressure difference or mass flow rate will be provided by the fan or pump, -i.e., the fan or pump has idealized perfect control and infinite capacity. -Using these models that take as an input the head or the mass flow rate often leads -to smaller system of equations compared to using the models that take -as an input the speed. -

    -

    -These models can be configured for three different control inputs. -For - -AixLib.Fluid.Movers.FlowControlled_dp, -the head is as follows: +both have a parameter m_flow_nominal. For + +AixLib.Fluid.Movers.FlowControlled_m_flow, this parameter +is used for convenience to set a default value for the parameters +constantMassFlowRate and +massFlowRates. +For both models, the value is also used for the following:

    +

    -Similarly, for - -AixLib.Fluid.Movers.FlowControlled_m_flow, -the mass flow rate is as follows: -

    - -

    -These two models do not need to use a performance curve for the flow -characteristics. -The reason is that

    - -

    -However, the computation of the electrical power consumption -requires the mover speed to be known -and the computation of the mover speed requires the performance -curves for the flow and efficiency/power characteristics. -Therefore these performance curves do need to be provided -if the user desires a correct electrical power computation. -If the curves are not provided, a simplified computation is used, -where the efficiency curve is used and assumed to be correct for all speeds. -This loss of accuracy has the advantage that it allows to use the -mover models without requiring flow and efficiency/power characteristics. -

    -

    -The model -AixLib.Fluid.Movers.FlowControlled_dp -has an option to control the mover such -that the pressure difference set point is obtained -across two remote points in the system. -To use this functionality -parameter prescribeSystemPressure has -to be enabled and a differential pressure measurement -must be connected to -the pump input dpMea. -This functionality is demonstrated in - -AixLib.Fluid.Movers.Validation.FlowControlled_dpSystem. -

    -

    -The models -AixLib.Fluid.Movers.FlowControlled_dp and - -AixLib.Fluid.Movers.FlowControlled_m_flow -both have a parameter m_flow_nominal. For - -AixLib.Fluid.Movers.FlowControlled_m_flow, this parameter -is used for convenience to set a default value for the parameters -constantMassFlowRate and -massFlowRates. -For both models, the value is also used for the following: -

    - - -

    -However, otherwise m_flow_nominal does not affect the mass flow rate of the mover as -the mass flow rate is determined by the input signal or the above explained parameters. +However, otherwise m_flow_nominal does not affect the mass flow rate of the mover as +the mass flow rate is determined by the input signal or the above explained parameters.

    Start-up and shut-down transients

    @@ -4014,1255 +2727,1462 @@ line 473 column 1 - Warning:

    attribute "align" not allowed for HTML5 line 484 column 1 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowAIT.mo ---- +---- AixLib/BoundaryConditions/Validation/BESTEST/WD400.mo ---- -------- HTML Code -------- -

    - The example contains - experimental data from a real district heating network. -

    -

    The pipes' temperatures are not initialized. Therefore, results of - outflow temperature before approximately the first 10000 seconds should not be - considered. -

    -

    - Note that these three models are identical, except for the pipe model that is used: -

    -

    - This comparison between different discretization levels and pipe models is made - to check the influence of the discretization and pipe model on computation time - and simulation accuracy. -

    -

    Test bench schematic

    -

    \"Schematic -

    -

    Calibration

    -

    To calculate the length specific thermal resistance R of the pipe, - the thermal resistance of the surrounding ground is added, which yields

    -

    - R=1/(0.208)+1/(2   lambda_g   Modelica.Constants.pi)   log(1/0.18),

    -

    where the thermal conductivity of the ground lambda_g = 2.4 W/(m K). -

    - - +

    WD400: High Latitude Case

    +

    Weather data file : WD400.epw

    +

    Table 1: Site Data for Weather file WD400.epw

    + + + + + + + + + + + + + + + + +

    Latitude

    71.286° north

    Longitude

    156.767° west

    Altitude

    10 m

    Time Zone

    -9

    + -------- Corrected Code -------- -

    - The example contains experimental data from a real district heating - network. -

    -

    - The pipes' temperatures are not initialized. Therefore, results of - outflow temperature before approximately the first 10000 seconds - should not be considered. -

    -

    - Note that these three models are identical, except for the pipe model - that is used: -

    +

    + WD400: High Latitude Case +

    - This comparison between different discretization levels and pipe - models is made to check the influence of the discretization and pipe - model on computation time and simulation accuracy. -

    -

    - Test bench schematic -

    -

    - \"Schematic -

    -

    - Calibration -

    -

    - To calculate the length specific thermal resistance R of - the pipe, the thermal resistance of the surrounding ground is added, - which yields -

    -

    - R=1/(0.208)+1/(2   lambda_g   Modelica.Constants.pi)   - log(1/0.18), + Weather data file : WD400.epw

    - where the thermal conductivity of the ground lambda_g = - 2.4 W/(m K). + Table 1: Site Data for Weather file WD400.epw

    - + + + + + + + + + + + + + + + + + +
    +

    + Latitude +

    +
    +

    + 71.286° north +

    +
    +

    + Longitude +

    +
    +

    + 156.767° west +

    +
    +

    + Altitude +

    +
    +

    + 10 m +

    +
    +

    + Time Zone +

    +
    +

    + -9 +

    +
    -------- Errors -------- -line 48 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Fluid/Movers/BaseClasses/Characteristics/power.mo ---- +---- AixLib/Fluid/HeatExchangers/SensibleCooler_T.mo ---- -------- HTML Code --------

    - This function computes the fan power consumption for given volume flow rate, - speed and performance data. The power consumption is + Model for an ideal sensible-only cooler that controls its outlet temperature to + a prescribed outlet temperature. +

    +

    + This model forces the outlet temperature at port_b to be + no higher than the temperature of the input signal + TSet, subject to optional limits on the + capacity. + By default, the model has unlimited cooling capacity. +

    +

    + The output signal Q_flow ≤ 0 is the heat added + to the medium if the mass flow rate is from port_a to port_b. + If the flow is reversed, then Q_flow=0. +

    +

    + The outlet conditions at port_a are not affected by this model, + other than for a possible pressure difference due to flow friction. +

    +

    + If the parameter energyDynamics is different from + Modelica.Fluid.Types.Dynamics.SteadyState, + the component models the dynamic response using a first order differential equation. + The time constant of the component is equal to the parameter tau. + This time constant is adjusted based on the mass flow rate using

    - P = rN3   s(V̇/rN, d), + τeff = τ |ṁ| ⁄ ṁnom

    where - P is the power consumption, - rN is the normalized fan speed, - is the volume flow rate and - d are performance data for fan or pump power consumption at rN=1. + τeff is the effective time constant for the given mass flow rate + and + τ is the time constant at the nominal mass flow rate + nom. + This type of dynamics is equal to the dynamics that a completely mixed + control volume would have.

    -

    Implementation

    - The function s(·, ·) is a cubic hermite spline. - If the data d define a monotone decreasing sequence, then - s(·, d) is a monotone decreasing function. + Optionally, this model can have a flow resistance. + Set dp_nominal = 0 to disable the flow friction calculation. +

    +

    + For a similar model that is a heater, use + + AixLib.Fluid.HeatExchangers.Heater_T. + For a model that uses a control signal u ∈ [0, 1] and multiplies + this with the nominal heating or cooling power, use + + AixLib.Fluid.HeatExchangers.HeaterCooler_u. +

    +

    Limitations

    +

    + If the flow is from port_b to port_a, + then the enthalpy of the medium is not affected by this model. +

    +

    + This model does not affect the humidity of the air. Therefore, + if used to cool air below the dew point temperature, the water mass fraction + will not change. +

    +

    Validation

    +

    + The model has been validated against the analytical solution in + the examples + + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet + and + + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic.

    • - February 26, 2014, by Filip Jorissen:
      - Changed polynomial to be evaluated at V_flow/r_N - instead of V_flow to properly account for the - scaling law. See - #202 - for a discussion and validation. + September 10, 2018, by Michael Wetter:
      + Corrected missing propagation of initial conditions.
      + This is for + + AixLib, #1016.
    • - September 28, 2011, by Michael Wetter:
      - First implementation. + May 3, 2017, by Michael Wetter:
      + First implementation.
      + This is for + + AixLib, #763.
    -------- Corrected Code --------

    - This function computes the fan power consumption for given volume - flow rate, speed and performance data. The power consumption is + Model for an ideal sensible-only cooler that controls its outlet + temperature to a prescribed outlet temperature. +

    +

    + This model forces the outlet temperature at port_b to be + no higher than the temperature of the input signal TSet, + subject to optional limits on the capacity. By default, the model has + unlimited cooling capacity. +

    +

    + The output signal Q_flow ≤ 0 is the heat added to the + medium if the mass flow rate is from port_a to + port_b. If the flow is reversed, then + Q_flow=0. +

    +

    + The outlet conditions at port_a are not affected by this + model, other than for a possible pressure difference due to flow + friction. +

    +

    + If the parameter energyDynamics is different from + Modelica.Fluid.Types.Dynamics.SteadyState, the component + models the dynamic response using a first order differential + equation. The time constant of the component is equal to the + parameter tau. This time constant is adjusted based on + the mass flow rate using

    - P = rN3   s(V̇/rN, d), + τeff = τ |ṁ| ⁄ ṁnom

    - where P is the power consumption, rN is the - normalized fan speed, is the volume flow rate and d - are performance data for fan or pump power consumption at - rN=1. + where τeff is the effective time constant for the + given mass flow rate and τ is the time constant at + the nominal mass flow rate nom. This type of + dynamics is equal to the dynamics that a completely mixed control + volume would have. +

    +

    + Optionally, this model can have a flow resistance. Set + dp_nominal = 0 to disable the flow friction calculation. +

    +

    + For a similar model that is a heater, use AixLib.Fluid.HeatExchangers.Heater_T. + For a model that uses a control signal u ∈ [0, 1] and + multiplies this with the nominal heating or cooling power, use + AixLib.Fluid.HeatExchangers.HeaterCooler_u.

    - Implementation + Limitations

    - The function s(·, ·) is a cubic hermite spline. If the data - d define a monotone decreasing sequence, then s(·, d) - is a monotone decreasing function. + If the flow is from port_b to port_a, then + the enthalpy of the medium is not affected by this model.

    -
      -
    • February 26, 2014, by Filip Jorissen:
      - Changed polynomial to be evaluated at V_flow/r_N - instead of V_flow to properly account for the scaling - law. See #202 - for a discussion and validation. +

      + This model does not affect the humidity of the air. Therefore, if + used to cool air below the dew point temperature, the water mass + fraction will not change. +

      +

      + Validation +

      +

      + The model has been validated against the analytical solution in the + examples AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet + and + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic. +

      +
        +
      • September 10, 2018, by Michael Wetter:
        + Corrected missing propagation of initial conditions.
        + This is for AixLib, + #1016.
      • -
      • September 28, 2011, by Michael Wetter:
        +
      • May 3, 2017, by Michael Wetter:
        + First implementation.
        + This is for AixLib, + #763. +
      • +
      + +-------- Errors -------- +line 29 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Utilities/Math/Polynomial.mo ---- +-------- HTML Code -------- + +

      This block computes a polynomial of arbitrary order. The polynomial has the form

      +

      y = a1 + a2 x + a3 x2 + ...

      + +
        +
      • + September 21, 2021, by Michael Wetter:
        + Renamed class to correct typo in class name.
        + This is for + IBPSA, #1524. +
      • +
      • + November 28, 2013, by Marcus Fuchs:
        + First implementation. +
      • +
      + +-------- Corrected Code -------- +

      + This block computes a polynomial of arbitrary order. The polynomial + has the form +

      +

      + y = a1 + a2 x + a3 x2 + ... +

      +
        +
      • September 21, 2021, by Michael Wetter:
        + Renamed class to correct typo in class name.
        + This is for IBPSA, + #1524. +
      • +
      • November 28, 2013, by Marcus Fuchs:
        First implementation.
      -------- Errors -------- -line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 3 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/gFunction.mo ---- +---- AixLib/Fluid/HeatPumps/Carnot_TCon.mo ---- -------- HTML Code --------

      - This function implements the g-function evaluation method introduced by - Cimmino and Bernier (see: Cimmino and Bernier (2014), and Cimmino (2018)) based - on the g-function function concept first introduced by Eskilson (1987). - The g-function gives the relation between the variation of the borehole - wall temperature at a time t and the heat extraction and injection rates - at all times preceding time t as + This is a model of a heat pump whose coefficient of performance COP changes + with temperatures in the same way as the Carnot efficiency changes. + The control input is the setpoint of the condenser leaving temperature, which + is met exactly at steady state if the heat pump has sufficient capacity.

      -

      - \"image\" +

      + The model allows to either specify the Carnot effectivness + ηCarnot,0, or + a COP0 + at the nominal conditions, together with + the evaporator temperature Teva,0 and + the condenser temperature Tcon,0, in which + case the model computes the Carnot effectivness as +

      +

      + ηCarnot,0 = + COP0 + ⁄ (Tcon,0 ⁄ (Tcon,0-Teva,0)).

      - where Tb is the borehole wall temperature, - Tg is the undisturbed ground temperature, Q is the - heat injection rate into the ground through the borehole wall per unit borehole - length, ks is the soil thermal conductivity and g is - the g-function. + The heat pump COP is computed as the product +

      +

      + COP = ηCarnot,0 COPCarnot ηPL,

      - The g-function is constructed from the combination of the combination of - the finite line source (FLS) solution (see - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource), - the cylindrical heat source (CHS) solution (see - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource), - and the infinite line source (ILS) solution (see - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.infiniteLineSource). - To obtain the g-function of a bore field, each borehole is divided into a - series of nSeg segments of equal length, each modeled as a line - source of finite length. The finite line source solution is superimposed in - space to obtain a system of equations that gives the relation between the heat - injection rate at each of the segments and the borehole wall temperature at each - of the segments. The system is solved to obtain the uniform borehole wall - temperature required at any time to maintain a constant total heat injection - rate (Qtot = 2πksHtot) into the bore - field. The uniform borehole wall temperature is then equal to the finite line - source based g-function. + where COPCarnot is the Carnot efficiency and + ηPL is a polynomial in heating part load ratio yPL + that can be used to take into account a change in COP at part load + conditions. + This polynomial has the form +

      +

      + ηPL = a1 + a2 yPL + a3 yPL2 + ...

      - Since this g-function is based on line sources of heat, rather than - cylinders, the g-function is corrected to consider the cylindrical - geometry. The correction factor is then the difference between the cylindrical - heat source solution and the infinite line source solution, as proposed by - Li et al. (2014) as + where the coefficients ai + are declared by the parameter a.

      -

      - g(t) = gFLS + (gCHS - gILS) +

      + On the Dynamics tag, the model can be parametrized to compute a transient + or steady-state response. + The transient response of the model is computed using a first + order differential equation for the evaporator and condenser fluid volumes. + The heat pump outlet temperatures are equal to the temperatures of these lumped volumes.

      -

      Implementation

      +

      Typical use and important parameters

      - The calculation of the g-function is separated into two regions: the - short-time region and the long-time region. In the short-time region, - corresponding to times t < 1 hour, heat interaction between boreholes - and axial variations of heat injection rate are not considered. The - g-function is calculated using only one borehole and one segment. In the - long-time region, corresponding to times t > 1 hour, all boreholes - are represented as series of nSeg line segments and the - g-function is evaluated as described above. + When using this component, make sure that the condenser has sufficient mass flow rate. + Based on the evaporator mass flow rate, temperature difference and the efficiencies, + the model computes how much heat will be removed by to the evaporator. + If the mass flow rate is too small, very low outlet temperatures can result, possibly below freezing.

      -

      References

      - Cimmino, M. and Bernier, M. 2014. A semi-analytical method to generate - g-functions for geothermal bore fields. International Journal of Heat and - Mass Transfer 70: 641-650. + The condenser heat flow rate QCon_flow_nominal is used to assign + the default value for the mass flow rates, which are used for the pressure drop + calculations. + It is also used to compute the part load efficiency. + Hence, make sure that QCon_flow_nominal is set to a reasonable value.

      - Cimmino, M. 2018. Fast calculation of the g-functions of geothermal borehole - fields using similarities in the evaluation of the finite line source - solution. Journal of Building Performance Simulation. DOI: - 10.1080/19401493.2017.1423390. + The maximum heating capacity is set by the parameter QCon_flow_max, + which is by default set to infinity.

      - Eskilson, P. 1987. Thermal analysis of heat extraction boreholes. Ph.D. - Thesis. Department of Mathematical Physics. University of Lund. Sweden. + The coefficient of performance depends on the + evaporator and condenser leaving temperature + since otherwise the second law of thermodynamics may be violated.

      +

      Notes

      - Li, M., Li, P., Chan, V. and Lai, A.C.K. 2014. Full-scale temperature - response function (G-function) for heat transfer by borehole heat exchangers - (GHEs) from sub-hour to decades. Applied Energy 136: 197-205. + For a similar model that can be used as a chiller, see + + AixLib.Fluid.Chillers.Examples.Carnot_TEva.

      • - March 22, 2018 by Massimo Cimmino:
        + January 3, 2017, by Michael Wetter:
        + Removed parameters + effInpEva and effInpCon + and updated documentation. + This is for + + issue 497. +
      • +
      • + August 8, 2016, by Michael Wetter:
        + Changed default temperature to compute COP to be the leaving temperature as + use of the entering temperature can violate the 2nd law if the temperature + lift is small.
        + This is for + + Annex 60, issue 497. +
      • +
      • + November 25, 2015 by Michael Wetter:
        First implementation.
      -------- Corrected Code --------

      - This function implements the g-function evaluation method - introduced by Cimmino and Bernier (see: Cimmino and Bernier (2014), - and Cimmino (2018)) based on the g-function function concept - first introduced by Eskilson (1987). The g-function gives the - relation between the variation of the borehole wall temperature at a - time t and the heat extraction and injection rates at all - times preceding time t as + This is a model of a heat pump whose coefficient of performance COP + changes with temperatures in the same way as the Carnot efficiency + changes. The control input is the setpoint of the condenser leaving + temperature, which is met exactly at steady state if the heat pump + has sufficient capacity.

      -

      - \"image\" +

      + The model allows to either specify the Carnot effectivness + ηCarnot,0, or a COP0 at the + nominal conditions, together with the evaporator temperature + Teva,0 and the condenser temperature + Tcon,0, in which case the model computes the Carnot + effectivness as +

      +

      + ηCarnot,0 = COP0 ⁄ (Tcon,0 ⁄ + (Tcon,0-Teva,0)).

      - where Tb is the borehole wall temperature, - Tg is the undisturbed ground temperature, Q - is the heat injection rate into the ground through the borehole wall - per unit borehole length, ks is the soil thermal - conductivity and g is the g-function. + The heat pump COP is computed as the product +

      +

      + COP = ηCarnot,0 COPCarnot ηPL,

      - The g-function is constructed from the combination of the - combination of the finite line source (FLS) solution (see - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource), - the cylindrical heat source (CHS) solution (see - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource), - and the infinite line source (ILS) solution (see - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.infiniteLineSource). - To obtain the g-function of a bore field, each borehole is - divided into a series of nSeg segments of equal length, - each modeled as a line source of finite length. The finite line - source solution is superimposed in space to obtain a system of - equations that gives the relation between the heat injection rate at - each of the segments and the borehole wall temperature at each of the - segments. The system is solved to obtain the uniform borehole wall - temperature required at any time to maintain a constant total heat - injection rate (Qtot = - 2πksHtot) into the bore field. The uniform - borehole wall temperature is then equal to the finite line source - based g-function. + where COPCarnot is the Carnot efficiency and + ηPL is a polynomial in heating part load ratio + yPL that can be used to take into account a change + in COP at part load conditions. This polynomial has the form

      -

      - Since this g-function is based on line sources of heat, rather - than cylinders, the g-function is corrected to consider the - cylindrical geometry. The correction factor is then the difference - between the cylindrical heat source solution and the infinite line - source solution, as proposed by Li et al. (2014) as +

      + ηPL = a1 + a2 yPL + + a3 yPL2 + ...

      -

      - g(t) = gFLS + (gCHS - gILS) +

      + where the coefficients ai are declared by the + parameter a.

      -

      - Implementation -

      - The calculation of the g-function is separated into two - regions: the short-time region and the long-time region. In the - short-time region, corresponding to times t < 1 hour, heat - interaction between boreholes and axial variations of heat injection - rate are not considered. The g-function is calculated using - only one borehole and one segment. In the long-time region, - corresponding to times t > 1 hour, all boreholes are - represented as series of nSeg line segments and the - g-function is evaluated as described above. + On the Dynamics tag, the model can be parametrized to + compute a transient or steady-state response. The transient response + of the model is computed using a first order differential equation + for the evaporator and condenser fluid volumes. The heat pump outlet + temperatures are equal to the temperatures of these lumped volumes.

      - References + Typical use and important parameters

      - Cimmino, M. and Bernier, M. 2014. A semi-analytical method to - generate g-functions for geothermal bore fields. International - Journal of Heat and Mass Transfer 70: 641-650. + When using this component, make sure that the condenser has + sufficient mass flow rate. Based on the evaporator mass flow rate, + temperature difference and the efficiencies, the model computes how + much heat will be removed by to the evaporator. If the mass flow rate + is too small, very low outlet temperatures can result, possibly below + freezing.

      - Cimmino, M. 2018. Fast calculation of the g-functions of - geothermal borehole fields using similarities in the evaluation of - the finite line source solution. Journal of Building Performance - Simulation. DOI: 10.1080/19401493.2017.1423390. + The condenser heat flow rate QCon_flow_nominal is used + to assign the default value for the mass flow rates, which are used + for the pressure drop calculations. It is also used to compute the + part load efficiency. Hence, make sure that + QCon_flow_nominal is set to a reasonable value.

      - Eskilson, P. 1987. Thermal analysis of heat extraction - boreholes. Ph.D. Thesis. Department of Mathematical Physics. - University of Lund. Sweden. + The maximum heating capacity is set by the parameter + QCon_flow_max, which is by default set to infinity.

      - Li, M., Li, P., Chan, V. and Lai, A.C.K. 2014. Full-scale - temperature response function (G-function) for heat transfer by - borehole heat exchangers (GHEs) from sub-hour to decades. Applied - Energy 136: 197-205. + The coefficient of performance depends on the evaporator and + condenser leaving temperature since otherwise the second law of + thermodynamics may be violated.

      -
        -
      • March 22, 2018 by Massimo Cimmino:
        - First implementation. -
      • -
      - --------- Errors -------- -line 10 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 49 column 2 - Warning:

      attribute "align" not allowed for HTML5 - - ----- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/InteriorWall.mo ---- --------- HTML Code -------- - -

      InteriorWall represents heat storage within walls. It links a - variable number n of thermal resistances and capacities to a - series connection. n thus defines the spatial discretization of - thermal effects within the wall. All effects are considered as one-dimensional - normal to the wall's surface. This model is thought for interior wall - elements that only serve as heat storage elements. The RC-chain is defined via - a vector of capacities CInt[n] and a vector of resistances - RInt[n]. - Resistances and capacities are connected alternately, starting with the first - resistance RInt[1], from heat port_a into the wall. -

      -

      \"image\"/

      - -
        -
      • - April 27, 2016, by Michael Wetter:
        - Added graphical connections. -
      • -
      • - April 17, 2015, by Moritz Lauster:
        - Implemented. -
      • -
      - --------- Corrected Code -------- +

      + Notes +

      - InteriorWall represents heat storage within walls. It - links a variable number n of thermal resistances and - capacities to a series connection. n thus defines the - spatial discretization of thermal effects within the wall. All - effects are considered as one-dimensional normal to the wall's - surface. This model is thought for interior wall elements that only - serve as heat storage elements. The RC-chain is defined via a vector - of capacities CInt[n] and a vector of resistances - RInt[n]. Resistances and capacities are connected - alternately, starting with the first resistance RInt[1], - from heat port_a into the wall. -

      -

      - \"image\" + For a similar model that can be used as a chiller, see AixLib.Fluid.Chillers.Examples.Carnot_TEva.

        -
      • April 27, 2016, by Michael Wetter:
        - Added graphical connections. +
      • January 3, 2017, by Michael Wetter:
        + Removed parameters effInpEva and + effInpCon and updated documentation. This is for + issue + 497.
      • -
      • April 17, 2015, by Moritz Lauster:
        - Implemented. +
      • August 8, 2016, by Michael Wetter:
        + Changed default temperature to compute COP to be the leaving + temperature as use of the entering temperature can violate the 2nd + law if the temperature lift is small.
        + This is for Annex 60, + issue 497. +
      • +
      • November 25, 2015 by Michael Wetter:
        + First implementation.
      -------- Errors -------- -line 13 column 4 - Warning:

      attribute "align" not allowed for HTML5 +line 17 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 25 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 35 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Controls/Continuous/Examples/OffTimer.mo ---- +---- AixLib/Fluid/Chillers/Carnot_y.mo ---- -------- HTML Code --------

      - Example that demonstrates the use of the model - - AixLib.Controls.Continuous.OffTimer. - The input to the two timers are alternating boolean values. - Whenever the input becomes false(=0), the timer is reset. - The figures below show the input and output of the blocks. -

      -

      - \"Input
      - \"Input + This is model of a chiller whose coefficient of performance COP changes + with temperatures in the same way as the Carnot efficiency changes. + The input signal y is the control signal for the compressor.

      - -
        -
      • - November 21, 2011, by Michael Wetter:
        - Added documentation. -
      • -
      - --------- Corrected Code -------- -

      - Example that demonstrates the use of the model AixLib.Controls.Continuous.OffTimer. - The input to the two timers are alternating boolean values. Whenever - the input becomes false(=0), the timer is reset. The - figures below show the input and output of the blocks. -

      -

      - \"Input
      - \"Input -

      -
        -
      • November 21, 2011, by Michael Wetter:
        - Added documentation. -
      • -
      - --------- Errors -------- -line 10 column 2 - Warning:

      attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Sources/Outside_CpLowRise.mo ---- --------- HTML Code -------- -

      - This model describes boundary conditions for - pressure, enthalpy, and species concentration that can be obtained - from weather data. The model is identical to - - AixLib.Fluid.Sources.Outside, - except that it adds the wind pressure to the - pressure at the fluid port ports. - The correlation that is used to compute the wind pressure is based - on Swami and Chandra (1987) and valid for low-rise buildings - with rectangular shape. - The same correlation is also implemented in CONTAM (Persily and Ivy, 2001). - + The model allows to either specify the Carnot effectivness + ηCarnot,0, or + a COP0 + at the nominal conditions, together with + the evaporator temperature Teva,0 and + the condenser temperature Tcon,0, in which + case the model computes the Carnot effectivness as +

      +

      + ηCarnot,0 = + COP0 + ⁄ (Teva,0 ⁄ (Tcon,0-Teva,0)).

      - The wind pressure coefficient is computed based on the - side ratio of the walls, which is defined as + The chiller COP is computed as the product

      - s = x ⁄ y + COP = ηCarnot,0 COPCarnot ηPL,

      - where x is the length of the wall that will be connected to - this model, and y is the length of the adjacent wall. - The wind direction is computed relative to the azimuth of this surface, - which is equal to the parameter azi. - The surface azimuth is defined in - - AixLib.Types.Azimuth. - For example, if an exterior wall is South oriented, i.e., its outside-facing - surface is towards South, use - AixLib.Types.Azimuth.S. + where COPCarnot is the Carnot efficiency and + ηPL is a polynomial in the cooling part load ratio yPL + that can be used to take into account a change in COP at part load + conditions. + This polynomial has the form +

      +

      + ηPL = a1 + a2 yPL + a3 yPL2 + ...

      - Based on the surface azimuth, the wind direction and the side ratio - of the walls, the model computes how much the wind pressure - is attenuated compared to the reference wind pressure Cp0. - The reference wind pressure Cp0 is a user-defined parameter, - and must be equal to the wind pressure at zero wind incidence angle. - Swami and Chandra (1987) recommend Cp0 = 0.6 for - all low-rise buildings as this represents the average of - various values reported in the literature. - The computation of the actual wind pressure coefficient Cp - is explained in the function - - Buildings.Airflow.Multizone.BaseClasses.windPressureLowRise - that is called by this model. + where the coefficients ai + are declared by the parameter a.

      - The pressure p at the port ports is computed as + On the Dynamics tag, the model can be parametrized to compute a transient + or steady-state response. + The transient response of the model is computed using a first + order differential equation for the evaporator and condenser fluid volumes. + The chiller outlet temperatures are equal to the temperatures of these lumped volumes.

      -

      - p = pw + Cp 1 ⁄ 2 v2 ρ, +

      Typical use and important parameters

      +

      + When using this component, make sure that the evaporator and the condenser have sufficient mass flow rate. + Based on the mass flow rates, the compressor power, temperature difference and the efficiencies, + the model computes how much heat will be added to the condenser and removed at the evaporator. + If the mass flow rates are too small, very high temperature differences can result.

      - where - pw is the atmospheric pressure from the weather bus, - v is the wind speed from the weather bus, and - ρ is the fluid density. + The evaporator heat flow rate QEva_flow_nominal is used to assign + the default value for the mass flow rates, which are used for the pressure drop + calculations. + It is also used to compute the part load efficiency. + Hence, make sure that QEva_flow_nominal is set to a reasonable value.

      -

      - This model differs from - AixLib.Fluid.Sources.Outside_CpData by the calculation of the wind pressure coefficient Cp,act. - The wind pressure coefficient is defined by an equation in stead of a user-defined table. - This model is only suited for low-rise rectangular buildings. + The maximum cooling capacity is set by the parameter QEva_flow_min, + which is by default set to negative infinity. +

      +

      + The coefficient of performance depends on the + evaporator and condenser leaving temperature + since otherwise the second law of thermodynamics may be violated. +

      +

      Notes

      +

      + For a similar model that can be used as a heat pump, see + AixLib.Fluid.HeatPumps.Carnot_y.

      -

      References

      - -
      • - February 2, 2022, by Michael Wetter:
        - Revised implementation.
        + January 26, 2016, by Michael Wetter:
        + Refactored model to use the same base class as + AixLib.Fluid.HeatPumps.Carnot_y. +
        + Changed part load efficiency to depend on cooling part load ratio rather than on the compressor + part load ratio.
        + Changed sign convention of dTEva_nominal to be negative rather than positive. + For positive values, the simulation will stop with an assertion. +
      • +
      • + December 18, 2015, by Michael Wetter:
        + Corrected wrong computation of staB1 and staB2 + which mistakenly used the inStream operator + for the configuration without flow reversal. This is for - IBPSA, #1436. + + issue 476.
      • - Jun 28, 2021, by Klaas De Jonge:
        - Documentation changes to explain the difference with - AixLib.Fluid.Sources.Outside_CpData. + November 25, 2015 by Michael Wetter:
        + Changed sign convention for dTEva_nominal to be consistent with + other models. + The model will still work with the old values for dTEva_nominal, + but it will write a warning so that users can transition their models. +
        + Corrected assert statement for the efficiency curve. + This is for + + issue 468.
      • - January 26, 2016, by Michael Wetter:
        - Added unit and quantity attributes. + September 3, 2015 by Michael Wetter:
        + Expanded documentation.
      • - October 26, 2011 by Michael Wetter:
        + May 6, 2015 by Michael Wetter:
        + Added prescribedHeatFlowRate=true for vol2. +
      • +
      • + October 9, 2013 by Michael Wetter:
        + Reimplemented the computation of the port states to avoid using + the conditionally removed variables sta_a1, + sta_a2, sta_b1 and sta_b2. +
      • +
      • + May 10, 2013 by Michael Wetter:
        + Added electric power P as an output signal. +
      • +
      • + October 11, 2010 by Michael Wetter:
        + Fixed bug in energy balance. +
      • +
      • + March 3, 2009 by Michael Wetter:
        First implementation.
      -------- Corrected Code --------

      - This model describes boundary conditions for pressure, enthalpy, and - species concentration that can be obtained from weather data. The - model is identical to AixLib.Fluid.Sources.Outside, - except that it adds the wind pressure to the pressure at the fluid - port ports. The correlation that is used to compute the - wind pressure is based on Swami and Chandra (1987) and valid for - low-rise buildings with rectangular shape. The same correlation is - also implemented in CONTAM (Persily and Ivy, 2001). - + This is model of a chiller whose coefficient of performance COP + changes with temperatures in the same way as the Carnot efficiency + changes. The input signal y is the control signal for the + compressor.

      - The wind pressure coefficient is computed based on the side ratio of - the walls, which is defined as + The model allows to either specify the Carnot effectivness + ηCarnot,0, or a COP0 at the + nominal conditions, together with the evaporator temperature + Teva,0 and the condenser temperature + Tcon,0, in which case the model computes the Carnot + effectivness as

      - s = x ⁄ y + ηCarnot,0 = COP0 ⁄ (Teva,0 ⁄ + (Tcon,0-Teva,0)).

      - where x is the length of the wall that will be connected to - this model, and y is the length of the adjacent wall. The wind - direction is computed relative to the azimuth of this surface, which - is equal to the parameter azi. The surface azimuth is - defined in AixLib.Types.Azimuth. For - example, if an exterior wall is South oriented, i.e., its - outside-facing surface is towards South, use - AixLib.Types.Azimuth.S. + The chiller COP is computed as the product

      -

      - Based on the surface azimuth, the wind direction and the side ratio - of the walls, the model computes how much the wind pressure is - attenuated compared to the reference wind pressure Cp0. - The reference wind pressure Cp0 is a user-defined - parameter, and must be equal to the wind pressure at zero wind - incidence angle. Swami and Chandra (1987) recommend Cp0 - = 0.6 for all low-rise buildings as this represents the average - of various values reported in the literature. The computation of the - actual wind pressure coefficient Cp is explained in - the function - Buildings.Airflow.Multizone.BaseClasses.windPressureLowRise that - is called by this model. +

      + COP = ηCarnot,0 COPCarnot ηPL,

      - The pressure p at the port ports is computed as + where COPCarnot is the Carnot efficiency and + ηPL is a polynomial in the cooling part load ratio + yPL that can be used to take into account a change + in COP at part load conditions. This polynomial has the form

      - p = pw + Cp 1 ⁄ 2 v2 ρ, + ηPL = a1 + a2 yPL + + a3 yPL2 + ...

      - where pw is the atmospheric pressure from the - weather bus, v is the wind speed from the weather bus, and - ρ is the fluid density. + where the coefficients ai are declared by the + parameter a.

      - This model differs from AixLib.Fluid.Sources.Outside_CpData - by the calculation of the wind pressure coefficient - Cp,act. The wind pressure coefficient is defined by an - equation in stead of a user-defined table. This model is only suited - for low-rise rectangular buildings. + On the Dynamics tag, the model can be parametrized to + compute a transient or steady-state response. The transient response + of the model is computed using a first order differential equation + for the evaporator and condenser fluid volumes. The chiller outlet + temperatures are equal to the temperatures of these lumped volumes.

      - References + Typical use and important parameters

      +

      + When using this component, make sure that the evaporator and the + condenser have sufficient mass flow rate. Based on the mass flow + rates, the compressor power, temperature difference and the + efficiencies, the model computes how much heat will be added to the + condenser and removed at the evaporator. If the mass flow rates are + too small, very high temperature differences can result. +

      +

      + The evaporator heat flow rate QEva_flow_nominal is used + to assign the default value for the mass flow rates, which are used + for the pressure drop calculations. It is also used to compute the + part load efficiency. Hence, make sure that + QEva_flow_nominal is set to a reasonable value. +

      +

      + The maximum cooling capacity is set by the parameter + QEva_flow_min, which is by default set to negative + infinity. +

      +

      + The coefficient of performance depends on the evaporator and + condenser leaving temperature since otherwise the second law of + thermodynamics may be violated. +

      +

      + Notes +

      +

      + For a similar model that can be used as a heat pump, see AixLib.Fluid.HeatPumps.Carnot_y. +

      -
        -
      • February 2, 2022, by Michael Wetter:
        - Revised implementation.
        - This is for IBPSA, - #1436. +
      • January 2, 2017, by Filip Jorissen:
        + Removed parameters effInpEva and + effInpCon and updated documentation. This is for + issue + 497.
      • -
      • Jun 28, 2021, by Klaas De Jonge:
        - Documentation changes to explain the difference with AixLib.Fluid.Sources.Outside_CpData. +
      • August 8, 2016, by Michael Wetter:
        + Changed default temperature to compute COP to be the leaving + temperature as use of the entering temperature can violate the 2nd + law if the temperature lift is small.
        + This is for Annex 60, + issue 497.
      • January 26, 2016, by Michael Wetter:
        - Added unit and quantity attributes. + Refactored model to use the same base class as AixLib.Fluid.HeatPumps.Carnot_y.
        + + Changed part load efficiency to depend on cooling part load ratio + rather than on the compressor part load ratio.
        + Changed sign convention of dTEva_nominal to be + negative rather than positive. For positive values, the simulation + will stop with an assertion.
      • -
      • October 26, 2011 by Michael Wetter:
        +
      • December 18, 2015, by Michael Wetter:
        + Corrected wrong computation of staB1 and + staB2 which mistakenly used the inStream + operator for the configuration without flow reversal. This is for + issue + 476. +
      • +
      • November 25, 2015 by Michael Wetter:
        + Changed sign convention for dTEva_nominal to be + consistent with other models. The model will still work with the + old values for dTEva_nominal, but it will write a + warning so that users can transition their models.
        + Corrected assert statement for the efficiency curve. + This is for issue + 468. +
      • +
      • September 3, 2015 by Michael Wetter:
        + Expanded documentation. +
      • +
      • May 6, 2015 by Michael Wetter:
        + Added prescribedHeatFlowRate=true for + vol2. +
      • +
      • October 9, 2013 by Michael Wetter:
        + Reimplemented the computation of the port states to avoid using the + conditionally removed variables sta_a1, + sta_a2, sta_b1 and sta_b2. +
      • +
      • May 10, 2013 by Michael Wetter:
        + Added electric power P as an output signal. +
      • +
      • October 11, 2010 by Michael Wetter:
        + Fixed bug in energy balance. +
      • +
      • March 3, 2009 by Michael Wetter:
        First implementation.
      -------- Errors -------- -line 28 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 61 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 16 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 24 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 34 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD200.mo ---- +---- AixLib/Utilities/Math/Functions/bicubic.mo ---- -------- HTML Code -------- + This function computes +

      + y = a1 + + a2 x1 + a3 x12 + + a4 x2 + a5 x22 + + a6 x1 x2 + + a7 x1^3 + + a8 x2^3 + + a9 x12 x2 + + a10 x1 x22 +

      +
      • - September 6, 2021, by Ettore Zanetti:
        - Removed parameter lat as it is now obtained from the weather data bus.
        - This is for - IBPSA, #1477. -
      • -
      • - March 11, 2020, by Ettore Zanetti:
        + Sep 17, 2010 by Michael Wetter:
        First implementation.
      • -
      • - April 14, 2020, by Ettore Zanetti:
        - Rework after comments from pull request - #1339. -
      • -
      • - May 2, 2021, by Ettore Zanetti:
        - Updated weather file as explained in #1478. -
      -

      WD200: Low Elevation, Hot and Humid Case.

      -

      Weather data file : WD200.epw

      -

      Table 1: Site Data for Weather file WD200.epw

      -
    - - - - - - - - - - - - - - - -

    Latitude

    33.633° north

    Longitude

    84.433° west

    Altitude

    308 m

    Time Zone

    -5

    - -------- Corrected Code -------- +This function computes +

    + y = a1 + a2 x1 + a3 + x12 + a4 x2 + + a5 x22 + a6 x1 + x2 + a7 x1^3 + a8 + x2^3 + a9 x12 + x2 + a10 x1 + x22 +

    -

    - WD200: Low Elevation, Hot and Humid Case. -

    -

    - Weather data file : WD200.epw -

    -

    - Table 1: Site Data for Weather file WD200.epw -

    - - - - - - - - - - - - - - - - - -
    -

    - Latitude -

    -
    -

    - 33.633° north -

    -
    -

    - Longitude -

    -
    -

    - 84.433° west -

    -
    -

    - Altitude -

    -
    -

    - 308 m -

    -
    -

    - Time Zone -

    -
    -

    - -5 -

    -
    -------- Errors -------- -line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/ThreeElements.mo ---- +---- AixLib/Fluid/FixedResistances/CheckValve.mo ---- -------- HTML Code -------- -

    + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    VariableUnitDescription
    TKtemperature
    pPaabsolute pressure
    dkg/m3density
    hJ/kgspecific enthalpy
    uJ/kgspecific internal energy
    Xi[nXi]kg/kgindependent mass fractions m_i/m
    RJ/kg.Kgas constant
    Mkg/molmolar mass
    --------- Corrected Code -------- -

    - This block computes -

    -

    - y = a1 + a2 x1 + a3 - x12 + a4 x2 + - a5 x22 + a6 x1 - x2 -

    - - --------- Errors -------- -line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/HeatExchangers/BaseClasses/WetCoilWetRegime.mo ---- --------- HTML Code -------- - + Density is computed from pressure, temperature and composition in the thermodynamic state record applying the ideal gas law. + +

    + This function returns the dynamic viscosity. +

    +

    Implementation

    +

    + The function is based on the 5th order polynomial + of + + Modelica.Media.Air.MoistAir.dynamicViscosity. + However, for the typical range of temperatures encountered + in building applications, a linear function sufficies. + This implementation is therefore the above 5th order polynomial, + linearized around 20°C. + The relative error of this linearization is + 0.4% at -20°C, + and less then + 0.2% between -5°C and +50°C. +

    + + The ideal gas constant for moist air is computed from thermodynamic state assuming that all water is in the gas phase. + + Pressure is returned from the thermodynamic state record input as a simple assignment. +

    - This model implements the calculation for a 100% wet coil. + This function returns the isobaric expansion coefficient at constant pressure, + which is zero for this medium. + The isobaric expansion coefficient at constant pressure is

    -

    - The equations from Braun (1988) and Mitchell and Braun (2012a and b), - which are essentially the extension of the ε-NTU approach to - simultaneous sensible and latent heat transfer, are utilized. +

    + βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p = 0,

    - The mathematical equations are analogous to that of the sensible heat exchanger. - However, the key distinction is that the heat transfer is driven by an enthalpy difference - not by an temperature difference. This change in the driving potential results in re-defining - capacitances and heat transfer coefficients accordingly. + where + v is the specific volume, + T is the temperature and + p is the pressure.

    + +

    - The total heat transfer rate is expressed as + This function returns the isothermal compressibility coefficient. + The isothermal compressibility is

    -

    - Qtot=ε* C*min - (hair,in-hsat(Twat,in)), +

    + κT = -1 ⁄ v   (∂ v ⁄ ∂ p)T + = -1 ⁄ p,

    - where ε*=f(Cr*,NTU*) and f is the same ε-NTU relationships - (depending on the heat exchanger configuration) for the sensible heat exchanger. + where + v is the specific volume, + T is the temperature and + p is the pressure.

    + + +

    - hair,in and hsat(Twat,in) are - the specific enthalpies of the incoming moist air and saturated moist air - at the water inlet temperature. + This function computes the specific entropy.

    - The capacitances of water and air streams are defined as + The specific entropy of the mixture is obtained from

    -

    C*air=mair and - C*wat=mwatcp,wat/csat, +

    + s = ss + sm,

    - where csat is an specific heat capacity, which indicates the sensitivity - of the enthalpy of the staturated moist air w.r.t. the temperature, and is defined - here as csat=(hsat(Twat,out)-hsat(Twat,in)) - /(Twat,out-Twat,in). + where + ss is the entropy change due to the state change + (relative to the reference temperature) and + sm is the entropy change due to mixing + of the dry air and water vapor.

    - The capacitance ratio and minimum capacitance are naturally defined as + The entropy change due to change in state is obtained from

    -

    Cr*=min(C*air,C*wat)/max(C*air,C*wat) - and C*min=min(C*air,C*wat). +

    + ss = cv ln(T/T0) + R ln(v/v0)
    + = cv ln(T/T0) + R ln(ρ0/ρ)

    -


    - The number of transfer unit for the wet-coil is defined as NTU*=UA*/C*min, where +

    If we assume ρ = p0/(R T), + and because cp = cv + R, + we can write

    -

    - UA*=1/(1/(UAair/cp,air)+1/(UAwat/csat). +

    + ss = cv ln(T/T0) + R ln(T/T0)
    + =cp ln(T/T0).

    - -

    References

    - Braun, James E. 1988. - "Methodologies for the Design and Control of Central Cooling Plants". - PhD Thesis. University of Wisconsin - Madison. - Available - - online. + Next, the entropy of mixing is obtained from a reversible isothermal + expansion process. Hence, +

    +

    + sm = -R ∑i( Xi ⁄ Mi + ln(Yi p/p0)),

    - Mitchell, John W., and James E. Braun. 2012a. - Principles of heating, ventilation, and air conditioning in buildings. - Hoboken, N.J.: Wiley. + where R is the gas constant, + X is the mass fraction, + M is the molar mass, and + Y is the mole fraction.

    - Mitchell, John W., and James E. Braun. 2012b. - "Supplementary Material Chapter 2: Heat Exchangers for Cooling Applications". - Excerpt from Principles of heating, ventilation, and air conditioning in buildings. - Hoboken, N.J.: Wiley. - Available - - online. + To obtain the state for a given pressure, entropy and mass fraction, use + + AixLib.Media.Air.setState_psX.

    - --------- Corrected Code -------- - -

    - This model implements the calculation for a 100% wet coil. -

    -

    - The equations from Braun (1988) and Mitchell and Braun (2012a and b), - which are essentially the extension of the ε-NTU approach to - simultaneous sensible and latent heat transfer, are utilized. -

    -

    - The mathematical equations are analogous to that of the sensible heat - exchanger. However, the key distinction is that the heat transfer is - driven by an enthalpy difference not by an temperature difference. - This change in the driving potential results in re-defining - capacitances and heat transfer coefficients accordingly. -

    -

    - The total heat transfer rate is expressed as -

    -

    - Qtot=ε* C*min - (hair,in-hsat(Twat,in)), -

    -

    - where ε*=f(Cr*,NTU*) and f is the same ε-NTU - relationships (depending on the heat exchanger configuration) for the - sensible heat exchanger. -

    -

    - hair,in and - hsat(Twat,in) are the specific - enthalpies of the incoming moist air and saturated moist air at the - water inlet temperature. -

    -

    - The capacitances of water and air streams are defined as -

    -

    - C*air=mair and - C*wat=mwatcp,wat/csat, -

    -

    - where csat is an specific heat capacity, which indicates the - sensitivity of the enthalpy of the staturated moist air w.r.t. the - temperature, and is defined here as - csat=(hsat(Twat,out)-hsat(Twat,in)) - /(Twat,out-Twat,in). -

    -

    - The capacitance ratio and minimum capacitance are naturally defined - as -

    -

    - Cr*=min(C*air,C*wat)/max(C*air,C*wat) - and C*min=min(C*air,C*wat). -

    -

    -
    - The number of transfer unit for the wet-coil is defined as - NTU*=UA*/C*min, where -

    -

    - UA*=1/(1/(UAair/cp,air)+1/(UAwat/csat). -

    -

    - References -

    -

    - Braun, James E. 1988. \"Methodologies for the Design and Control of - Central Cooling Plants\". PhD Thesis. University of Wisconsin - - Madison. Available online. -

    -

    - Mitchell, John W., and James E. Braun. 2012a. Principles of heating, - ventilation, and air conditioning in buildings. Hoboken, N.J.: Wiley. -

    -

    - Mitchell, John W., and James E. Braun. 2012b. \"Supplementary Material - Chapter 2: Heat Exchangers for Cooling Applications\". Excerpt from - Principles of heating, ventilation, and air conditioning in - buildings. Hoboken, N.J.: Wiley. Available - online. -

    - --------- Errors -------- -line 20 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 36 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 48 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 54 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Utilities/Math/Functions/bicubic.mo ---- --------- HTML Code -------- - - This function computes -

    - y = a1 - + a2 x1 + a3 x12 - + a4 x2 + a5 x22 - + a6 x1 x2 - + a7 x1^3 - + a8 x2^3 - + a9 x12 x2 - + a10 x1 x22 +

    Limitations

    +

    + This function is only valid for a relative humidity below 100%.

    --------- Corrected Code -------- -This function computes -

    - y = a1 + a2 x1 + a3 - x12 + a4 x2 + - a5 x22 + a6 x1 - x2 + a7 x1^3 + a8 - x2^3 + a9 x12 - x2 + a10 x1 - x22 -

    - - --------- Errors -------- -line 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Movers/BaseClasses/Characteristics/efficiency.mo ---- --------- HTML Code -------- -

    - This function computes the fan or pump efficiency for given normalized volume flow rate - and performance data. The efficiency is -

    -

    - η = s(V̇/rN, d), + This function returns the partial derivative of density + with respect to pressure at constant temperature.

    + + +

    - where - η is the efficiency, - rN is the normalized fan speed, - is the volume flow rate, and - d are performance data for fan or pump efficiency. -

    -

    Implementation

    -

    - The function s(·, ·) is a cubic hermite spline. - If the data d define a monotone decreasing sequence, then - s(·, d) is a monotone decreasing function. + This function computes the derivative of density with respect to temperature + at constant pressure.

    + +

    + This function returns the partial derivative of density + with respect to mass fraction. + This value is zero because in this medium, density is proportional + to pressure, but independent of the species concentration. +

    + + + +

    + The thermodynamic state record + is computed from density d, temperature T and composition X. +

    + + The + thermodynamic state record is computed from pressure p, specific enthalpy h and composition X. + + The + thermodynamic state record is computed from pressure p, temperature T and composition X. + +

    + This function returns the thermodynamic state based on pressure, + specific entropy and mass fraction. +

    +

    + The state is computed by symbolically solving + + AixLib.Media.Air.specificEntropy + for temperature. +

    + + + + Specific enthalpy as a function of temperature and species concentration. + The pressure is input for compatibility with the medium models, but the specific enthalpy + is independent of the pressure. + + + +

    + This function computes the specific enthalpy for + an isentropic state change from the temperature + that corresponds to the state refState + to reference_T. +

    + + --------- Corrected Code -------- -

    - This function computes the fan or pump efficiency for given - normalized volume flow rate and performance data. The efficiency is -

    -

    - η = s(V̇/rN, d), -

    -

    - where η is the efficiency, rN is the - normalized fan speed, is the volume flow rate, and d - are performance data for fan or pump efficiency. -

    -

    - Implementation -

    -

    - The function s(·, ·) is a cubic hermite spline. If the data - d define a monotone decreasing sequence, then s(·, d) - is a monotone decreasing function. -

    - - --------- Errors -------- -line 6 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Chillers/Carnot_y.mo ---- --------- HTML Code -------- - + Temperature is returned from the thermodynamic state record input as a simple assignment. +

    - This is model of a chiller whose coefficient of performance COP changes - with temperatures in the same way as the Carnot efficiency changes. - The input signal y is the control signal for the compressor. + This function returns the molar mass.

    + + + + Temperature as a function of specific enthalpy and species concentration. + The pressure is input for compatibility with the medium models, but the temperature + is independent of the pressure. + + +

    - The model allows to either specify the Carnot effectivness - ηCarnot,0, or - a COP0 - at the nominal conditions, together with - the evaporator temperature Teva,0 and - the condenser temperature Tcon,0, in which - case the model computes the Carnot effectivness as + This data record contains the coefficients for perfect gases.

    -

    - ηCarnot,0 = - COP0 - ⁄ (Teva,0 ⁄ (Tcon,0-Teva,0)). + +

    + +

    + This medium package models moist air using a gas law in which pressure and temperature + are independent, which often leads to significantly faster and more robust computations. + The specific heat capacities at constant pressure and at constant volume are constant. + The air is assumed to be not saturated.

    - The chiller COP is computed as the product + This medium uses the gas law

    - COP = ηCarnot,0 COPCarnot ηPL, + ρ/ρstp = p/pstp,

    - where COPCarnot is the Carnot efficiency and - ηPL is a polynomial in the cooling part load ratio yPL - that can be used to take into account a change in COP at part load - conditions. - This polynomial has the form + where + pstd and ρstp are constant reference + temperature and density, rathern than the ideal gas law

    - ηPL = a1 + a2 yPL + a3 yPL2 + ... + ρ = p ⁄(R T),

    - where the coefficients ai - are declared by the parameter a. + where R is the gas constant and T is the temperature.

    - On the Dynamics tag, the model can be parametrized to compute a transient - or steady-state response. - The transient response of the model is computed using a first - order differential equation for the evaporator and condenser fluid volumes. - The chiller outlet temperatures are equal to the temperatures of these lumped volumes. + This formulation often leads to smaller systems of nonlinear equations + because equations for pressure and temperature are decoupled. + Therefore, if air inside a control volume such as room air is heated, it + does not increase its specific volume. Consequently, merely heating or cooling + a control volume does not affect the air flow calculations in a duct network + that may be connected to that volume. + Note that multizone air exchange simulation in which buoyancy drives the + air flow is still possible as the models in + + AixLib.Airflow.Multizone compute the mass density using the function + + AixLib.Utilities.Psychrometrics.Functions.density_pTX in which density + is a function of temperature.

    -

    Typical use and important parameters

    - When using this component, make sure that the evaporator and the condenser have sufficient mass flow rate. - Based on the mass flow rates, the compressor power, temperature difference and the efficiencies, - the model computes how much heat will be added to the condenser and removed at the evaporator. - If the mass flow rates are too small, very high temperature differences can result. + Note that models in this package implement the equation for the internal energy as +

    +

    + u = h - pstp ⁄ ρstp,

    - The evaporator heat flow rate QEva_flow_nominal is used to assign - the default value for the mass flow rates, which are used for the pressure drop - calculations. - It is also used to compute the part load efficiency. - Hence, make sure that QEva_flow_nominal is set to a reasonable value. + where + u is the internal energy per unit mass, + h is the enthalpy per unit mass, + pstp is the static pressure and + ρstp is the mass density at standard pressure and temperature. + The reason for this implementation is that in general, +

    +

    + h = u + p v,

    - The maximum cooling capacity is set by the parameter QEva_flow_min, - which is by default set to negative infinity. + from which follows that +

    +

    + u = h - p v = h - p ⁄ ρ = h - pstp ⁄ ρstd,

    - The coefficient of performance depends on the - evaporator and condenser leaving temperature - since otherwise the second law of thermodynamics may be violated. + because p ⁄ ρ = pstp ⁄ ρstp in this medium model.

    -

    Notes

    - For a similar model that can be used as a heat pump, see - AixLib.Fluid.HeatPumps.Carnot_y. + The enthalpy is computed using the convention that h=0 + if T=0 °C and no water vapor is present.

    -------- Corrected Code --------

    - This is model of a chiller whose coefficient of performance COP - changes with temperatures in the same way as the Carnot efficiency - changes. The input signal y is the control signal for the - compressor. -

    -

    - The model allows to either specify the Carnot effectivness - ηCarnot,0, or a COP0 at the - nominal conditions, together with the evaporator temperature - Teva,0 and the condenser temperature - Tcon,0, in which case the model computes the Carnot - effectivness as -

    -

    - ηCarnot,0 = COP0 ⁄ (Teva,0 ⁄ - (Tcon,0-Teva,0)). -

    -

    - The chiller COP is computed as the product -

    -

    - COP = ηCarnot,0 COPCarnot ηPL, -

    -

    - where COPCarnot is the Carnot efficiency and - ηPL is a polynomial in the cooling part load ratio - yPL that can be used to take into account a change - in COP at part load conditions. This polynomial has the form -

    -

    - ηPL = a1 + a2 yPL + - a3 yPL2 + ... -

    -

    - where the coefficients ai are declared by the - parameter a. -

    -

    - On the Dynamics tag, the model can be parametrized to - compute a transient or steady-state response. The transient response - of the model is computed using a first order differential equation - for the evaporator and condenser fluid volumes. The chiller outlet - temperatures are equal to the temperatures of these lumped volumes. -

    -

    - Typical use and important parameters -

    -

    - When using this component, make sure that the evaporator and the - condenser have sufficient mass flow rate. Based on the mass flow - rates, the compressor power, temperature difference and the - efficiencies, the model computes how much heat will be added to the - condenser and removed at the evaporator. If the mass flow rates are - too small, very high temperature differences can result. + Model with basic thermodynamic properties.

    - The evaporator heat flow rate QEva_flow_nominal is used - to assign the default value for the mass flow rates, which are used - for the pressure drop calculations. It is also used to compute the - part load efficiency. Hence, make sure that - QEva_flow_nominal is set to a reasonable value. -

    -

    - The maximum cooling capacity is set by the parameter - QEva_flow_min, which is by default set to negative - infinity. + This model provides equation for the following thermodynamic + properties:

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + Variable + + Unit + + Description +
    + T + + K + + temperature +
    + p + + Pa + + absolute pressure +
    + d + + kg/m3 + + density +
    + h + + J/kg + + specific enthalpy +
    + u + + J/kg + + specific internal energy +
    + Xi[nXi] + + kg/kg + + independent mass fractions m_i/m +
    + R + + J/kg.K + + gas constant +
    + M + + kg/mol + + molar mass +
    + +Density is computed from pressure, temperature and composition in the +thermodynamic state record applying the ideal gas law.

    - The coefficient of performance depends on the evaporator and - condenser leaving temperature since otherwise the second law of - thermodynamics may be violated. + This function returns the dynamic viscosity.

    - Notes + Implementation

    - For a similar model that can be used as a heat pump, see AixLib.Fluid.HeatPumps.Carnot_y. + The function is based on the 5th order polynomial of Modelica.Media.Air.MoistAir.dynamicViscosity. + However, for the typical range of temperatures encountered in + building applications, a linear function sufficies. This + implementation is therefore the above 5th order polynomial, + linearized around 20°C. The relative error of this + linearization is 0.4% at -20°C, and less then + 0.2% between -5°C and +50°C.

    - --------- Errors -------- -line 16 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 24 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 34 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Storage/UsersGuide.mo ---- --------- HTML Code -------- - +The ideal gas constant for moist air is computed from thermodynamic +state assuming that all water is in the gas phase. +Pressure is returned from the thermodynamic state record input as a +simple assignment.

    -This user's guide describes the storage tank models. -There are three storage tank models in the this package. + This function returns the isobaric expansion coefficient at constant + pressure, which is zero for this medium. The isobaric expansion + coefficient at constant pressure is +

    +

    + βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p = 0,

    - - - - - - - - - - - - - - -
    Model name Description
    - -AixLib.Fluid.Storage.Stratified -

    -This is a model of a stratified storage tank as shown in the figure below. + where v is the specific volume, T is the temperature + and p is the pressure.

    -

    -\"Image +

      +
    • December 18, 2013, by Michael Wetter:
      + First implementation. +
    • +
    +

    + This function returns the isothermal compressibility coefficient. The + isothermal compressibility is +

    +

    + κT = -1 ⁄ v   (∂ v ⁄ ∂ p)T = -1 ⁄ p,

    -The tank uses several volumes to model the stratification. -Heat conduction is modeled between the volumes through the fluid, -and between the volumes and the ambient. + where v is the specific volume, T is the temperature + and p is the pressure.

    +
      +
    • December 18, 2013, by Michael Wetter:
      + First implementation. +
    • +

    -The heat port heaPorVol may be used to connect a temperature sensor -that measures the fluid temperature of an individual volume. It may also -be used to add heat to individual volumes, for example if the tank contains -an electrical resistance heater. + This function computes the specific entropy.

    -Similarly, the fluid port fluPorVol may be used to connect a fluid pipe -to an individual volume. This allows for example to draw water from that volume whose temperature -is close to the temperature required by the consumer. -Conversely, water could be added to that tank volume whose temperature is close to the -inlet water temperature. -If you don't use such a pipe, simply leave the ports unconnected. + The specific entropy of the mixture is obtained from +

    +

    + s = ss + sm,

    -The tank has nSeg fluid volumes. The top segment has the index 1. -Thus, to add a heating element to the bottom element, connect a heat input to -heaPorVol[nSeg]. + where ss is the entropy change due to the state + change (relative to the reference temperature) and + sm is the entropy change due to mixing of the dry + air and water vapor.

    -The heat ports outside the tank insulation can be -used to specify an ambient temperature. -Leave these ports unconnected to force adiabatic boundary conditions. -Note, however, that all heat conduction elements through the tank wall (but not the top and bottom) are connected to the -heat port heaPorSid. Thus, not connecting -heaPorSid means an adiabatic boundary condition in the sense -that heaPorSid.Q_flow = 0. This, however, still allows heat to flow -through the tank walls, modeled by conWal, from one fluid volume -to another one. + The entropy change due to change in state is obtained from +

    +

    + ss = cv ln(T/T0) + R + ln(v/v0)
    + = cv ln(T/T0) + R ln(ρ0/ρ)

    -
    - -AixLib.Fluid.Storage.StratifiedEnhanced -

    -The model is identical to - -AixLib.Fluid.Storage.Stratified, -except for the following: + If we assume ρ = p0/(R T), and because + cp = cv + R, we can write +

    +

    + ss = cv ln(T/T0) + R + ln(T/T0)
    + =cp ln(T/T0). +

    +

    + Next, the entropy of mixing is obtained from a reversible isothermal + expansion process. Hence, +

    +

    + sm = -R ∑i( Xi ⁄ Mi + ln(Yi p/p0)), +

    +

    + where R is the gas constant, X is the mass fraction, + M is the molar mass, and Y is the mole fraction. +

    +

    + To obtain the state for a given pressure, entropy and mass fraction, + use AixLib.Media.Air.setState_psX. +

    +

    + Limitations +

    +

    + This function is only valid for a relative humidity below 100%.

      -
    • -It adds a correction that reduces the numerical dissipation. -
    • -
    • -It does not contain the fluid ports fluPorVol that -connect from the outside to the individual volumes. -
    • +
    • November 27, 2013, by Michael Wetter:
      + First implementation. +

    -The correction uses a third order upwind scheme to compute the -outlet temperatures of the segments in the tank. This model -is implemented in - -AixLib.Fluid.Storage.BaseClasses.ThirdOrderStratifier. + This function returns the partial derivative of density with respect + to pressure at constant temperature.

    -
    - -AixLib.Fluid.Storage.StratifiedEnhancedInternalHex - +
      +
    • December 18, 2013, by Michael Wetter:
      + First implementation. +
    • +

    -This model is identical to - -AixLib.Fluid.Storage.StratifiedEnhanced -except that it adds a heat exchanger to the tank. + This function computes the derivative of density with respect to + temperature at constant pressure.

    +
      +
    • December 18, 2013, by Michael Wetter:
      + First implementation. +
    • +

    -The modifications consist of adding a heat exchanger -and fluid ports to connect to the heat exchanger. -The modifications allow to run a fluid through the tank causing heat transfer to the stored fluid. -A typical example is a storage tank in a solar hot water system. + This function returns the partial derivative of density with respect + to mass fraction. This value is zero because in this medium, density + is proportional to pressure, but independent of the species + concentration.

    +
      +
    • December 18, 2013, by Michael Wetter:
      + First implementation. +
    • +

    -The heat exchanger model assumes flow through the inside of a helical coil heat exchanger, -and stagnant fluid on the outside. Parameters are used to describe the -heat transfer on the inside of the heat exchanger at nominal conditions, and -geometry of the outside of the heat exchanger. This information is used to compute -an hA-value for each side of the coil. -Convection calculations are then performed to identify heat transfer -between the heat transfer fluid and the fluid in the tank. + The + thermodynamic state record is computed from density + d, temperature T and composition + X.

    +The +thermodynamic state record is computed from pressure p, specific +enthalpy h and composition X. +The +thermodynamic state record is computed from pressure p, temperature +T and composition X.

    -The location of the heat exchanger can be parameterized as follows: -The parameters hHex_a and hHex_b are the heights -of the heat exchanger ports portHex_a and portHex_b, -measured from the bottom of the tank. -For example, to place the port portHex_b at the bottom of the tank, -set hHexB_b=0. -The parameters hHex_a and hHex_b are then used to provide -a default value for the parameters -segHex_a and segHex_b, which are the numbers of the tank -segments to which the heat exchanger ports portHex_a and portHex_b -are connected. -

    -

    -\"Image + This function returns the thermodynamic state based on pressure, + specific entropy and mass fraction.

    -Optionally, this model computes a dynamic response of the heat exchanger. -This can be configured using the parameters -energyDynamicsHexSolid, -energyDynamicsHex and -massDynamicsHex. -For this computation, the fluid volume inside the heat exchanger -and the heat capacity of the heat -exchanger wall CHex are approximated. -Both depend on the length lHex -of the heat exchanger. -The model provides default values for these -parameters, as well as for the heat exchanger material which is -assumed to be steel. These default values can be overwritten by the user. -The default values for the heat exchanger geometry are computed assuming -that there is a cylindrical heat exchanger -made of steel whose diameter is half the diameter of the tank, e.g., -rHex=rTan/2. -Hence, the length of the heat exchanger is approximated as -lHex = 2 rHex π h = 2 rTan/2 π h, -where h is the distance between the heat exchanger inlet and outlet. -The wall thickness is assumed to be 10% of the heat exchanger -outer diameter. -For typical applications, users do not need to change these values. + The state is computed by symbolically solving AixLib.Media.Air.specificEntropy + for temperature.

    +
      +
    • November 27, 2013, by Michael Wetter:
      + First implementation. +
    • +
    +Specific enthalpy as a function of temperature and species +concentration. The pressure is input for compatibility with the medium +models, but the specific enthalpy is independent of the pressure. +
      +
    • April 30, 2015, by Filip Jorissen and Michael Wetter:
      + Added Inline=true for issue 227. +
    • +

    -Setting energyDynamicsHexSolid to a dynamic balance and -energyDynamicsHex to a steady-state balance may be of interest -to remove very fast dynamics of the fluid, while still modeling slower -dynamics that arises from the metal of the heat exchanger. -By default, energyDynamicsHexSolid is set -to the same value as energyDynamicsHex -as this seems to be the typical configuration. + This function computes the specific enthalpy for an isentropic state + change from the temperature that corresponds to the state + refState to reference_T.

    +
      +
    • December 18, 2013, by Michael Wetter:
      + First implementation. +
    • +
    +Temperature is returned from the thermodynamic state record input as a +simple assignment.

    -The heat exchanger is implemented in - -AixLib.Fluid.Storage.BaseClasses.IndirectTankHeatExchanger. + This function returns the molar mass.

    -
    - --------- Corrected Code -------- + +Temperature as a function of specific enthalpy and species +concentration. The pressure is input for compatibility with the medium +models, but the temperature is independent of the pressure. +

    - This user's guide describes the storage tank models. There are three - storage tank models in the this package. + This data record contains the coefficients for perfect gases.

    - - - - - - - - - - - - - - - - - -
    - Model name - - Description -
    - AixLib.Fluid.Storage.Stratified - -

    - This is a model of a stratified storage tank as shown in the - figure below. -

    -

    - \"Image -

    -

    - The tank uses several volumes to model the stratification. Heat - conduction is modeled between the volumes through the fluid, - and between the volumes and the ambient. -

    -

    - The heat port heaPorVol may be used to connect a - temperature sensor that measures the fluid temperature of an - individual volume. It may also be used to add heat to - individual volumes, for example if the tank contains an - electrical resistance heater. -

    -

    - Similarly, the fluid port fluPorVol may be used to - connect a fluid pipe to an individual volume. This allows for - example to draw water from that volume whose temperature is - close to the temperature required by the consumer. Conversely, - water could be added to that tank volume whose temperature is - close to the inlet water temperature. If you don't use such a - pipe, simply leave the ports unconnected. -

    -

    - The tank has nSeg fluid volumes. The top segment - has the index 1. Thus, to add a heating element to - the bottom element, connect a heat input to - heaPorVol[nSeg]. -

    -

    - The heat ports outside the tank insulation can be used to - specify an ambient temperature. Leave these ports unconnected - to force adiabatic boundary conditions. Note, however, that all - heat conduction elements through the tank wall (but not the top - and bottom) are connected to the heat port - heaPorSid. Thus, not connecting - heaPorSid means an adiabatic boundary condition in - the sense that heaPorSid.Q_flow = 0. This, - however, still allows heat to flow through the tank walls, - modeled by conWal, from one fluid volume to - another one. -

    -
    - AixLib.Fluid.Storage.StratifiedEnhanced - -

    - The model is identical to AixLib.Fluid.Storage.Stratified, - except for the following: -

    -
      -
    • It adds a correction that reduces the numerical - dissipation. -
    • -
    • It does not contain the fluid ports fluPorVol - that connect from the outside to the individual volumes. -
    • -
    -

    - The correction uses a third order upwind scheme to compute the - outlet temperatures of the segments in the tank. This model is - implemented in - AixLib.Fluid.Storage.BaseClasses.ThirdOrderStratifier. -

    -
    - AixLib.Fluid.Storage.StratifiedEnhancedInternalHex - -

    - This model is identical to AixLib.Fluid.Storage.StratifiedEnhanced - except that it adds a heat exchanger to the tank. -

    -

    - The modifications consist of adding a heat exchanger and fluid - ports to connect to the heat exchanger. The modifications allow - to run a fluid through the tank causing heat transfer to the - stored fluid. A typical example is a storage tank in a solar - hot water system. -

    -

    - The heat exchanger model assumes flow through the inside of a - helical coil heat exchanger, and stagnant fluid on the outside. - Parameters are used to describe the heat transfer on the inside - of the heat exchanger at nominal conditions, and geometry of - the outside of the heat exchanger. This information is used to - compute an hA-value for each side of the coil. - Convection calculations are then performed to identify heat - transfer between the heat transfer fluid and the fluid in the - tank. -

    -

    - The location of the heat exchanger can be parameterized as - follows: The parameters hHex_a and - hHex_b are the heights of the heat exchanger ports - portHex_a and portHex_b, measured - from the bottom of the tank. For example, to place the port - portHex_b at the bottom of the tank, set - hHexB_b=0. The parameters hHex_a and - hHex_b are then used to provide a default value - for the parameters segHex_a and - segHex_b, which are the numbers of the tank - segments to which the heat exchanger ports - portHex_a and portHex_b are - connected. -

    -

    - \"Image -

    -

    - Optionally, this model computes a dynamic response of the heat - exchanger. This can be configured using the parameters - energyDynamicsHexSolid, - energyDynamicsHex and - massDynamicsHex. For this computation, the fluid - volume inside the heat exchanger and the heat capacity of the - heat exchanger wall CHex are approximated. Both - depend on the length lHex of the heat exchanger. - The model provides default values for these parameters, as well - as for the heat exchanger material which is assumed to be - steel. These default values can be overwritten by the user. The - default values for the heat exchanger geometry are computed - assuming that there is a cylindrical heat exchanger made of - steel whose diameter is half the diameter of the tank, e.g., - rHex=rTan/2. Hence, the length of - the heat exchanger is approximated as lHex = 2 - rHex π h = 2 rTan/2 π h, where - h is the distance between the heat exchanger inlet and - outlet. The wall thickness is assumed to be 10% of the - heat exchanger outer diameter. For typical applications, users - do not need to change these values. -

    -

    - Setting energyDynamicsHexSolid to a dynamic - balance and energyDynamicsHex to a steady-state - balance may be of interest to remove very fast dynamics of the - fluid, while still modeling slower dynamics that arises from - the metal of the heat exchanger. By default, - energyDynamicsHexSolid is set to the same value as - energyDynamicsHex as this seems to be the typical - configuration. -

    -

    - The heat exchanger is implemented in AixLib.Fluid.Storage.BaseClasses.IndirectTankHeatExchanger. -

    -
    - --------- Errors -------- -line 6 column 1 - Warning: The summary attribute on the element is obsolete in HTML5 -line 17 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 129 column 1 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/ThermalZones/ReducedOrder/RC/TwoElements.mo ---- --------- HTML Code -------- - -

    - -

    This model distinguishes between internal - thermal masses and exterior walls. While exterior walls contribute to heat - transfer to the ambient, adiabatic conditions apply to internal masses. - Parameters for the internal wall element are the length of the RC-chain - nInt, the vector of the capacities - CInt[nInt] and the vector of the resistances RInt[nInt]. - This approach allows considering the dynamic behaviour induced by internal - heat storage. -

    -

    - The image below shows the RC-network of this model. -

    -

    - \"image\"/ -

    - --------- Corrected Code --------

    - This model distinguishes between internal thermal masses and exterior - walls. While exterior walls contribute to heat transfer to the - ambient, adiabatic conditions apply to internal masses. Parameters - for the internal wall element are the length of the RC-chain - nInt, the vector of the capacities - CInt[nInt] and the vector of the resistances - RInt[nInt]. This approach allows considering the dynamic - behaviour induced by internal heat storage. + This medium package models moist air using a gas law in which + pressure and temperature are independent, which often leads to + significantly faster and more robust computations. The specific heat + capacities at constant pressure and at constant volume are constant. + The air is assumed to be not saturated.

    - The image below shows the RC-network of this model. + This medium uses the gas law

    -

    - \"image\" +

    + ρ/ρstp = p/pstp,

    - --------- Errors -------- -line 14 column 4 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FMI/UsersGuide.mo ---- --------- HTML Code -------- -

    -This user's guide describes the FMI package (Wetter et al., 2015). -The FMI package has been implemented to facilitate the export -of thermofluid flow models such as HVAC components, HVAC systems -and thermal zones as Functional Mockup Units (FMUs). -This allows to export thermofluid flow models as FMUs so that they can be -imported in other simulators. -To export thermofluid flow components, a Modelica block is needed -in order for the model to only have input and output signals -rather than fluid connectors, as fluid connectors do not impose any causality -on the signal flow. -This package implements such blocks and its connectors. + where pstd and ρstp are constant + reference temperature and density, rathern than the ideal gas law

    -

    -The main packages are as follows: +

    + ρ = p ⁄(R T),

    -
    - - - - - - - - - - - - - - - - - - - -
    PackageDescription
    - - AixLib.Fluid.FMI.ExportContainers - -

    - Package with blocks to export thermofluid flow components and systems. -

    -

    - To export an HVAC component or system with a single inlet and outlet port, instantiate - - AixLib.Fluid.FMI.ExportContainers.ReplaceableTwoPort - with a replaceable model, - or extend from - - AixLib.Fluid.FMI.ExportContainers.PartialTwoPort - and add components.
    - See - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.Fan - and - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ResistanceVolume. -

    -

    - To export an HVAC system that serves a single thermal zone, extend from - - AixLib.Fluid.FMI.ExportContainers.HVACZone - and add the HVAC system.
    - See - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone. -

    -

    - To export an HVAC system that serves multiple thermal zones, extend from - - AixLib.Fluid.FMI.ExportContainers.HVACZones - and add the HVAC system.
    - See - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones. -

    -

    - To export a single thermal zone, extend from - - AixLib.Fluid.FMI.ExportContainers.ThermalZone - and add the thermal zone.
    - See - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone. -

    -

    - To export multiple thermal zones, extend from - - AixLib.Fluid.FMI.ExportContainers.ThermalZones - and add the thermal zone models.
    - See - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones. -

    -
    - - AixLib.Fluid.FMI.Adaptors - -

    - Package with adaptors to connect models with fluid ports to blocks that - have input and output signals. -

    -
    -

    - - AixLib.Fluid.FMI.Conversion -

    -
    -

    - Package with blocks that convert between the signal connectors of - - AixLib.Fluid.FMI.Interfaces - and the real input and output signal connectors of the Modelica Standard Library. -

    -
    - - AixLib.Fluid.FMI.Interfaces - -

    - Package with composite connectors that have different input and output - signals. These connectors are used to export FMUs, and they contain - quantities such as mass flow rate, temperature, optional pressure, etc. -

    -

    -The package - -AixLib.Fluid.FMI.ExportContainers.Examples.FMUs -contains various examples in which HVAC components, HVAC systems -and thermal zones are exported as an FMU. + where R is the gas constant and T is the temperature.

    -

    Typical use

    -Users who want to export a single thermofluid flow component, or a -subsystem of thermofluid flow components, can use the block - -AixLib.Fluid.FMI.ExportContainers.ReplaceableTwoPort. -This block has a fluid inlet, a fluid outlet, and a replaceable -component that can be replaced with an HVAC component or system that -has an inlet and outlet fluid port. + This formulation often leads to smaller systems of nonlinear + equations because equations for pressure and temperature are + decoupled. Therefore, if air inside a control volume such as room air + is heated, it does not increase its specific volume. Consequently, + merely heating or cooling a control volume does not affect the air + flow calculations in a duct network that may be connected to that + volume. Note that multizone air exchange simulation in which buoyancy + drives the air flow is still possible as the models in AixLib.Airflow.Multizone + compute the mass density using the function AixLib.Utilities.Psychrometrics.Functions.density_pTX + in which density is a function of temperature.

    -Users who want to export a whole HVAC system that serves a single thermal zone -can do so by extending the partial block - -AixLib.Fluid.FMI.ExportContainers.HVACZone. -The example - -AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone -illustrates how this can be accomplished.
    -Similar export containers and examples are implemented for HVAC systems that serve multiple thermal zones. + Note that models in this package implement the equation for the + internal energy as

    -

    -Conversely, to export a thermal zone, users can extend the partial block - -AixLib.Fluid.FMI.ExportContainers.ThermalZone. -The example - -AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone -illustrates how this can be accomplished.
    -Similar export containers and examples are implemented for models of multiple thermal zones. +

    + u = h - pstp ⁄ ρstp,

    -Each example and validation model has a Dymola script that -either simulates the model, or exports the model as an FMU. -The script can be invoked from the pull -down menu Commands -> Export FMU. + where u is the internal energy per unit mass, h is the + enthalpy per unit mass, pstp is the static pressure + and ρstp is the mass density at standard pressure + and temperature. The reason for this implementation is that in + general,

    -

    Options

    -

    -In the -AixLib.Fluid package, -most models have a boolean parameter called allowFlowReversal. -If set to true, then the flow can be in either direction, -otherwise it needs to be from the inlet to the outlet port. -This parameter is also used in the -AixLib.Fluid.FMI package. -The package was designed in such a way that an FMU, -if exported with allowFlowReversal=false -has as input the mass flow rate, -pressure and fluid properties of the inflowing fluid. The outputs -are the outlet mass flow rate, outlet pressure and the fluid -properties of the outflowing medium. This allows simulators -such as Ptolemy II -to evaluate the FMUs in the direction of the mass flow by first -setting all inputs, then evaluating the model equations, -and finally retrieving the -outputs before proceeding the simulation with the next downstream -component. -If allowFlowReversal=true, then the connectors have additional -signals for the properties of the fluid if it flows backwards. +

    + h = u + p v,

    -Most components have a boolean parameter use_p_in. -If use_p_in=true, then the pressure is used from the -connector, and based on the mass flow rate, the outlet pressure -is computed and assigned to the outlet connectors. -If use_p_in=false, then the pressure as declared -by the constant p_default of the medium model is -used, and the component computes no pressure drop. -Setting use_p_in=false therefore leads to fewer -equations, but it requires a component that specifies the mass -flow rate, such as - -AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.IdealSource_m_flow. + from which follows that

    -

    Notes

    -

    -Note the following when exporting HVAC component models as an FMU: +

    + u = h - p v = h - p ⁄ ρ = h - pstp ⁄ ρstd,

    -
      -
    1. -For models with control volumes, -the mass balance must be configured using -massDynamics=Modelica.Fluid.Types.Dynamics.SteadyState -when used with the media - -AixLib.Media.Air. -Otherwise, the translation stops with the error + because p ⁄ ρ = pstp ⁄ ρstp in this + medium model.

      -
      -The model requires derivatives of some inputs as listed below:
      -1 inlet.p
      -

      -The reason is that for - -AixLib.Media.Air, -mass is proportional to pressure and pressure is proportional -to density. Hence, dm/dt requires dp/dt, -but the time derivative of the pressure is not an input to the model. -

      -

      -For -AixLib.Media.Water, this setting is not needed -as the mass is independent of pressure. -

      -
    2. -
    3. -

      -The model - -AixLib.Fluid.Movers.FlowControlled_m_flow -cannot be exported as an FMU. -This is because it assignes the mass flow rate. -However, the input connector - -AixLib.Fluid.FMI.Interfaces.Inlet -already declares the mass flow rate as an input. -Therefore, the mass flow rate is overdetermined. -As a fall back, if a user needs to set the mass flow rate, he/she can -do so by using - -AixLib.Fluid.FMI.Source_T, -which takes as an input signal the mass flow rate. -

      -
    4. -
    -

    -When connecting fluid flow components in a loop, -be careful to avoid circular assignments for example for the temperature, -as these can of course not be simulated. -An example of such an ill-posed problem is to connect the outlet of - -AixLib.Fluid.FixedResistances.PressureDrop -to its inlet. In this situation, neither pressure, nor mass flow rate or temperature -can be computed. To model such loops, a control volume with a dynamic energy -balance must be presented, and the medium needs to be compressible. -

    -

    References

    -

    -Michael Wetter, Marcus Fuchs and Thierry Stephane Nouidui.
    - -Design choices for thermofluid flow components and systems that are exported as Functional Mockup Units.
    -Proc. of the 11th International Modelica Conference, - p. 31-41, - Versailles, France, September 2015. -

    - --------- Corrected Code -------- -

    - This user's guide describes the FMI package (Wetter et al., 2015). - The FMI package has been implemented to facilitate the export of - thermofluid flow models such as HVAC components, HVAC systems and - thermal zones as Functional Mockup Units (FMUs). This allows to - export thermofluid flow models as FMUs so that they can be imported - in other simulators. To export thermofluid flow components, a - Modelica block is needed in order for the model to only have input - and output signals rather than fluid connectors, as fluid connectors - do not impose any causality on the signal flow. This package - implements such blocks and its connectors. -

    -

    - The main packages are as follows: -

    - - - - - - - - - - - - - - - - - - - - - -
    - Package - - Description -
    - AixLib.Fluid.FMI.ExportContainers - -

    - Package with blocks to export thermofluid flow components and - systems. -

    -

    - To export an HVAC component or system with a single inlet and - outlet port, instantiate - AixLib.Fluid.FMI.ExportContainers.ReplaceableTwoPort with a - replaceable model, or extend from AixLib.Fluid.FMI.ExportContainers.PartialTwoPort - and add components.
    - See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.Fan and - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ResistanceVolume. -

    -

    - To export an HVAC system that serves a single thermal zone, - extend from AixLib.Fluid.FMI.ExportContainers.HVACZone - and add the HVAC system.
    - See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone. -

    -

    - To export an HVAC system that serves multiple thermal zones, - extend from AixLib.Fluid.FMI.ExportContainers.HVACZones - and add the HVAC system.
    - See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones. -

    -

    - To export a single thermal zone, extend from AixLib.Fluid.FMI.ExportContainers.ThermalZone - and add the thermal zone.
    - See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone. -

    -

    - To export multiple thermal zones, extend from AixLib.Fluid.FMI.ExportContainers.ThermalZones - and add the thermal zone models.
    - See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones. -

    -
    - AixLib.Fluid.FMI.Adaptors - -

    - Package with adaptors to connect models with fluid ports to - blocks that have input and output signals. -

    -
    -

    - AixLib.Fluid.FMI.Conversion -

    -
    -

    - Package with blocks that convert between the signal connectors - of AixLib.Fluid.FMI.Interfaces - and the real input and output signal connectors of the Modelica - Standard Library. -

    -
    - AixLib.Fluid.FMI.Interfaces - -

    - Package with composite connectors that have different input and - output signals. These connectors are used to export FMUs, and - they contain quantities such as mass flow rate, temperature, - optional pressure, etc. -

    -
    -

    - The package AixLib.Fluid.FMI.ExportContainers.Examples.FMUs - contains various examples in which HVAC components, HVAC systems and - thermal zones are exported as an FMU. -

    -

    - Typical use -

    -

    - Users who want to export a single thermofluid flow component, or a - subsystem of thermofluid flow components, can use the block AixLib.Fluid.FMI.ExportContainers.ReplaceableTwoPort. - This block has a fluid inlet, a fluid outlet, and a replaceable - component that can be replaced with an HVAC component or system that - has an inlet and outlet fluid port. -

    -

    - Users who want to export a whole HVAC system that serves a single - thermal zone can do so by extending the partial block AixLib.Fluid.FMI.ExportContainers.HVACZone. - The example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone - illustrates how this can be accomplished.
    - Similar export containers and examples are implemented for HVAC - systems that serve multiple thermal zones. -

    -

    - Conversely, to export a thermal zone, users can extend the partial - block AixLib.Fluid.FMI.ExportContainers.ThermalZone. - The example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone - illustrates how this can be accomplished.
    - Similar export containers and examples are implemented for models of - multiple thermal zones. -

    -

    - Each example and validation model has a Dymola script that either - simulates the model, or exports the model as an FMU. The script can - be invoked from the pull down menu Commands -> Export - FMU. -

    -

    - Options -

    -

    - In the AixLib.Fluid package, - most models have a boolean parameter called - allowFlowReversal. If set to true, then the - flow can be in either direction, otherwise it needs to be from the - inlet to the outlet port. This parameter is also used in the AixLib.Fluid.FMI package. The - package was designed in such a way that an FMU, if exported with - allowFlowReversal=false has as input the mass flow rate, - pressure and fluid properties of the inflowing fluid. The outputs are - the outlet mass flow rate, outlet pressure and the fluid properties - of the outflowing medium. This allows simulators such as Ptolemy II - to evaluate the FMUs in the direction of the mass flow by first - setting all inputs, then evaluating the model equations, and finally - retrieving the outputs before proceeding the simulation with the next - downstream component. If allowFlowReversal=true, then - the connectors have additional signals for the properties of the - fluid if it flows backwards. -

    -

    - Most components have a boolean parameter use_p_in. If - use_p_in=true, then the pressure is used from the - connector, and based on the mass flow rate, the outlet pressure is - computed and assigned to the outlet connectors. If - use_p_in=false, then the pressure as declared by the - constant p_default of the medium model is used, and the - component computes no pressure drop. Setting - use_p_in=false therefore leads to fewer equations, but - it requires a component that specifies the mass flow rate, such as - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.IdealSource_m_flow. -

    -

    - Notes -

    -

    - Note the following when exporting HVAC component models as an FMU: -

    -
      -
    1. -

      - For models with control volumes, the mass balance must be - configured using - massDynamics=Modelica.Fluid.Types.Dynamics.SteadyState - when used with the media AixLib.Media.Air. Otherwise, - the translation stops with the error -

      -
      -The model requires derivatives of some inputs as listed below:
      -1 inlet.p
      -
      -

      - The reason is that for AixLib.Media.Air, mass is - proportional to pressure and pressure is proportional to density. - Hence, dm/dt requires dp/dt, but the time - derivative of the pressure is not an input to the model. -

      -

      - For AixLib.Media.Water, this - setting is not needed as the mass is independent of pressure. -

      -
    2. -
    3. -

      - The model AixLib.Fluid.Movers.FlowControlled_m_flow - cannot be exported as an FMU. This is because it assignes the - mass flow rate. However, the input connector AixLib.Fluid.FMI.Interfaces.Inlet - already declares the mass flow rate as an input. Therefore, the - mass flow rate is overdetermined. As a fall back, if a user needs - to set the mass flow rate, he/she can do so by using AixLib.Fluid.FMI.Source_T, - which takes as an input signal the mass flow rate. -

      -
    4. -
    -

    - When connecting fluid flow components in a loop, be careful to avoid - circular assignments for example for the temperature, as these can of - course not be simulated. An example of such an ill-posed problem is - to connect the outlet of AixLib.Fluid.FixedResistances.PressureDrop - to its inlet. In this situation, neither pressure, nor mass flow rate - or temperature can be computed. To model such loops, a control volume - with a dynamic energy balance must be presented, and the medium needs - to be compressible. -

    -

    - References -

    -

    - Michael Wetter, Marcus Fuchs and Thierry Stephane Nouidui.
    - - Design choices for thermofluid flow components and systems that are - exported as Functional Mockup Units.
    - Proc. of the 11th International Modelica Conference, p. 31-41, - Versailles, France, September 2015. + The enthalpy is computed using the convention that h=0 if + T=0 °C and no water vapor is present.

    + -------- Errors -------- -line 18 column 1 - Warning: The summary attribute on the element is obsolete in HTML5 +line 8 column 2 - Warning: The summary attribute on the
    element is obsolete in HTML5 ----- AixLib/Controls/SetPoints/Examples/OccupancySchedule.mo ---- --------- HTML Code -------- +line 7 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +line 6 column 2 - Warning:

    attribute "align" not allowed for HTML5 -

    - Example that demonstrates the use of the occupancy schedule. - The figure below shows how the time until the next occupancy starts or ends - is decreased. The red line hits zero when the schedule indicates an occupied time, - and the blue line hits zero when the schedule indicates a non-occupied time. -

    -

    - \"Time -

    - - - --------- Corrected Code -------- -

    - Example that demonstrates the use of the occupancy schedule. The - figure below shows how the time until the next occupancy starts or - ends is decreased. The red line hits zero when the schedule indicates - an occupied time, and the blue line hits zero when the schedule - indicates a non-occupied time. -

    -

    - \"Time -

    - --------- Errors -------- line 8 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 21 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 37 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatPumps/ReciprocatingWaterToWater.mo ---- --------- HTML Code -------- +line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 19 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 43 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 54 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 60 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/FixedResistances/HydraulicDiameter.mo ---- +-------- HTML Code --------

    - Model for a water to water heat pump with a reciprocating compressor, as - described in Jin (2002). The thermodynamic heat pump cycle is represented below. + This is a model of a flow resistance with a fixed flow coefficient. + The mass flow rate is computed as

    -

    - \"image\" +

    + ṁ = k + √ΔP,

    - The rate of heat transferred to the evaporator is given by: + where + k is a constant and + ΔP is the pressure drop. + The constant k is equal to + k=m_flow_nominal/sqrt(dp_nominal), + where m_flow_nominal is a parameter.

    -

    - Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ). +

    Assumptions

    +

    + In the region + abs(m_flow) < m_flow_turbulent, + the square root is replaced by a differentiable function + with finite slope. + The value of m_flow_turbulent is + computed as + m_flow_turbulent = eta_nominal*dh/4*π*ReC, + where + eta_nominal is the dynamic viscosity, obtained from + the medium model. The parameter + dh is the hydraulic diameter and + ReC=4000 is the critical Reynolds number, which both + can be set by the user.

    +

    Important parameters

    - The power consumed by the compressor is given by a linear efficiency relation: + By default, the pressure drop at nominal flow rate is computed as

    -

    - P = PTheoretical / η + PLoss,constant. +

    + dp_nominal = fac * dpStraightPipe_nominal,
    + 
    +

    + where dpStraightPipe_nominal is a parameter that is automatically computed + based on the + nominal mass flow rate, hydraulic diameter, pipe roughness and medium properties. + The hydraulic diameter dh is by default + computed based on the flow velocity v_nominal and the nominal + mass flow rate m_flow_nominal. Hence, users should change the + default values of dh or v_nominal + if they are not applicable for their model.

    - Heat transfer in the evaporator and condenser is calculated using an - ε-NTU method, assuming constant refrigerant temperature and constant heat - transfer coefficient between fluid and refrigerant. + The factor fac takes into account additional resistances such as + for bends. The default value of 2 can be changed by the user.

    - Variable speed is acheived by multiplying the full load piston displacement - by the normalized compressor speed. The power and heat transfer rates are forced - to zero if the resulting heat pump state has higher evaporating pressure than - condensing pressure. + The parameter from_dp is used to determine + whether the mass flow rate is computed as a function of the + pressure drop (if from_dp=true), or vice versa. + This setting can affect the size of the nonlinear system of equations.

    -

    Options

    - Parameters TConMax and TEvaMin - may be used to set an upper or lower bound for the - condenser and evaporator. - The compressor is disabled when these conditions - are not satisfied, or when the - evaporator temperature is larger - than the condenser temperature. - This mimics the temperature protection - of heat pumps and moreover it avoids - non-converging algebraic loops of equations, - or freezing of evaporator medium. - This option can be disabled by setting - enable_temperature_protection = false. + If the parameter linearized is set to true, + then the pressure drop is computed as a linear function of the + mass flow rate.

    -

    Assumptions and limitations

    - The compression process is assumed isentropic. The thermal energy - of superheating is ignored in the evaluation of the heat transferred to the refrigerant - in the evaporator. There is no supercooling. + Setting allowFlowReversal=false can lead to simpler + equations. However, this should only be set to false + if one can guarantee that the flow never reverses its direction. + This can be difficult to guarantee, as pressure imbalance after + the initialization, or due to medium expansion and contraction, + can lead to reverse flow.

    -

    References

    - H. Jin. - - Parameter estimation based models of water source heat pumps. - - PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002. + If the parameter + show_T is set to true, + then the model will compute the + temperature at its ports. Note that this can lead to state events + when the mass flow rate approaches zero, + which can increase computing time. +

    +

    Notes

    +

    + For more detailed models that compute the actual flow friction, + models from the package + + Modelica.Fluid + can be used and combined with models from the + AixLib library. +

    +

    + For a model that uses dp_nominal as a parameter rather than + geoemetric data, use + + AixLib.Fluid.FixedResistances.PressureDrop. +

    +

    Implementation

    +

    + The pressure drop is computed by calling a function in the package + + AixLib.Fluid.BaseClasses.FlowModels, + This package contains regularized implementations of the equation +

    +

    + m = sign(Δp) k √ Δp   +

    +

    + and its inverse function. +

    +

    + To decouple the energy equation from the mass equations, + the pressure drop is a function of the mass flow rate, + and not the volume flow rate. + This leads to simpler equations.

    -------- Corrected Code --------

    - Model for a water to water heat pump with a reciprocating compressor, - as described in Jin (2002). The thermodynamic heat pump cycle is - represented below. + This is a model of a flow resistance with a fixed flow coefficient. + The mass flow rate is computed as

    -

    - \"image\" +

    + ṁ = k √ΔP,

    - The rate of heat transferred to the evaporator is given by: + where k is a constant and ΔP is the pressure drop. The + constant k is equal to + k=m_flow_nominal/sqrt(dp_nominal), where + m_flow_nominal is a parameter.

    -

    - Q̇Eva = ṁref ( - hVap(TEva) - hLiq(TCon) - ). +

    + Assumptions +

    +

    + In the region abs(m_flow) < m_flow_turbulent, the + square root is replaced by a differentiable function with finite + slope. The value of m_flow_turbulent is computed as + m_flow_turbulent = eta_nominal*dh/4*π*ReC, where + eta_nominal is the dynamic viscosity, obtained from the + medium model. The parameter dh is the hydraulic diameter + and ReC=4000 is the critical Reynolds number, which both + can be set by the user.

    +

    + Important parameters +

    - The power consumed by the compressor is given by a linear efficiency - relation: + By default, the pressure drop at nominal flow rate is computed as

    -

    - P = PTheoretical / η + PLoss,constant. +

    + dp_nominal = fac * dpStraightPipe_nominal,
    + 
    +

    + where dpStraightPipe_nominal is a parameter that is + automatically computed based on the nominal mass flow rate, hydraulic + diameter, pipe roughness and medium properties. The hydraulic + diameter dh is by default computed based on the flow + velocity v_nominal and the nominal mass flow rate + m_flow_nominal. Hence, users should change the default + values of dh or v_nominal if they are not + applicable for their model.

    - Heat transfer in the evaporator and condenser is calculated using an - ε-NTU method, assuming constant refrigerant temperature and constant - heat transfer coefficient between fluid and refrigerant. + The factor fac takes into account additional resistances + such as for bends. The default value of 2 can be changed + by the user.

    - Variable speed is acheived by multiplying the full load piston - displacement by the normalized compressor speed. The power and heat - transfer rates are forced to zero if the resulting heat pump state - has higher evaporating pressure than condensing pressure. + The parameter from_dp is used to determine whether the + mass flow rate is computed as a function of the pressure drop (if + from_dp=true), or vice versa. This setting can affect + the size of the nonlinear system of equations.

    -

    - Options -

    - Parameters TConMax and TEvaMin may be used - to set an upper or lower bound for the condenser and evaporator. The - compressor is disabled when these conditions are not satisfied, or - when the evaporator temperature is larger than the condenser - temperature. This mimics the temperature protection of heat pumps and - moreover it avoids non-converging algebraic loops of equations, or - freezing of evaporator medium. This option can be disabled by setting - enable_temperature_protection = false. + If the parameter linearized is set to true, + then the pressure drop is computed as a linear function of the mass + flow rate.

    -

    - Assumptions and limitations -

    - The compression process is assumed isentropic. The thermal energy of - superheating is ignored in the evaluation of the heat transferred to - the refrigerant in the evaporator. There is no supercooling. + Setting allowFlowReversal=false can lead to simpler + equations. However, this should only be set to false if + one can guarantee that the flow never reverses its direction. This + can be difficult to guarantee, as pressure imbalance after the + initialization, or due to medium expansion and contraction, can lead + to reverse flow. +

    +

    + If the parameter show_T is set to true, + then the model will compute the temperature at its ports. Note that + this can lead to state events when the mass flow rate approaches + zero, which can increase computing time.

    - References + Notes

    - H. Jin. Parameter estimation based models of water source heat - pumps. PhD Thesis. Oklahoma State University. Stillwater, - Oklahoma, USA. 2002. -

    + For more detailed models that compute the actual flow friction, + models from the package Modelica.Fluid can be used and + combined with models from the AixLib library. +

    +

    + For a model that uses dp_nominal as a parameter rather + than geoemetric data, use AixLib.Fluid.FixedResistances.PressureDrop. +

    +

    + Implementation +

    +

    + The pressure drop is computed by calling a function in the package + AixLib.Fluid.BaseClasses.FlowModels, + This package contains regularized implementations of the equation +

    +

    + m = sign(Δp) k √ Δp +   +

    +

    + and its inverse function. +

    +

    + To decouple the energy equation from the mass equations, the pressure + drop is a function of the mass flow rate, and not the volume flow + rate. This leads to simpler equations. +

    -------- Errors -------- line 6 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 12 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 18 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 104 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD100.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/cylindricalHeatSource.mo ---- -------- HTML Code -------- -

    WD100: Base Case

    -

    Weather data file : WD100.epw

    -

    Table 1: Site Data for Weather file WD100.epw

    -
    - - - - - - - - - - - - - - - -

    Latitude

    39.833° north

    Longitude

    104.65° west

    Altitude

    1650 m

    Time Zone

    -7

    -

    This model is a template for all the other test cases. - It allows to extrapolate all the weather data from the Reader TMY3 for a specific location, incliation and azimuth. - The model - AixLib.BoundaryConditions.Validation.IsotropicAndPerezDiffuseRadiation - outputs radiation data using the available Isotropic and Perez methodlogies. - The sky temperature is calculated using both the Horizontal radiation model, - from data reader weaBusHorRad and the dew point temperature plus sky cover model from the datareader weaBusSkyCovDewTem.

    +

    + This function evaluates the cylindrical heat source solution. This solution + gives the relation between the constant heat transfer rate (per unit length) + injected by a cylindrical heat source of infinite length and the temperature + raise in the medium. The cylindrical heat source solution is defined by +

    +

    + \"image\" +

    +

    + where ΔT(t,r) is the temperature raise after a time t of + constant heat injection and at a distance r from the cylindrical source, + Q' is the heat injection rate per unit length, ks is + the soil thermal conductivity, Fo is the Fourier number, + aSois is the ground thermal diffusivity, + rb is the radius of the cylindrical source and G + is the cylindrical heat source solution. +

    +

    + The cylindrical heat source solution is given by: +

    +

    + \"image\" +

    +

    + The integral is solved numerically, with the integrand defined in + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource_Integrand. +

    -------- Corrected Code -------- -

    - WD100: Base Case -

    - Weather data file : WD100.epw + This function evaluates the cylindrical heat source solution. This + solution gives the relation between the constant heat transfer rate + (per unit length) injected by a cylindrical heat source of infinite + length and the temperature raise in the medium. The cylindrical heat + source solution is defined by +

    +

    + \"image\"

    - Table 1: Site Data for Weather file WD100.epw + where ΔT(t,r) is the temperature raise after a time t + of constant heat injection and at a distance r from the + cylindrical source, Q' is the heat injection rate per unit + length, ks is the soil thermal conductivity, + Fo is the Fourier number, aSois is the + ground thermal diffusivity, rb is the radius of the + cylindrical source and G is the cylindrical heat source + solution.

    - - - - - - - - - - - - - - - - - -
    -

    - Latitude -

    -
    -

    - 39.833° north -

    -
    -

    - Longitude -

    -
    -

    - 104.65° west -

    -
    -

    - Altitude -

    -
    -

    - 1650 m -

    -
    -

    - Time Zone -

    -
    -

    - -7 -

    -

    - This model is a template for all the other test cases. It allows to - extrapolate all the weather data from the Reader TMY3 for a specific - location, incliation and azimuth. The model - AixLib.BoundaryConditions.Validation.IsotropicAndPerezDiffuseRadiation - outputs radiation data using the available Isotropic and Perez - methodlogies. The sky temperature is calculated using both the - Horizontal radiation model, from data reader weaBusHorRad and the dew - point temperature plus sky cover model from the datareader - weaBusSkyCovDewTem. + The cylindrical heat source solution is given by: +

    +

    + \"image\" +

    +

    + The integral is solved numerically, with the integrand defined in + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource_Integrand.

    -------- Errors -------- -line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 8 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 23 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Media/Antifreeze/PropyleneGlycolWater.mo ---- +---- AixLib/Fluid/Sources/Outside_CpLowRise.mo ---- -------- HTML Code -------- -

    - This base properties model is identical to - - Modelica.Media.Water.ConstantPropertyLiquidWater, - except that the equation - u = cv_const*(T - reference_T) - has been replaced by u=h because - cp_const=cv_const. - Also, the model checks if the mass fraction of the mixture is within the - allowed limits. -

    - -

    - Density of propylene antifreeze-water mixture at specified mass fraction - and temperature, based on Melinder (2010). -

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. -

    - - -

    - Dynamic viscosity of antifreeze-water mixture at specified mass fraction and - temperature, based on Melinder (2010). + This model describes boundary conditions for + pressure, enthalpy, and species concentration that can be obtained + from weather data. The model is identical to + + AixLib.Fluid.Sources.Outside, + except that it adds the wind pressure to the + pressure at the fluid port ports. + The correlation that is used to compute the wind pressure is based + on Swami and Chandra (1987) and valid for low-rise buildings + with rectangular shape. + The same correlation is also implemented in CONTAM (Persily and Ivy, 2001). +

    -

    References

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. + The wind pressure coefficient is computed based on the + side ratio of the walls, which is defined as

    - - - -

    - Fusion temperature of antifreeze-water mixture at specified mass fraction and - temperature, based on Melinder (2010). +

    + s = x ⁄ y

    -

    References

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. + where x is the length of the wall that will be connected to + this model, and y is the length of the adjacent wall. + The wind direction is computed relative to the azimuth of this surface, + which is equal to the parameter azi. + The surface azimuth is defined in + + AixLib.Types.Azimuth. + For example, if an exterior wall is South oriented, i.e., its outside-facing + surface is towards South, use + AixLib.Types.Azimuth.S.

    - - -

    - Evaluates a thermophysical property of a mixture, based on correlations proposed - by Melinder (2010). + Based on the surface azimuth, the wind direction and the side ratio + of the walls, the model computes how much the wind pressure + is attenuated compared to the reference wind pressure Cp0. + The reference wind pressure Cp0 is a user-defined parameter, + and must be equal to the wind pressure at zero wind incidence angle. + Swami and Chandra (1987) recommend Cp0 = 0.6 for + all low-rise buildings as this represents the average of + various values reported in the literature. + The computation of the actual wind pressure coefficient Cp + is explained in the function + + Buildings.Airflow.Multizone.BaseClasses.windPressureLowRise + that is called by this model.

    - The polynomial has the form + The pressure p at the port ports is computed as

    - f = a1 (x-xm)0(y-ym)0 - + a2 (x-xm)0(y-ym)1 - + ... + - any[1] (x-xm)0(y-ym)ny[1]-1 - + ... + - any[1])+1 (x-xm)1(y-ym)0 - + ... + - any[1]+ny[2] (x-xm)1(y-ym)ny[2]-1 - + ... + p = pw + Cp 1 ⁄ 2 v2 ρ,

    -

    References

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. + where + pw is the atmospheric pressure from the weather bus, + v is the wind speed from the weather bus, and + ρ is the fluid density.

    - - -

    - Specific heat capacity of antifreeze-water mixture at specified mass fraction - and temperature, based on Melinder (2010). -

    -

    References

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. + This model differs from + AixLib.Fluid.Sources.Outside_CpData by the calculation of the wind pressure coefficient Cp,act. + The wind pressure coefficient is defined by an equation in stead of a user-defined table. + This model is only suited for low-rise rectangular buildings.

    +

    References

    -

    - Thermal conductivity of antifreeze-water mixture at specified mass fraction and - temperature, based on Melinder (2010). -

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. -

    - - -

    - This medium package models propylene glycol - water mixtures. -

    -

    - The mass density, specific heat capacity, thermal conductivity and viscosity - are assumed constant and evaluated at a set temperature and mass fraction of - propylene glycol within the mixture. The dependence of the four properties - are shown on the figure below. -

    -

    - \"Relative -

    -

    - The accuracy of the thermophysical properties is dependent on the temperature - variations encountered during simulations. - The figure below shows the relative error of the the four properties over a - 10 °C range around the temperature used to evaluate the constant - properties. The maximum errors are 0.8 % for mass density, 1.5 % - for specific heat capacity, 3.2 % for thermal conductivity and 250 - % for dynamic viscosity. -

    -

    - \"Relative -

    -

    - The figure below shows the relative error of the the four properties over a - 20 °C range around the temperature used to evaluate the constant - proepties. The maximum errors are 1.6 % for mass density, 3.0 % - for specific heat capacity, 6.2 % for thermal conductivity and 950 - % for dynamic viscosity. -

    -

    - \"Relative -

    -

    - The enthalpy is computed using the convention that h=0 - if T=0 °C. -

    -

    Limitations

    -

    - Density, specific heat capacity, thermal conductivity and viscosity are constant. - The propylene glycol/water mixture is modeled as an incompressible liquid. - There are no phase changes. The medium is limited to temperatures below - 100 °C and mass fractions below 0.60. - As is the case for AixLib.Media.Water, - this medium package should not be used if - the simulation relies on the dynamic viscosity. -

    -

    Typical use and important parameters

    -

    - The temperature and mass fraction must be specified for the evaluation of the - constant thermophysical properties. A typical use of the package is (e.g. for - a temperature of 20 °C and a mass fraction of 0.40): -

    -

    - Medium = AixLib.Media.Antifreeze.PropyleneGlycolWater(property_T=293.15, X_a=0.40) -

    - - -------- Corrected Code --------

    - This base properties model is identical to Modelica.Media.Water.ConstantPropertyLiquidWater, - except that the equation u = cv_const*(T - reference_T) - has been replaced by u=h because - cp_const=cv_const. Also, the model checks if the mass - fraction of the mixture is within the allowed limits. -

    -

    - Density of propylene antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). -

    -

    - References -

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. -

    - -

    - Dynamic viscosity of antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). + This model describes boundary conditions for pressure, enthalpy, and + species concentration that can be obtained from weather data. The + model is identical to AixLib.Fluid.Sources.Outside, + except that it adds the wind pressure to the pressure at the fluid + port ports. The correlation that is used to compute the + wind pressure is based on Swami and Chandra (1987) and valid for + low-rise buildings with rectangular shape. The same correlation is + also implemented in CONTAM (Persily and Ivy, 2001). +

    -

    - References -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. + The wind pressure coefficient is computed based on the side ratio of + the walls, which is defined as

    - -

    - Fusion temperature of antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). +

    + s = x ⁄ y

    -

    - References -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. + where x is the length of the wall that will be connected to + this model, and y is the length of the adjacent wall. The wind + direction is computed relative to the azimuth of this surface, which + is equal to the parameter azi. The surface azimuth is + defined in AixLib.Types.Azimuth. For + example, if an exterior wall is South oriented, i.e., its + outside-facing surface is towards South, use + AixLib.Types.Azimuth.S.

    -

    - Evaluates a thermophysical property of a mixture, based on - correlations proposed by Melinder (2010). + Based on the surface azimuth, the wind direction and the side ratio + of the walls, the model computes how much the wind pressure is + attenuated compared to the reference wind pressure Cp0. + The reference wind pressure Cp0 is a user-defined + parameter, and must be equal to the wind pressure at zero wind + incidence angle. Swami and Chandra (1987) recommend Cp0 + = 0.6 for all low-rise buildings as this represents the average + of various values reported in the literature. The computation of the + actual wind pressure coefficient Cp is explained in + the function + Buildings.Airflow.Multizone.BaseClasses.windPressureLowRise that + is called by this model.

    - The polynomial has the form + The pressure p at the port ports is computed as

    - f = a1 (x-xm)0(y-ym)0 + - a2 (x-xm)0(y-ym)1 + ... + - any[1] (x-xm)0(y-ym)ny[1]-1 + ... + - any[1])+1 (x-xm)1(y-ym)0 + ... + - any[1]+ny[2] (x-xm)1(y-ym)ny[2]-1 + - ... + p = pw + Cp 1 ⁄ 2 v2 ρ,

    -

    - References -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. + where pw is the atmospheric pressure from the + weather bus, v is the wind speed from the weather bus, and + ρ is the fluid density.

    -

    - Specific heat capacity of antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). + This model differs from AixLib.Fluid.Sources.Outside_CpData + by the calculation of the wind pressure coefficient + Cp,act. The wind pressure coefficient is defined by an + equation in stead of a user-defined table. This model is only suited + for low-rise rectangular buildings.

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. -

    -

    - Thermal conductivity of antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). -

    -

    - References -

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. -

    + +-------- Errors -------- +line 28 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 61 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Storage/UsersGuide.mo ---- +-------- HTML Code -------- +

    - This medium package models propylene glycol - water mixtures. +This user's guide describes the storage tank models. +There are three storage tank models in the this package.

    +
    + + + + + + + + + + + + + +
    Model name Description
    + +AixLib.Fluid.Storage.Stratified +

    - The mass density, specific heat capacity, thermal conductivity and - viscosity are assumed constant and evaluated at a set temperature and - mass fraction of propylene glycol within the mixture. The dependence - of the four properties are shown on the figure below. +This is a model of a stratified storage tank as shown in the figure below.

    - - +\"Image

    - The accuracy of the thermophysical properties is dependent on the - temperature variations encountered during simulations. The figure - below shows the relative error of the the four properties over a - 10 °C range around the temperature used to evaluate the - constant properties. The maximum errors are 0.8 % for mass - density, 1.5 % for specific heat capacity, 3.2 % for - thermal conductivity and 250 % for dynamic viscosity. -

    -

    - - +The tank uses several volumes to model the stratification. +Heat conduction is modeled between the volumes through the fluid, +and between the volumes and the ambient.

    - The figure below shows the relative error of the the four properties - over a 20 °C range around the temperature used to evaluate the - constant proepties. The maximum errors are 1.6 % for mass - density, 3.0 % for specific heat capacity, 6.2 % for - thermal conductivity and 950 % for dynamic viscosity. -

    -

    - - +The heat port heaPorVol may be used to connect a temperature sensor +that measures the fluid temperature of an individual volume. It may also +be used to add heat to individual volumes, for example if the tank contains +an electrical resistance heater.

    - The enthalpy is computed using the convention that h=0 if - T=0 °C. +Similarly, the fluid port fluPorVol may be used to connect a fluid pipe +to an individual volume. This allows for example to draw water from that volume whose temperature +is close to the temperature required by the consumer. +Conversely, water could be added to that tank volume whose temperature is close to the +inlet water temperature. +If you don't use such a pipe, simply leave the ports unconnected.

    -

    - Limitations -

    - Density, specific heat capacity, thermal conductivity and viscosity - are constant. The propylene glycol/water mixture is modeled as an - incompressible liquid. There are no phase changes. The medium is - limited to temperatures below 100 °C and mass fractions below - 0.60. As is the case for AixLib.Media.Water, this medium - package should not be used if the simulation relies on the dynamic - viscosity. +The tank has nSeg fluid volumes. The top segment has the index 1. +Thus, to add a heating element to the bottom element, connect a heat input to +heaPorVol[nSeg].

    -

    - Typical use and important parameters -

    - The temperature and mass fraction must be specified for the - evaluation of the constant thermophysical properties. A typical use - of the package is (e.g. for a temperature of 20 °C and a mass - fraction of 0.40): +The heat ports outside the tank insulation can be +used to specify an ambient temperature. +Leave these ports unconnected to force adiabatic boundary conditions. +Note, however, that all heat conduction elements through the tank wall (but not the top and bottom) are connected to the +heat port heaPorSid. Thus, not connecting +heaPorSid means an adiabatic boundary condition in the sense +that heaPorSid.Q_flow = 0. This, however, still allows heat to flow +through the tank walls, modeled by conWal, from one fluid volume +to another one.

    +
    + +AixLib.Fluid.Storage.StratifiedEnhanced +

    - Medium = - AixLib.Media.Antifreeze.PropyleneGlycolWater(property_T=293.15, - X_a=0.40) +The model is identical to + +AixLib.Fluid.Storage.Stratified, +except for the following:

      -
    • October 26, 2018, by Filip Jorissen and Michael Wetter:
      - Now printing different messages if temperature or mass fraction is - above or below its limit, and adding instance name as JModelica - does not print the full instance name in the assertion. This is for - #1045. -
    • -
    • March 16, 2018, by Massimo Cimmino:
      - First implementation. -
    • +
    • +It adds a correction that reduces the numerical dissipation. +
    • +
    • +It does not contain the fluid ports fluPorVol that +connect from the outside to the individual volumes. +
    - --------- Errors -------- -line 9 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - -line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 24 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 35 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/Cylindrical.mo ---- --------- HTML Code -------- - -

    - Model for radial heat transfer in a hollow cylinder. -

    -

    - If the heat capacity of the material is non-zero, then this model computes transient heat conduction, i.e., it - computes a numerical approximation to the solution of the heat equation -

    -

    - ρ c ( ∂ T(r,t) ⁄ ∂t ) = - k ( ∂² T(r,t) ⁄ ∂r² + 1 ⁄ r   ∂ T(r,t) ⁄ ∂r ), -

    -

    - where - ρ - is the mass density, - c - is the specific heat capacity per unit mass, - T - is the temperature at location r and time t and - k is the heat conductivity. - At the locations r=ra and r=rb, - the temperature and heat flow rate are equal to the - temperature and heat flow rate of the heat ports. -

    -

    - If the heat capacity of the material is set to zero, then steady-state heat flow is computed using -

    -

    - Q = 2 π k (Ta-Tb)⁄ ln(ra ⁄ rb), -

    -

    - where - ra is the internal radius, - rb is the external radius, - Ta is the temperature at port a and - Tb is the temperature at port b. -

    -

    Implementation

    -

    - To spatially discretize the heat equation, the construction is - divided into compartments with nSta ≥ 1 state variables. - The state variables are connected to each other through thermal conductors. - There is also a thermal conductor - between the surfaces and the outermost state variables. Thus, to obtain - the surface temperature, use port_a.T (or port_b.T) - and not the variable T[1]. -

    - -
      -
    • - January, 2014, by Damien Picard:
      - Modify the discretization of the cilindrical layer so that the first three layers have an equal thickness the following an exponentionally growing thickness. - This follows the guidelines of Eskilson (P. Eskilson. Thermal analysis of heat extraction - boreholes. PhD thesis, Dep. of Mathematical - Physics, University of Lund, Sweden, 1987). -
    • -
    • - March 9, 2012, by Michael Wetter:
      - Removed protected variable der_T as it is not required. -
    • -
    • - April 14 2011, by Pierre Vigouroux:
      - First implementation. -
    • -
    - --------- Corrected Code --------

    - Model for radial heat transfer in a hollow cylinder. +The correction uses a third order upwind scheme to compute the +outlet temperatures of the segments in the tank. This model +is implemented in + +AixLib.Fluid.Storage.BaseClasses.ThirdOrderStratifier.

    +
    + +AixLib.Fluid.Storage.StratifiedEnhancedInternalHex +

    - If the heat capacity of the material is non-zero, then this model - computes transient heat conduction, i.e., it computes a numerical - approximation to the solution of the heat equation +This model is identical to + +AixLib.Fluid.Storage.StratifiedEnhanced +except that it adds a heat exchanger to the tank.

    -

    - ρ c ( ∂ T(r,t) ⁄ ∂t ) = k ( ∂² T(r,t) ⁄ ∂r² + 1 ⁄ r   ∂ T(r,t) ⁄ - ∂r ), +

    +The modifications consist of adding a heat exchanger +and fluid ports to connect to the heat exchanger. +The modifications allow to run a fluid through the tank causing heat transfer to the stored fluid. +A typical example is a storage tank in a solar hot water system.

    - where ρ is the mass density, c is the specific heat - capacity per unit mass, T is the temperature at location - r and time t and k is the heat conductivity. At - the locations r=ra and r=rb, the - temperature and heat flow rate are equal to the temperature and heat - flow rate of the heat ports. +The heat exchanger model assumes flow through the inside of a helical coil heat exchanger, +and stagnant fluid on the outside. Parameters are used to describe the +heat transfer on the inside of the heat exchanger at nominal conditions, and +geometry of the outside of the heat exchanger. This information is used to compute +an hA-value for each side of the coil. +Convection calculations are then performed to identify heat transfer +between the heat transfer fluid and the fluid in the tank.

    - If the heat capacity of the material is set to zero, then - steady-state heat flow is computed using +The location of the heat exchanger can be parameterized as follows: +The parameters hHex_a and hHex_b are the heights +of the heat exchanger ports portHex_a and portHex_b, +measured from the bottom of the tank. +For example, to place the port portHex_b at the bottom of the tank, +set hHexB_b=0. +The parameters hHex_a and hHex_b are then used to provide +a default value for the parameters +segHex_a and segHex_b, which are the numbers of the tank +segments to which the heat exchanger ports portHex_a and portHex_b +are connected.

    -

    - Q = 2 π k (Ta-Tb)⁄ ln(ra ⁄ - rb), +

    +\"Image

    - where ra is the internal radius, - rb is the external radius, Ta is - the temperature at port a and Tb is the temperature - at port b. +Optionally, this model computes a dynamic response of the heat exchanger. +This can be configured using the parameters +energyDynamicsHexSolid, +energyDynamicsHex and +massDynamicsHex. +For this computation, the fluid volume inside the heat exchanger +and the heat capacity of the heat +exchanger wall CHex are approximated. +Both depend on the length lHex +of the heat exchanger. +The model provides default values for these +parameters, as well as for the heat exchanger material which is +assumed to be steel. These default values can be overwritten by the user. +The default values for the heat exchanger geometry are computed assuming +that there is a cylindrical heat exchanger +made of steel whose diameter is half the diameter of the tank, e.g., +rHex=rTan/2. +Hence, the length of the heat exchanger is approximated as +lHex = 2 rHex π h = 2 rTan/2 π h, +where h is the distance between the heat exchanger inlet and outlet. +The wall thickness is assumed to be 10% of the heat exchanger +outer diameter. +For typical applications, users do not need to change these values.

    -

    - Implementation -

    - To spatially discretize the heat equation, the construction is - divided into compartments with nSta ≥ 1 state variables. - The state variables are connected to each other through thermal - conductors. There is also a thermal conductor between the surfaces - and the outermost state variables. Thus, to obtain the surface - temperature, use port_a.T (or port_b.T) and - not the variable T[1]. +Setting energyDynamicsHexSolid to a dynamic balance and +energyDynamicsHex to a steady-state balance may be of interest +to remove very fast dynamics of the fluid, while still modeling slower +dynamics that arises from the metal of the heat exchanger. +By default, energyDynamicsHexSolid is set +to the same value as energyDynamicsHex +as this seems to be the typical configuration.

    -
      -
    • January, 2014, by Damien Picard:
      - Modify the discretization of the cilindrical layer so that the - first three layers have an equal thickness the following an - exponentionally growing thickness. This follows the guidelines of - Eskilson (P. Eskilson. Thermal analysis of heat extraction - boreholes. PhD thesis, Dep. of Mathematical Physics, University of - Lund, Sweden, 1987). -
    • -
    • March 9, 2012, by Michael Wetter:
      - Removed protected variable der_T as it is not - required. -
    • -
    • April 14 2011, by Pierre Vigouroux:
      - First implementation. -
    • -
    +

    +The heat exchanger is implemented in + +AixLib.Fluid.Storage.BaseClasses.IndirectTankHeatExchanger. +

    +
    + +-------- Corrected Code -------- +

    + This user's guide describes the storage tank models. There are three + storage tank models in the this package. +

    + + + + + + + + + + + + + + + + + +
    + Model name + + Description +
    + AixLib.Fluid.Storage.Stratified + +

    + This is a model of a stratified storage tank as shown in the + figure below. +

    +

    + \"Image +

    +

    + The tank uses several volumes to model the stratification. Heat + conduction is modeled between the volumes through the fluid, + and between the volumes and the ambient. +

    +

    + The heat port heaPorVol may be used to connect a + temperature sensor that measures the fluid temperature of an + individual volume. It may also be used to add heat to + individual volumes, for example if the tank contains an + electrical resistance heater. +

    +

    + Similarly, the fluid port fluPorVol may be used to + connect a fluid pipe to an individual volume. This allows for + example to draw water from that volume whose temperature is + close to the temperature required by the consumer. Conversely, + water could be added to that tank volume whose temperature is + close to the inlet water temperature. If you don't use such a + pipe, simply leave the ports unconnected. +

    +

    + The tank has nSeg fluid volumes. The top segment + has the index 1. Thus, to add a heating element to + the bottom element, connect a heat input to + heaPorVol[nSeg]. +

    +

    + The heat ports outside the tank insulation can be used to + specify an ambient temperature. Leave these ports unconnected + to force adiabatic boundary conditions. Note, however, that all + heat conduction elements through the tank wall (but not the top + and bottom) are connected to the heat port + heaPorSid. Thus, not connecting + heaPorSid means an adiabatic boundary condition in + the sense that heaPorSid.Q_flow = 0. This, + however, still allows heat to flow through the tank walls, + modeled by conWal, from one fluid volume to + another one. +

    +
    + AixLib.Fluid.Storage.StratifiedEnhanced + +

    + The model is identical to AixLib.Fluid.Storage.Stratified, + except for the following: +

    +
      +
    • It adds a correction that reduces the numerical + dissipation. +
    • +
    • It does not contain the fluid ports fluPorVol + that connect from the outside to the individual volumes. +
    • +
    +

    + The correction uses a third order upwind scheme to compute the + outlet temperatures of the segments in the tank. This model is + implemented in + AixLib.Fluid.Storage.BaseClasses.ThirdOrderStratifier. +

    +
    + AixLib.Fluid.Storage.StratifiedEnhancedInternalHex + +

    + This model is identical to AixLib.Fluid.Storage.StratifiedEnhanced + except that it adds a heat exchanger to the tank. +

    +

    + The modifications consist of adding a heat exchanger and fluid + ports to connect to the heat exchanger. The modifications allow + to run a fluid through the tank causing heat transfer to the + stored fluid. A typical example is a storage tank in a solar + hot water system. +

    +

    + The heat exchanger model assumes flow through the inside of a + helical coil heat exchanger, and stagnant fluid on the outside. + Parameters are used to describe the heat transfer on the inside + of the heat exchanger at nominal conditions, and geometry of + the outside of the heat exchanger. This information is used to + compute an hA-value for each side of the coil. + Convection calculations are then performed to identify heat + transfer between the heat transfer fluid and the fluid in the + tank. +

    +

    + The location of the heat exchanger can be parameterized as + follows: The parameters hHex_a and + hHex_b are the heights of the heat exchanger ports + portHex_a and portHex_b, measured + from the bottom of the tank. For example, to place the port + portHex_b at the bottom of the tank, set + hHexB_b=0. The parameters hHex_a and + hHex_b are then used to provide a default value + for the parameters segHex_a and + segHex_b, which are the numbers of the tank + segments to which the heat exchanger ports + portHex_a and portHex_b are + connected. +

    +

    + \"Image +

    +

    + Optionally, this model computes a dynamic response of the heat + exchanger. This can be configured using the parameters + energyDynamicsHexSolid, + energyDynamicsHex and + massDynamicsHex. For this computation, the fluid + volume inside the heat exchanger and the heat capacity of the + heat exchanger wall CHex are approximated. Both + depend on the length lHex of the heat exchanger. + The model provides default values for these parameters, as well + as for the heat exchanger material which is assumed to be + steel. These default values can be overwritten by the user. The + default values for the heat exchanger geometry are computed + assuming that there is a cylindrical heat exchanger made of + steel whose diameter is half the diameter of the tank, e.g., + rHex=rTan/2. Hence, the length of + the heat exchanger is approximated as lHex = 2 + rHex π h = 2 rTan/2 π h, where + h is the distance between the heat exchanger inlet and + outlet. The wall thickness is assumed to be 10% of the + heat exchanger outer diameter. For typical applications, users + do not need to change these values. +

    +

    + Setting energyDynamicsHexSolid to a dynamic + balance and energyDynamicsHex to a steady-state + balance may be of interest to remove very fast dynamics of the + fluid, while still modeling slower dynamics that arises from + the metal of the heat exchanger. By default, + energyDynamicsHexSolid is set to the same value as + energyDynamicsHex as this seems to be the typical + configuration. +

    +

    + The heat exchanger is implemented in AixLib.Fluid.Storage.BaseClasses.IndirectTankHeatExchanger. +

    +
    -------- Errors -------- -line 9 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 6 column 1 - Warning: The summary attribute on the element is obsolete in HTML5 +line 17 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 129 column 1 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/PrescribedOutlet.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/GroundTemperatureResponse.mo ---- -------- HTML Code --------

    - Model that allows specifying the temperature and mass fraction of the fluid - that leaves the model from port_b. -

    -

    - This model forces the outlet temperature at port_b to be equal to the temperature - of the input signal TSet, subject to optional limits on the - heating or cooling capacity QMax_flow ≥ 0 and QMin_flow ≤ 0. - Similarly than for the temperature, - this model also forces the outlet water mass fraction at port_b to be - no lower than the - input signal X_wSet, subject to optional limits on the - maximum water vapor mass flow rate that is added, as - described by the parameter mWatMax_flow. - By default, the model has unlimited capacity, but control of temperature - and humidity can be subject to capacity limits, or be disabled. + This model calculates the ground temperature response to obtain the temperature + at the borehole wall in a geothermal system where heat is being injected into or + extracted from the ground.

    - The output signal Q_flow is the heat added (for heating) or subtracted (for cooling) - to the medium if the flow rate is from port_a to port_b. - If the flow is reversed, then Q_flow=0. + A load-aggregation scheme based on that developed by Claesson and Javed (2012) is + used to calculate the borehole wall temperature response with the temporal superposition + of ground thermal loads. In its base form, the + load-aggregation scheme uses fixed-length aggregation cells to agglomerate + thermal load history together, with more distant cells (denoted with a higher cell and vector index) + representing more distant thermal history. The more distant the thermal load, the + less impactful it is on the borehole wall temperature change at the current time step. + Each cell has an aggregation time associated to it denoted by nu, + which corresponds to the simulation time (since the beginning of heat injection or + extraction) at which the cell will begin shifting its thermal load to more distant + cells. To determine nu, cells have a temporal size rcel + (rcel in this model) + which follows the exponential growth +

    +

    + \"image\"

    - The outlet conditions at port_a are not affected by this model. + where nCel is the number of consecutive cells which can have the same size. + Decreasing rcel will generally decrease calculation times, at the cost of + precision in the temporal superposition. rcel is expressed in multiples + of the aggregation time resolution (via the parameter tLoaAgg). + Then, nu may be expressed as the sum of all rcel values + (multiplied by the aggregation time resolution) up to and including that cell in question.

    - If the parameter energyDynamics is not equal to - Modelica.Fluid.Types.Dynamics.SteadyState, - the component models the dynamic response using a first order differential equation. - The time constant of the component is equal to the parameter tau. - This time constant is adjusted based on the mass flow rate using + To determine the weighting factors, the borefield's temperature + step response at the borefield wall is determined as

    -

    - τeff = τ |ṁ| ⁄ ṁnom +

    + \"image\"

    - where - τeff is the effective time constant for the given mass flow rate - and - τ is the time constant at the nominal mass flow rate - nom. - This type of dynamics is equal to the dynamics that a completely mixed - control volume would have. + where g(·) is the borefield's thermal response factor known as the g-function, + H is the total length of all boreholes and ks is the thermal + conductivity of the soil. The weighting factors kappa (κ in the equation below) + for a given cell i are then expressed as follows. +

    +

    + \"image\"

    - Optionally, this model can have a flow resistance. - If no flow resistance is requested, set dp_nominal=0. + where ν refers to the vector nu in this model and + Tstep0)=0.

    - For a model that uses a control signal u ∈ [0, 1] and multiplies - this with the nominal heating or cooling power, use - - AixLib.Fluid.HeatExchangers.HeaterCooler_u - + At every aggregation time step, a time event is generated to perform the load aggregation steps. + First, the thermal load is shifted. When shifting between cells of different size, total + energy is conserved. This operation is illustred in the figure below by Cimmino (2014). +

    +

    + \"image\"

    -

    Limitations

    - This model only adds or removes heat or water vapor for the flow from - port_a to port_b. - The enthalpy of the reverse flow is not affected by this model. + After the cell-shifting operation is performed, the first aggregation cell has its + value set to the average thermal load since the last aggregation step. + Temporal superposition is then applied by means + of a scalar product between the aggregated thermal loads QAgg_flow and the + weighting factors κ.

    - If this model is used to cool air below the dew point temperature, the water mass fraction - will not change. + Due to Modelica's variable time steps, the load aggregation scheme is modified by separating + the thermal response between the current aggregation time step and everything preceding it. + This is done according to +

    +

    + \"image\" +
    + \"image\"

    - Note that for use_TSet = false, the enthalpy of the leaving fluid - will not be changed, even if moisture is added. The enthalpy added (or removed) - by the change in humidity is neglected. To properly account for change in enthalpy - due to humidification, use instead - - AixLib.Fluid.Humidifiers.SprayAirWasher_X. + where Tb is the borehole wall temperature, + Tg + is the undisturbed ground temperature, + Q is the ground thermal load per borehole length and h = g/(2 π ks) + is a temperature response factor based on the g-function. tk + is the last discrete aggregation time step, meaning that the current time t + satisfies tk≤t≤tk+1. + Δtagg(=tk+1-tk) is the + parameter tLoaAgg in the present model.

    -

    Validation

    - The model has been validated against the analytical solution in - the examples - - AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet - and - - AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic. + Thus, + ΔTb*(t) + is the borehole wall temperature change due to the thermal history prior to the current + aggregation step. At every aggregation time step, load aggregation and temporal superposition + are used to calculate its discrete value. Assuming no heat injection or extraction until + tk+1, this term is assumed to have a linear + time derivative, which is given by the difference between ΔTb*(tk+1) + (the temperature change from load history at the next discrete aggregation time step, which + is constant over the duration of the ongoing aggregation time step) and the total + temperature change at the last aggregation time step, ΔTb(t). +

    +

    + \"image\" +

    +

    + The second term ΔTb,q(t) concerns the ongoing aggregation time step. + To obtain the time derivative of this term, the thermal response factor h is assumed + to vary linearly over the course of an aggregation time step. Therefore, because + the ongoing aggregation time step always concerns the first aggregation cell, its derivative (denoted + by the parameter dTStepdt in this model) can be calculated as + kappa[1], the first value in the kappa vector, + divided by the aggregation time step Δt. + The derivative of the temperature change at the borehole wall is then expressed + as the multiplication of dTStepdt (which only needs to be + calculated once at the start of the simulation) and the heat flow Q at + the borehole wall. +

    +

    + \"image\" +

    +

    + \"image\" +

    +

    + With the two terms in the expression of ΔTb(t) expressed + as time derivatives, ΔTb(t) can itself also be + expressed as its time derivative and implemented as such directly in the Modelica + equations block with the der() operator. +

    +

    + \"image\" +
    + \"image\" +

    +

    + This load aggregation scheme is validated in + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.Validation.Analytic_20Years. +

    +

    References

    +

    + Cimmino, M. 2014. Développement et validation expérimentale de facteurs de réponse + thermique pour champs de puits géothermiques, + Ph.D. Thesis, École Polytechnique de Montréal. +

    +

    + Claesson, J. and Javed, S. 2012. A load-aggregation method to calculate extraction temperatures of borehole heat exchangers. ASHRAE Transactions 118(1): 530-539.

    • - March 3, 2022, by Michael Wetter:
      - Removed massDynamics.
      - This is for - issue 1542. -
    • -
    • - May 3, 2017, by Michael Wetter:
      - Updated protected model for - #763. -
    • -
    • - December 1, 2016, by Michael Wetter:
      - Updated model as use_dh is no longer a parameter in the pressure drop model.
      - This is for - #480. -
    • -
    • - November 11, 2014, by Michael Wetter:
      - Revised implementation. + August 30, 2018, by Michael Wetter:
      + Refactored model to compute the temperature difference relative to the initial temperature, + because the model is independent of the initial temperature.
    • - March 19, 2014, by Christoph Nytsch-Geusen:
      + April 5, 2018, by Alex Laferrière:
      First implementation.
    -------- Corrected Code --------

    - Model that allows specifying the temperature and mass fraction of the - fluid that leaves the model from port_b. + This model calculates the ground temperature response to obtain the + temperature at the borehole wall in a geothermal system where heat is + being injected into or extracted from the ground.

    - This model forces the outlet temperature at port_b to be - equal to the temperature of the input signal TSet, - subject to optional limits on the heating or cooling capacity - QMax_flow ≥ 0 and QMin_flow ≤ 0. Similarly - than for the temperature, this model also forces the outlet water - mass fraction at port_b to be no lower than the input - signal X_wSet, subject to optional limits on the maximum - water vapor mass flow rate that is added, as described by the - parameter mWatMax_flow. By default, the model has - unlimited capacity, but control of temperature and humidity can be - subject to capacity limits, or be disabled. + A load-aggregation scheme based on that developed by Claesson and + Javed (2012) is used to calculate the borehole wall temperature + response with the temporal superposition of ground thermal loads. In + its base form, the load-aggregation scheme uses fixed-length + aggregation cells to agglomerate thermal load history together, with + more distant cells (denoted with a higher cell and vector index) + representing more distant thermal history. The more distant the + thermal load, the less impactful it is on the borehole wall + temperature change at the current time step. Each cell has an + aggregation time associated to it denoted by + nu, which corresponds to the simulation time (since the + beginning of heat injection or extraction) at which the cell will + begin shifting its thermal load to more distant cells. To determine + nu, cells have a temporal size rcel + (rcel in this model) which follows the exponential + growth

    -

    - The output signal Q_flow is the heat added (for heating) - or subtracted (for cooling) to the medium if the flow rate is from - port_a to port_b. If the flow is reversed, - then Q_flow=0. +

    + \"image\"

    - The outlet conditions at port_a are not affected by this - model. + where nCel is the number of consecutive cells which + can have the same size. Decreasing rcel will + generally decrease calculation times, at the cost of precision in the + temporal superposition. rcel is expressed in multiples + of the aggregation time resolution (via the parameter + tLoaAgg). Then, nu may be expressed as the + sum of all rcel values (multiplied by the aggregation + time resolution) up to and including that cell in question.

    - If the parameter energyDynamics is not equal to - Modelica.Fluid.Types.Dynamics.SteadyState, the component - models the dynamic response using a first order differential - equation. The time constant of the component is equal to the - parameter tau. This time constant is adjusted based on - the mass flow rate using + To determine the weighting factors, the borefield's temperature step + response at the borefield wall is determined as

    -

    - τeff = τ |ṁ| ⁄ ṁnom +

    + \"image\"

    - where τeff is the effective time constant for the - given mass flow rate and τ is the time constant at - the nominal mass flow rate nom. This type of - dynamics is equal to the dynamics that a completely mixed control - volume would have. + where g(·) is the borefield's thermal response factor known as + the g-function, H is the total length of all + boreholes and ks is the thermal conductivity of the + soil. The weighting factors kappa (κ in the + equation below) for a given cell i are then expressed as + follows. +

    +

    + \"image\"

    - Optionally, this model can have a flow resistance. If no flow - resistance is requested, set dp_nominal=0. + where ν refers to the vector nu in this model and + Tstep0)=0.

    - For a model that uses a control signal u ∈ [0, 1] and - multiplies this with the nominal heating or cooling power, use - AixLib.Fluid.HeatExchangers.HeaterCooler_u + At every aggregation time step, a time event is generated to perform + the load aggregation steps. First, the thermal load is shifted. When + shifting between cells of different size, total energy is conserved. + This operation is illustred in the figure below by Cimmino (2014). +

    +

    + \"image\"

    -

    - Limitations -

    - This model only adds or removes heat or water vapor for the flow from - port_a to port_b. The enthalpy of the - reverse flow is not affected by this model. + After the cell-shifting operation is performed, the first aggregation + cell has its value set to the average thermal load since the last + aggregation step. Temporal superposition is then applied by means of + a scalar product between the aggregated thermal loads + QAgg_flow and the weighting factors κ.

    - If this model is used to cool air below the dew point temperature, - the water mass fraction will not change. + Due to Modelica's variable time steps, the load aggregation scheme is + modified by separating the thermal response between the current + aggregation time step and everything preceding it. This is done + according to +

    +

    + \"image\"
    + + \"image\"

    - Note that for use_TSet = false, the enthalpy of the - leaving fluid will not be changed, even if moisture is added. The - enthalpy added (or removed) by the change in humidity is neglected. - To properly account for change in enthalpy due to humidification, use - instead AixLib.Fluid.Humidifiers.SprayAirWasher_X. + where Tb is the borehole wall temperature, + Tg is the undisturbed ground temperature, Q + is the ground thermal load per borehole length and h = g/(2 π + ks) is a temperature response factor based on the + g-function. tk is the last discrete aggregation + time step, meaning that the current time t satisfies + tk≤t≤tk+1. + Δtagg(=tk+1-tk) is the + parameter tLoaAgg in the present model. +

    +

    + Thus, ΔTb*(t) is the borehole wall temperature + change due to the thermal history prior to the current aggregation + step. At every aggregation time step, load aggregation and temporal + superposition are used to calculate its discrete value. Assuming no + heat injection or extraction until tk+1, this term + is assumed to have a linear time derivative, which is given by the + difference between ΔTb*(tk+1) (the + temperature change from load history at the next discrete aggregation + time step, which is constant over the duration of the ongoing + aggregation time step) and the total temperature change at the last + aggregation time step, ΔTb(t). +

    +

    + \"image\" +

    +

    + The second term ΔTb,q(t) concerns the ongoing + aggregation time step. To obtain the time derivative of this term, + the thermal response factor h is assumed to vary linearly over + the course of an aggregation time step. Therefore, because the + ongoing aggregation time step always concerns the first aggregation + cell, its derivative (denoted by the parameter dTStepdt + in this model) can be calculated as kappa[1], the first + value in the kappa vector, divided by the aggregation + time step Δt. The derivative of the temperature change at the + borehole wall is then expressed as the multiplication of + dTStepdt (which only needs to be calculated once at the + start of the simulation) and the heat flow Q at the borehole + wall. +

    +

    + \"image\" +

    +

    + \"image\" +

    +

    + With the two terms in the expression of ΔTb(t) + expressed as time derivatives, ΔTb(t) can itself + also be expressed as its time derivative and implemented as such + directly in the Modelica equations block with the der() + operator. +

    +

    + \"image\"
    + + \"image\" +

    +

    + This load aggregation scheme is validated in + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.Validation.Analytic_20Years.

    - Validation + References

    - The model has been validated against the analytical solution in the - examples AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet - and - AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic. + Cimmino, M. 2014. Développement et validation expérimentale de + facteurs de réponse thermique pour champs de puits géothermiques, + Ph.D. Thesis, École Polytechnique de Montréal. +

    +

    + Claesson, J. and Javed, S. 2012. A load-aggregation method to + calculate extraction temperatures of borehole heat exchangers. + ASHRAE Transactions 118(1): 530-539.

      -
    • March 3, 2022, by Michael Wetter:
      - Removed massDynamics.
      - This is for issue - 1542. -
    • -
    • May 3, 2017, by Michael Wetter:
      - Updated protected model for #763. -
    • -
    • December 1, 2016, by Michael Wetter:
      - Updated model as use_dh is no longer a parameter in - the pressure drop model.
      - This is for #480. -
    • -
    • November 11, 2014, by Michael Wetter:
      - Revised implementation. +
    • August 30, 2018, by Michael Wetter:
      + Refactored model to compute the temperature difference relative to + the initial temperature, because the model is independent of the + initial temperature.
    • -
    • March 19, 2014, by Christoph Nytsch-Geusen:
      +
    • April 5, 2018, by Alex Laferrière:
      First implementation.
    -------- Errors -------- -line 34 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 22 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 37 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 46 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 58 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 73 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 101 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 117 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 120 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 129 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/Functions/quadraticLinear.mo ---- +---- AixLib/Fluid/HeatPumps/Carnot_y.mo ---- -------- HTML Code -------- - This function computes +

    + This is model of a heat pump whose coefficient of performance COP changes + with temperatures in the same way as the Carnot efficiency changes. + The input signal y is the control signal for the compressor. +

    +

    + The model allows to either specify the Carnot effectivness + ηCarnot,0, or + a COP0 + at the nominal conditions, together with + the evaporator temperature Teva,0 and + the condenser temperature Tcon,0, in which + case the model computes the Carnot effectivness as +

    - y = a1 + a2 x1 - + a3 x12 - + (a4 + a5 x1 - + a6 x12) x2 + ηCarnot,0 = + COP0 + ⁄ (Tcon,0 ⁄ (Tcon,0-Teva,0)). +

    +

    + The heat pump COP is computed as the product +

    +

    + COP = ηCarnot,0 COPCarnot ηPL, +

    +

    + where COPCarnot is the Carnot efficiency and + ηPL is a polynomial in the heating part load ratio yPL + that can be used to take into account a change in COP at part load + conditions. + This polynomial has the form +

    +

    + ηPL = a1 + a2 yPL + a3 yPL2 + ... +

    +

    + where the coefficients ai are declared by the parameter a. +

    +

    + On the Dynamics tag, the model can be parametrized to compute a transient + or steady-state response. + The transient response of the model is computed using a first + order differential equation for the evaporator and condenser fluid volumes. + The heat pump outlet temperatures are equal to the temperatures of these lumped volumes. +

    +

    Typical use and important parameters

    +

    + When using this component, make sure that the evaporator and the condenser have sufficient mass flow rate. + Based on the mass flow rates, the compressor power, temperature difference and the efficiencies, + the model computes how much heat will be added to the condenser and removed at the evaporator. + If the mass flow rates are too small, very high temperature differences can result. +

    +

    + The condenser heat flow rate QCon_flow_nominal is used to assign + the default value for the mass flow rates, which are used for the pressure drop + calculations. + It is also used to compute the part load efficiency. + Hence, make sure that QCon_flow_nominal is set to a reasonable value. +

    +

    + The maximum heating capacity is set by the parameter QCon_flow_max, + which is by default set to infinity. +

    +

    + The coefficient of performance depends on the + evaporator and condenser leaving temperature + since otherwise the second law of thermodynamics may be violated. +

    +

    Notes

    +

    + For a similar model that can be used as a chiller, see + AixLib.Fluid.Chillers.Carnot_y.

    • - February 29, 2009 by Michael Wetter:
      - First implementation. -
    • -
    - --------- Corrected Code -------- -This function computes -

    - y = a1 + a2 x1 + a3 - x12 + (a4 + a5 - x1 + a6 x12) - x2 -

    -
      -
    • February 29, 2009 by Michael Wetter:
      - First implementation. -
    • -
    - --------- Errors -------- -line 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/HeatExchangers/BaseClasses/HANaturalCylinder.mo ---- --------- HTML Code -------- - -

    - This model calculates the convection coefficient h for natural convection - from a cylinder submerged in fluid. h is calcualted using Eq 9.34 from - Incropera and DeWitt (1996). - Output of the block is the hA value. -

    -

    - The Nusselt number is computed as -

    -

    - NuD = (0.6 + (0.387 RaD(1/6))/(1+(0.559 Pr) - (9/16))(8/27))2); -

    -

    - where NuD is the Nusselt number, RaD is the - Rayleigh number and - Pr is the Prandtl number.
    - This correclation is accurate for RaD less than 1012. -

    -

    - h is then calculated from the Nusselt number. The equation is -

    -

    - h = NuD k/D -

    -

    - where k is the thermal conductivity of the fluid and D is the diameter - of the submerged cylinder. -

    -

    References

    -

    - Fundamentals of Heat and Mass Transfer (Fourth Edition), Frank Incropera and David - DeWitt, John Wiley and Sons, 1996 -

    - -
      + January 3, 2017, by Michael Wetter:
      + Removed parameters + effInpEva and effInpCon + and updated documentation. + This is for + + issue 497. +
    • - August 29, 2014 by Michael Wetter:
      - Refactored function calls for medium properties. + August 8, 2016, by Michael Wetter:
      + Changed default temperature to compute COP to be the leaving temperature as + use of the entering temperature can violate the 2nd law if the temperature + lift is small.
      + This is for + + Annex 60, issue 497. +
    • +
    • + January 26, 2016, by Michael Wetter:
      + Refactored model to use the same base class as + AixLib.Fluid.Chillers.Carnot_y.
      + Changed part load efficiency to depend on heating part load ratio rather than on the compressor + part load ratio. +
    • +
    • + January 20, 2015, by Damien Picard:
      + Add Carnot model to Annex 60 from the Buildings library.
      + Removed the flow direction dependency of + staA1, staB1, staA2 and staB2 as the + efficiency of the Carnot machine should only be computed in the design flow direction.
      +
    • +
    • + December 18, 2015, by Michael Wetter:
      + Corrected wrong computation of staB1 and staB2 + which mistakenly used the inStream operator + for the configuration without flow reversal. + This is for + + issue 476. +
    • +
    • + November 25, 2015 by Michael Wetter:
      + Changed sign convention for dTEva_nominal to be consistent with + other models. + The model will still work with the old values for dTEva_nominal, + but it will write a warning so that users can transition their models. +
      + Corrected assert statement for the efficiency curve. + This is for + + issue 468. +
    • +
    • + September 3, 2015 by Michael Wetter:
      + Expanded documentation. +
    • +
    • + May 6, 2015 by Michael Wetter:
      + Added prescribedHeatFlowRate=true for vol2. +
    • +
    • + October 9, 2013 by Michael Wetter:
      + Reimplemented the computation of the port states to avoid using + the conditionally removed variables sta_a1, + sta_a2, sta_b1 and sta_b2.
    • May 10, 2013 by Michael Wetter:
      - Revised implementation to use hA_nominal as a parameter, and compute the - associated surface area A. This revision was required to have a consistent - computation of the hA values inside and outside of the coil in the - heat exchanger model of the water tank. + Added electric power P as an output signal.
    • - February 26, 2013 by Peter Grant:
      + October 11, 2010 by Michael Wetter:
      + Fixed bug in energy balance. +
    • +
    • + March 3, 2009 by Michael Wetter:
      First implementation.
    -------- Corrected Code --------

    - This model calculates the convection coefficient h for natural - convection from a cylinder submerged in fluid. h is calcualted - using Eq 9.34 from Incropera and DeWitt (1996). Output of the block - is the hA value. + This is model of a heat pump whose coefficient of performance COP + changes with temperatures in the same way as the Carnot efficiency + changes. The input signal y is the control signal for the + compressor.

    - The Nusselt number is computed as + The model allows to either specify the Carnot effectivness + ηCarnot,0, or a COP0 at the + nominal conditions, together with the evaporator temperature + Teva,0 and the condenser temperature + Tcon,0, in which case the model computes the Carnot + effectivness as

    - NuD = (0.6 + (0.387 - RaD(1/6))/(1+(0.559 Pr) - (9/16))(8/27))2); + ηCarnot,0 = COP0 ⁄ (Tcon,0 ⁄ + (Tcon,0-Teva,0)).

    - where NuD is the Nusselt number, - RaD is the Rayleigh number and Pr is the - Prandtl number.
    - This correclation is accurate for RaD less than - 1012. + The heat pump COP is computed as the product +

    +

    + COP = ηCarnot,0 COPCarnot ηPL,

    - h is then calculated from the Nusselt number. The equation is + where COPCarnot is the Carnot efficiency and + ηPL is a polynomial in the heating part load ratio + yPL that can be used to take into account a change + in COP at part load conditions. This polynomial has the form

    - h = NuD k/D + ηPL = a1 + a2 yPL + + a3 yPL2 + ...

    - where k is the thermal conductivity of the fluid and D - is the diameter of the submerged cylinder. + where the coefficients ai are declared by the + parameter a. +

    +

    + On the Dynamics tag, the model can be parametrized to + compute a transient or steady-state response. The transient response + of the model is computed using a first order differential equation + for the evaporator and condenser fluid volumes. The heat pump outlet + temperatures are equal to the temperatures of these lumped volumes.

    - References + Typical use and important parameters

    - Fundamentals of Heat and Mass Transfer (Fourth Edition), Frank - Incropera and David DeWitt, John Wiley and Sons, 1996 + When using this component, make sure that the evaporator and the + condenser have sufficient mass flow rate. Based on the mass flow + rates, the compressor power, temperature difference and the + efficiencies, the model computes how much heat will be added to the + condenser and removed at the evaporator. If the mass flow rates are + too small, very high temperature differences can result.

    -
      -
    • August 29, 2014 by Michael Wetter:
      - Refactored function calls for medium properties. -
    • -
    • May 10, 2013 by Michael Wetter:
      - Revised implementation to use hA_nominal as a - parameter, and compute the associated surface area A. - This revision was required to have a consistent computation of the - hA values inside and outside of the coil in the heat - exchanger model of the water tank. -
    • -
    • February 26, 2013 by Peter Grant:
      - First implementation. -
    • -
    - --------- Errors -------- -line 11 column 14 - Warning:

    attribute "align" not allowed for HTML5 -line 24 column 14 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/BoundaryConditions/Validation/UsersGuide.mo ---- --------- HTML Code -------- -

    -The package AixLib.BoundaryConditions.Validation.BESTEST -contains the models that are used for the BESTEST validation ASHRAE 2020 for weather data acquisition and postprocessing. + The condenser heat flow rate QCon_flow_nominal is used + to assign the default value for the mass flow rates, which are used + for the pressure drop calculations. It is also used to compute the + part load efficiency. Hence, make sure that + QCon_flow_nominal is set to a reasonable value.

    -Each model represents a different climate with different days as shown in the tables below. -All examples have a script that runs the simulation according to the specifications and derive the required Json file as reported below. + The maximum heating capacity is set by the parameter + QCon_flow_max, which is by default set to infinity.

    -The weather radiation data has to be provided at different orientations and inclinations. + The coefficient of performance depends on the evaporator and + condenser leaving temperature since otherwise the second law of + thermodynamics may be violated.

    -

    Table 2: Azimuth and Slope for Surfaces

    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

    Azimuth

    Slope

    Horizontal

    0° from horizontal

    South

    90° from horizontal

    East

    90° from horizontal

    North

    90° from horizontal

    West

    90° from horizontal

    45° East of South

    90° from horizontal

    45° West of South

    90° from horizontal

    East

    30° from horizontal

    South

    30° from horizontal

    West

    30° from horizontal

    - -

    Additional parameters and correlations

    - -

    Outputs required

    -

    Annual Outputs

    -

     The following outputs are provided for an annual simulation:

    - -

    Hourly Outputs

    -

    The following outputs are provided for each hour of the days specified for each test case in Table 3:

    - -

    Table 3: Specific Days for Output

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -

    Case

    Days

    WD100

    May 4th, July 14th, September 6th

    WD200

    May 24th, August 26th

    WD300

    February 7th, August 13th

    WD400

    January 24th, July 1st

    WD500

    March 1st, September 14th

    WD600

    May 4th, July 14th, September 6th

    -

    Sub-hourly Outputs

    -

    The following outputs are provided at each timestep of the days specified for each test case in Table 3:

    - -

    The following outputs are provided integrated hourly for the days specified for each test case in Table 3:

    - -

    Validation results

    -

    (Not available yet)

    -

    Implementation

    -

    To generate the data shown in this user guide, run

    -
    -cd AixLib/Resources/Data/BoundaryConditions/Validation/BESTEST
    -python3 generateResults.py -p
    -
    -

    At the beginning of the Python script there are several options that the user can choose, by default the script will: +

    + Notes +

    +

    + For a similar model that can be used as a chiller, see AixLib.Fluid.Chillers.Carnot_y.

    -

    References

    -

    (Not available yet)

    +
  • January 3, 2017, by Michael Wetter:
    + Removed parameters effInpEva and + effInpCon and updated documentation. This is for + issue + 497. +
  • +
  • August 8, 2016, by Michael Wetter:
    + Changed default temperature to compute COP to be the leaving + temperature as use of the entering temperature can violate the 2nd + law if the temperature lift is small.
    + This is for Annex 60, + issue 497. +
  • +
  • January 26, 2016, by Michael Wetter:
    + Refactored model to use the same base class as AixLib.Fluid.Chillers.Carnot_y.
    - --------- Corrected Code -------- -

    - The package AixLib.BoundaryConditions.Validation.BESTEST - contains the models that are used for the BESTEST validation ASHRAE - 2020 for weather data acquisition and postprocessing. -

    -

    - Each model represents a different climate with different days as - shown in the tables below. All examples have a script that runs the - simulation according to the specifications and derive the required - Json file as reported below. -

    -

    - The weather radiation data has to be provided at different - orientations and inclinations. -

    -

    - Table 2: Azimuth and Slope for Surfaces -

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    -

    - Azimuth -

    -
    -

    - Slope -

    -
    -

    - Horizontal -

    -
    -

    - 0° from horizontal -

    -
    -

    - South -

    -
    -

    - 90° from horizontal -

    -
    -

    - East -

    -
    -

    - 90° from horizontal -

    -
    -

    - North -

    -
    -

    - 90° from horizontal -

    -
    -

    - West -

    -
    -

    - 90° from horizontal -

    -
    -

    - 45° East of South -

    -
    -

    - 90° from horizontal -

    -
    -

    - 45° West of South -

    -
    -

    - 90° from horizontal -

    -
    -

    - East -

    -
    -

    - 30° from horizontal -

    -
    -

    - South -

    -
    -

    - 30° from horizontal -

    -
    -

    - West -

    -
    -

    - 30° from horizontal -

    -

    +-------- Errors -------- +line 16 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 24 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 34 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/FMI/ExportContainers/ThermalZones.mo ---- +-------- HTML Code -------- + +

    + Model that is used as a container for a multiple thermal zones + that are to be exported as an FMU. +

    +

    Typical use and important parameters

    +

    + To use this model as a container for an FMU, extend + from this model, rather than instantiate it, + add your thermal zones. For each thermal zone, + add a vector of mass flow rate sensors. + By extending from this model, the top-level + signal connectors on the left stay at the top-level, and hence + will be visible at the FMI interface. +

    + + Note that + + +

    + The example + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones + shows how multiple simple thermal zones can be implemented and exported as + an FMU. + +

    + +

    + The conversion between the fluid ports and signal ports is done + in the thermal zone adapter theZonAda[nZon]. + This adapter has a vector of fluid ports called ports[nPorts] + which needs to be connected to the air volume of the thermal zones. + At this port, air exchanged between the thermal zones, the HVAC system + and any infiltration flow paths. +

    +

    + This model has input signals fluPor[nZon, nPorts] which carry + the mass flow rate for each flow that is connected to ports[1:nPorts] + for the respective zone, together with its + temperature, water vapor mass fraction per total mass of the air (not per kg dry + air), and trace substances. These quantities are always as if the flow + enters the respective room, even if the flow is zero or negative. + If a medium has no moisture, e.g., if Medium.nXi=0, or + if it has no trace substances, e.g., if Medium.nC=0, then + the output signal for these properties are removed. + Thus, a thermal zone model that uses these signals to compute the + heat added by the HVAC system need to implement an equation such as +

    +

    + Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), +

    +

    + where + Qsen is the sensible heat flow rate added to the thermal zone, + sup is the supply air mass flow rate from + the port fluPor (which is negative if it is an exhaust), + cp is the specific heat capacity at constant pressure, + Tsup is the supply air temperature and + Tair,zon is the zone air temperature. + Note that without the max(·, ·), the energy + balance would be wrong. + For example, + + the control volumes in + + AixLib.Fluid.MixingVolumes + implement such a max(·, ·) function. +

    +

    + For each zone, its air temperature, + water vapor mass fraction per total mass of the air (unless Medium.nXi=0) + and trace substances (unless Medium.nC=0) + can be obtained from the outupt connector + fluPor[1:nZon].backward. + These signals are the same as the inflowing fluid stream(s) + at the port theAdaZon[1:nZon].ports[1:nPorts]. + The fluid connector ports[nPorts] has a prescribed mass flow rate, but + it does not set any pressure. +

    +

    + This model has a user-defined parameter nPorts + which sets the number of fluid ports, which in turn is used + for the ports fluPor and ports. + All zones must have the same number of fluid ports nPorts. + All nPorts + ports[1:nPorts] need to be connected as demonstrated in the example + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones. +

    +

    + +

    + + + +-------- Corrected Code --------

    - Additional parameters and correlations + Model that is used as a container for a multiple thermal zones that + are to be exported as an FMU.

    -

    - Outputs required + Typical use and important parameters

    - Annual Outputs -

    -

    -  The following outputs are provided for an annual - simulation: -

    + To use this model as a container for an FMU, extend from this model, + rather than instantiate it, add your thermal zones. For each thermal + zone, add a vector of mass flow rate sensors. By extending from this + model, the top-level signal connectors on the left stay at the + top-level, and hence will be visible at the FMI interface. +

    Note that
    +

    - Hourly Outputs + The example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones + shows how multiple simple thermal zones can be implemented and + exported as an FMU.

    - The following outputs are provided for each hour of the days - specified for each test case in Table 3: + The conversion between the fluid ports and signal ports is done in + the thermal zone adapter theZonAda[nZon]. This adapter + has a vector of fluid ports called ports[nPorts] which + needs to be connected to the air volume of the thermal zones. At this + port, air exchanged between the thermal zones, the HVAC system and + any infiltration flow paths.

    -

    - Table 3: Specific Days for Output + This model has input signals fluPor[nZon, nPorts] which + carry the mass flow rate for each flow that is connected to + ports[1:nPorts] for the respective zone, together with + its temperature, water vapor mass fraction per total mass of the air + (not per kg dry air), and trace substances. These quantities are + always as if the flow enters the respective room, even if the flow is + zero or negative. If a medium has no moisture, e.g., if + Medium.nXi=0, or if it has no trace substances, e.g., if + Medium.nC=0, then the output signal for these properties + are removed. Thus, a thermal zone model that uses these signals to + compute the heat added by the HVAC system need to implement an + equation such as

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    -

    - Case -

    -
    -

    - Days -

    -
    -

    - WD100 -

    -
    -

    - May 4th, July 14th, September 6th -

    -
    -

    - WD200 -

    -
    -

    - May 24th, August 26th -

    -
    -

    - WD300 -

    -
    -

    - February 7th, August 13th -

    -
    -

    - WD400 -

    -
    -

    - January 24th, July 1st -

    -
    -

    - WD500 -

    -
    -

    - March 1st, September 14th -

    -
    -

    - WD600 -

    -
    -

    - May 4th, July 14th, September 6th -

    -

    -

    - Sub-hourly Outputs +

    + Qsen = max(0, ṁsup)   cp   + (Tsup - Tair,zon),

    - The following outputs are provided at each timestep of the days - specified for each test case in Table 3: + where Qsen is the sensible heat flow rate added to + the thermal zone, sup is the supply air mass flow + rate from the port fluPor (which is negative if it is an + exhaust), cp is the specific heat capacity at + constant pressure, Tsup is the supply air + temperature and Tair,zon is the zone air + temperature. Note that without the max(·, ·), the energy + balance would be wrong. For example, + the control volumes in AixLib.Fluid.MixingVolumes + implement such a max(·, ·) function.

    -

    - The following outputs are provided integrated hourly for the days - specified for each test case in Table 3: + For each zone, its air temperature, water vapor mass fraction per + total mass of the air (unless Medium.nXi=0) and trace + substances (unless Medium.nC=0) can be obtained from the + outupt connector fluPor[1:nZon].backward. These signals + are the same as the inflowing fluid stream(s) at the port + theAdaZon[1:nZon].ports[1:nPorts]. The fluid connector + ports[nPorts] has a prescribed mass flow rate, but it + does not set any pressure.

    - -

    - Validation results -

    - (Not available yet) -

    -

    - Implementation -

    -

    - To generate the data shown in this user guide, run + This model has a user-defined parameter nPorts which + sets the number of fluid ports, which in turn is used for the ports + fluPor and ports. All zones must have the + same number of fluid ports nPorts. All + nPorts ports[1:nPorts] need to be connected + as demonstrated in the example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones.

    -
    -cd AixLib/Resources/Data/BoundaryConditions/Validation/BESTEST
    -python3 generateResults.py -p
    -

    - At the beginning of the Python script there are several options that - the user can choose, by default the script will: +

    -

    - References -

    -

    - (Not available yet) -

    - -------- Errors -------- -line 14 column 1 - Warning: The summary attribute on the element is obsolete in HTML5 -line 98 column 1 - Warning: The summary attribute on the
    element is obsolete in HTML5 +line 78 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/ActiveBeams/Data/BaseClasses/TemperatureDifference.mo ---- +---- AixLib/Fluid/HeatExchangers/DryCoilEffectivenessNTU.mo ---- -------- HTML Code --------

    - Data record for performance data that describe the normalized - temperature difference - versus the change in the rate of heating or cooling. - The normalized temperature difference is defined as + Model of a coil without humidity condensation. + This model transfers heat in the amount of

    - rΔTi= - ΔTi ⁄ ΔTnominal - = - (Twi-Tz) - ⁄ - (Tw,nominal-Tz), + Q̇ = Q̇max ε
    + ε = f(NTU, Z, flowRegime),

    where - Twi is the water inlet temperature, - Tz is the zone air temperature and - Tw,nominal is the nominal water inlet temperature. + max is the maximum heat that can be transferred, + ε is the heat transfer effectiveness, + NTU is the Number of Transfer Units, + Z is the ratio of minimum to maximum capacity flow rate and + flowRegime is the heat exchanger flow regime. + such as + parallel flow, cross flow or counter flow.

    - The normalized temperature difference rΔT must be strictly increasing, i.e., - rΔTi < rΔTi+1. - Both vectors, rΔT and f - must have the same size. + The flow regimes depend on the heat exchanger configuration. All configurations + defined in + + AixLib.Fluid.Types.HeatExchangerConfiguration + are supported. +

    +

    + The convective heat transfer coefficients scale proportional to + (ṁ/ṁ0)n, where + is the mass flow rate, + 0 is the nominal mass flow rate, and + n=0.8 on the air-side and n=0.85 on the water side. +

    +

    + For a heat and moisture exchanger, use + + AixLib.Fluid.MassExchangers.ConstantEffectiveness.

    -------- Corrected Code --------

    - Data record for performance data that describe the normalized - temperature difference versus the change in the rate of heating or - cooling. The normalized temperature difference is defined as + Model of a coil without humidity condensation. This model transfers + heat in the amount of

    - rΔTi= ΔTi ⁄ ΔTnominal = - (Twi-Tz) ⁄ - (Tw,nominal-Tz), + Q̇ = Q̇max ε
    + ε = f(NTU, Z, flowRegime),

    - where Twi is the water inlet - temperature, Tz is the zone air temperature and - Tw,nominal is the nominal water inlet temperature. + where max is the maximum heat that can be + transferred, ε is the heat transfer effectiveness, NTU + is the Number of Transfer Units, Z is the ratio of minimum to + maximum capacity flow rate and flowRegime is the heat + exchanger flow regime. such as parallel flow, cross flow or counter + flow.

    - The normalized temperature difference rΔT must be - strictly increasing, i.e., rΔTi < - rΔTi+1. Both vectors, rΔT - and f must have the same size. + The flow regimes depend on the heat exchanger configuration. All + configurations defined in AixLib.Fluid.Types.HeatExchangerConfiguration + are supported.

    - - --------- Errors -------- -line 8 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Geothermal/Borefields/Types.mo ---- --------- HTML Code -------- - -

    - Enumeration that defines the pipe configuration in the borehole. -

    -

    - The following pipe configurations are available in this enumeration: -

    -
    - - - - - -
    EnumerationDescription
    SingleUTubeSingle U-tube configuration
    DoubleUTubeParallelDouble U-tube configuration with pipes connected in parallel
    DoubleUTubeSeriesDouble U-tube configuration with pipes connected in series
    - - - -

    - This package contains type definitions. -

    - --------- Corrected Code --------

    - Enumeration that defines the pipe configuration in the borehole. + The convective heat transfer coefficients scale proportional to + (ṁ/ṁ0)n, where is the mass + flow rate, 0 is the nominal mass flow rate, and + n=0.8 on the air-side and n=0.85 on the water side.

    - The following pipe configurations are available in this enumeration: + For a heat and moisture exchanger, use AixLib.Fluid.MassExchangers.ConstantEffectiveness.

    - - - - - - - - - - - - - - - - - -
    - Enumeration - - Description -
    - SingleUTube - - Single U-tube configuration -
    - DoubleUTubeParallel - - Double U-tube configuration with pipes connected in parallel -
    - DoubleUTubeSeries - - Double U-tube configuration with pipes connected in series -
    -

    - This package contains type definitions. -

    -------- Errors -------- -line 8 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 6 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Chillers/BaseClasses/Carnot.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/UsersGuide.mo ---- -------- HTML Code -------- -

    - This is the base class for the Carnot chiller and the Carnot heat pump - whose coefficient of performance COP changes - with temperatures in the same way as the Carnot efficiency changes. -

    -

    - The model allows to either specify the Carnot effectivness - ηCarnot,0, or - a COP0 - at the nominal conditions, together with - the evaporator temperature Teva,0 and - the condenser temperature Tcon,0, in which - case the model computes the Carnot effectivness as -

    -

    - ηCarnot,0 = - COP0 - ⁄ (Tuse,0 ⁄ (Tcon,0-Teva,0)), -

    -

    - where - Tuse is the temperature of the the useful heat, - e.g., the evaporator temperature for a chiller or the condenser temperature - for a heat pump. -

    -

    - The COP is computed as the product -

    -

    - COP = ηCarnot,0 COPCarnot ηPL, -

    -

    - where COPCarnot is the Carnot efficiency and - ηPL is the part load efficiency, expressed using - a polynomial. - This polynomial has the form -

    -

    - ηPL = a1 + a2 y + a3 y2 + ... -

    -

    - where y ∈ [0, 1] is - either the part load for cooling in case of a chiller, or the part load of heating in - case of a heat pump, and the coefficients ai - are declared by the parameter a. -

    -

    Implementation

    -

    - To make this base class applicable to chiller or heat pumps, it uses - the boolean constant COP_is_for_cooling. - Depending on its value, the equations for the coefficient of performance - and the part load ratio are set up. -

    - - - --------- Corrected Code --------

    - This is the base class for the Carnot chiller and the Carnot heat - pump whose coefficient of performance COP changes with temperatures - in the same way as the Carnot efficiency changes. +This package contains borefield models. These models can simulate any arbitrary +configuration of vertical boreholes with equal lengths with both short and +long-term accuracy with an aggregation method to speed up the calculations of the ground heat transfer. Examples +of how to use the borefield models and validation cases can be found in + +AixLib.Fluid.Geothermal.Borefields.Examples +and + +AixLib.Fluid.Geothermal.Borefields.Validation, +respectively.

    - The model allows to either specify the Carnot effectivness - ηCarnot,0, or a COP0 at the - nominal conditions, together with the evaporator temperature - Teva,0 and the condenser temperature - Tcon,0, in which case the model computes the Carnot - effectivness as +The major features and configurations currently supported are: +

    + +

    +The model is limited to the simulation of borefields with boreholes connected in +parallel, as shown on the figure below for a single U-tube configuration. All +boreholes have the same length hBor, the same radius +rBor, and are buried at the same depth dBor below the +ground surface (also known as the inactive borehole length).

    -

    - ηCarnot,0 = COP0 ⁄ (Tuse,0 ⁄ - (Tcon,0-Teva,0)), +

    +\"image\"

    + +

    How to use the borefield models

    +
    Borefield data record

    - where Tuse is the temperature of the the useful - heat, e.g., the evaporator temperature for a chiller or the condenser - temperature for a heat pump. +Most of the parameter values of the model are contained in the record called borFieDat. +This record is composed of three subrecords: +filDat (containing the thermal characteristics of the borehole filling material), +soiDat (containing the thermal characteristics of the surrounding soil), +and conDat (containing all others parameters, namely parameters +defining the configuration of the borefield). +The structure and default values of the record are in the package: +AixLib.Fluid.Geothermal.Borefields.Data. +The borFieDat record +can be found in the +AixLib.Fluid.Geothermal.Borefields.Data.Borefield subpackage therein. +Examples of the subrecords conDat, filDat and soiDat +can be found in + +AixLib.Fluid.Geothermal.Borefields.Data.Configuration, + +AixLib.Fluid.Geothermal.Borefields.Data.Filling and + +AixLib.Fluid.Geothermal.Borefields.Data.Soil, respectively.

    - The COP is computed as the product +It is important to make sure that the borCon parameter within +the conDat subrecord is compatible with the chosen borefield model. +For example, if a double U-tube +borefield model is chosen, the borCon parameter could be set +to both a parallel double U-tube configuration and a double U-tube configuration in series, +but could not be set to a single U-tube configuration. An incompatible borehole +configuration will stop the simulation.

    -

    - COP = ηCarnot,0 COPCarnot ηPL, +

    Ground heat transfer parameters
    +

    +Other than the parameters contained in the borFieDat record, +the borefield models have other parameters which can be modified by the user. +The tLoaAgg parameter is the time resolution of the load aggregation +for the calculation of the ground heat transfer. It represents the +frequency at which the load aggregation procedure is performed in the simulation. +Therefore, smaller values of tLoaAgg will improve +the accuracy of the model, at the cost of increased simulation times +due to a higher number of events occuring in the simulation. While a default value +is provided for this parameter, it is advisable to ensure that it is lower +than a fraction (e.g. half) of the time required for the fluid to completely circulate +through the borefield, +as increasing the value of tLoaAgg beyond this +will result in non-physical borehole wall temperatures.

    - where COPCarnot is the Carnot efficiency and - ηPL is the part load efficiency, expressed using a - polynomial. This polynomial has the form +The nCel parameter also affects the accuracy and simulation time +of the ground heat transfer calculations. As this parameter sets the number +of consecutive equal-size aggregation cells before increasing the size of cells, +increasing its value will result in less load aggregation, which will increase +accuracy at the cost of computation time. On the other hand, +decreasing the value of nCel (down to a minimum of 1) +will decrease accuracy but improve +computation time. The default value is chosen as a compromise between the two.

    -

    - ηPL = a1 + a2 y + a3 - y2 + ... +

    +Further information on the tLoaAgg and nCel parameters can +be found in the documentation of + +AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse.

    +
    Other parameters

    - where y ∈ [0, 1] is either the part load for cooling in case - of a chiller, or the part load of heating in case of a heat pump, and - the coefficients ai are declared by the parameter - a. +Other parameters which can be modified include the dynamics, initial conditions, +and further information regarding the fluid flow, for example whether the flow is reversible. +It is worth noting that regardless of the energyDynamics chosen, +the dynFil parameter can be set to false +to remove the effect of the thermal capacitance +of the filling material in the borehole(s). +The nSeg parameter specifies the number of segments for the vertical discretization of the borehole(s). +Further information on this discretization can be found in the "Model description" section below.

    -

    - Implementation -

    +
    Running simulations

    - To make this base class applicable to chiller or heat pumps, it uses - the boolean constant COP_is_for_cooling. Depending on - its value, the equations for the coefficient of performance and the - part load ratio are set up. +When running simulations using the borefield models, +the tmp/temperatureResponseMatrix directory within the current directory +will be checked to see if any of the +borefield configurations used in the simulation have already +had their ground temperature response calculated previously +If the data doesn't exist in the tmp/temperatureResponseMatrix folder, +it will be calculated during the initialization of the model +and will be saved there for future use.

    +

    Model description

    +

    +The borefield models rely on the following key assumptions:

    - --------- Errors -------- -line 16 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 30 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 39 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FixedResistances/PressureDrop.mo ---- --------- HTML Code -------- - -

    - Model of a flow resistance with a fixed flow coefficient. - The mass flow rate is -

    -

    - ṁ = k - √ΔP, -

    -

    - where - k is a constant and - ΔP is the pressure drop. - The constant k is equal to - k=m_flow_nominal/sqrt(dp_nominal), - where m_flow_nominal and dp_nominal - are parameters. -

    -

    Assumptions

    -

    - In the region - abs(m_flow) < m_flow_turbulent, - the square root is replaced by a differentiable function - with finite slope. - The value of m_flow_turbulent is - computed as - m_flow_turbulent = deltaM * abs(m_flow_nominal), - where deltaM=0.3 and - m_flow_nominal are parameters that can be set by the user. -

    -

    - The figure below shows the pressure drop for the parameters - m_flow_nominal=5 kg/s, - dp_nominal=10 Pa and - deltaM=0.3. -

    -

    - \"image\" -

    -

    Important parameters

    -

    - The parameter from_dp is used to determine - whether the mass flow rate is computed as a function of the - pressure drop (if from_dp=true), or vice versa. - This setting can affect the size of the nonlinear system of equations. -

    -

    - If the parameter linearized is set to true, - then the pressure drop is computed as a linear function of the - mass flow rate. -

    -

    - Setting allowFlowReversal=false can lead to simpler - equations. However, this should only be set to false - if one can guarantee that the flow never reverses its direction. - This can be difficult to guarantee, as pressure imbalance after - the initialization, or due to medium expansion and contraction, - can lead to reverse flow. -

    -

    - If the parameter - show_T is set to true, - then the model will compute the - temperature at its ports. Note that this can lead to state events - when the mass flow rate approaches zero, - which can increase computing time. -

    -

    Notes

    -

    - For more detailed models that compute the actual flow friction, - models from the package - - Modelica.Fluid - can be used and combined with models from the - AixLib library. -

    -

    - For a model that uses the hydraulic parameter and flow velocity at nominal conditions - as a parameter, use - - AixLib.Fluid.FixedResistances.HydraulicDiameter. -

    -

    Implementation

    -

    - The pressure drop is computed by calling a function in the package - - AixLib.Fluid.BaseClasses.FlowModels, - This package contains regularized implementations of the equation -

    -

    - m = sign(Δp) k √ Δp   -

    -

    - and its inverse function. -

    -

    - To decouple the energy equation from the mass equations, - the pressure drop is a function of the mass flow rate, - and not the volume flow rate. - This leads to simpler equations. -

    - - - --------- Corrected Code --------

    - Model of a flow resistance with a fixed flow coefficient. The mass - flow rate is +The borefield models are constructed in two main parts: the borehole(s) and the ground heat transfer. +The former is modeled as a vertical discretization of borehole segments, where a uniform temperature increase or decrease +(due to heat injection or extraction) is superimposed to the far-field ground temperature to obtain the borehole wall +temperature. The thermal effects of the circulating fluid (including the convection resistance), +of the pipes and of the filling material are all taken into consideration, which allows modeling +short-term thermal effects in the borehole. The borehole segments do not take into account axial effects, +thus only radial (horizontal) effects are considered within the borehole(s). The thermal +behavior between the pipes and borehole wall are modeled as a resistance-capacitance network, with +the grout capacitance being split in the number of pipes present in a borehole section. +The capacitance is only present if the dynFil parameter is set to true. +The figure below shows an example for a borehole section within a single U-tube configuration.

    -

    - ṁ = k √ΔP, +

    +\"image\"

    - where k is a constant and ΔP is the pressure drop. The - constant k is equal to - k=m_flow_nominal/sqrt(dp_nominal), where - m_flow_nominal and dp_nominal are - parameters. +The second main part of the borefield models is the ground heat transfer, which shares a thermal boundary +condition at the uniform borehole wall with all of the borehole segments. The heat transfer in the ground +is modeled analytically as a convolution integral between the heat flux at the borehole wall +and the borefield's thermal response factor. +

    +

    +\"image\"

    -

    - Assumptions -

    - In the region abs(m_flow) < m_flow_turbulent, the - square root is replaced by a differentiable function with finite - slope. The value of m_flow_turbulent is computed as - m_flow_turbulent = deltaM * abs(m_flow_nominal), where - deltaM=0.3 and m_flow_nominal are - parameters that can be set by the user. +The model uses a load aggregation technique to reduce the time required to calculate +the borehole wall temperature changes resulting from heat injection or extraction.

    - The figure below shows the pressure drop for the parameters - m_flow_nominal=5 kg/s, dp_nominal=10 Pa and - deltaM=0.3. -

    -

    - \"image\" +The ground heat transfer takes into account both the borehole axial effects and +the borehole radial effects which are a result of its cylindrical geometry. The borefield's +thermal response to a constant load, also known as its g-function, is used +to calculate the thermal response in the simulation. This g-function +is stored in the tmp/temperatureResponseMatrix subdirectory, +as discussed previously in the +"How to use the borefield models" section. Further information on the +ground heat transfer model and the thermal temperature response calculations can +be found in + +AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse +and + +AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.gFunction.

    -

    - Important parameters -

    +

    References

    - The parameter from_dp is used to determine whether the - mass flow rate is computed as a function of the pressure drop (if - from_dp=true), or vice versa. This setting can affect - the size of the nonlinear system of equations. +D. Picard, L. Helsen. +Advanced Hybrid Model for Borefield Heat +Exchanger Performance Evaluation; an Implementation in Modelica +Proc. of the 10th Intertional ModelicaConference, p. 857-866. Lund, Sweden. March 2014. +https://lirias.kuleuven.be/retrieve/270880.

    + +-------- Corrected Code --------

    - If the parameter linearized is set to true, - then the pressure drop is computed as a linear function of the mass - flow rate. + This package contains borefield models. These models can simulate any + arbitrary configuration of vertical boreholes with equal lengths with + both short and long-term accuracy with an aggregation method to speed + up the calculations of the ground heat transfer. Examples of how to + use the borefield models and validation cases can be found in + AixLib.Fluid.Geothermal.Borefields.Examples + and AixLib.Fluid.Geothermal.Borefields.Validation, + respectively.

    - Setting allowFlowReversal=false can lead to simpler - equations. However, this should only be set to false if - one can guarantee that the flow never reverses its direction. This - can be difficult to guarantee, as pressure imbalance after the - initialization, or due to medium expansion and contraction, can lead - to reverse flow. + The major features and configurations currently supported are:

    +

    - If the parameter show_T is set to true, - then the model will compute the temperature at its ports. Note that - this can lead to state events when the mass flow rate approaches - zero, which can increase computing time. + The model is limited to the simulation of borefields with boreholes + connected in parallel, as shown on the figure below for a single + U-tube configuration. All boreholes have the same length + hBor, the same radius rBor, and are buried + at the same depth dBor below the ground surface (also + known as the inactive borehole length). +

    +

    + \"image\"

    - Notes + How to use the borefield models

    +
    + Borefield data record +

    - For more detailed models that compute the actual flow friction, - models from the package Modelica.Fluid can be used and - combined with models from the AixLib library. + Most of the parameter values of the model are contained in the record + called borFieDat. This record is composed of three + subrecords: filDat (containing the thermal + characteristics of the borehole filling material), + soiDat (containing the thermal characteristics of the + surrounding soil), and conDat (containing all others + parameters, namely parameters defining the configuration of the + borefield). The structure and default values of the record are in the + package: AixLib.Fluid.Geothermal.Borefields.Data. + The borFieDat record can be found in the AixLib.Fluid.Geothermal.Borefields.Data.Borefield + subpackage therein. Examples of the subrecords conDat, + filDat and soiDat can be found in AixLib.Fluid.Geothermal.Borefields.Data.Configuration, + AixLib.Fluid.Geothermal.Borefields.Data.Filling + and AixLib.Fluid.Geothermal.Borefields.Data.Soil, + respectively.

    - For a model that uses the hydraulic parameter and flow velocity at - nominal conditions as a parameter, use AixLib.Fluid.FixedResistances.HydraulicDiameter. + It is important to make sure that the borCon parameter + within the conDat subrecord is compatible with the + chosen borefield model. For example, if a double U-tube borefield + model is chosen, the borCon parameter could be set to + both a parallel double U-tube configuration and a double U-tube + configuration in series, but could not be set to a single U-tube + configuration. An incompatible borehole configuration will stop the + simulation.

    -

    - Implementation -

    +
    + Ground heat transfer parameters +

    - The pressure drop is computed by calling a function in the package - AixLib.Fluid.BaseClasses.FlowModels, - This package contains regularized implementations of the equation + Other than the parameters contained in the borFieDat + record, the borefield models have other parameters which can be + modified by the user. The tLoaAgg parameter is the time + resolution of the load aggregation for the calculation of the ground + heat transfer. It represents the frequency at which the load + aggregation procedure is performed in the simulation. Therefore, + smaller values of tLoaAgg will improve the accuracy of + the model, at the cost of increased simulation times due to a higher + number of events occuring in the simulation. While a default value is + provided for this parameter, it is advisable to ensure that it is + lower than a fraction (e.g. half) of the time required for the fluid + to completely circulate through the borefield, as increasing the + value of tLoaAgg beyond this will result in non-physical + borehole wall temperatures.

    -

    - m = sign(Δp) k √ Δp -   +

    + The nCel parameter also affects the accuracy and + simulation time of the ground heat transfer calculations. As this + parameter sets the number of consecutive equal-size aggregation cells + before increasing the size of cells, increasing its value will result + in less load aggregation, which will increase accuracy at the cost of + computation time. On the other hand, decreasing the value of + nCel (down to a minimum of 1) will decrease accuracy but + improve computation time. The default value is chosen as a compromise + between the two.

    - and its inverse function. + Further information on the tLoaAgg and nCel + parameters can be found in the documentation of + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse. +

    +
    + Other parameters +
    +

    + Other parameters which can be modified include the dynamics, initial + conditions, and further information regarding the fluid flow, for + example whether the flow is reversible. It is worth noting that + regardless of the energyDynamics chosen, the + dynFil parameter can be set to false to + remove the effect of the thermal capacitance of the filling material + in the borehole(s). The nSeg parameter specifies the + number of segments for the vertical discretization of the + borehole(s). Further information on this discretization can be found + in the \"Model description\" section below.

    +
    + Running simulations +

    - To decouple the energy equation from the mass equations, the pressure - drop is a function of the mass flow rate, and not the volume flow - rate. This leads to simpler equations. + When running simulations using the borefield models, the + tmp/temperatureResponseMatrix directory within the + current directory will be checked to see if any of the borefield + configurations used in the simulation have already had their ground + temperature response calculated previously If the data doesn't exist + in the tmp/temperatureResponseMatrix folder, it will be + calculated during the initialization of the model and will be saved + there for future use. +

    +

    + Model description +

    +

    + The borefield models rely on the following key assumptions:

    +

    + The borefield models are constructed in two main parts: the + borehole(s) and the ground heat transfer. The former is modeled as a + vertical discretization of borehole segments, where a uniform + temperature increase or decrease (due to heat injection or + extraction) is superimposed to the far-field ground temperature to + obtain the borehole wall temperature. The thermal effects of the + circulating fluid (including the convection resistance), of the pipes + and of the filling material are all taken into consideration, which + allows modeling short-term thermal effects in the borehole. The + borehole segments do not take into account axial effects, thus only + radial (horizontal) effects are considered within the borehole(s). + The thermal behavior between the pipes and borehole wall are modeled + as a resistance-capacitance network, with the grout capacitance being + split in the number of pipes present in a borehole section. The + capacitance is only present if the dynFil parameter is + set to true. The figure below shows an example for a + borehole section within a single U-tube configuration. +

    +

    + \"image\" +

    +

    + The second main part of the borefield models is the ground heat + transfer, which shares a thermal boundary condition at the uniform + borehole wall with all of the borehole segments. The heat transfer in + the ground is modeled analytically as a convolution integral between + the heat flux at the borehole wall and the borefield's thermal + response factor. +

    +

    + \"image\" +

    +

    + The model uses a load aggregation technique to reduce the time + required to calculate the borehole wall temperature changes resulting + from heat injection or extraction. +

    +

    + The ground heat transfer takes into account both the borehole axial + effects and the borehole radial effects which are a result of its + cylindrical geometry. The borefield's thermal response to a constant + load, also known as its g-function, is used to calculate the + thermal response in the simulation. This g-function is stored in the + tmp/temperatureResponseMatrix subdirectory, as discussed + previously in the \"How to use the borefield models\" section. Further + information on the ground heat transfer model and the thermal + temperature response calculations can be found in + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse + and + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.gFunction. +

    +

    + References +

    +

    + D. Picard, L. Helsen. Advanced Hybrid Model for Borefield Heat + Exchanger Performance Evaluation; an Implementation in Modelica + Proc. of the 10th Intertional ModelicaConference, p. 857-866. Lund, + Sweden. March 2014. https://lirias.kuleuven.be/retrieve/270880. +

    -------- Errors -------- -line 6 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 37 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 90 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 56 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 179 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 188 column 1 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_dp.mo ---- +---- AixLib/Fluid/HeatExchangers/ConstantEffectiveness.mo ---- -------- HTML Code --------

    - Function that computes the pressure drop of flow elements as -

    -

    - m = sign(Δp) k √ Δp   + Model for a heat exchanger with constant effectiveness.

    - with regularization near the origin. - Therefore, the flow coefficient is + This model transfers heat in the amount of

    - k = m ⁄ √ Δp   + Q = Qmax ε,

    - The input m_flow_turbulent determines the location of the regularization. + where ε is a constant effectiveness and + Qmax is the maximum heat that can be transferred. +

    +

    + For a heat and moisture exchanger, use + + AixLib.Fluid.MassExchangers.ConstantEffectiveness + instead of this model.

    -------- Corrected Code --------

    - Function that computes the pressure drop of flow elements as -

    -

    - m = sign(Δp) k √ Δp -   + Model for a heat exchanger with constant effectiveness.

    - with regularization near the origin. Therefore, the flow coefficient - is + This model transfers heat in the amount of

    - k = m ⁄ √ Δp -   + Q = Qmax ε,

    - The input m_flow_turbulent determines the location of - the regularization. + where ε is a constant effectiveness and Qmax + is the maximum heat that can be transferred. +

    +

    + For a heat and moisture exchanger, use AixLib.Fluid.MassExchangers.ConstantEffectiveness + instead of this model.

    -------- Errors -------- -line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 12 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 8 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Humidifiers/Humidifier_u.mo ---- +---- AixLib/Utilities/IO/SignalExchange/SignalTypes/SignalsForKPIs.mo ---- -------- HTML Code --------

    - Model for an air humidifier or dehumidifier. -

    -

    - This model adds (or removes) moisture from the air stream. - The amount of exchanged moisture is equal to -

    -

    - ṁwat = u ṁwat,nom, -

    -

    - where u is the control input signal and - wat,nom is equal to the parameter mWat_flow_nominal. - The parameter mWat_flow_nominal can be positive or negative. - If wat is positive, then moisture is added - to the air stream, otherwise it is removed. + This enumeration defines the signal types that are used by BOPTEST + to compute the key performance indices (KPI).

    - If the heat port heatPort is unconnected, then the enthalpy of the - air that flows through the device remains unchanged, e.g., the humidification - is adiabatic. To change the enthalpy of the air, add heat flow to the connector - heatPort. + The following signal types are supported.

    +
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    ValueDescription
    NoneNot used for KPI
    AirZoneTemperatureAir zone temperature
    RadiativeZoneTemperatureRadiative zone temperature
    OperativeZoneTemperatureOperative zone temperature
    RelativeHumidityRelative humidity
    CO2ConcentrationCO2 concentration
    ElectricPowerElectric power from grid
    DistrictHeatingPowerThermal power from district heating
    GasPowerThermal power from natural gas
    BiomassPowerThermal power from biomass
    SolarThermalPowerThermal power from solar thermal
    FreshWaterFlowRateFreshWaterFlowRate
    -------- Corrected Code --------

    - Model for an air humidifier or dehumidifier. -

    -

    - This model adds (or removes) moisture from the air stream. The amount - of exchanged moisture is equal to -

    -

    - ṁwat = u ṁwat,nom, -

    -

    - where u is the control input signal and - wat,nom is equal to the parameter - mWat_flow_nominal. The parameter - mWat_flow_nominal can be positive or negative. If - wat is positive, then moisture is added to the - air stream, otherwise it is removed. + This enumeration defines the signal types that are used by BOPTEST to + compute the key performance indices (KPI).

    - If the heat port heatPort is unconnected, then the - enthalpy of the air that flows through the device remains unchanged, - e.g., the humidification is adiabatic. To change the enthalpy of the - air, add heat flow to the connector heatPort. + The following signal types are supported.

    - - --------- Errors -------- -line 9 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Media/Specialized/Air/PerfectGas.mo ---- --------- HTML Code -------- - - Function to set the state for given pressure, enthalpy and species concentration. - - The thermodynamic state record - is computed from density d, temperature T and composition X. - - Saturation pressure of water above the triple point temperature is computed from temperature. It's range of validity is between - 273.16 and 373.16 K. Outside these limits a less accurate result is returned. - - Derivative function of - - AixLib.Media.Specialized.Air.PerfectGas.saturationPressureLiquid - - Pressure is returned from the thermodynamic state record input as a simple assignment. - - Temperature is returned from the thermodynamic state record input as a simple assignment. - - Density is computed from pressure, temperature and composition in the thermodynamic state record applying the ideal gas law. - - Specific entropy is calculated from the thermodynamic state record, assuming ideal gas behavior and including entropy of mixing. Liquid or solid water is not taken into account, the entire water content X[1] is assumed to be in the vapor state (relative humidity below 1.0). - - Temperature as a function of specific enthalpy and species concentration. - The pressure is input for compatibility with the medium models, but the temperature - is independent of the pressure. - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + Value + + Description +
    + None + + Not used for KPI +
    + AirZoneTemperature + + Air zone temperature +
    + RadiativeZoneTemperature + + Radiative zone temperature +
    + OperativeZoneTemperature + + Operative zone temperature +
    + RelativeHumidity + + Relative humidity +
    + CO2Concentration + + CO2 concentration +
    + ElectricPower + + Electric power from grid +
    + DistrictHeatingPower + + Thermal power from district heating +
    + GasPower + + Thermal power from natural gas +
    + BiomassPower + + Thermal power from biomass +
    + SolarThermalPower + + Thermal power from solar thermal +
    + FreshWaterFlowRate + + FreshWaterFlowRate +
    +

    + +-------- Errors -------- +line 9 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/gFunction.mo ---- +-------- HTML Code -------- +

    - This data record contains the coefficients for perfect gases. + This function implements the g-function evaluation method introduced by + Cimmino and Bernier (see: Cimmino and Bernier (2014), and Cimmino (2018)) based + on the g-function function concept first introduced by Eskilson (1987). + The g-function gives the relation between the variation of the borehole + wall temperature at a time t and the heat extraction and injection rates + at all times preceding time t as

    - - - -

    - This package contains a thermally perfect model of moist air. +

    + \"image\"

    - A medium is called thermally perfect if + where Tb is the borehole wall temperature, + Tg is the undisturbed ground temperature, Q is the + heat injection rate into the ground through the borehole wall per unit borehole + length, ks is the soil thermal conductivity and g is + the g-function.

    -

    - In addition, this medium model is calorically perfect, i.e., the - specific heat capacities at constant pressure cp - and constant volume cv are both constant (Bower 1998). + The g-function is constructed from the combination of the combination of + the finite line source (FLS) solution (see + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource), + the cylindrical heat source (CHS) solution (see + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource), + and the infinite line source (ILS) solution (see + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.infiniteLineSource). + To obtain the g-function of a bore field, each borehole is divided into a + series of nSeg segments of equal length, each modeled as a line + source of finite length. The finite line source solution is superimposed in + space to obtain a system of equations that gives the relation between the heat + injection rate at each of the segments and the borehole wall temperature at each + of the segments. The system is solved to obtain the uniform borehole wall + temperature required at any time to maintain a constant total heat injection + rate (Qtot = 2πksHtot) into the bore + field. The uniform borehole wall temperature is then equal to the finite line + source based g-function.

    - This medium uses the ideal gas law + Since this g-function is based on line sources of heat, rather than + cylinders, the g-function is corrected to consider the cylindrical + geometry. The correction factor is then the difference between the cylindrical + heat source solution and the infinite line source solution, as proposed by + Li et al. (2014) as

    -

    - ρ = p ⁄(R T), +

    + g(t) = gFLS + (gCHS - gILS)

    +

    Implementation

    - where - ρ is the density, - p is the pressure, - R is the gas constant and - T is the temperature. + The calculation of the g-function is separated into two regions: the + short-time region and the long-time region. In the short-time region, + corresponding to times t < 1 hour, heat interaction between boreholes + and axial variations of heat injection rate are not considered. The + g-function is calculated using only one borehole and one segment. In the + long-time region, corresponding to times t > 1 hour, all boreholes + are represented as series of nSeg line segments and the + g-function is evaluated as described above.

    +

    References

    - The enthalpy is computed using the convention that h=0 - if T=0 °C and no water vapor is present. + Cimmino, M. and Bernier, M. 2014. A semi-analytical method to generate + g-functions for geothermal bore fields. International Journal of Heat and + Mass Transfer 70: 641-650.

    - Note that for typical building simulations, the media - AixLib.Media.Air - should be used as it leads generally to faster simulation. + Cimmino, M. 2018. Fast calculation of the g-functions of geothermal borehole + fields using similarities in the evaluation of the finite line source + solution. Journal of Building Performance Simulation. DOI: + 10.1080/19401493.2017.1423390.

    -

    References

    - Bower, William B. A primer in fluid mechanics: Dynamics of flows in one - space dimension. CRC Press. 1998. + Eskilson, P. 1987. Thermal analysis of heat extraction boreholes. Ph.D. + Thesis. Department of Mathematical Physics. University of Lund. Sweden.

    - -
    + + + + + + + + + + + + + + + +

    Latitude

    39.833° north

    Longitude

    104.65° west

    Altitude

    1650 m

    Time Zone

    -7

    - +-------- Corrected Code -------- + +

    + WD600: Ground Reflactance +

    +

    + Weather data file : WD600.epw +

    +

    + Table 1: Site Data for Weather file WD600.epw +

    + + + + + + + + + + + + + + + + + +
    +

    + Latitude +

    +
    +

    + 39.833° north +

    +
    +

    + Longitude +

    +
    +

    + 104.65° west +

    +
    +

    + Altitude +

    +
    +

    + 1650 m +

    +
    +

    + Time Zone +

    +
    +

    + -7 +

    +
    + +-------- Errors -------- +line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- AixLib/Fluid/FMI/Adaptors/HVAC.mo ---- +-------- HTML Code -------- + +

    + The (time varying) vector Real output signal of this block can be defined in its + parameter menu via variable y. The purpose is to support the + easy definition of vector-valued Real expressions in a block diagram. +

    - This component reads TMY3 weather data (Wilcox and Marion, 2008) or user specified weather data. - The Modelica built-in variable time determines what row - of the weather file is read. - The value of time is the number of seconds - that have passed since January 1st at midnight (00:00) in the local time zone. - The local time zone value, longitude and latitute are also read from the weather data, - such that the solar position computations are consistent with the weather data. + Adaptor that can be used to connect an HVAC system (with acausal ports) + to input/output signals, which then can be exposed in an FMI interface.

    - The weather data format is the Typical Meteorological Year (TMY3) - as obtained from the EnergyPlus web site at - - http://energyplus.net/weather. These - data, which are in the EnergyPlus format, need to be converted as described - below. + The adaptor has a vector of fluid ports called ports. + The supply and return air ducts need to be connected to these ports. + Also, if a thermal zone has interzonal air exchange or air infiltration, + these flow paths also need be connected to ports.

    - -

    Output to weaBus

    - The following variables serve as output and are accessible via weaBus: + This model outputs at the port fluPor the mass flow rate for + each flow that is connected to ports, together with its + temperature, water vapor mass fraction per total mass of the air (not per kg dry + air), and trace substances. These quantities are always as if the flow + enters the room, even if the flow is zero or negative. + If a medium has no moisture, e.g., if Medium.nXi=0, or + if it has no trace substances, e.g., if Medium.nC=0, then + the output signal for these properties are removed. + These quantities are always as if the flow + enters the room, even if the flow is zero or negative. + Thus, a thermal zone model that uses these signals to compute the + heat added by the HVAC system need to implement an equation such as +

    +

    + Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon),

    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    Name - Unit - Description -
    - HDifHor - - W/m2 - - Horizontal diffuse solar radiation. -
    - HDifNor - - W/m2 - - Direct normal radiation. -
    - HGloHor - - W/m2 - - Horizontal global radiation. -
    - HHorIR - - W/m2 - - Horizontal infrared irradiation. -
    - TBlaSky - - K - - Output temperature. -
    - TDewPoi - - K - - Dew point temperature. -
    - TDryBul - - K - - Dry bulb temperature at ground level. -
    - TWetBul - - K - - Wet bulb temperature. -
    - celHei - - m - - Ceiling height. -
    - cloTim - - s - - One-based day number in seconds. -
    - lat - - rad - - Latitude of the location. -
    - lon - - rad - - Longitude of the location. -
    - nOpa - - 1 - - Opaque sky cover [0, 1]. -
    - nTot - - 1 - - Total sky Cover [0, 1]. -
    - pAtm - - Pa - - Atmospheric pressure. -
    - relHum - - 1 - - Relative humidity. -
    - solAlt - - rad - - Altitude angle. -
    - solDec - - rad - - Declination angle. -
    - solHouAng - - rad - - Solar hour angle. -
    - solTim - - s - - Solar time. -
    - solZen - - rad - - Zenith angle. -
    - winDir - - rad - - Wind direction. -
    - winSpe - - m/s - - Wind speed. -
    - -

    Adding new weather data

    - To add new weather data, proceed as follows: + where + Qsen is the sensible heat flow rate added to the thermal zone, + sup is the supply air mass flow rate from + the port fluPor (which is negative if it is an exhaust), + cp is the specific heat capacity at constant pressure, + Tsup is the supply air temperature and + Tair,zon is the zone air temperature. + Note that without the max(·, ·) function, the energy + balance would be wrong.

    -
      +

      + The output signals of this model are the zone air temperature, + the water vapor mass fraction per total mass of the air (unless Medium.nXi=0) + and trace substances (unless Medium.nC=0). + These output connectors can be used to connect to a controller. + These values are obtained from the fluid stream(s) that flow into this component + at the port fluPor, e.g., from the connector + fluPor.backward. + Note that there are nPorts of these signals. + For a completely mixed room, they will all have the same value, but + for a room with non-uniform temperatures, they can have different values. +

      +

      Assumption and limitations

      +

      + The mass flow rates at ports sum to zero, hence this + model conserves mass. +

      +

      + This model does not impose any pressure, other than setting the pressure + of all fluid connections to ports to be equal. + The reason is that setting a pressure can lead to non-physical system models, + for example if a mass flow rate is imposed and the HVAC system is connected + to a model that sets a pressure boundary condition such as + + AixLib.Fluid.Sources.Outside. + Also, setting a pressure would make it impossible to use multiple instances + of this model (one for each thermal zone) and build in Modelica an airflow network + model with pressure driven mass flow rates. +

      +

      + The model has no pressure drop. Hence, the pressure drop + of an air diffuser or of an exhaust grill need to be modelled + in models that are connected to ports. +

      +

      Typical use and important parameters

      +

      + See + + AixLib.Fluid.FMI.ExportContainers.HVACZone + for a model that uses this model. +

      + +
      • - Download the weather data file with the epw extension from - - http://energyplus.net/weather. + January 18, 2019, by Jianjun Hu:
        + Limited the media choice to moist air only. + See #1050.
      • - Add the file to AixLib/Resources/weatherdata (or to any directory - for which you have write permission). + September 13, 2017, by Michael Wetter:
        + Removed erroneous each.
      • - On a console window, type
        -   cd AixLib/Resources/weatherdata
        -   java -jar ../bin/ConvertWeatherData.jar inputFile.epw
        - 
        - if inputFile contains space in the name: -
        -   java -jar ../bin/ConvertWeatherData.jar \"inputFile .epw\"
        - 
        - This will generate the weather data file inputFile.mos, which can be read - by the model - - AixLib.BoundaryConditions.WeatherData.ReaderTMY3. -
      • -
    - -

    Location data that are read automatically from the weather data file

    -

    - The following location data are automatically read from the weather file: -

    - - -

    Wet bulb temperature

    + +-------- Corrected Code -------- +

    + The (time varying) vector Real output signal of this + block can be defined in its parameter menu via variable + y. The purpose is to support the easy definition of + vector-valued Real expressions in a block diagram. +

    +

    + Adaptor that can be used to connect an HVAC system (with acausal + ports) to input/output signals, which then can be exposed in an FMI + interface. +

    +

    + The adaptor has a vector of fluid ports called ports. + The supply and return air ducts need to be connected to these ports. + Also, if a thermal zone has interzonal air exchange or air + infiltration, these flow paths also need be connected to + ports. +

    +

    + This model outputs at the port fluPor the mass flow rate + for each flow that is connected to ports, together with + its temperature, water vapor mass fraction per total mass of the air + (not per kg dry air), and trace substances. These quantities are + always as if the flow enters the room, even if the flow is zero or + negative. If a medium has no moisture, e.g., if + Medium.nXi=0, or if it has no trace substances, e.g., if + Medium.nC=0, then the output signal for these properties + are removed. These quantities are always as if the flow enters the + room, even if the flow is zero or negative. Thus, a thermal zone + model that uses these signals to compute the heat added by the HVAC + system need to implement an equation such as +

    +

    + Qsen = max(0, ṁsup)   cp   + (Tsup - Tair,zon), +

    +

    + where Qsen is the sensible heat flow rate added to + the thermal zone, sup is the supply air mass flow + rate from the port fluPor (which is negative if it is an + exhaust), cp is the specific heat capacity at + constant pressure, Tsup is the supply air + temperature and Tair,zon is the zone air + temperature. Note that without the max(·, ·) function, the + energy balance would be wrong. +

    +

    + The output signals of this model are the zone air temperature, the + water vapor mass fraction per total mass of the air (unless + Medium.nXi=0) and trace substances (unless + Medium.nC=0). These output connectors can be used to + connect to a controller. These values are obtained from the fluid + stream(s) that flow into this component at the port + fluPor, e.g., from the connector + fluPor.backward. Note that there are nPorts + of these signals. For a completely mixed room, they will all have the + same value, but for a room with non-uniform temperatures, they can + have different values. +

    +

    + Assumption and limitations +

    +

    + The mass flow rates at ports sum to zero, hence this + model conserves mass. +

    +

    + This model does not impose any pressure, other than setting the + pressure of all fluid connections to ports to be equal. + The reason is that setting a pressure can lead to non-physical system + models, for example if a mass flow rate is imposed and the HVAC + system is connected to a model that sets a pressure boundary + condition such as AixLib.Fluid.Sources.Outside. + Also, setting a pressure would make it impossible to use multiple + instances of this model (one for each thermal zone) and build in + Modelica an airflow network model with pressure driven mass flow + rates. +

    +

    + The model has no pressure drop. Hence, the pressure drop of an air + diffuser or of an exhaust grill need to be modelled in models that + are connected to ports. +

    +

    + Typical use and important parameters +

    +

    + See AixLib.Fluid.FMI.ExportContainers.HVACZone + for a model that uses this model. +

    + + +-------- Errors -------- +line 26 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Controls/Continuous/Examples/SignalRanker.mo ---- +-------- HTML Code -------- +

    - By default, the data bus contains the wet bulb temperature. - This introduces a nonlinear equation. - However, we have not observed an increase in computing time because - of this equation. - To disable the computation of the wet bulb temperature, set - computeWetBulbTemperature=false. + Example that demonstrates the use of the signal ranker model. + The figure below shows the input and output signals of the block. + Note that + sigRan.y[1] ≥ sigRan.y[2] ≥ sigRan.y[3].

    - -

    Using constant or user-defined input signals for weather data

    -

    - This model has the option of using a constant value, using the data from the weather file, - or using data from an input connector for the following variables: +

    + \"Input
    + \"Output

    + + +-------- Corrected Code -------- +

    + Example that demonstrates the use of the signal ranker model. The + figure below shows the input and output signals of the block. Note + that sigRan.y[1] ≥ sigRan.y[2] ≥ sigRan.y[3]. +

    +

    + \"Input
    + \"Output +

    + + +-------- Errors -------- +line 8 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlow.mo ---- +-------- HTML Code -------- + +

    +

    - By default, all data are obtained from the weather data file, - except for the atmospheric pressure, which is set to the - parameter pAtm=101325 Pascals. + Model that computes the temperature propagation of + a fluid flow through a pipe, idealized as a plug flow.

    +

    Main equation

    - The parameter *Sou configures the source of the data. - For the atmospheric pressure, temperatures, relative humidity, wind speed and wind direction, - the enumeration - - AixLib.BoundaryConditions.Types.DataSource - is used as follows: + The transport delay is computed using the one-dimensional wave equation + without source or sink terms, +

    + ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0,

    - - - - - - - - - - - - - - - - - - - - - -
    Parameter *Sou - Data used to compute weather data. -
    - File - - Use data from file. -
    - Parameter - - Use value specified by the parameter. -
    - Input - - Use value from the input connector. -
    +

    where z(x,t) is the spatial distribution as a function of time of any + property z of the fluid. + For the temperature propagation, z will be replaced by T. +

    +

    Assumptions

    - Because global, diffuse and direct radiation are related to each other, the parameter - HSou is treated differently. - It is set to a value of the enumeration - - AixLib.BoundaryConditions.Types.RadiationDataSource, - and allows the following configurations: + This model is based on the following assumptions:

    - - - - - - - - - - - - - - - - - - - - - - - - -
    Parameter HSou - Data used to compute weather data. -
    - File - - Use data from file. -
    - Input_HGloHor_HDifHor - - Use global horizontal and diffuse horizontal radiation from input connector. -
    - Input_HDirNor_HDifHor - - Use direct normal and diffuse horizontal radiation from input connector. -
    - Input_HDirNor_HGloHor - - Use direct normal and global horizontal radiation from input connector. -
    - -

    Length of weather data and simulation period

    + + +-------- Corrected Code -------- + +

    + Model that computes the temperature propagation of a fluid flow + through a pipe, idealized as a plug flow. +

    +

    + Main equation +

    +

    + The transport delay is computed using the one-dimensional wave + equation without source or sink terms, +

    +

    + ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0, +

    +

    + where z(x,t) is the spatial distribution as a function of time + of any property z of the fluid. For the temperature + propagation, z will be replaced by T. +

    +

    + Assumptions +

    +

    + This model is based on the following assumptions: +

    + + +-------- Errors -------- +line 10 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Controls/Continuous/Examples/NumberOfRequests.mo ---- +-------- HTML Code -------- + +

    +

    - If weather data span a year, which is the default for TMY3 data, or multiple years, - then this model can be used for simulations that span multiple years. The simulation - start time needs to be set to the clock time of the respective start time. For example, - to start at January 2 at 10am, set start time to t=(24+10)*3600 seconds. - For this computation, the used date and time (here January 2, 10 am) must be expressed in the same time zone - as the one that is used to define the TMY3 file. This is usually the local (winter) time zone. - The parameter `timZon` represents the TMY3 file time zone, expressed in seconds compared to UTC. + Example that demonstrates the use of the block + + AixLib.Controls.Continuous.NumberOfRequests. + The parameters of the block are such that the output is incremented + for each input signal that is strictly larger than 0. + The figure below shows the inputs and the output of the block.

    +

    + \"Simulation +

    + +-------- Corrected Code -------- + +

    + Example that demonstrates the use of the block AixLib.Controls.Continuous.NumberOfRequests. + The parameters of the block are such that the output is incremented + for each input signal that is strictly larger than 0. The + figure below shows the inputs and the output of the block. +

    +

    + \"Simulation +

    + +-------- Errors -------- +line 10 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/HeatExchangers/ActiveBeams/UsersGuide.mo ---- +-------- HTML Code -------- + +

    +This package contains models of active beams. +Active beams are devices used for heating, cooling and ventilation of spaces. +A schematic diagram of an active beam unit is given below. +

    +

    +\"image\" +

    +

    +The active beam unit consists of a primary air plenum, a mixing chamber, a heat exchanger (coil) and several nozzles. +Typically, an air-handling unit supplies primary air to the active beams. +The primary air is discharged to the mixing chamber through the nozzles. +This generates a low-pressure region which induces air from the room up through the heat exchanger, +where hot or cold water is circulating. +The conditioned induced air is then mixed with primary air, and the mixture descents back to the space. +

    +

    +This package contains two models. The model + +AixLib.Fluid.HeatExchangers.ActiveBeams.Cooling +is for cooling only, while the model + +AixLib.Fluid.HeatExchangers.ActiveBeams.CoolingAndHeating +has two water streams, one for heating and one for cooling. +

    + +

    Model equations for cooling

    +

    +The performance of the model + +AixLib.Fluid.HeatExchangers.ActiveBeams.Cooling +is computed based on manufacturer data +specified in the package + +AixLib.Fluid.HeatExchangers.ActiveBeams.Data. +

    +

    +For off-design conditions, the performance is adjusted using modification factors +that account for changes in water flow rate, +primary air flow rate and temperature difference. +The total heat flow rate of the active beam unit is the sum of the heat flow rate provided by the primary air supply +Qsa and the cooling heat flow rate provided by the beam convector Qc,Beam +which injects room air and mixes it with the primary air. +

    +

    +The heat flow rate +Qsa is delivered to a thermal zone +through the fluid ports, while the heat flow rate from the convector Qc,Beam +is coupled directly to the heat port. +See for example + +AixLib.Fluid.HeatExchangers.ActiveBeams.Examples.CoolingOnly +for how to connect these heat flow rates to a control volume. +

    +

    +The primary air contribution is +

    +

    + Qsa = ṁsa cp,sa (Tsa-Tz) +

    +

    +where sa is the primary air mass flow rate, +cp,sa is the air specific heat capacity, +Tsa is the primary air temperature +and Tz is the zone air temperature. +

    +

    +The heat flow rate of the beam convector Qc,Beam is determined using +the rated capacity which is modified by three separate functions as +

    +

    + Qc,Beam = Qc,nominal +fΔT ( ΔTc ⁄ ΔTc,nominal ) +fsa( ṁsa ⁄ ṁsa,nominal ) +fw( ṁc,w ), +

    +

    +the modification factors are as follows: +The modification factor fΔT(·) +describes how the capacity is adjusted to account for the temperature difference +between the zone air and the water entering the convector. +The independent variable is the ratio between the current temperature difference +ΔTc and the temperature difference used to rate beam performance ΔTc,nominal. +The temperature difference is +

    +

    + ΔTc = Tcw-Tz, +

    +

    +where Tcw is the chilled water temperature entering the convector. + +The modification factor fsa(·) adjusts the cooling capacity to account for varying primary air flow rate. +The independent variable is the ratio between the current primary air flow rate sa +and the nominal air flow rate used to rate the beam performance. + +The modification factor fw(·) adjusts the cooling capacity for changes in water flow rate through the convector. +The independent variable is the ratio between the current water flow rate w +and the nominal water flow rate used to rate the beam performance. +

    + +

    Model equations for heating

    +

    +The performance of the model + +AixLib.Fluid.HeatExchangers.ActiveBeams.CoolingAndHeating +is computed identical to the above described model that only provides cooling, +with the exception that this model contains an additional water stream that +can be used to provide heating. +

    +

    +For the heating water stream, the temperature difference ΔTh +used for the calculation of the modification factor fΔT(·) is +

    +

    +ΔTh = Thw-Tz, +

    +

    +where Thw is the hot water temperature entering the convector in heating mode +and Tz is the zone air temperature. +

    + +

    Dynamics

    +

    +The model can be configured to be steady-state or dynamic. +If configured as dynamic, then a dynamic conservation equation is applied to the water streams +for heating and for cooling. +However, because the capacity of the beam depends on its inlet temperature, and is independent of the +outlet temperature, the heat transferred +to the room at the port heaPor.Q_flow, as well as the heat added to or removed from the +water streams, will instantaneously change. +The only dynamic responses are the water outlet temperatures, which change with a first +order response, parameterized with the time constant tau. +

    + +

    Energy balance

    +

    +All heat flow rate that is added to or extracted from the room is transmitted through the heat port +heaPor. Hence, this model does not cool the supply air between the ports +air_a and air_b. Rather, it adds this heat flow rate +to the heat port heaPor. +The rationale for this implementation is that the beam transfers heat by convection directly to the room, and +by induction of room air into the supply air. As this split of heat flow rate is generally not known, +and because the amount of inducted air is also unknown, +it was decided to transfer all heat through the heat port heaPor. +This also avoids having to add an extra air flow path for the air induced from the room. +

    + +-------- Corrected Code -------- +

    + This package contains models of active beams. Active beams are + devices used for heating, cooling and ventilation of spaces. A + schematic diagram of an active beam unit is given below. +

    +

    + \"image\" +

    +

    + The active beam unit consists of a primary air plenum, a mixing + chamber, a heat exchanger (coil) and several nozzles. Typically, an + air-handling unit supplies primary air to the active beams. The + primary air is discharged to the mixing chamber through the nozzles. + This generates a low-pressure region which induces air from the room + up through the heat exchanger, where hot or cold water is + circulating. The conditioned induced air is then mixed with primary + air, and the mixture descents back to the space. +

    +

    + This package contains two models. The model AixLib.Fluid.HeatExchangers.ActiveBeams.Cooling + is for cooling only, while the model + AixLib.Fluid.HeatExchangers.ActiveBeams.CoolingAndHeating has two + water streams, one for heating and one for cooling. +

    +

    + Model equations for cooling +

    +

    + The performance of the model AixLib.Fluid.HeatExchangers.ActiveBeams.Cooling + is computed based on manufacturer data specified in the package + AixLib.Fluid.HeatExchangers.ActiveBeams.Data. +

    +

    + For off-design conditions, the performance is adjusted using + modification factors that account for changes in water flow rate, + primary air flow rate and temperature difference. The total heat flow + rate of the active beam unit is the sum of the heat flow rate + provided by the primary air supply Qsa and the + cooling heat flow rate provided by the beam convector + Qc,Beam which injects room air and mixes it with + the primary air. +

    +

    + The heat flow rate Qsa is delivered to a thermal + zone through the fluid ports, while the heat flow rate from the + convector Qc,Beam is coupled directly to the heat + port. See for example + AixLib.Fluid.HeatExchangers.ActiveBeams.Examples.CoolingOnly for + how to connect these heat flow rates to a control volume. +

    +

    + The primary air contribution is +

    +

    + Qsa = ṁsa cp,sa + (Tsa-Tz) +

    +

    + where sa is the primary air mass flow rate, + cp,sa is the air specific heat capacity, + Tsa is the primary air temperature and + Tz is the zone air temperature. +

    +

    + The heat flow rate of the beam convector Qc,Beam is + determined using the rated capacity which is modified by three + separate functions as +

    +

    + Qc,Beam = Qc,nominal fΔT ( + ΔTc ⁄ ΔTc,nominal ) fsa( + ṁsa ⁄ ṁsa,nominal ) fw( + ṁc,w ), +

    +

    + the modification factors are as follows: The modification factor + fΔT(·) describes how the capacity is adjusted to + account for the temperature difference between the zone air and the + water entering the convector. The independent variable is the ratio + between the current temperature difference ΔTc and + the temperature difference used to rate beam performance + ΔTc,nominal. The temperature difference is +

    +

    + ΔTc = Tcw-Tz, +

    +

    + where Tcw is the chilled water temperature entering + the convector. The modification factor fsa(·) + adjusts the cooling capacity to account for varying primary air flow + rate. The independent variable is the ratio between the current + primary air flow rate sa and the nominal air flow + rate used to rate the beam performance. The modification factor + fw(·) adjusts the cooling capacity for changes in + water flow rate through the convector. The independent variable is + the ratio between the current water flow rate w + and the nominal water flow rate used to rate the beam performance. +

    +

    + Model equations for heating +

    +

    + The performance of the model + AixLib.Fluid.HeatExchangers.ActiveBeams.CoolingAndHeating is + computed identical to the above described model that only provides + cooling, with the exception that this model contains an additional + water stream that can be used to provide heating. +

    +

    + For the heating water stream, the temperature difference + ΔTh used for the calculation of the + modification factor fΔT(·) is +

    +

    + ΔTh = Thw-Tz, +

    +

    + where Thw is the hot water temperature entering the + convector in heating mode and Tz is the zone air + temperature. +

    +

    + Dynamics +

    +

    + The model can be configured to be steady-state or dynamic. If + configured as dynamic, then a dynamic conservation equation is + applied to the water streams for heating and for cooling. However, + because the capacity of the beam depends on its inlet temperature, + and is independent of the outlet temperature, the heat transferred to + the room at the port heaPor.Q_flow, as well as the heat + added to or removed from the water streams, will instantaneously + change. The only dynamic responses are the water outlet temperatures, + which change with a first order response, parameterized with the time + constant tau. +

    +

    + Energy balance +

    +

    + All heat flow rate that is added to or extracted from the room is + transmitted through the heat port heaPor. Hence, this + model does not cool the supply air between the ports + air_a and air_b. Rather, it adds this heat + flow rate to the heat port heaPor. The rationale for + this implementation is that the beam transfers heat by convection + directly to the room, and by induction of room air into the supply + air. As this split of heat flow rate is generally not known, and + because the amount of inducted air is also unknown, it was decided to + transfer all heat through the heat port heaPor. This + also avoids having to add an extra air flow path for the air induced + from the room. +

    + +-------- Errors -------- +line 7 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 59 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 72 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 87 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 115 column 1 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Actuators/BaseClasses/PartialDamperExponential.mo ---- +-------- HTML Code -------- +

    - Moreover, weather data need not span a whole year, or it can span across New Year. - In this case, the simulation cannot exceed the time of the weather data file. Otherwise, - the simulation stops with an error. + Partial model for air dampers with exponential opening characteristics. + This is the base model for air dampers. + The model implements the functions that relate the opening signal and the + flow coefficient. + The model also defines parameters that are used by different air damper + models.

    - As weather data have one entry at the start of the time interval, the end time of the weather - data file is computed as the last time entry plus the average time increment of the file. - For example, an hourly weather data file has 8760 entries, starting on January 1 at 0:00. - The last entry in the file will be for December 31 at 23:00. As the time increment is 1 hour, - the model assumes the weather file to end at December 31 at 23:00 plus 1 hour, e.g., at January 1 at 0:00. + The model is as in ASHRAE 825-RP except that a control signal of + y=0 means the damper is closed, and y=1 means + the damper is open. + This is opposite of the implementation of ASHRAE 825-RP, but used here + for consistency within this library.

    - -

    Notes

    -
      -
    1. - In HVAC systems, when the fan is off, changes in atmospheric pressure can cause small air flow rates - in the duct system due to change in pressure and hence in the mass of air that is stored - in air volumes (such as in fluid junctions or in the room model). - This may increase computing time. Therefore, the default value for the atmospheric pressure is set to a constant. - Furthermore, if the initial pressure of air volumes are different - from the atmospheric pressure, then fast pressure transients can happen in the first few seconds of the simulation. - This can cause numerical problems for the solver. To avoid this problem, set the atmospheric pressure to the - same value as the medium default pressure, which is typically set to the parameter Medium.p_default. - For medium models for moist air and dry air, the default is - Medium.p_default=101325 Pascals. + For yL < y < yU, the damper characteristics is:

      -
    2. -
    3. -

      - Different units apply depending on whether data are obtained from a file, or - from a parameter or an input connector: +

      + kd(y) = exp(a+b (1-y))

      -
        -
      • - When using TMY3 data from a file (e.g. USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.mos), the units must be the same as the original TMY3 file used by EnergyPlus (e.g. - USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.epw). - The TMY3 data used by EnergyPlus are in both SI units and non-SI units. - If Resources/bin/ConvertWeatherData.jar is used to convert the .epw file to an .mos file, the units of the TMY3 data are preserved and the file can be directly - used by this data reader. - The data reader will automatically convert units to the SI units used by Modelica. - For example, the dry bulb temperature TDryBul in TMY3 is in degree Celsius. - The data reader will automatically convert the data to Kelvin. - The wind direction winDir in TMY3 is degrees and will be automatically converted to radians. -
      • -
      • - When using data from a parameter or from an input connector, - the data must be in the SI units used by Modelica. - For instance, the unit must be - Pa for pressure, - K for temperature, - W/m2 for solar radiations and - rad for wind direction. -
      • -
      -
    4. -
    5. - Hourly and subhourly timestamp are handled in a different way in .epw files. - From the EnergyPlus Auxiliary Programs Document (v9.3.0, p. 63): - In hourly data the minute field can be 00 or 60. In this case as mentioned in the previous section, the weather data - is reported at the hourly value and the minute field has to be ignored, writing 1, 60 or 1, 00 is equivalent. - If the minute field is between 00 and 60, the file becomes subhourly, in this case the timestamp corresponds to the - minute field in the considered hour. For example: 1, 30 is equivalent to 00:30 and 3, 45 is equivalent to 02:45.
      - (Note the offset in the hour digit.) + where kd is the loss coefficient (total pressure drop divided + by dynamic pressure) and y is the fractional opening.

      -
    6. -
    7. - The ReaderTMY3 should only be used with TMY3 data. It contains a time shift for solar radiation data - that is explained below. This time shift needs to be removed if the user may want to - use the ReaderTMY3 for other weather data types. -
    8. -
    -

    Implementation

    -
    Start and end data for annual weather data files

    - The TMY3 weather data, as well as the EnergyPlus weather data, start at 1:00 AM - on January 1, and provide hourly data until midnight on December 31. - Thus, the first entry for temperatures, humidity, wind speed etc. are values - at 1:00 AM and not at midnight. Furthermore, the TMY3 weather data files can have - values at midnight of December 31 that may be significantly different from the values - at 1:00 AM on January 1. - Since annual simulations require weather data that start at 0:00 on January 1, - data need to be provided for this hour. Due to the possibly large change in - weatherdata between 1:00 AM on January 1 and midnight at December 31, - the weather data files in the AixLib library do not use the data entry from - midnight at December 31 as the value for t=0. Rather, the - value from 1:00 AM on January 1 is duplicated and used for 0:00 on January 1. - To maintain a data record with 8760 hours, the weather data record from - midnight at December 31 is deleted. - These changes in the weather data file are done in the Java program - AixLib/Resources/bin/ConvertWeatherData.jar that converts - EnergyPlus weather data file to Modelica weather data files, and which is described - above. - The length of the weather data is calculated as the - end time stamp minus start time stamp plus average increment, where the - average increment is equal to the end time stamp minus start time stamp divided - by the number of rows minus 1. - This only works correctly for weather files with equidistant time stamps. + Outside this range, the damper characteristics is defined by a quadratic polynomial that + matches the damper resistance at y=0 and y=yL or + y=yU and y=1, respectively. + In addition, the polynomials are such that kd(y) is differentiable in + y and the derivative is continuous.

    -
    Time shift for solar radiation data

    - To read weather data from the TMY3 weather data file, there are - two data readers in this model. One data reader obtains all data - except solar radiation, and the other data reader reads only the - solar radiation data, shifted by 30 minutes. - The reason for this time shift is as follows: - The TMY3 weather data file contains for solar radiation the - \"...radiation received - on a horizontal surface during - the 60-minute period ending at - the timestamp.\" - - Thus, as the figure below shows, a more accurate interpolation is obtained if - time is shifted by 30 minutes prior to reading the weather data. -

    -

    - \"image\" + The damper characteristics is then used to compute the flow coefficient k(y) as:

    -

    References

    - - -

    - Location data that are read automatically from the weather data file + Outputs required

    - The following location data are automatically read from the weather - file: + Annual Outputs +

    +

    +  The following outputs are provided for an annual + simulation:

    -

    - Wet bulb temperature -

    +
  • Average humidity ratio (kg moisture/kg dry air) +
  • +
  • Average wet bulb temperature (°C) +
  • +
  • Sum of total, beam, and diffuse solar radiation incident on each + surface (Wh/m2) +
  • +

    - By default, the data bus contains the wet bulb temperature. This - introduces a nonlinear equation. However, we have not observed an - increase in computing time because of this equation. To disable the - computation of the wet bulb temperature, set - computeWetBulbTemperature=false. -

    -

    - Using constant or user-defined input signals for weather data -

    + Hourly Outputs +

    - This model has the option of using a constant value, using the data - from the weather file, or using data from an input connector for the - following variables: + The following outputs are provided for each hour of the days + specified for each test case in Table 3:

    -

    - By default, all data are obtained from the weather data file, except - for the atmospheric pressure, which is set to the parameter - pAtm=101325 Pascals. -

    +

    - The parameter *Sou configures the source of the data. - For the atmospheric pressure, temperatures, relative humidity, wind - speed and wind direction, the enumeration AixLib.BoundaryConditions.Types.DataSource - is used as follows: + Table 3: Specific Days for Output

    - - - - - - +
    - Parameter *Sou - - Data used to compute weather data. -
    - + - + -
    - File +

    + Case +

    - Use data from file. +

    + Days +

    - Parameter +

    + WD100 +

    - Use value specified by the parameter. +

    + May 4th, July 14th, September 6th +

    - Input +

    + WD200 +

    - Use value from the input connector. +

    + May 24th, August 26th +

    -

    - Because global, diffuse and direct radiation are related to each - other, the parameter HSou is treated differently. It is - set to a value of the enumeration AixLib.BoundaryConditions.Types.RadiationDataSource, - and allows the following configurations: -

    - - - - - - - + -
    - Parameter HSou - - Data used to compute weather data. -
    - File +

    + WD300 +

    - Use data from file. +

    + February 7th, August 13th +

    - Input_HGloHor_HDifHor +

    + WD400 +

    - Use global horizontal and diffuse horizontal radiation from input - connector. +

    + January 24th, July 1st +

    - Input_HDirNor_HDifHor +

    + WD500 +

    - Use direct normal and diffuse horizontal radiation from input - connector. +

    + March 1st, September 14th +

    - Input_HDirNor_HGloHor +

    + WD600 +

    - Use direct normal and global horizontal radiation from input - connector. +

    + May 4th, July 14th, September 6th +

    -

    - Length of weather data and simulation period -

    +

    - If weather data span a year, which is the default for TMY3 data, or - multiple years, then this model can be used for simulations that span - multiple years. The simulation start time needs to be set to the - clock time of the respective start time. For example, to start at - January 2 at 10am, set start time to t=(24+10)*3600 - seconds. For this computation, the used date and time (here January - 2, 10 am) must be expressed in the same time zone as the one that is - used to define the TMY3 file. This is usually the local (winter) time - zone. The parameter `timZon` represents the TMY3 file time zone, - expressed in seconds compared to UTC. + Sub-hourly Outputs

    - Moreover, weather data need not span a whole year, or it can span - across New Year. In this case, the simulation cannot exceed the time - of the weather data file. Otherwise, the simulation stops with an - error. + The following outputs are provided at each timestep of the days + specified for each test case in Table 3:

    -

    - As weather data have one entry at the start of the time interval, the - end time of the weather data file is computed as the last time entry - plus the average time increment of the file. For example, an hourly - weather data file has 8760 entries, starting on January 1 at 0:00. - The last entry in the file will be for December 31 at 23:00. As the - time increment is 1 hour, the model assumes the weather file to end - at December 31 at 23:00 plus 1 hour, e.g., at January 1 at 0:00. -

    -

    - Notes -

    -
      -
    1. -

      - In HVAC systems, when the fan is off, changes in atmospheric - pressure can cause small air flow rates in the duct system due to - change in pressure and hence in the mass of air that is stored in - air volumes (such as in fluid junctions or in the room model). - This may increase computing time. Therefore, the default value - for the atmospheric pressure is set to a constant. Furthermore, - if the initial pressure of air volumes are different from the - atmospheric pressure, then fast pressure transients can happen in - the first few seconds of the simulation. This can cause numerical - problems for the solver. To avoid this problem, set the - atmospheric pressure to the same value as the medium default - pressure, which is typically set to the parameter - Medium.p_default. For medium models for moist air - and dry air, the default is Medium.p_default=101325 - Pascals. -

      +
        +
      • Dry bulb temperature (C)
      • -
      • -

        - Different units apply depending on whether data are obtained from - a file, or from a parameter or an input connector: -

        -
          -
        • When using TMY3 data from a file (e.g. - USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.mos), the - units must be the same as the original TMY3 file used by - EnergyPlus (e.g. - USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.epw). The - TMY3 data used by EnergyPlus are in both SI units and non-SI - units. If Resources/bin/ConvertWeatherData.jar is - used to convert the .epw file to an - .mos file, the units of the TMY3 data are preserved - and the file can be directly used by this data reader. The data - reader will automatically convert units to the SI units used by - Modelica. For example, the dry bulb temperature - TDryBul in TMY3 is in degree Celsius. The data - reader will automatically convert the data to Kelvin. The wind - direction winDir in TMY3 is degrees and will be - automatically converted to radians. -
        • -
        • When using data from a parameter or from an input connector, - the data must be in the SI units used by Modelica. For instance, - the unit must be Pa for pressure, K for - temperature, W/m2 for solar radiations and - rad for wind direction. -
        • -
        +
      • Relative humidity (%)
      • -
      • -

        - Hourly and subhourly timestamp are handled in a different way in - .epw files. From the EnergyPlus Auxiliary Programs - Document (v9.3.0, p. 63): In hourly data the minute field can be - 00 or 60. In this case as mentioned in - the previous section, the weather data is reported at the hourly - value and the minute field has to be ignored, writing 1, - 60 or 1, 00 is equivalent. If the minute - field is between 00 and 60, the file - becomes subhourly, in this case the timestamp corresponds to the - minute field in the considered hour. For example: 1, - 30 is equivalent to 00:30 and 3, 45 is - equivalent to 02:45.
        - (Note the offset in the hour digit.) -

        +
      • Sum of total, beam, and diffuse solar radiation incident on each + surface (Wh/m2) +
      • +
      +

      + The following outputs are provided integrated hourly for the days + specified for each test case in Table 3: +

      +
        +
      • Total incident horizontal solar radiation (Wh/m2) +
      • +
      • Total incident horizontal beam solar radiation (Wh/m2)
      • -
      • The ReaderTMY3 should only be used with TMY3 data. It contains a - time shift for solar radiation data that is explained below. This - time shift needs to be removed if the user may want to use the - ReaderTMY3 for other weather data types. +
      • Total incident horizontal diffuse solar radiation (Wh/m2)
      • -
    + +

    + Validation results +

    +

    + (Not available yet) +

    Implementation

    -
    - Start and end data for annual weather data files -

    - The TMY3 weather data, as well as the EnergyPlus weather data, start - at 1:00 AM on January 1, and provide hourly data until midnight on - December 31. Thus, the first entry for temperatures, humidity, wind - speed etc. are values at 1:00 AM and not at midnight. Furthermore, - the TMY3 weather data files can have values at midnight of December - 31 that may be significantly different from the values at 1:00 AM on - January 1. Since annual simulations require weather data that start - at 0:00 on January 1, data need to be provided for this hour. Due to - the possibly large change in weatherdata between 1:00 AM on January 1 - and midnight at December 31, the weather data files in the AixLib - library do not use the data entry from midnight at December 31 as the - value for t=0. Rather, the value from 1:00 AM on January 1 is - duplicated and used for 0:00 on January 1. To maintain a data record - with 8760 hours, the weather data record from midnight at - December 31 is deleted. These changes in the weather data file are - done in the Java program - AixLib/Resources/bin/ConvertWeatherData.jar that - converts EnergyPlus weather data file to Modelica weather data files, - and which is described above. The length of the weather data is - calculated as the end time stamp minus start time stamp plus average - increment, where the average increment is equal to the end time stamp - minus start time stamp divided by the number of rows minus 1. This - only works correctly for weather files with equidistant time stamps. + To generate the data shown in this user guide, run +

    +
    +cd AixLib/Resources/Data/BoundaryConditions/Validation/BESTEST
    +python3 generateResults.py -p
    +
    +

    + At the beginning of the Python script there are several options that + the user can choose, by default the script will: +

    + +

    + References +

    +

    + (Not available yet) +

    + + +-------- Errors -------- +line 14 column 1 - Warning: The summary attribute on the element is obsolete in HTML5 +line 98 column 1 - Warning: The summary attribute on the
    element is obsolete in HTML5 + + +---- AixLib/Fluid/HeatExchangers/Radiators/RadiatorEN442_2.mo ---- +-------- HTML Code -------- + +

    + This is a model of a radiator that can be used as a dynamic or steady-state model. + The required parameters are data that are typically available from + manufacturers that follow the European Norm EN 442-2. +

    +

    + However, to allow for varying mass flow rates, the transferred heat is computed + using a discretization along the water flow path, and heat is exchanged between + each compartment and a uniform room air and radiation temperature. + This discretization is different from the computation in EN 442-2, which + may yield water outlet temperatures that are below + the room temperature at low mass flow rates. + Furthermore, rather than using only one room temperature, this model uses + a room air and room radiation temperature. +

    +

    + The transferred heat is modeled as follows: + Let N denote the number of elements used to discretize the radiator model. + For each element i ∈ {1, … , N}, + the convective and radiative heat transfer + Qic and + Qir + from the radiator to the room is +

    +

    + Qic = sign(Ti-Ta) + (1-fr) UA ⁄ N |Ti-Ta|n +

    + Qir = sign(Ti-Tr) + fr UA ⁄ N |Ti-Tr|n +

    +

    + where + Ti is the water temperature of the element, + Ta is the temperature of the room air, + Tr is the radiative temperature, + 0 < fr < 1 is the fraction of radiant to total heat transfer, + UA is the UA-value of the radiator, + and + n is an exponent for the heat transfer. + The model computes the UA-value by numerically solving the above equations + for given + nominal heating power, nominal temperatures, fraction radiant to total heat transfer + and exponent for heat transfer. +

    +

    + The parameter energyDynamics (in the Assumptions tab), + determines whether the model computes the dynamic or the steady-state response. + For the transient response, heat storage is computed using a + finite volume approach for the + water and the metal mass, which are both assumed to be at the same + temperature. +

    +

    + The default parameters for the heat capacities are valid for a flat plate radiator without fins, + with one plate of water carying fluid, and a height of 0.42 meters. +

    + + + +-------- Corrected Code -------- +

    + This is a model of a radiator that can be used as a dynamic or + steady-state model. The required parameters are data that are + typically available from manufacturers that follow the European Norm + EN 442-2. +

    +

    + However, to allow for varying mass flow rates, the transferred heat + is computed using a discretization along the water flow path, and + heat is exchanged between each compartment and a uniform room air and + radiation temperature. This discretization is different from the + computation in EN 442-2, which may yield water outlet temperatures + that are below the room temperature at low mass flow rates. + Furthermore, rather than using only one room temperature, this model + uses a room air and room radiation temperature.

    -
    - Time shift for solar radiation data -

    - To read weather data from the TMY3 weather data file, there are two - data readers in this model. One data reader obtains all data except - solar radiation, and the other data reader reads only the solar - radiation data, shifted by 30 minutes. The reason for this - time shift is as follows: The TMY3 weather data file contains for - solar radiation the \"...radiation received on a horizontal surface - during the 60-minute period ending at the timestamp.\" Thus, as the - figure below shows, a more accurate interpolation is obtained if time - is shifted by 30 minutes prior to reading the weather data. + The transferred heat is modeled as follows: Let N denote the + number of elements used to discretize the radiator model. For each + element i ∈ {1, … , N}, the convective and radiative heat + transfer Qic and + Qir from the radiator to the room is

    -

    - \"image\" +

    + Qic = sign(Ti-Ta) + (1-fr) UA ⁄ N + |Ti-Ta|n
    +
    + Qir = sign(Ti-Tr) + fr UA ⁄ N |Ti-Tr|n +

    +

    + where Ti is the water temperature of the element, + Ta is the temperature of the room air, + Tr is the radiative temperature, 0 < + fr < 1 is the fraction of radiant to total heat + transfer, UA is the UA-value of the radiator, and n is + an exponent for the heat transfer. The model computes the UA-value by + numerically solving the above equations for given nominal heating + power, nominal temperatures, fraction radiant to total heat transfer + and exponent for heat transfer. +

    +

    + The parameter energyDynamics (in the Assumptions tab), + determines whether the model computes the dynamic or the steady-state + response. For the transient response, heat storage is computed using + a finite volume approach for the water and the metal mass, which are + both assumed to be at the same temperature. +

    +

    + The default parameters for the heat capacities are valid for a flat + plate radiator without fins, with one plate of water carying fluid, + and a height of 0.42 meters.

    -

    - References -

    - + +-------- Errors -------- +line 26 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Sources/Outside_CpData.mo ---- +-------- HTML Code -------- + +

    + This model describes boundary conditions for + pressure, enthalpy, and species concentration that can be obtained + from weather data. The model is identical to + + AixLib.Fluid.Sources.Outside, + except that it adds the wind pressure to the + pressure at the fluid ports ports. +

    +

    + The pressure p at the fluid ports is computed as: +

    +

    + p = pw + Cp,act Cs v2 ρ ⁄ 2, +

    +

    + where pw is the atmospheric pressure from the weather bus, + v is the wind speed from the weather bus, and + ρ is the fluid density. +

    +

    + The wind pressure coefficient Cp,act is a function of the surface wind incidence + angle and is defined relative to the surface azimuth (normal to the surface is 0). + The wind incidence angle incAng is computed from the wind direction obtained from the weather file + with the surface azimuth azi as the base of the angle. + The relation between the wind pressure coefficient Cp,act and the incidence angle incAng + is defined by a cubic hermite interpolation of the users table input. + Typical table values can be obtained from the "AIVC guide to energy efficient ventilation", + appendix 2 (1996). The default table is appendix 2, table 2.2, face 1. +

    +

    + The wind speed modifier Cs can be used to incorporate the effect of the surroundings on the local wind speed. +

    +

    Definition of angles

    +

    + The angles incAngSurNor for the wind incidence angle relative to the surface normal + are measured counter-clock wise. + The figure below shows an example entry, which is also used in the model + + AixLib.Fluid.Sources.Examples.Outside_CpData_Specification. +

    +

    \"image\"

    + +

    + The wind incidence angle and surface azimuths are defined as follows: + The wind indicience angle is obtained directly from the weather data bus weaBus.winDir. + This variable contains the data from the weather data file that was read, such as a TMY3 file. + In accordance to TMY3, the data is as shown in the table below. +

    +
    + + + + +
    Value of winDir if the wind blows from different directions.
    Wind from North:
    0
    Wind from West:
    3π/2
    270°
    Wind from East:
    π/2
    90°
    Wind from South:
    π
    180°
    +

    + For the surface azimuth azi, the specification from + AixLib.Types.Azimuth is + used, which is as shown in the table below. +

    + + + + + + +
    Value of azi if the exterior wall faces in the different directions.
    Wall facing north:
    π
    180°
    Wall facing West:
    π/2
    90°
    Wall facing east:
    3π/2
    270°
    Wall facing South:
    0;
    + +

    Related model

    +

    + This model differs from + AixLib.Fluid.Sources.Outside_CpLowRise by the calculation of the wind pressure coefficient + Cp,act. + The wind pressure coefficient is defined by a user-defined table instead of a generalized equation + such that it can be used for all building sizes and situations, for shielded buildings, + and for buildings with non-rectangular shapes. +

    +

    + References +

    + + + + +-------- Corrected Code -------- +

    + This model describes boundary conditions for pressure, enthalpy, and + species concentration that can be obtained from weather data. The + model is identical to AixLib.Fluid.Sources.Outside, + except that it adds the wind pressure to the pressure at the fluid + ports ports. +

    +

    + The pressure p at the fluid ports is computed as: +

    +

    + p = pw + Cp,act Cs v2 ρ ⁄ + 2, +

    +

    + where pw is the atmospheric pressure from the + weather bus, v is the wind speed from the weather bus, and + ρ is the fluid density. +

    +

    + The wind pressure coefficient Cp,act is a function + of the surface wind incidence angle and is defined relative to the + surface azimuth (normal to the surface is 0). The wind + incidence angle incAng is computed from the wind + direction obtained from the weather file with the surface azimuth + azi as the base of the angle. The relation between the + wind pressure coefficient Cp,act and the incidence + angle incAng is defined by a cubic hermite interpolation + of the users table input. Typical table values can be obtained from + the \"AIVC guide to energy efficient ventilation\", appendix 2 (1996). + The default table is appendix 2, table 2.2, face 1. +

    +

    + The wind speed modifier Cs can be used to + incorporate the effect of the surroundings on the local wind speed. +

    +

    + Definition of angles +

    +

    + The angles incAngSurNor for the wind incidence angle + relative to the surface normal are measured counter-clock wise. The + figure below shows an example entry, which is also used in the model + + AixLib.Fluid.Sources.Examples.Outside_CpData_Specification. +

    +

    + \"image\" +

    +

    + The wind incidence angle and surface azimuths are defined as follows: + The wind indicience angle is obtained directly from the weather data + bus weaBus.winDir. This variable contains the data from + the weather data file that was read, such as a TMY3 file. In + accordance to TMY3, the data is as shown in the table below. +

    + + + + + + + + + + + + + + + + + +
    + Value of winDir if the wind blows from different + directions. +
    + Wind from North:
    + 0
    + 0° +
    + Wind from West:
    + 3π/2
    + 270° +
    + Wind from East:
    + π/2
    + 90° +
    + Wind from South:
    + π
    + 180° +
    +

    + For the surface azimuth azi, the specification from + AixLib.Types.Azimuth is + used, which is as shown in the table below. +

    + + + + + + + + + + + + + + + + + +
    + Value of azi if the exterior wall faces in the + different directions. +
    + Wall facing north:
    + π
    + 180° +
    + Wall facing West:
    + π/2
    + 90° +
    + Wall facing east:
    + 3π/2
    + 270° +
    + Wall facing South:
    + 0;
    + 0° +
    +

    + Related model +

    +

    + This model differs from AixLib.Fluid.Sources.Outside_CpLowRise + by the calculation of the wind pressure coefficient + Cp,act. The wind pressure coefficient is defined by + a user-defined table instead of a generalized equation such that it + can be used for all building sizes and situations, for shielded + buildings, and for buildings with non-rectangular shapes. +

    +

    + References +

    + + + +-------- Errors -------- +line 51 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 63 column 2 - Warning: The summary attribute on the
    element is obsolete in HTML5 +line 14 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 43 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/HeatPumps/Compressors/ScrollCompressor.mo ---- +-------- HTML Code -------- + +

    + Model for a scroll processor, as detailed in Jin (2002). The rate of heat transferred to the evaporator is given by: +

    +

    + Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ). +

    +

    + The power consumed by the compressor is given by a linear efficiency relation: +

    +

    + P = PTheoretical / η + PLoss,constant. +

    +

    + Variable speed is achieved by multiplying the full load suction volume flow rate + by the normalized compressor speed. The power and heat transfer rates are forced + to zero if the resulting heat pump state has higher evaporating pressure than + condensing pressure. +

    +

    Assumptions and limitations

    +

    + The compression process is assumed isentropic. The thermal energy + of superheating is ignored in the evaluation of the heat transferred to the refrigerant + in the evaporator. There is no supercooling. +

    +

    References

    +

    + H. Jin. + + Parameter estimation based models of water source heat pumps. + + PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002. +

    + + + +-------- Corrected Code -------- +

    + Model for a scroll processor, as detailed in Jin (2002). The rate of + heat transferred to the evaporator is given by: +

    +

    + Q̇Eva = ṁref ( + hVap(TEva) - hLiq(TCon) + ). +

    +

    + The power consumed by the compressor is given by a linear efficiency + relation: +

    +

    + P = PTheoretical / η + PLoss,constant. +

    +

    + Variable speed is achieved by multiplying the full load suction + volume flow rate by the normalized compressor speed. The power and + heat transfer rates are forced to zero if the resulting heat pump + state has higher evaporating pressure than condensing pressure. +

    +

    + Assumptions and limitations +

    +

    + The compression process is assumed isentropic. The thermal energy of + superheating is ignored in the evaluation of the heat transferred to + the refrigerant in the evaporator. There is no supercooling. +

    +

    + References +

    +

    + H. Jin. Parameter estimation based models of water source heat + pumps. PhD Thesis. Oklahoma State University. Stillwater, + Oklahoma, USA. 2002. +

    + -------- Errors -------- -line 24 column 2 - Warning: The summary attribute on the
    element is obsolete in HTML5 -line 425 column 2 - Warning: The summary attribute on the
    element is obsolete in HTML5 -line 469 column 2 - Warning: The summary attribute on the
    element is obsolete in HTML5 -line 640 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/ExportContainers/HVACZones.mo ---- +---- AixLib/Fluid/HeatExchangers/PrescribedOutlet.mo ---- -------- HTML Code --------

    - Model that is used as a container for an HVAC system that is - to be exported as an FMU and that serves multiple zones. + Model that allows specifying the temperature and mass fraction of the fluid + that leaves the model from port_b.

    -

    Typical use and important parameters

    - To use this model as a container for an FMU, simply extend - from this model, rather than instantiate it, - and add your HVAC system. By extending from this model, the top-level - signal connectors on the right stay at the top-level, and hence - will be visible at the FMI interface. - The example - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones - shows how a simple HVAC system that serves two rooms can be implemented and exported as - an FMU. - + This model forces the outlet temperature at port_b to be equal to the temperature + of the input signal TSet, subject to optional limits on the + heating or cooling capacity QMax_flow ≥ 0 and QMin_flow ≤ 0. + Similarly than for the temperature, + this model also forces the outlet water mass fraction at port_b to be + no lower than the + input signal X_wSet, subject to optional limits on the + maximum water vapor mass flow rate that is added, as + described by the parameter mWatMax_flow. + By default, the model has unlimited capacity, but control of temperature + and humidity can be subject to capacity limits, or be disabled.

    - The following two parameters need to be assigned by the user: - Set nZon to the number of thermal zones to which the - FMU will be connected. - Set nPorts to the largest number of fluid ports - that the thermal zones has. For example, - if nZon=2 and zone 1 has one inlet and one outlet - (hence it has 2 ports), - and zone 2 has one inlets and two outlets - (hence it has 3 ports), then - set nPorts=3. This will add more fluid ports than are needed - for zone 1, but this causes no overhead if they are not connected. + The output signal Q_flow is the heat added (for heating) or subtracted (for cooling) + to the medium if the flow rate is from port_a to port_b. + If the flow is reversed, then Q_flow=0.

    - The conversion between the fluid ports and signal ports is done - in the HVAC adapter hvacAda. - This adapter has a vector of fluid ports called ports. - The supply and return air ducts, including any resistance model for the inlet - diffusor or exhaust grill, need to be connected to these ports. - Also, if a thermal zone has interzonal air exchange or air infiltration, - these flows need to be connected to ports. - This model outputs at the port fluPor the mass flow rate for - each flow that is connected to ports, together with its - temperature, water vapor mass fraction per total mass of the air (not per kg dry - air), and trace substances. These quantities are always as if the flow - enters the room, even if the flow is zero or negative. - If a medium has no moisture, e.g., if Medium.nXi=0, or - if it has no trace substances, e.g., if Medium.nC=0, then - the output signal for these properties are removed. - These quantities are always as if the flow - enters the room, even if the flow is zero or negative. - Thus, a thermal zone model that uses these signals to compute the - heat added by the HVAC system need to implement an equation such as + The outlet conditions at port_a are not affected by this model. +

    +

    + If the parameter energyDynamics is not equal to + Modelica.Fluid.Types.Dynamics.SteadyState, + the component models the dynamic response using a first order differential equation. + The time constant of the component is equal to the parameter tau. + This time constant is adjusted based on the mass flow rate using

    - Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), + τeff = τ |ṁ| ⁄ ṁnom

    where - Qsen is the sensible heat flow rate added to the thermal zone, - sup is the supply air mass flow rate from - the port fluPor (which is negative if it is an exhaust), - cp is the specific heat capacity at constant pressure, - Tsup is the supply air temperature and - Tair,zon is the zone air temperature. - Note that without the max(·, ·), the energy - balance would be wrong. + τeff is the effective time constant for the given mass flow rate + and + τ is the time constant at the nominal mass flow rate + nom. + This type of dynamics is equal to the dynamics that a completely mixed + control volume would have.

    -

    - The input signals of this model are the radiative temperature of each zone. - The the zone air temperatures, - the water vapor mass fractions per total mass of the air (unless Medium.nXi=0) - and trace substances (unless Medium.nC=0) are obtained from the connector - fluPor.backward. - The outflowing fluid stream(s) at the port ports will be at the - states obtained from fluPor.backward. - For any given izon ∈ {1, ..., nzon}, - for each iports ∈ {1, ..., nports} - all fluid streams at port ports[izon, iports] are at the same - pressure. - For convenience, the instance hvacAda also outputs the - properties obtained from fluPor.backward. These can be used - to connect a controller. The properties are available for each flow path in - fluPor.backward. For a thermal zone with mixed air, these are - all equal, while for a stratified room model, they can be different. + Optionally, this model can have a flow resistance. + If no flow resistance is requested, set dp_nominal=0.

    - See - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones - for a model that uses this model. + For a model that uses a control signal u ∈ [0, 1] and multiplies + this with the nominal heating or cooling power, use + + AixLib.Fluid.HeatExchangers.HeaterCooler_u +

    +

    Limitations

    - For models that only have one thermal zone connected to the HVAC system, - use the simpler model - - AixLib.Fluid.FMI.ExportContainers.HVACZone. + This model only adds or removes heat or water vapor for the flow from + port_a to port_b. + The enthalpy of the reverse flow is not affected by this model.

    -

    Assumption and limitations

    - The mass flow rates at ports sum to zero, hence this - model conserves mass for each thermal zone. + If this model is used to cool air below the dew point temperature, the water mass fraction + will not change.

    - This model does not impose any pressure, other than, - for any given izon ∈ {1, ..., nzon} and - for each j,k ∈ {1, ..., nports}, - setting the pressure of ports[izon, j].p = ports[izon, k].p - to be the same. - The reason is that setting a pressure can lead to non-physical system models, - for example if a mass flow rate is imposed and the HVAC system is connected - to a model that sets a pressure boundary condition such as - - AixLib.Fluid.Sources.Outside. - Also, setting a pressure would make it impossible to use multiple instances - of this model (one for each thermal zone) and build in Modelica an airflow network - model with pressure driven mass flow rates. + Note that for use_TSet = false, the enthalpy of the leaving fluid + will not be changed, even if moisture is added. The enthalpy added (or removed) + by the change in humidity is neglected. To properly account for change in enthalpy + due to humidification, use instead + + AixLib.Fluid.Humidifiers.SprayAirWasher_X.

    +

    Validation

    - The model has no pressure drop. Hence, the pressure drop - of an air diffuser or of an exhaust grill needs to be modelled - in models that are connected to ports. + The model has been validated against the analytical solution in + the examples + + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet + and + + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic.

    -------- Corrected Code --------

    - Model that is used as a container for an HVAC system that is to be - exported as an FMU and that serves multiple zones. + Model that allows specifying the temperature and mass fraction of the + fluid that leaves the model from port_b.

    -

    - Typical use and important parameters -

    - To use this model as a container for an FMU, simply extend from this - model, rather than instantiate it, and add your HVAC system. By - extending from this model, the top-level signal connectors on the - right stay at the top-level, and hence will be visible at the FMI - interface. The example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones shows - how a simple HVAC system that serves two rooms can be implemented and - exported as an FMU. + This model forces the outlet temperature at port_b to be + equal to the temperature of the input signal TSet, + subject to optional limits on the heating or cooling capacity + QMax_flow ≥ 0 and QMin_flow ≤ 0. Similarly + than for the temperature, this model also forces the outlet water + mass fraction at port_b to be no lower than the input + signal X_wSet, subject to optional limits on the maximum + water vapor mass flow rate that is added, as described by the + parameter mWatMax_flow. By default, the model has + unlimited capacity, but control of temperature and humidity can be + subject to capacity limits, or be disabled.

    - The following two parameters need to be assigned by the user: Set - nZon to the number of thermal zones to which the FMU - will be connected. Set nPorts to the largest number of - fluid ports that the thermal zones has. For example, if - nZon=2 and zone 1 has one inlet and one outlet - (hence it has 2 ports), and zone 2 has one inlets and two - outlets (hence it has 3 ports), then set nPorts=3. This - will add more fluid ports than are needed for zone 1, but this - causes no overhead if they are not connected. + The output signal Q_flow is the heat added (for heating) + or subtracted (for cooling) to the medium if the flow rate is from + port_a to port_b. If the flow is reversed, + then Q_flow=0.

    - The conversion between the fluid ports and signal ports is done in - the HVAC adapter hvacAda. This adapter has a vector of - fluid ports called ports. The supply and return air - ducts, including any resistance model for the inlet diffusor or - exhaust grill, need to be connected to these ports. Also, if a - thermal zone has interzonal air exchange or air infiltration, these - flows need to be connected to ports. This model outputs - at the port fluPor the mass flow rate for each flow that - is connected to ports, together with its temperature, - water vapor mass fraction per total mass of the air (not per kg dry - air), and trace substances. These quantities are always as if the - flow enters the room, even if the flow is zero or negative. If a - medium has no moisture, e.g., if Medium.nXi=0, or if it - has no trace substances, e.g., if Medium.nC=0, then the - output signal for these properties are removed. These quantities are - always as if the flow enters the room, even if the flow is zero or - negative. Thus, a thermal zone model that uses these signals to - compute the heat added by the HVAC system need to implement an - equation such as + The outlet conditions at port_a are not affected by this + model. +

    +

    + If the parameter energyDynamics is not equal to + Modelica.Fluid.Types.Dynamics.SteadyState, the component + models the dynamic response using a first order differential + equation. The time constant of the component is equal to the + parameter tau. This time constant is adjusted based on + the mass flow rate using

    - Qsen = max(0, ṁsup)   cp   - (Tsup - Tair,zon), + τeff = τ |ṁ| ⁄ ṁnom

    - where Qsen is the sensible heat flow rate added to - the thermal zone, sup is the supply air mass flow - rate from the port fluPor (which is negative if it is an - exhaust), cp is the specific heat capacity at - constant pressure, Tsup is the supply air - temperature and Tair,zon is the zone air - temperature. Note that without the max(·, ·), the energy - balance would be wrong. + where τeff is the effective time constant for the + given mass flow rate and τ is the time constant at + the nominal mass flow rate nom. This type of + dynamics is equal to the dynamics that a completely mixed control + volume would have.

    - The input signals of this model are the radiative temperature of each - zone. The the zone air temperatures, the water vapor mass fractions - per total mass of the air (unless Medium.nXi=0) and - trace substances (unless Medium.nC=0) are obtained from - the connector fluPor.backward. The outflowing fluid - stream(s) at the port ports will be at the states - obtained from fluPor.backward. For any given - izon ∈ {1, ..., nzon}, for each - iports ∈ {1, ..., nports} all fluid - streams at port ports[izon, - iports] are at the same pressure. For convenience, - the instance hvacAda also outputs the properties - obtained from fluPor.backward. These can be used to - connect a controller. The properties are available for each flow path - in fluPor.backward. For a thermal zone with mixed air, - these are all equal, while for a stratified room model, they can be - different. + Optionally, this model can have a flow resistance. If no flow + resistance is requested, set dp_nominal=0.

    - See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones for a - model that uses this model. + For a model that uses a control signal u ∈ [0, 1] and + multiplies this with the nominal heating or cooling power, use + AixLib.Fluid.HeatExchangers.HeaterCooler_u

    +

    + Limitations +

    - For models that only have one thermal zone connected to the HVAC - system, use the simpler model AixLib.Fluid.FMI.ExportContainers.HVACZone. + This model only adds or removes heat or water vapor for the flow from + port_a to port_b. The enthalpy of the + reverse flow is not affected by this model. +

    +

    + If this model is used to cool air below the dew point temperature, + the water mass fraction will not change. +

    +

    + Note that for use_TSet = false, the enthalpy of the + leaving fluid will not be changed, even if moisture is added. The + enthalpy added (or removed) by the change in humidity is neglected. + To properly account for change in enthalpy due to humidification, use + instead AixLib.Fluid.Humidifiers.SprayAirWasher_X.

    - Assumption and limitations + Validation

    - The mass flow rates at ports sum to zero, hence this - model conserves mass for each thermal zone. -

    -

    - This model does not impose any pressure, other than, for any given - izon ∈ {1, ..., nzon} and for each - j,k ∈ {1, ..., nports}, setting the pressure of - ports[izon, j].p = ports[izon, - k].p to be the same. The reason is that setting a pressure can - lead to non-physical system models, for example if a mass flow rate - is imposed and the HVAC system is connected to a model that sets a - pressure boundary condition such as AixLib.Fluid.Sources.Outside. - Also, setting a pressure would make it impossible to use multiple - instances of this model (one for each thermal zone) and build in - Modelica an airflow network model with pressure driven mass flow - rates. -

    -

    - The model has no pressure drop. Hence, the pressure drop of an air - diffuser or of an exhaust grill needs to be modelled in models that - are connected to ports. + The model has been validated against the analytical solution in the + examples AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet + and + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic.

    -------- Errors -------- -line 60 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 34 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowULg.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/LoadAggregation/Validation/ShiftAggregationCells.mo ---- -------- HTML Code --------

    - The example contains - experimental data from a real district heating network. -

    -

    - This model compares the results with the original Modelica Standard Library pipes. + This validation case replicates the load-shifting procedure illustred in the figure below by Cimmino (2014).

    -

    The pipes' temperatures are not initialized. Therefore, results of - outflow temperature before approximately the first 10000 seconds should not be - considered. +

    + \"image\"

    -

    Test bench schematic

    -

    \"Schematic

    -

    Calibration

    +

    References

    - There are some uncertainties about the heat loss coefficient between pipe and - surrounding air as well as regarding the heat conductivity of the insulation - material. - With the - given data, the length specific thermal resistance is R = 2.164 - ((m K)/W), calculated as follows: + Cimmino, M. 2014. Développement et validation expérimentale de facteurs de réponse + thermique pour champs de puits géothermiques, + Ph.D. Thesis, École Polytechnique de Montréal.

    -

    - R=((1/(2*pipe.kIns)*log((0.0603+2*pipe.dIns)/(0.0603)))+1/(5*(0.0603+2*pipe.dIns)))/Modelica.Constants.pi

    -

    - U = 1/R = 0.462 W/(m K)

    -------- Corrected Code --------

    - The example contains experimental data from a real district heating - network. -

    -

    - This model compares the results with the original Modelica Standard - Library pipes. -

    -

    - The pipes' temperatures are not initialized. Therefore, results of - outflow temperature before approximately the first 10000 seconds - should not be considered. + This validation case replicates the load-shifting procedure illustred + in the figure below by Cimmino (2014).

    -

    - Test bench schematic -

    -

    - \"Schematic +

    + \"image\"

    - Calibration + References

    - There are some uncertainties about the heat loss coefficient between - pipe and surrounding air as well as regarding the heat conductivity - of the insulation material. With the - given data, the length specific thermal resistance is R = - 2.164 ((m K)/W), calculated as follows: -

    -

    - R=((1/(2*pipe.kIns)*log((0.0603+2*pipe.dIns)/(0.0603)))+1/(5*(0.0603+2*pipe.dIns)))/Modelica.Constants.pi -

    -

    - U = 1/R = 0.462 W/(m K) + Cimmino, M. 2014. Développement et validation expérimentale de + facteurs de réponse thermique pour champs de puits géothermiques, + Ph.D. Thesis, École Polytechnique de Montréal.

    -------- Errors -------- -line 25 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 27 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Controls/Continuous/NumberOfRequests.mo ---- +---- AixLib/Utilities/Math/Functions/biquadratic.mo ---- -------- HTML Code -------- -

    - Block that outputs the number of inputs that exceed a threshold. - The parameter kind is used to determine the kind of the - inequality. The table below shows the allowed settings. -

    -
    - - - - - - - - - - - - - - - - - - - - -
    Value of parameter kindOutput signal incremented by 1 for each i ∈ {1, ..., nin} if
    0u[i] > threShold
    1u[i] ≥ threShold
    2u[i] ≤ threShold
    3u[i] < threShold
    -

    - This model may be used to check how many rooms - exceed a temperature threshold. + This function computes +

    + y = a1 + a2 x1 + + a3 x12 + + a4 x2 + a5 x22 + + a6 x1 x2

    -------- Corrected Code -------- -

    - Block that outputs the number of inputs that exceed a threshold. The - parameter kind is used to determine the kind of the - inequality. The table below shows the allowed settings. -

    - - - - - - - - - - - - - - - - - - - - - -
    - Value of parameter kind - - Output signal incremented by 1 for each i ∈ {1, ..., nin} - if -
    - 0 - - u[i] > threShold -
    - 1 - - u[i] ≥ threShold -
    - 2 - - u[i] ≤ threShold -
    - 3 - - u[i] < threShold -
    -

    - This model may be used to check how many rooms exceed a temperature - threshold. +This function computes +

    + y = a1 + a2 x1 + a3 + x12 + a4 x2 + + a5 x22 + a6 x1 + x2

    -------- Errors -------- -line 7 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/Junction.mo ---- +---- AixLib/Media/Antifreeze/EthyleneGlycolWater.mo ---- -------- HTML Code -------- +

    + This base properties model is identical to + + Modelica.Media.Water.ConstantPropertyLiquidWater, + except that the equation + u = cv_const*(T - reference_T) + has been replaced by u=h because + cp_const=cv_const. + Also, the model checks if the mass fraction of the mixture is within the + allowed limits. +

    + +

    + Density of propylene antifreeze-water mixture at specified mass fraction + and temperature, based on Melinder (2010). +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + +

    - Model of a flow junction with an optional fixed resistance in each flow leg - and an optional mixing volume at the junction. + Dynamic viscosity of antifreeze-water mixture at specified mass fraction and + temperature, based on Melinder (2010).

    +

    References

    - The pressure drop is implemented using the model - - AixLib.Fluid.FixedResistances.PressureDrop. - If its nominal pressure drop is set to zero, then the pressure drop - model will be removed. - For example, the pressure drop declaration + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF.

    -
    -   m_flow_nominal={ 0.1, 0.1,  -0.2},
    -   dp_nominal =   {500,    0, -6000}
    - 
    + + +

    - would model a flow mixer that has the nominal flow rates and associated pressure drops - as shown in the figure below. Note that port_3 is set to negative values. - The negative values indicate that at the nominal conditions, fluid is leaving the component. + Fusion temperature of antifreeze-water mixture at specified mass fraction and + temperature, based on Melinder (2010).

    -

    - \"image\" +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF.

    + + +

    - If - energyDynamics <> Modelica.Fluid.Types.Dynamics.SteadyState, - then at the flow junction, a fluid volume is modeled. - The fluid volume is implemented using the model - - AixLib.Fluid.Delays.DelayFirstOrder. - The fluid volume has the size + Evaluates a thermophysical property of a mixture, based on correlations proposed + by Melinder (2010).

    -
    -   V = sum(abs(m_flow_nominal[:])/3)*tau/rho_nominal
    - 

    - where tau is a parameter and rho_nominal is the density - of the medium in the volume at nominal condition. - Setting energyDynamics=Modelica.Fluid.Types.Dynamics.FixedInitial - can help reducing the size of the nonlinear - system of equations. + The polynomial has the form +

    +

    + f = a1 (x-xm)0(y-ym)0 + + a2 (x-xm)0(y-ym)1 + + ... + + any[1] (x-xm)0(y-ym)ny[1]-1 + + ... + + any[1])+1 (x-xm)1(y-ym)0 + + ... + + any[1]+ny[2] (x-xm)1(y-ym)ny[2]-1 + + ... +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF.

    + +

    + Specific heat capacity of antifreeze-water mixture at specified mass fraction + and temperature, based on Melinder (2010). +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + + +

    + Thermal conductivity of antifreeze-water mixture at specified mass fraction and + temperature, based on Melinder (2010). +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + + +

    + This medium package models ethylene glycol - water mixtures. +

    +

    + The mass density, specific heat capacity, thermal conductivity and viscosity + are assumed constant and evaluated at a set temperature and mass fraction of + ethylene glycol within the mixture. The dependence of the four properties + are shown on the figure below. +

    +

    + \"Relative +

    +

    + The accuracy of the thermophysical properties is dependent on the temperature + variations encountered during simulations. + The figure below shows the relative error of the the four properties over a + 10 °C range around the temperature used to evaluate the constant + properties. The maximum errors are 0.8 % for mass density, 2.7 % + for specific heat capacity, 3.2 % for thermal conductivity and 160 + % for dynamic viscosity. +

    +

    + \"Relative +

    +

    + The figure below shows the relative error of the the four properties over a + 20 °C range around the temperature used to evaluate the constant + proepties. The maximum errors are 1.5 % for mass density, 5.3 % + for specific heat capacity, 5.9 % for thermal conductivity and 500 + % for dynamic viscosity. +

    +

    + \"Relative +

    +

    + The enthalpy is computed using the convention that h=0 + if T=0 °C. +

    +

    Limitations

    +

    + Density, specific heat capacity, thermal conductivity and viscosity are constant. + The ethylene glycol/water mixture is modeled as an incompressible liquid. + There are no phase changes. The medium is limited to temperatures below + 100 °C and mass fractions below 0.60. + As is the case for AixLib.Media.Water, + this medium package should not be used if + the simulation relies on the dynamic viscosity. +

    +

    Typical use and important parameters

    +

    + The temperature and mass fraction must be specified for the evaluation of the + constant thermophysical properties. A typical use of the package is (e.g. for + a temperature of 20 °C and a mass fraction of 0.40): +

    +

    + Medium = AixLib.Media.Antifreeze.EthyleneGlycolWater(property_T=293.15, X_a=0.40) +

    + + -------- Corrected Code --------

    - Model of a flow junction with an optional fixed resistance in each - flow leg and an optional mixing volume at the junction. -

    -

    - The pressure drop is implemented using the model AixLib.Fluid.FixedResistances.PressureDrop. - If its nominal pressure drop is set to zero, then the pressure drop - model will be removed. For example, the pressure drop declaration -

    -
    -   m_flow_nominal={ 0.1, 0.1,  -0.2},
    -   dp_nominal =   {500,    0, -6000}
    - 
    -

    - would model a flow mixer that has the nominal flow rates and - associated pressure drops as shown in the figure below. Note that - port_3 is set to negative values. The negative values - indicate that at the nominal conditions, fluid is leaving the - component. -

    -

    - \"image\" + This base properties model is identical to Modelica.Media.Water.ConstantPropertyLiquidWater, + except that the equation u = cv_const*(T - reference_T) + has been replaced by u=h because + cp_const=cv_const. Also, the model checks if the mass + fraction of the mixture is within the allowed limits.

    - If energyDynamics <> - Modelica.Fluid.Types.Dynamics.SteadyState, then at the flow - junction, a fluid volume is modeled. The fluid volume is implemented - using the model AixLib.Fluid.Delays.DelayFirstOrder. - The fluid volume has the size + Density of propylene antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    -
    -   V = sum(abs(m_flow_nominal[:])/3)*tau/rho_nominal
    - 
    +

    + References +

    - where tau is a parameter and rho_nominal is - the density of the medium in the volume at nominal condition. Setting - energyDynamics=Modelica.Fluid.Types.Dynamics.FixedInitial - can help reducing the size of the nonlinear system of equations. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    - --------- Errors -------- -line 23 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/BoundaryConditions/UsersGuide.mo ---- --------- HTML Code -------- - -

    This package contains models to read or compute boundary conditions, such as weather data, solar irradition and sky temperatures. -The calculations follow the description in Wetter (2004), Appendix A.4.2.

    -

    Accessing weather data

    -

    -The model - -AixLib.BoundaryConditions.WeatherData.ReaderTMY3 -can read TMY3 weather data for different locations. -The documentation of that model explains how to add -weather data for locations that are not distributed with the -AixLib library. -

    -To access these weather data from the graphical model editor, -proceed as follows: + Dynamic viscosity of antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    -
      -
    1. +

      + References +

      -Create an instance of - -AixLib.BoundaryConditions.WeatherData.ReaderTMY3. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

      -
    2. -
    3. +

      -Create an instance of - -AixLib.BoundaryConditions.WeatherData.Bus. + Fusion temperature of antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

      -
    4. -
    5. +

      + References +

      -Draw a connection between these two instances. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

      -
    6. -
    7. +

      -Finally, to send weather data to an input connector of a model, -connect the input connector of that model with the instance of - -AixLib.BoundaryConditions.WeatherData.Bus. -Some models connect to the whole weather data bus, such as - -AixLib.BoundaryConditions.SolarGeometry.Examples.IncidenceAngle, -in which case the connection will directly be drawn. -Other models require only an individual signal from the weather data bus, -such as - -AixLib.BoundaryConditions.SkyTemperature.Examples.BlackBody. -In this situation, Modelica modeling environments typically show a window that allows you to -select what data from this weather data bus you want to connect -with your model. + Evaluates a thermophysical property of a mixture, based on + correlations proposed by Melinder (2010).

      -
    8. -
    -

    Conventions for surface azimuth and tilt

    -

    To compute the solar irradiation, parameters such as the surface azimuth and the surface tilt are defined as shown in the following three figures.

    -

    \"image\"

    -

    \"image\"

    -

    \"image\"

    -For the surface azimuth and tilt, the enumerations - -AixLib.Types.Azimuth -and - -AixLib.Types.Tilt -can be used. + The polynomial has the form

    -

    -Note that a ceiling has a tilt of 0 - -if they are facing straight upwards. -This is correct because -the solar irradiation on a ceiling construction is on the other-side surface, -which faces upwards toward the sky. Hence, a construction is considered -a ceiling from the view point of a person standing inside a room. +

    + f = a1 (x-xm)0(y-ym)0 + + a2 (x-xm)0(y-ym)1 + ... + + any[1] (x-xm)0(y-ym)ny[1]-1 + ... + + any[1])+1 (x-xm)1(y-ym)0 + ... + + any[1]+ny[2] (x-xm)1(y-ym)ny[2]-1 + + ... +

    +

    + References +

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    - -

    References

    - --------- Corrected Code --------

    - This package contains models to read or compute boundary conditions, - such as weather data, solar irradition and sky temperatures. The - calculations follow the description in Wetter (2004), Appendix A.4.2. + Specific heat capacity of antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    - Accessing weather data + References

    - The model AixLib.BoundaryConditions.WeatherData.ReaderTMY3 - can read TMY3 weather data for different locations. The documentation - of that model explains how to add weather data for locations that are - not distributed with the AixLib library. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    +

    - To access these weather data from the graphical model editor, proceed - as follows: + Thermal conductivity of antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    -
      -
    1. -

      - Create an instance of AixLib.BoundaryConditions.WeatherData.ReaderTMY3. -

      -
    2. -
    3. -

      - Create an instance of AixLib.BoundaryConditions.WeatherData.Bus. -

      -
    4. -
    5. -

      - Draw a connection between these two instances. -

      -
    6. -
    7. -

      - Finally, to send weather data to an input connector of a model, - connect the input connector of that model with the instance of - AixLib.BoundaryConditions.WeatherData.Bus. - Some models connect to the whole weather data bus, such as - - AixLib.BoundaryConditions.SolarGeometry.Examples.IncidenceAngle, - in which case the connection will directly be drawn. Other models - require only an individual signal from the weather data bus, such - as - AixLib.BoundaryConditions.SkyTemperature.Examples.BlackBody. - In this situation, Modelica modeling environments typically show - a window that allows you to select what data from this weather - data bus you want to connect with your model. -

      -
    8. -

    - Conventions for surface azimuth and tilt + References

    - To compute the solar irradiation, parameters such as the surface - azimuth and the surface tilt are defined as shown in the following - three figures. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF. +

    + +

    + This medium package models ethylene glycol - water mixtures. +

    +

    + The mass density, specific heat capacity, thermal conductivity and + viscosity are assumed constant and evaluated at a set temperature and + mass fraction of ethylene glycol within the mixture. The dependence + of the four properties are shown on the figure below.

    - \"image\" + + +

    +

    + The accuracy of the thermophysical properties is dependent on the + temperature variations encountered during simulations. The figure + below shows the relative error of the the four properties over a + 10 °C range around the temperature used to evaluate the + constant properties. The maximum errors are 0.8 % for mass + density, 2.7 % for specific heat capacity, 3.2 % for + thermal conductivity and 160 % for dynamic viscosity.

    - \"image\" + + +

    +

    + The figure below shows the relative error of the the four properties + over a 20 °C range around the temperature used to evaluate the + constant proepties. The maximum errors are 1.5 % for mass + density, 5.3 % for specific heat capacity, 5.9 % for + thermal conductivity and 500 % for dynamic viscosity.

    - \"image\" + +

    - For the surface azimuth and tilt, the enumerations AixLib.Types.Azimuth and - AixLib.Types.Tilt can be - used. + The enthalpy is computed using the convention that h=0 if + T=0 °C.

    +

    + Limitations +

    - Note that a ceiling has a tilt of 0 - if they are facing straight upwards. This is correct because the - solar irradiation on a ceiling construction is on the other-side - surface, which faces upwards toward the sky. Hence, a construction is - considered a ceiling from the view point of a person standing inside - a room. + Density, specific heat capacity, thermal conductivity and viscosity + are constant. The ethylene glycol/water mixture is modeled as an + incompressible liquid. There are no phase changes. The medium is + limited to temperatures below 100 °C and mass fractions below + 0.60. As is the case for AixLib.Media.Water, this medium + package should not be used if the simulation relies on the dynamic + viscosity.

    - References + Typical use and important parameters

    - - --------- Errors -------- -line 60 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 61 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 62 column 1 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Utilities/Math/Functions/polynomial.mo ---- --------- HTML Code -------- - - This function computes a polynomial of arbitrary order. - The polynomial has the form -

    - y = a1 + a2 x + a3 x2 + ... -

    - - - --------- Corrected Code -------- -This function computes a polynomial of arbitrary order. The polynomial -has the form -

    - y = a1 + a2 x + a3 x2 + - ... +

    + The temperature and mass fraction must be specified for the + evaluation of the constant thermophysical properties. A typical use + of the package is (e.g. for a temperature of 20 °C and a mass + fraction of 0.40): +

    +

    + Medium = + AixLib.Media.Antifreeze.EthyleneGlycolWater(property_T=293.15, + X_a=0.40)

    -------- Errors -------- -line 4 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 9 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 24 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 35 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/infiniteLineSource.mo ---- +---- AixLib/Fluid/Humidifiers/SprayAirWasher_X.mo ---- -------- HTML Code --------

    - This function evaluates the infinite line source solution. This solution gives - the relation between the constant heat transfer rate (per unit length) injected - by a line heat source of infinite length and the temperature raise in the - medium. The infinite line source solution is defined by + Model for a spray air washer with a prescribed outlet water vapor mass fraction + in kg/kg total air.

    -

    - \"image\" +

    + This model forces the outlet water mass fraction at port_b to be + no lower than the + input signal X_wSet, subject to optional limits on the + maximum water vapor mass flow rate that is added, as + described by the parameter mWatMax_flow. + By default, the model has unlimited capacity.

    - where ΔT(t,r) is the temperature raise after a time t of - constant heat injection and at a distance r from the line source, - Q' is the heat injection rate per unit length, ks is - the soil thermal conductivity and hILS is the infinite line - source solution. + The output signal mWat_flow ≥ 0 is the moisture added + to the medium if the flow rate is from port_a to port_b. + If the flow is reversed, then mWat_flow = 0. + The outlet specific enthalpy at port_b is increased by + the enthalpy of liquid water at 10°C times the mass of water that was added. + Therefore, the temperature of the leaving fluid is below the inlet temperature.

    - The infinite line source solution is given by the exponential integral + The outlet conditions at port_a are not affected by this model, + other than for a possible pressure difference due to flow friction.

    -

    - \"image\" +

    + If the parameter energyDynamics is different from + Modelica.Fluid.Types.Dynamics.SteadyState, + the component models the dynamic response using a first order differential equation. + The time constant of the component is equal to the parameter tau. + This time constant is adjusted based on the mass flow rate using +

    +

    + τeff = τ |ṁ| ⁄ ṁnom

    - where αs is the ground thermal diffusivity. The - exponential integral is implemented in - AixLib.Utilities.Math.Functions.exponentialIntegralE1. + where + τeff is the effective time constant for the given mass flow rate + and + τ is the time constant at the nominal mass flow rate + nom. + This type of dynamics is equal to the dynamics that a completely mixed + control volume would have. +

    +

    + Optionally, this model can have a flow resistance. + Set dp_nominal = 0 to disable the flow friction calculation. +

    +

    + For a model that uses a control signal u ∈ [0, 1] and multiplies + this with the nominal water mass flow rate, use + + AixLib.Fluid.Humidifiers.Humidifier_u + +

    +

    Limitations

    +

    + This model only adds water vapor for the flow from + port_a to port_b. + The water vapor of the reverse flow is not affected by this model. +

    +

    + This model does not affect the enthalpy of the air. Therefore, + if water is added, the temperature will decrease, e.g., the humidification + is adiabatic.

    -------- Corrected Code --------

    - This function evaluates the infinite line source solution. This - solution gives the relation between the constant heat transfer rate - (per unit length) injected by a line heat source of infinite length - and the temperature raise in the medium. The infinite line source - solution is defined by + Model for a spray air washer with a prescribed outlet water vapor + mass fraction in kg/kg total air.

    -

    - \"image\" +

    + This model forces the outlet water mass fraction at + port_b to be no lower than the input signal + X_wSet, subject to optional limits on the maximum water + vapor mass flow rate that is added, as described by the parameter + mWatMax_flow. By default, the model has unlimited + capacity.

    - where ΔT(t,r) is the temperature raise after a time t - of constant heat injection and at a distance r from the line - source, Q' is the heat injection rate per unit length, - ks is the soil thermal conductivity and - hILS is the infinite line source solution. + The output signal mWat_flow ≥ 0 is the moisture added to + the medium if the flow rate is from port_a to + port_b. If the flow is reversed, then mWat_flow = + 0. The outlet specific enthalpy at port_b is + increased by the enthalpy of liquid water at 10°C times the + mass of water that was added. Therefore, the temperature of the + leaving fluid is below the inlet temperature.

    - The infinite line source solution is given by the exponential - integral + The outlet conditions at port_a are not affected by this + model, other than for a possible pressure difference due to flow + friction.

    -

    - \"image\" +

    + If the parameter energyDynamics is different from + Modelica.Fluid.Types.Dynamics.SteadyState, the component + models the dynamic response using a first order differential + equation. The time constant of the component is equal to the + parameter tau. This time constant is adjusted based on + the mass flow rate using +

    +

    + τeff = τ |ṁ| ⁄ ṁnom

    - where αs is the ground thermal diffusivity. The - exponential integral is implemented in AixLib.Utilities.Math.Functions.exponentialIntegralE1. + where τeff is the effective time constant for the + given mass flow rate and τ is the time constant at + the nominal mass flow rate nom. This type of + dynamics is equal to the dynamics that a completely mixed control + volume would have. +

    +

    + Optionally, this model can have a flow resistance. Set + dp_nominal = 0 to disable the flow friction calculation. +

    +

    + For a model that uses a control signal u ∈ [0, 1] and + multiplies this with the nominal water mass flow rate, use AixLib.Fluid.Humidifiers.Humidifier_u +

    +

    + Limitations +

    +

    + This model only adds water vapor for the flow from + port_a to port_b. The water vapor of the + reverse flow is not affected by this model. +

    +

    + This model does not affect the enthalpy of the air. Therefore, if + water is added, the temperature will decrease, e.g., the + humidification is adiabatic.

    -------- Errors -------- -line 8 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 21 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 33 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatPumps/Compressors/ReciprocatingCompressor.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/timeGeometric.mo ---- -------- HTML Code --------

    - Model for a reciprocating processor, as detailed in Jin (2002). The rate of heat transferred to the evaporator is given by: -

    -

    - Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ). + This function attemps to build a vector of length nTim with a geometric + expansion of the time variable between dt and t_max.

    - The power consumed by the compressor is given by a linear efficiency relation: + If t_max > nTim*dt, then a geometrically expanding vector is built as

    -

    - P = PTheoretical / η + PLoss,constant. +

    + t = [dt, dt*(1-r2)/(1-r), ... , dt*(1-rn)/(1-r), ... , tmax],

    - Variable speed is acheived by multiplying the full load piston displacement - by the normalized compressor speed. The power and heat transfer rates are forced - to zero if the resulting heat pump state has higher evaporating pressure than - condensing pressure. + where r is the geometric expansion factor.

    -

    Assumptions and limitations

    - The compression process is assumed isentropic. The thermal energy - of superheating is ignored in the evaluation of the heat transferred to the refrigerant - in the evaporator. There is no supercooling. + If t_max < nTim*dt, then a linearly expanding vector is built as

    -

    References

    -

    - H. Jin. - - Parameter estimation based models of water source heat pumps. - - PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002. +

    + t = [dt, 2*dt, ... , n*dt, ... , nTim*dt]

    -------- Corrected Code --------

    - Model for a reciprocating processor, as detailed in Jin (2002). The - rate of heat transferred to the evaporator is given by: -

    -

    - Q̇Eva = ṁref ( - hVap(TEva) - hLiq(TCon) - ). + This function attemps to build a vector of length nTim + with a geometric expansion of the time variable between + dt and t_max.

    - The power consumed by the compressor is given by a linear efficiency - relation: -

    -

    - P = PTheoretical / η + PLoss,constant. + If t_max > nTim*dt, then a geometrically expanding + vector is built as

    -

    - Variable speed is acheived by multiplying the full load piston - displacement by the normalized compressor speed. The power and heat - transfer rates are forced to zero if the resulting heat pump state - has higher evaporating pressure than condensing pressure. +

    + t = [dt, dt*(1-r2)/(1-r), ... , + dt*(1-rn)/(1-r), ... , tmax],

    -

    - Assumptions and limitations -

    - The compression process is assumed isentropic. The thermal energy of - superheating is ignored in the evaluation of the heat transferred to - the refrigerant in the evaporator. There is no supercooling. + where r is the geometric expansion factor.

    -

    - References -

    - H. Jin. Parameter estimation based models of water source heat - pumps. PhD Thesis. Oklahoma State University. Stillwater, - Oklahoma, USA. 2002. + If t_max < nTim*dt, then a linearly expanding vector + is built as +

    +

    + t = [dt, 2*dt, ... , n*dt, ... , nTim*dt]

    -------- Errors -------- -line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 9 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 18 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Actuators/Valves/TwoWayTable.mo ---- +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowULg.mo ---- -------- HTML Code --------

    - Two way valve with opening characteristic that is configured through - a table. -

    -

    - The mass flow rate for the fully open valve is determined based - on the value of the parameter CvData. - For the different valve positions y ∈ [0, 1], this nominal flow rate is - scaled by the values of the parameter - flowCharacteristics. - The parameter flowCharacteristics declares a table of the form -

    -
    - - - - - - -
    y 0 ... 1
    φ l ... 1
    -

    - where l = Kv(y=0)/Kv(y=1) > 0 is the valve leakage. - The first row is the valve opening, and the second row is the - mass flow rate, relative to the mass flow rate of the fully open - valve, under the assumption of a constant pressure difference across the - valve. - A suggested value for the valve leakage is l=0.0001. - If l = 0, then this model will replace it with - l = 10-8 for numerical reasons. - For example, if a valve has Kv=0.5 [m3/h/bar1/2] and - a linear opening characteristics and - a valve leakage of l=0.0001, then one would set -

    -
    -  CvData=AixLib.Fluid.Types.CvTypes.Kv
    -  Kv = 0.5
    -  flowCharacteristics(y={0,1}, phi={0.0001,1})
    -  
    -

    - Note, however, that - - AixLib.Fluid.Actuators.Valves.TwoWayLinear provides a more - efficient implementation for this simple case. + The example contains + experimental data from a real district heating network.

    - The parameter flowCharacteristics must meet the following - requirements, otherwise the model stops with an error: + This model compares the results with the original Modelica Standard Library pipes.

    - -

    - This model is based on the partial valve model - - AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve. - Check this model for more information, such - as the regularization near the origin. +

    The pipes' temperatures are not initialized. Therefore, results of + outflow temperature before approximately the first 10000 seconds should not be + considered.

    +

    Test bench schematic

    +

    \"Schematic

    +

    Calibration

    - For an example that specifies an opening characteristics, see - - AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable. + There are some uncertainties about the heat loss coefficient between pipe and + surrounding air as well as regarding the heat conductivity of the insulation + material. + With the + given data, the length specific thermal resistance is R = 2.164 + ((m K)/W), calculated as follows:

    +

    + R=((1/(2*pipe.kIns)*log((0.0603+2*pipe.dIns)/(0.0603)))+1/(5*(0.0603+2*pipe.dIns)))/Modelica.Constants.pi

    +

    + U = 1/R = 0.462 W/(m K)

    -------- Corrected Code --------

    - Two way valve with opening characteristic that is configured through - a table. -

    -

    - The mass flow rate for the fully open valve is determined based on - the value of the parameter CvData. For the different - valve positions y ∈ [0, 1], this nominal flow rate is scaled - by the values of the parameter flowCharacteristics. The - parameter flowCharacteristics declares a table of the - form -

    - - - - - - - - - - - - - -
    - y - - 0 - - ... - - 1 -
    - φ - - l - - ... - - 1 -
    -

    - where l = Kv(y=0)/Kv(y=1) > 0 is the - valve leakage. The first row is the valve opening, and the second row - is the mass flow rate, relative to the mass flow rate of the fully - open valve, under the assumption of a constant pressure difference - across the valve. A suggested value for the valve leakage is - l=0.0001. If l = 0, then this model will replace it - with l = 10-8 for numerical reasons. For example, - if a valve has Kv=0.5 - [m3/h/bar1/2] and a linear opening - characteristics and a valve leakage of l=0.0001, then one - would set + The example contains experimental data from a real district heating + network.

    -
    -  CvData=AixLib.Fluid.Types.CvTypes.Kv
    -  Kv = 0.5
    -  flowCharacteristics(y={0,1}, phi={0.0001,1})
    -  

    - Note, however, that AixLib.Fluid.Actuators.Valves.TwoWayLinear - provides a more efficient implementation for this simple case. + This model compares the results with the original Modelica Standard + Library pipes.

    - The parameter flowCharacteristics must meet the - following requirements, otherwise the model stops with an error: + The pipes' temperatures are not initialized. Therefore, results of + outflow temperature before approximately the first 10000 seconds + should not be considered.

    - +

    + Test bench schematic +

    - This model is based on the partial valve model AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve. - Check this model for more information, such as the regularization - near the origin. + \"Schematic

    +

    + Calibration +

    - For an example that specifies an opening characteristics, see - - AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable. + There are some uncertainties about the heat loss coefficient between + pipe and surrounding air as well as regarding the heat conductivity + of the insulation material. With the + given data, the length specific thermal resistance is R = + 2.164 ((m K)/W), calculated as follows: +

    +

    + R=((1/(2*pipe.kIns)*log((0.0603+2*pipe.dIns)/(0.0603)))+1/(5*(0.0603+2*pipe.dIns)))/Modelica.Constants.pi +

    +

    + U = 1/R = 0.462 W/(m K)

    -------- Errors -------- -line 14 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 25 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 27 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/ActiveBeams/UsersGuide.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/Cylindrical.mo ---- -------- HTML Code -------- +

    + Model for radial heat transfer in a hollow cylinder. +

    +

    + If the heat capacity of the material is non-zero, then this model computes transient heat conduction, i.e., it + computes a numerical approximation to the solution of the heat equation +

    +

    + ρ c ( ∂ T(r,t) ⁄ ∂t ) = + k ( ∂² T(r,t) ⁄ ∂r² + 1 ⁄ r   ∂ T(r,t) ⁄ ∂r ), +

    +

    + where + ρ + is the mass density, + c + is the specific heat capacity per unit mass, + T + is the temperature at location r and time t and + k is the heat conductivity. + At the locations r=ra and r=rb, + the temperature and heat flow rate are equal to the + temperature and heat flow rate of the heat ports. +

    +

    + If the heat capacity of the material is set to zero, then steady-state heat flow is computed using +

    +

    + Q = 2 π k (Ta-Tb)⁄ ln(ra ⁄ rb), +

    +

    + where + ra is the internal radius, + rb is the external radius, + Ta is the temperature at port a and + Tb is the temperature at port b. +

    +

    Implementation

    +

    + To spatially discretize the heat equation, the construction is + divided into compartments with nSta ≥ 1 state variables. + The state variables are connected to each other through thermal conductors. + There is also a thermal conductor + between the surfaces and the outermost state variables. Thus, to obtain + the surface temperature, use port_a.T (or port_b.T) + and not the variable T[1]. +

    + + + +-------- Corrected Code --------

    -This package contains models of active beams. -Active beams are devices used for heating, cooling and ventilation of spaces. -A schematic diagram of an active beam unit is given below. -

    -

    -\"image\" -

    -

    -The active beam unit consists of a primary air plenum, a mixing chamber, a heat exchanger (coil) and several nozzles. -Typically, an air-handling unit supplies primary air to the active beams. -The primary air is discharged to the mixing chamber through the nozzles. -This generates a low-pressure region which induces air from the room up through the heat exchanger, -where hot or cold water is circulating. -The conditioned induced air is then mixed with primary air, and the mixture descents back to the space. -

    -

    -This package contains two models. The model - -AixLib.Fluid.HeatExchangers.ActiveBeams.Cooling -is for cooling only, while the model - -AixLib.Fluid.HeatExchangers.ActiveBeams.CoolingAndHeating -has two water streams, one for heating and one for cooling. -

    - -

    Model equations for cooling

    -

    -The performance of the model - -AixLib.Fluid.HeatExchangers.ActiveBeams.Cooling -is computed based on manufacturer data -specified in the package - -AixLib.Fluid.HeatExchangers.ActiveBeams.Data. -

    -

    -For off-design conditions, the performance is adjusted using modification factors -that account for changes in water flow rate, -primary air flow rate and temperature difference. -The total heat flow rate of the active beam unit is the sum of the heat flow rate provided by the primary air supply -Qsa and the cooling heat flow rate provided by the beam convector Qc,Beam -which injects room air and mixes it with the primary air. -

    -

    -The heat flow rate -Qsa is delivered to a thermal zone -through the fluid ports, while the heat flow rate from the convector Qc,Beam -is coupled directly to the heat port. -See for example - -AixLib.Fluid.HeatExchangers.ActiveBeams.Examples.CoolingOnly -for how to connect these heat flow rates to a control volume. + Model for radial heat transfer in a hollow cylinder.

    -The primary air contribution is + If the heat capacity of the material is non-zero, then this model + computes transient heat conduction, i.e., it computes a numerical + approximation to the solution of the heat equation

    - Qsa = ṁsa cp,sa (Tsa-Tz) -

    -

    -where sa is the primary air mass flow rate, -cp,sa is the air specific heat capacity, -Tsa is the primary air temperature -and Tz is the zone air temperature. + ρ c ( ∂ T(r,t) ⁄ ∂t ) = k ( ∂² T(r,t) ⁄ ∂r² + 1 ⁄ r   ∂ T(r,t) ⁄ + ∂r ),

    -The heat flow rate of the beam convector Qc,Beam is determined using -the rated capacity which is modified by three separate functions as -

    -

    - Qc,Beam = Qc,nominal -fΔT ( ΔTc ⁄ ΔTc,nominal ) -fsa( ṁsa ⁄ ṁsa,nominal ) -fw( ṁc,w ), + where ρ is the mass density, c is the specific heat + capacity per unit mass, T is the temperature at location + r and time t and k is the heat conductivity. At + the locations r=ra and r=rb, the + temperature and heat flow rate are equal to the temperature and heat + flow rate of the heat ports.

    -the modification factors are as follows: -The modification factor fΔT(·) -describes how the capacity is adjusted to account for the temperature difference -between the zone air and the water entering the convector. -The independent variable is the ratio between the current temperature difference -ΔTc and the temperature difference used to rate beam performance ΔTc,nominal. -The temperature difference is + If the heat capacity of the material is set to zero, then + steady-state heat flow is computed using

    - ΔTc = Tcw-Tz, -

    -

    -where Tcw is the chilled water temperature entering the convector. - -The modification factor fsa(·) adjusts the cooling capacity to account for varying primary air flow rate. -The independent variable is the ratio between the current primary air flow rate sa -and the nominal air flow rate used to rate the beam performance. - -The modification factor fw(·) adjusts the cooling capacity for changes in water flow rate through the convector. -The independent variable is the ratio between the current water flow rate w -and the nominal water flow rate used to rate the beam performance. -

    - -

    Model equations for heating

    -

    -The performance of the model - -AixLib.Fluid.HeatExchangers.ActiveBeams.CoolingAndHeating -is computed identical to the above described model that only provides cooling, -with the exception that this model contains an additional water stream that -can be used to provide heating. + Q = 2 π k (Ta-Tb)⁄ ln(ra ⁄ + rb),

    -For the heating water stream, the temperature difference ΔTh -used for the calculation of the modification factor fΔT(·) is -

    -

    -ΔTh = Thw-Tz, + where ra is the internal radius, + rb is the external radius, Ta is + the temperature at port a and Tb is the temperature + at port b.

    +

    + Implementation +

    -where Thw is the hot water temperature entering the convector in heating mode -and Tz is the zone air temperature. + To spatially discretize the heat equation, the construction is + divided into compartments with nSta ≥ 1 state variables. + The state variables are connected to each other through thermal + conductors. There is also a thermal conductor between the surfaces + and the outermost state variables. Thus, to obtain the surface + temperature, use port_a.T (or port_b.T) and + not the variable T[1].

    + + +-------- Errors -------- +line 9 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Sensors/UsersGuide.mo ---- +-------- HTML Code -------- -

    Dynamics

    -The model can be configured to be steady-state or dynamic. -If configured as dynamic, then a dynamic conservation equation is applied to the water streams -for heating and for cooling. -However, because the capacity of the beam depends on its inlet temperature, and is independent of the -outlet temperature, the heat transferred -to the room at the port heaPor.Q_flow, as well as the heat added to or removed from the -water streams, will instantaneously change. -The only dynamic responses are the water outlet temperatures, which change with a first -order response, parameterized with the time constant tau. +This package contains models of sensors. +There are models with one and with two fluid ports.

    -

    Energy balance

    +

    Selection and parameterization of sensor models

    -All heat flow rate that is added to or extracted from the room is transmitted through the heat port -heaPor. Hence, this model does not cool the supply air between the ports -air_a and air_b. Rather, it adds this heat flow rate -to the heat port heaPor. -The rationale for this implementation is that the beam transfers heat by convection directly to the room, and -by induction of room air into the supply air. As this split of heat flow rate is generally not known, -and because the amount of inducted air is also unknown, -it was decided to transfer all heat through the heat port heaPor. -This also avoids having to add an extra air flow path for the air induced from the room. +When selecting a sensor model, a distinction needs to be made +whether the measured quantity depends on the direction of the flow or +not, and whether the sensor output signal is the product of the mass flow rate +and a medium property.

    --------- Corrected Code --------

    - This package contains models of active beams. Active beams are - devices used for heating, cooling and ventilation of spaces. A - schematic diagram of an active beam unit is given below. -

    -

    - \"image\" +Output signals that depend on the flow direction and are not multiplied by +the mass flow rate are temperature, relative humidity, +water vapor concentration X, trace substances C and density. +For such quantities, sensors with two fluid ports need to be used. +An exception is if the quantity is measured directly in a fluid volume, which is the case +for models from the package + +AixLib.Fluid.MixingVolumes. +Therefore, to measure for example the outlet temperature of a heat exchanger, the +configuration labelled correct use in the figure below should be used, and not the configuration +labelled not recommended. +For an explanation, see + +Modelica.Fluid.Examples.Explanatory.MeasuringTemperature.

    + +
    + + + + + + +
    Correct use + \"image\" +
    Not recommended + \"image\" +
    +

    - The active beam unit consists of a primary air plenum, a mixing - chamber, a heat exchanger (coil) and several nozzles. Typically, an - air-handling unit supplies primary air to the active beams. The - primary air is discharged to the mixing chamber through the nozzles. - This generates a low-pressure region which induces air from the room - up through the heat exchanger, where hot or cold water is - circulating. The conditioned induced air is then mixed with primary - air, and the mixture descents back to the space. +Except for the mass flow rate sensor, +all sensors with two ports can be +configured as dynamic sensors or as steady-state sensor. +The list below advices on how to configure sensors.

    +

    - The heat flow rate Qsa is delivered to a thermal - zone through the fluid ports, while the heat flow rate from the - convector Qc,Beam is coupled directly to the heat - port. See for example - AixLib.Fluid.HeatExchangers.ActiveBeams.Examples.CoolingOnly for - how to connect these heat flow rates to a control volume. +The table below summarizes the recommendations for the use of sensors.

    + + + + + + + + + + + + + + + + + + + + + + + +
    Measured quantityOne port sensorTwo port sensor
    steady-state (tau=0)dynamic (tau > 0)
    temperature
    + relative humidity
    + mass fraction
    + trace substances
    + specific enthalpy
    + specific entropy
    use only if connected to a volumeavoidrecommended
    volume flow rate
    + enthalpy flow rate
    + entropy flow rate
    -recommendedrecommended
    pressurerecommendedrecommendedrecommended
    + +

    Sensor Dynamics

    +
    Dynamic response to fluid flowing through the sensor

    - The primary air contribution is +If a sensor is configured as a dynamic sensor by setting tau > 0, +then the measured quantity, say the temperature T, is +computed as

    - Qsa = ṁsa cp,sa - (Tsa-Tz) -

    -

    - where sa is the primary air mass flow rate, - cp,sa is the air specific heat capacity, - Tsa is the primary air temperature and - Tz is the zone air temperature. + τ   dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T),

    - The heat flow rate of the beam convector Qc,Beam is - determined using the rated capacity which is modified by three - separate functions as -

    -

    - Qc,Beam = Qc,nominal fΔT ( - ΔTc ⁄ ΔTc,nominal ) fsa( - ṁsa ⁄ ṁsa,nominal ) fw( - ṁc,w ), +where τ is a user-defined time constant of the sensor (a suggested value is around 10 seconds, +which is the default setting for the components), +dT ⁄ dt is the time derivative of the sensor output signal, +|ṁ| is the absolute value of the mass flow rate, +0 is the user-specified nominal value of the mass flow rate and +θ is the temperature of the medium inside the sensor. +An equivalent physical model of such a sensor would be a perfectly mixed volume +with a sensor that outputs the temperature of this volume. In this situation, the size of the volume would +be V=τ   ṁ0 ⁄ ρ, where +ρ is the density of the fluid.

    +
    Dynamic response to ambient temperature

    - the modification factors are as follows: The modification factor - fΔT(·) describes how the capacity is adjusted to - account for the temperature difference between the zone air and the - water entering the convector. The independent variable is the ratio - between the current temperature difference ΔTc and - the temperature difference used to rate beam performance - ΔTc,nominal. The temperature difference is +For the sensor + +AixLib.Fluid.Sensors.TemperatureTwoPort, +by setting transferHeat = true, heat transfer to a +fixed ambient can be approximated. The heat transfer is computed as

    - ΔTc = Tcw-Tz, + τHeaTra   dT ⁄ dt = (TAmb-T),

    - where Tcw is the chilled water temperature entering - the convector. The modification factor fsa(·) - adjusts the cooling capacity to account for varying primary air flow - rate. The independent variable is the ratio between the current - primary air flow rate sa and the nominal air flow - rate used to rate the beam performance. The modification factor - fw(·) adjusts the cooling capacity for changes in - water flow rate through the convector. The independent variable is - the ratio between the current water flow rate w - and the nominal water flow rate used to rate the beam performance. +where τHeaTra is a fixed time constant and +TAmb is a fixed ambient temperature. +Setting transferHeat = true is useful if the sensor output T +is used to switch the mass flow rate on again. If transferHeat = false, +then the sensor output T remains constant if the mass flow rate is zero +and hence a fan or pump controller that uses this signal may never switch the device +on again. +If the sensor output T is not used to switch on the mass flow rate, then +in general one can use transferHeat=false.

    -

    - Model equations for heating -

    - The performance of the model - AixLib.Fluid.HeatExchangers.ActiveBeams.CoolingAndHeating is - computed identical to the above described model that only provides - cooling, with the exception that this model contains an additional - water stream that can be used to provide heating. +Note that since in practice the heat transfer is due to a combination of ambient +temperature and upstream or downstream fluid temperature, for example by two-way +buoyancy-driven flow inside the duct or pipe, the model uses as an approximation +a fixed ambient temperature. +Since the sensor is not affecting the temperature of the medium, this approximation +of the heat transfer does not add or remove heat from the fluid.

    +
    Combined dynamic response

    - For the heating water stream, the temperature difference - ΔTh used for the calculation of the - modification factor fΔT(·) is +For the sensor + +AixLib.Fluid.Sensors.TemperatureTwoPort, +if both dynamic effects are enabled, then +the output T is computed as

    - ΔTh = Thw-Tz, -

    -

    - where Thw is the hot water temperature entering the - convector in heating mode and Tz is the zone air - temperature. +dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T) ⁄ τ + +(TAmb-T) ⁄ τHeaTra.

    -

    - Dynamics -

    +

    Implementation

    - The model can be configured to be steady-state or dynamic. If - configured as dynamic, then a dynamic conservation equation is - applied to the water streams for heating and for cooling. However, - because the capacity of the beam depends on its inlet temperature, - and is independent of the outlet temperature, the heat transferred to - the room at the port heaPor.Q_flow, as well as the heat - added to or removed from the water streams, will instantaneously - change. The only dynamic responses are the water outlet temperatures, - which change with a first order response, parameterized with the time - constant tau. +The above equation is implemented in such a way that it is differentiable in the mass flow rate.

    -

    - Energy balance -

    - All heat flow rate that is added to or extracted from the room is - transmitted through the heat port heaPor. Hence, this - model does not cool the supply air between the ports - air_a and air_b. Rather, it adds this heat - flow rate to the heat port heaPor. The rationale for - this implementation is that the beam transfers heat by convection - directly to the room, and by induction of room air into the supply - air. As this split of heat flow rate is generally not known, and - because the amount of inducted air is also unknown, it was decided to - transfer all heat through the heat port heaPor. This - also avoids having to add an extra air flow path for the air induced - from the room. -

    - --------- Errors -------- -line 7 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 59 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 72 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 87 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 115 column 1 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Controls/Continuous/LimPID.mo ---- --------- HTML Code -------- - -

    - PID controller in the standard form -

    -

    - y = k   ( e(t) + 1 ⁄ Ti   ∫ e(s) ds + Td de(t)⁄dt ), -

    -

    - where - y is the control signal, - e(t) = us - um is the control error, - with us being the set point and um being - the measured quantity, - k is the gain, - Ti is the time constant of the integral term and - Td is the time constant of the derivative term. -

    -

    - Note that the units of k are the inverse of the units of the control error, - while the units of Ti and Td are seconds. -

    -

    - For detailed treatment of integrator anti-windup, set-point weights and output limitation, see - Modelica.Blocks.Continuous.LimPID. -

    -

    Options

    - This controller can be configured as follows. -
    P, PI, PD, or PID action
    -

    - Through the parameter controllerType, the controller can be configured - as P, PI, PD or PID controller. The default configuration is PI. -

    -
    Direct or reverse acting
    -

    - Through the parameter reverseActing, the controller can be configured to - be reverse or direct acting. - The above standard form is reverse acting, which is the default configuration. - For a reverse acting controller, for a constant set point, - an increase in measurement signal u_m decreases the control output signal y - (Montgomery and McDowall, 2008). - Thus, -

    - -
    Reset of the controller output
    -

    - The controller can be configured to enable an input port that allows resetting the controller - output. The controller output can be reset as follows: -

    - -

    - Note that this controller implements an integrator anti-windup. Therefore, - for most applications, keeping the default setting of - reset = AixLib.Types.Reset.Disabled is sufficient. - However, if the controller is used in conjuction with equipment that is being - switched on, better control performance may be achieved by resetting the controller - output when the equipment is switched on. - This is in particular the case in situations - where the equipment control input should continuously increase as the equipment is - switched on, such as a light dimmer that may slowly increase the luminance, or - a variable speed drive of a motor that should continuously increase the speed. -

    -

    References

    -

    - R. Montgomery and R. McDowall (2008). - \"Fundamentals of HVAC Control Systems.\" - American Society of Heating Refrigerating and Air-Conditioning Engineers Inc. Atlanta, GA. -

    - - - - +Note that the implementation of the dynamic sensors does not use the model + +AixLib.Fluid.MixingVolumes. +The reason is that depending on the selected medium model, the +mixing volume may introduce states for the pressure, species concentration, +trace substance, specific enthalpy and specific entropy. Not all states are typically needed to +model the dynamics of a sensor. Moreover, in many building system applications, +the sensor dynamics is not of concern, but is rather used here to avoid numerical +problems that steady-state models of sensors cause when flow rates are +very close to zero. +

    + -------- Corrected Code --------

    - PID controller in the standard form + This package contains models of sensors. There are models with one + and with two fluid ports.

    -

    - y = k   ( e(t) + 1 ⁄ Ti   ∫ e(s) ds + - Td de(t)⁄dt ), +

    + Selection and parameterization of sensor models +

    +

    + When selecting a sensor model, a distinction needs to be made whether + the measured quantity depends on the direction of the flow or not, + and whether the sensor output signal is the product of the mass flow + rate and a medium property.

    - where y is the control signal, e(t) = us - - um is the control error, with us - being the set point and um being the measured - quantity, k is the gain, Ti is the time - constant of the integral term and Td is the time - constant of the derivative term. + Output signals that depend on the flow direction and are not + multiplied by the mass flow rate are temperature, relative humidity, + water vapor concentration X, trace substances C and + density. For such quantities, sensors with two fluid ports need to be + used. An exception is if the quantity is measured directly in a fluid + volume, which is the case for models from the package AixLib.Fluid.MixingVolumes. + Therefore, to measure for example the outlet temperature of a heat + exchanger, the configuration labelled correct use in the + figure below should be used, and not the configuration labelled + not recommended. For an explanation, see + Modelica.Fluid.Examples.Explanatory.MeasuringTemperature.

    + + + + + + + + + +
    + Correct use + + \"image\" +
    + Not recommended + + \"image\" +

    - Note that the units of k are the inverse of the units of the - control error, while the units of Ti and - Td are seconds. + Except for the mass flow rate sensor, all sensors with two ports can + be configured as dynamic sensors or as steady-state sensor. The list + below advices on how to configure sensors.

    +

    - For detailed treatment of integrator anti-windup, set-point weights - and output limitation, see Modelica.Blocks.Continuous.LimPID. + The table below summarizes the recommendations for the use of + sensors.

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + Measured quantity + + One port sensor + + Two port sensor +
    + steady-state (tau=0) + + dynamic (tau > 0) +
    + temperature
    + relative humidity
    + mass fraction
    + trace substances
    + specific enthalpy
    + specific entropy +
    + use only if connected to a volume + + avoid + + recommended +
    + volume flow rate
    + enthalpy flow rate
    + entropy flow rate +
    + - + + recommended + + recommended +
    + pressure + + recommended + + recommended + + recommended +

    - Options -

    This controller can be configured as follows. + Sensor Dynamics +
    - P, PI, PD, or PID action + Dynamic response to fluid flowing through the sensor

    - Through the parameter controllerType, the controller can - be configured as P, PI, PD or PID controller. The default - configuration is PI. + If a sensor is configured as a dynamic sensor by setting tau + > 0, then the measured quantity, say the temperature + T, is computed as +

    +

    + τ   dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T), +

    +

    + where τ is a user-defined time constant of the sensor (a + suggested value is around 10 seconds, which is the default setting + for the components), dT ⁄ dt is the time derivative of the + sensor output signal, |ṁ| is the absolute value of the mass + flow rate, 0 is the user-specified nominal value + of the mass flow rate and θ is the temperature of the medium + inside the sensor. An equivalent physical model of such a sensor + would be a perfectly mixed volume with a sensor that outputs the + temperature of this volume. In this situation, the size of the volume + would be V=τ   ṁ0 ⁄ ρ, where ρ is the + density of the fluid.

    - Direct or reverse acting + Dynamic response to ambient temperature

    - Through the parameter reverseActing, the controller can - be configured to be reverse or direct acting. The above standard form - is reverse acting, which is the default configuration. For a reverse - acting controller, for a constant set point, an increase in - measurement signal u_m decreases the control output - signal y (Montgomery and McDowall, 2008). Thus, + For the sensor AixLib.Fluid.Sensors.TemperatureTwoPort, + by setting transferHeat = true, heat transfer to a fixed + ambient can be approximated. The heat transfer is computed as +

    +

    + τHeaTra   dT ⁄ dt = (TAmb-T), +

    +

    + where τHeaTra is a fixed time constant and + TAmb is a fixed ambient temperature. Setting + transferHeat = true is useful if the sensor output + T is used to switch the mass flow rate on again. If + transferHeat = false, then the sensor output T + remains constant if the mass flow rate is zero and hence a fan or + pump controller that uses this signal may never switch the device on + again. If the sensor output T is not used to switch on the + mass flow rate, then in general one can use + transferHeat=false. +

    +

    + Note that since in practice the heat transfer is due to a combination + of ambient temperature and upstream or downstream fluid temperature, + for example by two-way buoyancy-driven flow inside the duct or pipe, + the model uses as an approximation a fixed ambient temperature. Since + the sensor is not affecting the temperature of the medium, this + approximation of the heat transfer does not add or remove heat from + the fluid.

    -
    - Reset of the controller output + Combined dynamic response

    - The controller can be configured to enable an input port that allows - resetting the controller output. The controller output can be reset - as follows: + For the sensor AixLib.Fluid.Sensors.TemperatureTwoPort, + if both dynamic effects are enabled, then the output T is + computed as

    - -

    - Note that this controller implements an integrator anti-windup. - Therefore, for most applications, keeping the default setting of - reset = AixLib.Types.Reset.Disabled is sufficient. - However, if the controller is used in conjuction with equipment that - is being switched on, better control performance may be achieved by - resetting the controller output when the equipment is switched on. - This is in particular the case in situations where the equipment - control input should continuously increase as the equipment is - switched on, such as a light dimmer that may slowly increase the - luminance, or a variable speed drive of a motor that should - continuously increase the speed. +

    + dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T) ⁄ τ + + (TAmb-T) ⁄ τHeaTra.

    - References + Implementation

    - R. Montgomery and R. McDowall (2008). \"Fundamentals of HVAC Control - Systems.\" American Society of Heating Refrigerating and - Air-Conditioning Engineers Inc. Atlanta, GA. + The above equation is implemented in such a way that it is + differentiable in the mass flow rate.

    - - --------- Errors -------- -line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Media/Antifreeze/EthyleneGlycolWater.mo ---- --------- HTML Code -------- - -

    - This base properties model is identical to - - Modelica.Media.Water.ConstantPropertyLiquidWater, - except that the equation - u = cv_const*(T - reference_T) - has been replaced by u=h because - cp_const=cv_const. - Also, the model checks if the mass fraction of the mixture is within the - allowed limits. -

    - -

    - Density of propylene antifreeze-water mixture at specified mass fraction - and temperature, based on Melinder (2010). -

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. -

    - - - -

    - Dynamic viscosity of antifreeze-water mixture at specified mass fraction and - temperature, based on Melinder (2010). -

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. -

    - - - -

    - Fusion temperature of antifreeze-water mixture at specified mass fraction and - temperature, based on Melinder (2010). -

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. -

    - - - -

    - Evaluates a thermophysical property of a mixture, based on correlations proposed - by Melinder (2010). -

    -

    - The polynomial has the form -

    -

    - f = a1 (x-xm)0(y-ym)0 - + a2 (x-xm)0(y-ym)1 - + ... + - any[1] (x-xm)0(y-ym)ny[1]-1 - + ... + - any[1])+1 (x-xm)1(y-ym)0 - + ... + - any[1]+ny[2] (x-xm)1(y-ym)ny[2]-1 - + ... -

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. -

    - - - -

    - Specific heat capacity of antifreeze-water mixture at specified mass fraction - and temperature, based on Melinder (2010). -

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. -

    - - - +

    + Note that the implementation of the dynamic sensors does not use the + model AixLib.Fluid.MixingVolumes. + The reason is that depending on the selected medium model, the mixing + volume may introduce states for the pressure, species concentration, + trace substance, specific enthalpy and specific entropy. Not all + states are typically needed to model the dynamics of a sensor. + Moreover, in many building system applications, the sensor dynamics + is not of concern, but is rather used here to avoid numerical + problems that steady-state models of sensors cause when flow rates + are very close to zero. +

    + +-------- Errors -------- +line 32 column 1 - Warning: The summary attribute on the element is obsolete in HTML5 +line 105 column 1 - Warning: The summary attribute on the
    element is obsolete in HTML5 +line 33 column 5 - Warning:
    attribute "align" not allowed for HTML5 +line 38 column 5 - Warning: attribute "align" not allowed for HTML5 +line 144 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 167 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Utilities/Math/Biquadratic.mo ---- +-------- HTML Code -------- +

    - Thermal conductivity of antifreeze-water mixture at specified mass fraction and - temperature, based on Melinder (2010). + This block computes

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. +

    + y = a1 + a2 x1 + + a3 x12 + + a4 x2 + a5 x22 + + a6 x1 x2

    +-------- Corrected Code -------- +

    + This block computes +

    +

    + y = a1 + a2 x1 + a3 + x12 + a4 x2 + + a5 x22 + a6 x1 + x2 +

    +
      +
    • Sep. 8, 2010, by Michael Wetter:
      + First implementation. +
    • +
    + +-------- Errors -------- +line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Actuators/Valves/TwoWayTable.mo ---- +-------- HTML Code -------- +

    - This medium package models ethylene glycol - water mixtures. -

    -

    - The mass density, specific heat capacity, thermal conductivity and viscosity - are assumed constant and evaluated at a set temperature and mass fraction of - ethylene glycol within the mixture. The dependence of the four properties - are shown on the figure below. -

    -

    - \"Relative + Two way valve with opening characteristic that is configured through + a table.

    - The accuracy of the thermophysical properties is dependent on the temperature - variations encountered during simulations. - The figure below shows the relative error of the the four properties over a - 10 °C range around the temperature used to evaluate the constant - properties. The maximum errors are 0.8 % for mass density, 2.7 % - for specific heat capacity, 3.2 % for thermal conductivity and 160 - % for dynamic viscosity. -

    -

    - \"Relative + The mass flow rate for the fully open valve is determined based + on the value of the parameter CvData. + For the different valve positions y ∈ [0, 1], this nominal flow rate is + scaled by the values of the parameter + flowCharacteristics. + The parameter flowCharacteristics declares a table of the form

    + + + + + + + +
    y 0 ... 1
    φ l ... 1

    - The figure below shows the relative error of the the four properties over a - 20 °C range around the temperature used to evaluate the constant - proepties. The maximum errors are 1.5 % for mass density, 5.3 % - for specific heat capacity, 5.9 % for thermal conductivity and 500 - % for dynamic viscosity. -

    -

    - \"Relative + where l = Kv(y=0)/Kv(y=1) > 0 is the valve leakage. + The first row is the valve opening, and the second row is the + mass flow rate, relative to the mass flow rate of the fully open + valve, under the assumption of a constant pressure difference across the + valve. + A suggested value for the valve leakage is l=0.0001. + If l = 0, then this model will replace it with + l = 10-8 for numerical reasons. + For example, if a valve has Kv=0.5 [m3/h/bar1/2] and + a linear opening characteristics and + a valve leakage of l=0.0001, then one would set

    +
    +  CvData=AixLib.Fluid.Types.CvTypes.Kv
    +  Kv = 0.5
    +  flowCharacteristics(y={0,1}, phi={0.0001,1})
    +  

    - The enthalpy is computed using the convention that h=0 - if T=0 °C. + Note, however, that + + AixLib.Fluid.Actuators.Valves.TwoWayLinear provides a more + efficient implementation for this simple case.

    -

    Limitations

    - Density, specific heat capacity, thermal conductivity and viscosity are constant. - The ethylene glycol/water mixture is modeled as an incompressible liquid. - There are no phase changes. The medium is limited to temperatures below - 100 °C and mass fractions below 0.60. - As is the case for AixLib.Media.Water, - this medium package should not be used if - the simulation relies on the dynamic viscosity. + The parameter flowCharacteristics must meet the following + requirements, otherwise the model stops with an error:

    -

    Typical use and important parameters

    +
      +
    • + Their arrays + y and phi + must be strictly monotonic increasing. +
    • +
    • + The first value must satisfy + y[1]=0, and + phi[1] must be equal to the + leakage flow rate, which must be bigger than zero. + Otherwise, a default value of 1E-8 is used. +
    • +
    • + The last values must satisfy + y[end]=1 and + phi[end]=1. +
    • +

    - The temperature and mass fraction must be specified for the evaluation of the - constant thermophysical properties. A typical use of the package is (e.g. for - a temperature of 20 °C and a mass fraction of 0.40): + This model is based on the partial valve model + + AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve. + Check this model for more information, such + as the regularization near the origin.

    - Medium = AixLib.Media.Antifreeze.EthyleneGlycolWater(property_T=293.15, X_a=0.40) + For an example that specifies an opening characteristics, see + + AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable.

    • - August 05, 2020, by Wen HU:
      - First implementation. + June 10, 2021, by Michael Wetter:
      + Changed implementation of the filter and changed the parameter order to a constant + as most users need not change this value.
      + This is for + #1498.
    • -
    - --------- Corrected Code -------- -

    - This base properties model is identical to Modelica.Media.Water.ConstantPropertyLiquidWater, - except that the equation u = cv_const*(T - reference_T) - has been replaced by u=h because - cp_const=cv_const. Also, the model checks if the mass - fraction of the mixture is within the allowed limits. -

    -

    - Density of propylene antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). -

    -

    - References -

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. -

    - -

    - Dynamic viscosity of antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). -

    -

    - References -

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. -

    - +
  • + August 7, 2020, by Ettore Zanetti:
    + changed the computation of phi using + max(0.1*l, . ) to avoid + phi=0. + See + issue 1376. +
  • +
  • + November 9, 2019, by Filip Jorissen:
    + Guarded the computation of phi using + max(0, . ) to avoid + negative phi. + See + issue 1223. +
  • +
  • + January 26, 2016, by Michael Wetter:
    + Removed equality comparison for Real in the + assert statements as this is not allowed in Modelica. +
  • +
  • + August 12, 2014, by Michael Wetter:
    + Removed the end keyword when accessing array elements, + as this language construct caused an error in OpenModelica. +
  • +
  • + April 4, 2014, by Michael Wetter:
    + Moved the assignment of the flow function phi + to the model instantiation because in its base class, + the keyword input + has been added to the variable phi. +
  • +
  • + March 26, 2014 by Michael Wetter:
    + First implementation. +
  • + + +-------- Corrected Code --------

    - Fusion temperature of antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). + Two way valve with opening characteristic that is configured through + a table.

    -

    - References -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. + The mass flow rate for the fully open valve is determined based on + the value of the parameter CvData. For the different + valve positions y ∈ [0, 1], this nominal flow rate is scaled + by the values of the parameter flowCharacteristics. The + parameter flowCharacteristics declares a table of the + form

    - + + + + + + + + + + + + + +
    + y + + 0 + + ... + + 1 +
    + φ + + l + + ... + + 1 +

    - Evaluates a thermophysical property of a mixture, based on - correlations proposed by Melinder (2010). + where l = Kv(y=0)/Kv(y=1) > 0 is the + valve leakage. The first row is the valve opening, and the second row + is the mass flow rate, relative to the mass flow rate of the fully + open valve, under the assumption of a constant pressure difference + across the valve. A suggested value for the valve leakage is + l=0.0001. If l = 0, then this model will replace it + with l = 10-8 for numerical reasons. For example, + if a valve has Kv=0.5 + [m3/h/bar1/2] and a linear opening + characteristics and a valve leakage of l=0.0001, then one + would set

    +
    +  CvData=AixLib.Fluid.Types.CvTypes.Kv
    +  Kv = 0.5
    +  flowCharacteristics(y={0,1}, phi={0.0001,1})
    +  

    - The polynomial has the form -

    -

    - f = a1 (x-xm)0(y-ym)0 + - a2 (x-xm)0(y-ym)1 + ... + - any[1] (x-xm)0(y-ym)ny[1]-1 + ... + - any[1])+1 (x-xm)1(y-ym)0 + ... + - any[1]+ny[2] (x-xm)1(y-ym)ny[2]-1 + - ... + Note, however, that AixLib.Fluid.Actuators.Valves.TwoWayLinear + provides a more efficient implementation for this simple case.

    -

    - References -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. + The parameter flowCharacteristics must meet the + following requirements, otherwise the model stops with an error:

      -
    • March 16, 2018 by Massimo Cimmino:
      - First implementation. This function is used models in AixLib.Media.Antifreeze. +
    • Their arrays y and phi must be strictly + monotonic increasing.
    • -
    -

    - Specific heat capacity of antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). -

    -

    - References -

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. -

    -
      -
    • March 16, 2018 by Massimo Cimmino:
      - First implementation. This function is used by AixLib.Media.Antifreeze.EthyleneGlycolWater. +
    • The first value must satisfy y[1]=0, and + phi[1] must be equal to the leakage flow rate, which + must be bigger than zero. Otherwise, a default value of + 1E-8 is used. +
    • +
    • The last values must satisfy y[end]=1 and + phi[end]=1.

    - Thermal conductivity of antifreeze-water mixture at specified mass - fraction and temperature, based on Melinder (2010). + This model is based on the partial valve model AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve. + Check this model for more information, such as the regularization + near the origin.

    -

    - References -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids - (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for - Indirect Systems. Paris: IIR/IIF. + For an example that specifies an opening characteristics, see + + AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable.

      -
    • March 16, 2018 by Massimo Cimmino:
      - First implementation. This function is used by AixLib.Media.Antifreeze.EthyleneGlycolWater. +
    • June 10, 2021, by Michael Wetter:
      + Changed implementation of the filter and changed the parameter + order to a constant as most users need not change this + value.
      + This is for #1498. +
    • +
    • August 7, 2020, by Ettore Zanetti:
      + changed the computation of phi using max(0.1*l, + . ) to avoid phi=0. See issue + 1376. +
    • +
    • November 9, 2019, by Filip Jorissen:
      + Guarded the computation of phi using max(0, . + ) to avoid negative phi. See issue + 1223. +
    • +
    • January 26, 2016, by Michael Wetter:
      + Removed equality comparison for Real in the + assert statements as this is not allowed in Modelica. +
    • +
    • August 12, 2014, by Michael Wetter:
      + Removed the end keyword when accessing array elements, + as this language construct caused an error in OpenModelica. +
    • +
    • April 4, 2014, by Michael Wetter:
      + Moved the assignment of the flow function phi to the + model instantiation because in its base class, the keyword + input has been added to the variable phi. +
    • +
    • March 26, 2014 by Michael Wetter:
      + First implementation. +
    • +
    + +-------- Errors -------- +line 14 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- AixLib/BoundaryConditions/Validation/BESTEST/WD300.mo ---- +-------- HTML Code -------- + +
      +
    • + September 6, 2021, by Ettore Zanetti:
      + Removed parameter lat as it is now obtained from the weather data bus.
      + This is for + IBPSA, #1477. +
    • +
    • + March 11, 2020, by Ettore Zanetti:
      + First implementation. +
    • +
    • + April 14, 2020, by Ettore Zanetti:
      + Rework after comments from pull request + #1339. +
    • +
    • + May 2, 2021, by Ettore Zanetti:
      + Updated weather file as explained in #1478. +
    • +
    + +

    WD300: Southern Hemisphere Case

    +

    Weather data file : WD300.epw

    +

    Table 1: Site Data for Weather file WD300.epw

    +
    + + + + + + + + + + + + + + + +

    Latitude

    33.393° south

    Longitude

    70.786° west

    Altitude

    474 m

    Time Zone

    -4

    + +-------- Corrected Code -------- +
      +
    • September 6, 2021, by Ettore Zanetti:
      + Removed parameter lat as it is now obtained from the + weather data bus.
      + This is for IBPSA, + #1477. +
    • +
    • March 11, 2020, by Ettore Zanetti:
      + First implementation. +
    • +
    • April 14, 2020, by Ettore Zanetti:
      + Rework after comments from pull request #1339. +
    • +
    • May 2, 2021, by Ettore Zanetti:
      + Updated weather file as explained in #1478.
    -

    - This medium package models ethylene glycol - water mixtures. -

    -

    - The mass density, specific heat capacity, thermal conductivity and - viscosity are assumed constant and evaluated at a set temperature and - mass fraction of ethylene glycol within the mixture. The dependence - of the four properties are shown on the figure below. -

    -

    - - -

    -

    - The accuracy of the thermophysical properties is dependent on the - temperature variations encountered during simulations. The figure - below shows the relative error of the the four properties over a - 10 °C range around the temperature used to evaluate the - constant properties. The maximum errors are 0.8 % for mass - density, 2.7 % for specific heat capacity, 3.2 % for - thermal conductivity and 160 % for dynamic viscosity. -

    -

    - - -

    -

    - The figure below shows the relative error of the the four properties - over a 20 °C range around the temperature used to evaluate the - constant proepties. The maximum errors are 1.5 % for mass - density, 5.3 % for specific heat capacity, 5.9 % for - thermal conductivity and 500 % for dynamic viscosity. -

    -

    - - -

    -

    - The enthalpy is computed using the convention that h=0 if - T=0 °C. -

    - Limitations + WD300: Southern Hemisphere Case

    - Density, specific heat capacity, thermal conductivity and viscosity - are constant. The ethylene glycol/water mixture is modeled as an - incompressible liquid. There are no phase changes. The medium is - limited to temperatures below 100 °C and mass fractions below - 0.60. As is the case for AixLib.Media.Water, this medium - package should not be used if the simulation relies on the dynamic - viscosity. + Weather data file : WD300.epw

    -

    - Typical use and important parameters -

    - The temperature and mass fraction must be specified for the - evaluation of the constant thermophysical properties. A typical use - of the package is (e.g. for a temperature of 20 °C and a mass - fraction of 0.40): + Table 1: Site Data for Weather file WD300.epw

    -

    - Medium = - AixLib.Media.Antifreeze.EthyleneGlycolWater(property_T=293.15, - X_a=0.40) + + + + + + + + + + + + + + + + + +
    +

    + Latitude +

    +
    +

    + 33.393° south +

    +
    +

    + Longitude +

    +
    +

    + 70.786° west +

    +
    +

    + Altitude +

    +
    +

    + 474 m +

    +
    +

    + Time Zone +

    +
    +

    + -4 +

    +
    + +-------- Errors -------- +line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- AixLib/Utilities/Math/Functions/quadraticLinear.mo ---- +-------- HTML Code -------- + + This function computes +

    + y = a1 + a2 x1 + + a3 x12 + + (a4 + a5 x1 + + a6 x12) x2 +

    + +
      +
    • + February 29, 2009 by Michael Wetter:
      + First implementation. +
    • +
    + +-------- Corrected Code -------- +This function computes +

    + y = a1 + a2 x1 + a3 + x12 + (a4 + a5 + x1 + a6 x12) + x2

      -
    • August 05, 2020, by Wen HU:
      +
    • February 29, 2009 by Michael Wetter:
      First implementation.
    -------- Errors -------- -line 9 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - -line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 24 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 35 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/ExportContainers/ThermalZones.mo ---- +---- AixLib/Fluid/FixedResistances/PressureDrop.mo ---- -------- HTML Code -------- -

    - Model that is used as a container for a multiple thermal zones - that are to be exported as an FMU. +

    + Model of a flow resistance with a fixed flow coefficient. + The mass flow rate is +

    +

    + ṁ = k + √ΔP,

    -

    Typical use and important parameters

    - To use this model as a container for an FMU, extend - from this model, rather than instantiate it, - add your thermal zones. For each thermal zone, - add a vector of mass flow rate sensors. - By extending from this model, the top-level - signal connectors on the left stay at the top-level, and hence - will be visible at the FMI interface. + where + k is a constant and + ΔP is the pressure drop. + The constant k is equal to + k=m_flow_nominal/sqrt(dp_nominal), + where m_flow_nominal and dp_nominal + are parameters.

    - - Note that -
      -
    • - A vector of mass flow rate sensors is used to connect - one element of the thermal zone adapter with one thermal zone. -
    • -
    • - The size of the thermal zone adapter must be the same as the number - of vectors of mass flow rate sensors. -
    • -
    • - The vector of mass flow rate sensors must have the size nPorts. -
    • -
    • - All fluid ports of the mass flow rate sensor must be connected. -
    • -
    • - If mass flow rate sensors are not used, and your themal zone - has fluid ports which are autosized, then a direct connection between - an element of the thermal zone adpater theZonAda and your thermal - zone will be rejected. The reason is because autosized fluid ports - can only be connected to vector of ports whose sizes are literal. -
    • -
    - +

    Assumptions

    - The example - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones - shows how multiple simple thermal zones can be implemented and exported as - an FMU. - + In the region + abs(m_flow) < m_flow_turbulent, + the square root is replaced by a differentiable function + with finite slope. + The value of m_flow_turbulent is + computed as + m_flow_turbulent = deltaM * abs(m_flow_nominal), + where deltaM=0.3 and + m_flow_nominal are parameters that can be set by the user. +

    +

    + The figure below shows the pressure drop for the parameters + m_flow_nominal=5 kg/s, + dp_nominal=10 Pa and + deltaM=0.3. +

    +

    + \"image\" +

    +

    Important parameters

    +

    + The parameter from_dp is used to determine + whether the mass flow rate is computed as a function of the + pressure drop (if from_dp=true), or vice versa. + This setting can affect the size of the nonlinear system of equations. +

    +

    + If the parameter linearized is set to true, + then the pressure drop is computed as a linear function of the + mass flow rate. +

    +

    + Setting allowFlowReversal=false can lead to simpler + equations. However, this should only be set to false + if one can guarantee that the flow never reverses its direction. + This can be difficult to guarantee, as pressure imbalance after + the initialization, or due to medium expansion and contraction, + can lead to reverse flow.

    -

    - The conversion between the fluid ports and signal ports is done - in the thermal zone adapter theZonAda[nZon]. - This adapter has a vector of fluid ports called ports[nPorts] - which needs to be connected to the air volume of the thermal zones. - At this port, air exchanged between the thermal zones, the HVAC system - and any infiltration flow paths. + If the parameter + show_T is set to true, + then the model will compute the + temperature at its ports. Note that this can lead to state events + when the mass flow rate approaches zero, + which can increase computing time.

    +

    Notes

    - This model has input signals fluPor[nZon, nPorts] which carry - the mass flow rate for each flow that is connected to ports[1:nPorts] - for the respective zone, together with its - temperature, water vapor mass fraction per total mass of the air (not per kg dry - air), and trace substances. These quantities are always as if the flow - enters the respective room, even if the flow is zero or negative. - If a medium has no moisture, e.g., if Medium.nXi=0, or - if it has no trace substances, e.g., if Medium.nC=0, then - the output signal for these properties are removed. - Thus, a thermal zone model that uses these signals to compute the - heat added by the HVAC system need to implement an equation such as -

    -

    - Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), + For more detailed models that compute the actual flow friction, + models from the package + + Modelica.Fluid + can be used and combined with models from the + AixLib library.

    - where - Qsen is the sensible heat flow rate added to the thermal zone, - sup is the supply air mass flow rate from - the port fluPor (which is negative if it is an exhaust), - cp is the specific heat capacity at constant pressure, - Tsup is the supply air temperature and - Tair,zon is the zone air temperature. - Note that without the max(·, ·), the energy - balance would be wrong. - For example, - - the control volumes in - - AixLib.Fluid.MixingVolumes - implement such a max(·, ·) function. + For a model that uses the hydraulic parameter and flow velocity at nominal conditions + as a parameter, use + + AixLib.Fluid.FixedResistances.HydraulicDiameter.

    +

    Implementation

    - For each zone, its air temperature, - water vapor mass fraction per total mass of the air (unless Medium.nXi=0) - and trace substances (unless Medium.nC=0) - can be obtained from the outupt connector - fluPor[1:nZon].backward. - These signals are the same as the inflowing fluid stream(s) - at the port theAdaZon[1:nZon].ports[1:nPorts]. - The fluid connector ports[nPorts] has a prescribed mass flow rate, but - it does not set any pressure. + The pressure drop is computed by calling a function in the package + + AixLib.Fluid.BaseClasses.FlowModels, + This package contains regularized implementations of the equation +

    +

    + m = sign(Δp) k √ Δp  

    - This model has a user-defined parameter nPorts - which sets the number of fluid ports, which in turn is used - for the ports fluPor and ports. - All zones must have the same number of fluid ports nPorts. - All nPorts - ports[1:nPorts] need to be connected as demonstrated in the example - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones. + and its inverse function.

    - + To decouple the energy equation from the mass equations, + the pressure drop is a function of the mass flow rate, + and not the volume flow rate. + This leads to simpler equations.

    • - January 18, 2019, by Jianjun Hu:
      - Limited the media choice to moist air. - See #1050. + September 21, 2018, by Michael Wetter:
      + Decrease value of deltaM(min=...) attribute. + See #1026.
    • - September 20, 2016, by Thierry S. Nouidui:
      - Revised documentation to explain the rationale - of needing mass flow rate sensors. + February 3, 2018, by Filip Jorissen:
      + Revised implementation of pressure drop equation + such that it depends on from_dp + when linearized=true. + See #884.
    • - June 29, 2016, by Michael Wetter:
      - Revised implementation and documentation. + December 1, 2016, by Michael Wetter:
      + Simplified model by removing the geometry dependent parameters into the new + model + + AixLib.Fluid.FixedResistances.HydraulicDiameter.
    • - April 27, 2016, by Thierry S. Nouidui:
      + November 23, 2016, by Filip Jorissen:
      + Removed dp_nominal and + m_flow_nominal labels from icon. +
    • +
    • + October 14, 2016, by Michael Wetter:
      + Updated comment for parameter use_dh. +
    • +
    • + November 26, 2014, by Michael Wetter:
      + Added the required annotation(Evaluate=true) so + that the system of nonlinear equations in + + AixLib.Fluid.FixedResistances.Validation.PressureDropsExplicit + remains the same. +
    • +
    • + November 20, 2014, by Michael Wetter:
      + Rewrote the warning message using an assert with + AssertionLevel.warning + as this is the proper way to write warnings in Modelica. +
    • +
    • + August 5, 2014, by Michael Wetter:
      + Corrected error in documentation of computation of k. +
    • +
    • + May 29, 2014, by Michael Wetter:
      + Removed undesirable annotation Evaluate=true. +
    • +
    • + October 8, 2013, by Michael Wetter:
      + Removed parameter show_V_flow. +
    • +
    • + December 14, 2012 by Michael Wetter:
      + Renamed protected parameters for consistency with the naming conventions. +
    • +
    • + January 16, 2012 by Michael Wetter:
      + To simplify object inheritance tree, revised base classes + AixLib.Fluid.BaseClasses.PartialResistance, + AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve, + AixLib.Fluid.Actuators.BaseClasses.PartialDamperExponential, + AixLib.Fluid.Actuators.BaseClasses.PartialActuator + and model + AixLib.Fluid.FixedResistances.PressureDrop. +
    • +
    • + May 30, 2008 by Michael Wetter:
      + Added parameters use_dh and deltaM for easier parameterization. +
    • +
    • + July 20, 2007 by Michael Wetter:
      First implementation.
    -------- Corrected Code --------

    - Model that is used as a container for a multiple thermal zones that - are to be exported as an FMU. + Model of a flow resistance with a fixed flow coefficient. The mass + flow rate is +

    +

    + ṁ = k √ΔP, +

    +

    + where k is a constant and ΔP is the pressure drop. The + constant k is equal to + k=m_flow_nominal/sqrt(dp_nominal), where + m_flow_nominal and dp_nominal are + parameters.

    - Typical use and important parameters + Assumptions

    - To use this model as a container for an FMU, extend from this model, - rather than instantiate it, add your thermal zones. For each thermal - zone, add a vector of mass flow rate sensors. By extending from this - model, the top-level signal connectors on the left stay at the - top-level, and hence will be visible at the FMI interface. -

    Note that -
      -
    • A vector of mass flow rate sensors is used to connect one element - of the thermal zone adapter with one thermal zone. -
    • -
    • The size of the thermal zone adapter must be the same as the - number of vectors of mass flow rate sensors. -
    • -
    • The vector of mass flow rate sensors must have the size - nPorts. -
    • -
    • All fluid ports of the mass flow rate sensor must be connected. -
    • -
    • If mass flow rate sensors are not used, and your themal zone has - fluid ports which are autosized, then a direct connection between an - element of the thermal zone adpater theZonAda and your - thermal zone will be rejected. The reason is because autosized fluid - ports can only be connected to vector of ports whose sizes are - literal. -
    • -
    + In the region abs(m_flow) < m_flow_turbulent, the + square root is replaced by a differentiable function with finite + slope. The value of m_flow_turbulent is computed as + m_flow_turbulent = deltaM * abs(m_flow_nominal), where + deltaM=0.3 and m_flow_nominal are + parameters that can be set by the user. +

    - The example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones - shows how multiple simple thermal zones can be implemented and - exported as an FMU. + The figure below shows the pressure drop for the parameters + m_flow_nominal=5 kg/s, dp_nominal=10 Pa and + deltaM=0.3. +

    +

    + \"image\" +

    +

    + Important parameters +

    +

    + The parameter from_dp is used to determine whether the + mass flow rate is computed as a function of the pressure drop (if + from_dp=true), or vice versa. This setting can affect + the size of the nonlinear system of equations. +

    +

    + If the parameter linearized is set to true, + then the pressure drop is computed as a linear function of the mass + flow rate. +

    +

    + Setting allowFlowReversal=false can lead to simpler + equations. However, this should only be set to false if + one can guarantee that the flow never reverses its direction. This + can be difficult to guarantee, as pressure imbalance after the + initialization, or due to medium expansion and contraction, can lead + to reverse flow.

    - The conversion between the fluid ports and signal ports is done in - the thermal zone adapter theZonAda[nZon]. This adapter - has a vector of fluid ports called ports[nPorts] which - needs to be connected to the air volume of the thermal zones. At this - port, air exchanged between the thermal zones, the HVAC system and - any infiltration flow paths. + If the parameter show_T is set to true, + then the model will compute the temperature at its ports. Note that + this can lead to state events when the mass flow rate approaches + zero, which can increase computing time.

    +

    + Notes +

    - This model has input signals fluPor[nZon, nPorts] which - carry the mass flow rate for each flow that is connected to - ports[1:nPorts] for the respective zone, together with - its temperature, water vapor mass fraction per total mass of the air - (not per kg dry air), and trace substances. These quantities are - always as if the flow enters the respective room, even if the flow is - zero or negative. If a medium has no moisture, e.g., if - Medium.nXi=0, or if it has no trace substances, e.g., if - Medium.nC=0, then the output signal for these properties - are removed. Thus, a thermal zone model that uses these signals to - compute the heat added by the HVAC system need to implement an - equation such as -

    -

    - Qsen = max(0, ṁsup)   cp   - (Tsup - Tair,zon), + For more detailed models that compute the actual flow friction, + models from the package Modelica.Fluid can be used and + combined with models from the AixLib library.

    - where Qsen is the sensible heat flow rate added to - the thermal zone, sup is the supply air mass flow - rate from the port fluPor (which is negative if it is an - exhaust), cp is the specific heat capacity at - constant pressure, Tsup is the supply air - temperature and Tair,zon is the zone air - temperature. Note that without the max(·, ·), the energy - balance would be wrong. For example, - the control volumes in AixLib.Fluid.MixingVolumes - implement such a max(·, ·) function. + For a model that uses the hydraulic parameter and flow velocity at + nominal conditions as a parameter, use AixLib.Fluid.FixedResistances.HydraulicDiameter.

    +

    + Implementation +

    - For each zone, its air temperature, water vapor mass fraction per - total mass of the air (unless Medium.nXi=0) and trace - substances (unless Medium.nC=0) can be obtained from the - outupt connector fluPor[1:nZon].backward. These signals - are the same as the inflowing fluid stream(s) at the port - theAdaZon[1:nZon].ports[1:nPorts]. The fluid connector - ports[nPorts] has a prescribed mass flow rate, but it - does not set any pressure. + The pressure drop is computed by calling a function in the package + AixLib.Fluid.BaseClasses.FlowModels, + This package contains regularized implementations of the equation +

    +

    + m = sign(Δp) k √ Δp +  

    - This model has a user-defined parameter nPorts which - sets the number of fluid ports, which in turn is used for the ports - fluPor and ports. All zones must have the - same number of fluid ports nPorts. All - nPorts ports[1:nPorts] need to be connected - as demonstrated in the example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones. + and its inverse function.

    - + To decouple the energy equation from the mass equations, the pressure + drop is a function of the mass flow rate, and not the volume flow + rate. This leads to simpler equations.

      -
    • January 18, 2019, by Jianjun Hu:
      - Limited the media choice to moist air. See #1050. +
    • September 21, 2018, by Michael Wetter:
      + Decrease value of deltaM(min=...) attribute. See + #1026.
    • -
    • September 20, 2016, by Thierry S. Nouidui:
      - Revised documentation to explain the rationale of needing mass flow - rate sensors. +
    • February 3, 2018, by Filip Jorissen:
      + Revised implementation of pressure drop equation such that it + depends on from_dp when linearized=true. + See #884.
    • -
    • June 29, 2016, by Michael Wetter:
      - Revised implementation and documentation. +
    • December 1, 2016, by Michael Wetter:
      + Simplified model by removing the geometry dependent parameters into + the new model AixLib.Fluid.FixedResistances.HydraulicDiameter.
    • -
    • April 27, 2016, by Thierry S. Nouidui:
      +
    • November 23, 2016, by Filip Jorissen:
      + Removed dp_nominal and m_flow_nominal + labels from icon. +
    • +
    • October 14, 2016, by Michael Wetter:
      + Updated comment for parameter use_dh. +
    • +
    • November 26, 2014, by Michael Wetter:
      + Added the required annotation(Evaluate=true) so that + the system of nonlinear equations in + AixLib.Fluid.FixedResistances.Validation.PressureDropsExplicit + remains the same. +
    • +
    • November 20, 2014, by Michael Wetter:
      + Rewrote the warning message using an assert with + AssertionLevel.warning as this is the proper way to + write warnings in Modelica. +
    • +
    • August 5, 2014, by Michael Wetter:
      + Corrected error in documentation of computation of k. +
    • +
    • May 29, 2014, by Michael Wetter:
      + Removed undesirable annotation Evaluate=true. +
    • +
    • October 8, 2013, by Michael Wetter:
      + Removed parameter show_V_flow. +
    • +
    • December 14, 2012 by Michael Wetter:
      + Renamed protected parameters for consistency with the naming + conventions. +
    • +
    • January 16, 2012 by Michael Wetter:
      + To simplify object inheritance tree, revised base classes + AixLib.Fluid.BaseClasses.PartialResistance, + AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve, + AixLib.Fluid.Actuators.BaseClasses.PartialDamperExponential, + AixLib.Fluid.Actuators.BaseClasses.PartialActuator and + model AixLib.Fluid.FixedResistances.PressureDrop. +
    • +
    • May 30, 2008 by Michael Wetter:
      + Added parameters use_dh and deltaM for + easier parameterization. +
    • +
    • July 20, 2007 by Michael Wetter:
      First implementation.
    -------- Errors -------- -line 78 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 6 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 37 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 90 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/EvaporatorCondenser.mo ---- +---- AixLib/ThermalZones/ReducedOrder/RC/FourElements.mo ---- -------- HTML Code -------- -

    - Model for a constant temperature evaporator or condenser based on a ε-NTU - heat exchanger model. -

    -

    - The heat exchanger effectiveness is calculated from the number of transfer units - (NTU): -

    -

    - ε = 1 - exp(UA ⁄ (ṁ cp)) -

    -

    - Optionally, this model can have a flow resistance. - If no flow resistance is requested, set dp_nominal=0. -

    -

    Limitations

    -

    - This model does not consider any superheating or supercooling on the refrigerant - side. The refrigerant is considered to exchange heat at a constant temperature - throughout the heat exchanger. -

    -
    • March 7, 2022, by Michael Wetter:
      @@ -15511,4680 +14086,5979 @@ line 78 column 2 - Warning:

      attribute "align" not allowed for HTML5 #1542.

    • - May 27, 2017, by Filip Jorissen:
      - Regularised heat transfer around zero flow.
      - This is for - #769. + December 9, 2019, by Moritz Lauster:
      + Changes nExt to nRoof for + RRoof and CRoof
    • - April 12, 2017, by Michael Wetter:
      - Corrected invalid syntax for computing the specific heat capacity.
      - This is for - #707. + July 11, 2019, by Katharina Brinkmann:
      + Renamed alphaRoof to hConRoof, + alphaRoofConst to hConRoof_const
    • - October 11, 2016, by Massimo Cimmino:
      - First implementation. + August 31, 2018 by Moritz Lauster:
      + Updated schema in documentation and fixes + orientation and connections of roofRC for + + issue 997. +
    • +
    • + September 11, 2015 by Moritz Lauster:
      + First Implementation.
    +

    + This model adds another element for the roof. Roofs commonly + exhibit the same excitations as exterior walls but have different coefficients + of heat transfer due to their orientation. Adding an extra element for the roof + might lead to a finer resolution of the dynamic behaviour but increases + calculation times. The roof is parameterized via the length of the RC-chain + nRoof, + the vector of capacities CRoof[nRoof], the vector of resistances + RRoof[nRoof] and remaining resistances RRoofRem. +

    +

    + The image below shows the RC-network of this model. +

    +

    + \"image\"/ +

    + -------- Corrected Code -------- -

    - Model for a constant temperature evaporator or condenser based on a - ε-NTU heat exchanger model. -

    -

    - The heat exchanger effectiveness is calculated from the number of - transfer units (NTU): -

    -

    - ε = 1 - exp(UA ⁄ (ṁ cp)) -

    -

    - Optionally, this model can have a flow resistance. If no flow - resistance is requested, set dp_nominal=0. -

    -

    - Limitations -

    -

    - This model does not consider any superheating or supercooling on the - refrigerant side. The refrigerant is considered to exchange heat at a - constant temperature throughout the heat exchanger. -

    • March 7, 2022, by Michael Wetter:
      Removed massDynamics.
      This is for #1542.
    • -
    • May 27, 2017, by Filip Jorissen:
      - Regularised heat transfer around zero flow.
      - This is for #769. +
    • December 9, 2019, by Moritz Lauster:
      + Changes nExt to nRoof for + RRoof and CRoof +
    • +
    • July 11, 2019, by Katharina Brinkmann:
      + Renamed alphaRoof to hConRoof, + alphaRoofConst to hConRoof_const
    • -
    • April 12, 2017, by Michael Wetter:
      - Corrected invalid syntax for computing the specific heat - capacity.
      - This is for #707. +
    • August 31, 2018 by Moritz Lauster:
      + Updated schema in documentation and fixes orientation and + connections of roofRC for issue 997.
    • -
    • October 11, 2016, by Massimo Cimmino:
      - First implementation. +
    • September 11, 2015 by Moritz Lauster:
      + First Implementation.
    +

    + This model adds another element for the roof. Roofs commonly exhibit + the same excitations as exterior walls but have different + coefficients of heat transfer due to their orientation. Adding an + extra element for the roof might lead to a finer resolution of the + dynamic behaviour but increases calculation times. The roof is + parameterized via the length of the RC-chain nRoof, the + vector of capacities CRoof[nRoof], the vector of + resistances RRoof[nRoof] and remaining resistances + RRoofRem. +

    +

    + The image below shows the RC-network of this model. +

    +

    + \"image\" +

    -------- Errors -------- -line 10 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 15 column 4 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/Functions/Examples/CubicHermite.mo ---- +---- AixLib/BoundaryConditions/WeatherData/ReaderTMY3.mo ---- -------- HTML Code --------

    - This example demonstrates the use of the function for cubic hermite interpolation - and linear extrapolation. - The example use interpolation with two different settings: One settings - produces a monotone cubic hermite, whereas the other setting - does not enforce monotonicity. - The resulting plot should look as shown below, where for better visibility, the support points have been marked with black dots. - Notice that the red curve is monotone increasing. + Block to output the latitude of the location. + This block is added so that the latitude is displayed + with a comment in the GUI of the weather bus connector. +

    +

    Implementation

    +

    + If + + Modelica.Blocks.Sources.Constant where used, then + the comment for the latitude would be \"Connector of Real output signal\". + As this documentation string cannot be overwritten, a new block + was implemented.

    -

    \"image\"

    • - March 8, 2013, by Michael Wetter:
      + January 4, 2016, by Michael Wetter:
      First implementation.
    --------- Corrected Code -------- -

    - This example demonstrates the use of the function for cubic hermite - interpolation and linear extrapolation. The example use interpolation - with two different settings: One settings produces a monotone cubic - hermite, whereas the other setting does not enforce monotonicity. The - resulting plot should look as shown below, where for better - visibility, the support points have been marked with black dots. - Notice that the red curve is monotone increasing. -

    -

    - \"image\" -

    -
      -
    • March 8, 2013, by Michael Wetter:
      - First implementation. -
    • -
    - --------- Errors -------- -line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/BoundaryConditions/Validation/BESTEST/WD400.mo ---- --------- HTML Code -------- - +

    + Block to output the longitude of the location. + This block is added so that the longitude is displayed + with a comment in the GUI of the weather bus connector. +

    +

    Implementation

    +

    + If + + Modelica.Blocks.Sources.Constant where used, then + the comment for the longitude would be \"Connector of Real output signal\". + As this documentation string cannot be overwritten, a new block + was implemented. +

    +
    • - September 6, 2021, by Ettore Zanetti:
      - Removed parameter lat as it is now obtained from the weather data bus.
      - This is for - IBPSA, #1477. -
    • -
    • - March 11, 2020, by Ettore Zanetti:
      + January 4, 2016, by Michael Wetter:
      First implementation.
    • -
    • - April 14, 2020, by Ettore Zanetti:
      - Rework after comments from pull request - #1339. -
    • +
    + +

    + Block to output the altitude of the location. + This block is added so that the altitude is displayed + with a comment in the GUI of the weather bus connector. +

    +

    Implementation

    +

    + If + + Modelica.Blocks.Sources.Constant where used, then + the comment for the Altitude would be \"Connector of Real output signal\". + As this documentation string cannot be overwritten, a new block + was implemented. +

    + +
    • May 2, 2021, by Ettore Zanetti:
      - Updated weather file as explained in #1478. + First implementation.
    -

    WD400: High Latitude Case

    -

    Weather data file : WD400.epw

    -

    Table 1: Site Data for Weather file WD400.epw

    -
    - - +

    + This component reads TMY3 weather data (Wilcox and Marion, 2008) or user specified weather data. + The Modelica built-in variable time determines what row + of the weather file is read. + The value of time is the number of seconds + that have passed since January 1st at midnight (00:00) in the local time zone. + The local time zone value, longitude and latitute are also read from the weather data, + such that the solar position computations are consistent with the weather data. +

    +

    + The weather data format is the Typical Meteorological Year (TMY3) + as obtained from the EnergyPlus web site at + + http://energyplus.net/weather. These + data, which are in the EnergyPlus format, need to be converted as described + below. +

    + +

    Output to weaBus

    +

    + The following variables serve as output and are accessible via weaBus: +

    +

    Latitude

    71.286° north

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + - - + + + + - - + + + -
    Name + Unit + Description +
    + HDifHor + + W/m2 + + Horizontal diffuse solar radiation. +
    + HDifNor + + W/m2 + + Direct normal radiation. +
    + HGloHor + + W/m2 + + Horizontal global radiation. +
    + HHorIR + + W/m2 + + Horizontal infrared irradiation. +
    + TBlaSky + + K + + Output temperature. +
    + TDewPoi + + K + + Dew point temperature. +
    + TDryBul + + K + + Dry bulb temperature at ground level. +

    Longitude

    156.767° west

    + TWetBul + + K + + Wet bulb temperature. +

    Altitude

    10 m

    + celHei + + m + + Ceiling height. +

    Time Zone

    -9

    + cloTim + + s + + One-based day number in seconds. +
    - --------- Corrected Code -------- -

      -
    • September 6, 2021, by Ettore Zanetti:
      - Removed parameter lat as it is now obtained from the - weather data bus.
      - This is for IBPSA, - #1477. -
    • -
    • March 11, 2020, by Ettore Zanetti:
      - First implementation. -
    • -
    • April 14, 2020, by Ettore Zanetti:
      - Rework after comments from pull request #1339. -
    • -
    • May 2, 2021, by Ettore Zanetti:
      - Updated weather file as explained in #1478. -
    • -
    -

    - WD400: High Latitude Case -

    -

    - Weather data file : WD400.epw -

    -

    - Table 1: Site Data for Weather file WD400.epw -

    - - - - - - - - - - - - - - - - - -
    -

    - Latitude -

    -
    -

    - 71.286° north -

    -
    -

    - Longitude -

    -
    -

    - 156.767° west -

    -
    -

    - Altitude -

    -
    -

    - 10 m -

    -
    -

    - Time Zone -

    -
    -

    - -9 -

    -
    - --------- Errors -------- -line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/Controls/Continuous/Examples/SignalRanker.mo ---- --------- HTML Code -------- - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + lat + + rad + + Latitude of the location. +
    + lon + + rad + + Longitude of the location. +
    + nOpa + + 1 + + Opaque sky cover [0, 1]. +
    + nTot + + 1 + + Total sky Cover [0, 1]. +
    + pAtm + + Pa + + Atmospheric pressure. +
    + relHum + + 1 + + Relative humidity. +
    + solAlt + + rad + + Altitude angle. +
    + solDec + + rad + + Declination angle. +
    + solHouAng + + rad + + Solar hour angle. +
    + solTim + + s + + Solar time. +
    + solZen + + rad + + Zenith angle. +
    + winDir + + rad + + Wind direction. +
    + winSpe + + m/s + + Wind speed. +
    + +

    Adding new weather data

    - Example that demonstrates the use of the signal ranker model. - The figure below shows the input and output signals of the block. - Note that - sigRan.y[1] ≥ sigRan.y[2] ≥ sigRan.y[3]. -

    -

    - \"Input
    - \"Output + To add new weather data, proceed as follows:

    - -
      -
    • - October 15, 2021, by Michael Wetter:
      - Moved start time of sine input signal to avoid simultaneous state event and time event.
      - This is for - IBPSA, #1534. -
    • +
      1. - November 21, 2011, by Michael Wetter:
        - Added documentation. + Download the weather data file with the epw extension from + + http://energyplus.net/weather.
      2. -
    - --------- Corrected Code -------- -

    - Example that demonstrates the use of the signal ranker model. The - figure below shows the input and output signals of the block. Note - that sigRan.y[1] ≥ sigRan.y[2] ≥ sigRan.y[3]. -

    -

    - \"Input
    - \"Output -

    -
      -
    • October 15, 2021, by Michael Wetter:
      - Moved start time of sine input signal to avoid simultaneous state - event and time event.
      - This is for IBPSA, - #1534. -
    • -
    • November 21, 2011, by Michael Wetter:
      - Added documentation. -
    • -
    - --------- Errors -------- -line 8 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/ThermalZones/ReducedOrder/RC/OneElement.mo ---- --------- HTML Code -------- - -

    - This model merges all thermal masses into one - element, parameterized by the length of the RC-chain - nExt, the vector of the capacities CExt[nExt] that is - connected via the vector of resistances RExt[nExt] and - RExtRem to the ambient and indoor air. - By default, the model neglects all - internal thermal masses that are not directly connected to the ambient. - However, the thermal capacity of the room air can be increased by - using the parameter mSenFac. -

    -

    - The image below shows the RC-network of this model. -

    -

    - \"image\"/ -

    - -
    • - March 7, 2022, by Michael Wetter:
      - Removed massDynamics.
      - This is for - #1542. + Add the file to AixLib/Resources/weatherdata (or to any directory + for which you have write permission).
    • - October 9, 2019, by Michael Wetter:
      - Refactored addition of moisture to also account for the energy content of the - water vapor.
      - This is for IBPSA, issue 1209. + On a console window, type
      +   cd AixLib/Resources/weatherdata
      +   java -jar ../bin/ConvertWeatherData.jar inputFile.epw
      + 
      + if inputFile contains space in the name: +
      +   java -jar ../bin/ConvertWeatherData.jar \"inputFile .epw\"
      + 
      + This will generate the weather data file inputFile.mos, which can be read + by the model + + AixLib.BoundaryConditions.WeatherData.ReaderTMY3.
    • -
    • - September 24, 2019, by Martin Kremer:
      - Added possibility to consider moisture balance.
      - Defined volAir conditional. Added conditional volMoistAir and corresponding in- and output connectors. -
    • -
    • - July 11, 2019, by Katharina Brinkmann:
      - Renamed alphaRad to hRad, - alphaWin to hConWin, - alphaExt to hConExt, - alphaExtWallConst to hConExtWall_const, - alphaWinConst to hConWin_const -
    • -
    • - January 25, 2019, by Michael Wetter:
      - Added start value to avoid warning in JModelica. -
    • -
    • - September 26, 2016, by Moritz Lauster:
      - Added conditional statements to solar radiation part.
      - Deleted conditional statements of - splitFactor and splitFactorSolRad. -
    • -
    • - April 17, 2015, by Moritz Lauster:
      - First implementation. -
    • -
    - --------- Corrected Code -------- -

    - This model merges all thermal masses into one element, parameterized - by the length of the RC-chain nExt, the vector of the - capacities CExt[nExt] that is connected via the vector - of resistances RExt[nExt] and RExtRem to - the ambient and indoor air. By default, the model neglects all - internal thermal masses that are not directly connected to the - ambient. However, the thermal capacity of the room air can be - increased by using the parameter mSenFac. -

    -

    - The image below shows the RC-network of this model. -

    -

    - \"image\" -

    -
      -
    • March 7, 2022, by Michael Wetter:
      - Removed massDynamics.
      - This is for #1542. -
    • -
    • October 9, 2019, by Michael Wetter:
      - Refactored addition of moisture to also account for the energy - content of the water vapor.
      - This is for IBPSA, issue - 1209. -
    • -
    • September 24, 2019, by Martin Kremer:
      - Added possibility to consider moisture balance.
      - Defined volAir conditional. Added conditional - volMoistAir and corresponding in- and output - connectors. -
    • -
    • July 11, 2019, by Katharina Brinkmann:
      - Renamed alphaRad to hRad, - alphaWin to hConWin, - alphaExt to hConExt, - alphaExtWallConst to hConExtWall_const, - alphaWinConst to hConWin_const -
    • -
    • January 25, 2019, by Michael Wetter:
      - Added start value to avoid warning in JModelica. -
    • -
    • September 26, 2016, by Moritz Lauster:
      - Added conditional statements to solar radiation part.
      - Deleted conditional statements of splitFactor and - splitFactorSolRad. -
    • -
    • April 17, 2015, by Moritz Lauster:
      - First implementation. -
    • -
    - --------- Errors -------- -line 16 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource.mo ---- --------- HTML Code -------- - -

    - This function evaluates the finite line source solution. This solution - gives the relation between the constant heat transfer rate (per unit length) - injected by a line source of finite length H1 buried at a - distance D1 from a constant temperature surface - (T=0) and the average temperature raise over a line of finite length - H2 buried at a distance D2 from the constant - temperature surface. - The finite line source solution is defined by: -

    -

    - \"image\" -

    + + +

    Location data that are read automatically from the weather data file

    - where ΔT1-2(t,r,H1,D1,H2,D2) - is the temperature raise after a time t of constant heat injection and at - a distance r from the line heat source, Q' is the heat injection - rate per unit length, ks is the soil thermal conductivity and - hFLS is the finite line source solution. + The following location data are automatically read from the weather file:

    +
      +
    • + The latitude of the weather station, lat, +
    • +
    • + the longitude of the weather station, lon, and +
    • +
    • + the time zone relative to Greenwich Mean Time, timZone. +
    • +
    + +

    Wet bulb temperature

    - The finite line source solution is given by: -

    -

    - \"image\" + By default, the data bus contains the wet bulb temperature. + This introduces a nonlinear equation. + However, we have not observed an increase in computing time because + of this equation. + To disable the computation of the wet bulb temperature, set + computeWetBulbTemperature=false.

    + +

    Using constant or user-defined input signals for weather data

    - where αs is the ground thermal diffusivity and - erfint is the integral of the error function, defined in - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource_erfint. - The integral is solved numerically, with the integrand defined in - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource_Integrand. + This model has the option of using a constant value, using the data from the weather file, + or using data from an input connector for the following variables:

    -
    • - March 17, 2019, by Massimo Cimmino:
      - Modified the upper bound of integration to avoid underestimating the value of - the integral. - This is for - IBPSA, issue 1107. + The atmospheric pressure,
    • - March 22, 2018 by Massimo Cimmino:
      - First implementation. + the ceiling height, +
    • +
    • + the total sky cover, +
    • +
    • + the opaque sky cover, +
    • +
    • + the dry bulb temperature, +
    • +
    • + the dew point temperature, +
    • +
    • + the sky black body temperature, +
    • +
    • + the relative humidity, +
    • +
    • + the wind direction, +
    • +
    • + the wind speed, +
    • +
    • + the global horizontal radiation, direct normal and diffuse horizontal radiation, + and +
    • +
    • + the infrared horizontal radiation.
    - --------- Corrected Code -------- -

    - This function evaluates the finite line source solution. This - solution gives the relation between the constant heat transfer rate - (per unit length) injected by a line source of finite length - H1 buried at a distance D1 from a - constant temperature surface (T=0) and the average temperature - raise over a line of finite length H2 buried at a - distance D2 from the constant temperature surface. - The finite line source solution is defined by: -

    -

    - \"image\" -

    -

    - where - ΔT1-2(t,r,H1,D1,H2,D2) - is the temperature raise after a time t of constant heat - injection and at a distance r from the line heat source, - Q' is the heat injection rate per unit length, - ks is the soil thermal conductivity and - hFLS is the finite line source solution. -

    -

    - The finite line source solution is given by: -

    -

    - \"image\" -

    -

    - where αs is the ground thermal diffusivity and - erfint is the integral of the error function, defined in - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource_erfint. - The integral is solved numerically, with the integrand defined in - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource_Integrand. -

    -
      -
    • March 17, 2019, by Massimo Cimmino:
      - Modified the upper bound of integration to avoid underestimating - the value of the integral. This is for IBPSA, issue - 1107. -
    • -
    • March 22, 2018 by Massimo Cimmino:
      - First implementation. -
    • -
    - --------- Errors -------- -line 12 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 25 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Interfaces/PrescribedOutlet.mo ---- --------- HTML Code -------- -

    - This model sets the temperature or the water vapor mass fraction - of the medium that leaves port_a - to the value given by the input TSet or X_wSet, - subject to optional limitations on the capacity - for heating and cooling, or limitations on the humidification or dehumidification - moisture mass flow rate. - Also, optionally the model allows to take into account first order dynamics. + By default, all data are obtained from the weather data file, + except for the atmospheric pressure, which is set to the + parameter pAtm=101325 Pascals. +

    +

    + The parameter *Sou configures the source of the data. + For the atmospheric pressure, temperatures, relative humidity, wind speed and wind direction, + the enumeration + + AixLib.BoundaryConditions.Types.DataSource + is used as follows: +

    + + + + + + + + + + + + + + + + + + + + + +
    Parameter *Sou + Data used to compute weather data. +
    + File + + Use data from file. +
    + Parameter + + Use value specified by the parameter. +
    + Input + + Use value from the input connector. +
    +

    + Because global, diffuse and direct radiation are related to each other, the parameter + HSou is treated differently. + It is set to a value of the enumeration + + AixLib.BoundaryConditions.Types.RadiationDataSource, + and allows the following configurations: +

    + + + + + + + + + + + + + + + + + + + + + + + + +
    Parameter HSou + Data used to compute weather data. +
    + File + + Use data from file. +
    + Input_HGloHor_HDifHor + + Use global horizontal and diffuse horizontal radiation from input connector. +
    + Input_HDirNor_HDifHor + + Use direct normal and diffuse horizontal radiation from input connector. +
    + Input_HDirNor_HGloHor + + Use direct normal and global horizontal radiation from input connector. +
    + +

    Length of weather data and simulation period

    +

    + If weather data span a year, which is the default for TMY3 data, or multiple years, + then this model can be used for simulations that span multiple years. The simulation + start time needs to be set to the clock time of the respective start time. For example, + to start at January 2 at 10am, set start time to t=(24+10)*3600 seconds. + For this computation, the used date and time (here January 2, 10 am) must be expressed in the same time zone + as the one that is used to define the TMY3 file. This is usually the local (winter) time zone. + The parameter `timZon` represents the TMY3 file time zone, expressed in seconds compared to UTC. +

    +

    + Moreover, weather data need not span a whole year, or it can span across New Year. + In this case, the simulation cannot exceed the time of the weather data file. Otherwise, + the simulation stops with an error. +

    +

    + As weather data have one entry at the start of the time interval, the end time of the weather + data file is computed as the last time entry plus the average time increment of the file. + For example, an hourly weather data file has 8760 entries, starting on January 1 at 0:00. + The last entry in the file will be for December 31 at 23:00. As the time increment is 1 hour, + the model assumes the weather file to end at December 31 at 23:00 plus 1 hour, e.g., at January 1 at 0:00.

    + +

    Notes

    +
      +
    1. - If the parameters energyDynamics is not equal to - Modelica.Fluid.Types.Dynamics.SteadyState, - the component models the dynamic response using a first order differential equation. - The time constant of the component is equal to the parameter tau. - This time constant is adjusted based on the mass flow rate using + In HVAC systems, when the fan is off, changes in atmospheric pressure can cause small air flow rates + in the duct system due to change in pressure and hence in the mass of air that is stored + in air volumes (such as in fluid junctions or in the room model). + This may increase computing time. Therefore, the default value for the atmospheric pressure is set to a constant. + Furthermore, if the initial pressure of air volumes are different + from the atmospheric pressure, then fast pressure transients can happen in the first few seconds of the simulation. + This can cause numerical problems for the solver. To avoid this problem, set the atmospheric pressure to the + same value as the medium default pressure, which is typically set to the parameter Medium.p_default. + For medium models for moist air and dry air, the default is + Medium.p_default=101325 Pascals.

      -

      - τeff = τ |ṁ| ⁄ ṁnom +

    2. +
    3. +

      + Different units apply depending on whether data are obtained from a file, or + from a parameter or an input connector:

      +
        +
      • + When using TMY3 data from a file (e.g. USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.mos), the units must be the same as the original TMY3 file used by EnergyPlus (e.g. + USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.epw). + The TMY3 data used by EnergyPlus are in both SI units and non-SI units. + If Resources/bin/ConvertWeatherData.jar is used to convert the .epw file to an .mos file, the units of the TMY3 data are preserved and the file can be directly + used by this data reader. + The data reader will automatically convert units to the SI units used by Modelica. + For example, the dry bulb temperature TDryBul in TMY3 is in degree Celsius. + The data reader will automatically convert the data to Kelvin. + The wind direction winDir in TMY3 is degrees and will be automatically converted to radians. +
      • +
      • + When using data from a parameter or from an input connector, + the data must be in the SI units used by Modelica. + For instance, the unit must be + Pa for pressure, + K for temperature, + W/m2 for solar radiations and + rad for wind direction. +
      • +
      +
    4. +
    5. - where - τeff is the effective time constant for the given mass flow rate - and - τ is the time constant at the nominal mass flow rate - nom. - This type of dynamics is equal to the dynamics that a completely mixed - control volume would have. + Hourly and subhourly timestamp are handled in a different way in .epw files. + From the EnergyPlus Auxiliary Programs Document (v9.3.0, p. 63): + In hourly data the minute field can be 00 or 60. In this case as mentioned in the previous section, the weather data + is reported at the hourly value and the minute field has to be ignored, writing 1, 60 or 1, 00 is equivalent. + If the minute field is between 00 and 60, the file becomes subhourly, in this case the timestamp corresponds to the + minute field in the considered hour. For example: 1, 30 is equivalent to 00:30 and 3, 45 is equivalent to 02:45.
      + (Note the offset in the hour digit.)

      +
    6. +
    7. + The ReaderTMY3 should only be used with TMY3 data. It contains a time shift for solar radiation data + that is explained below. This time shift needs to be removed if the user may want to + use the ReaderTMY3 for other weather data types. +
    8. +
    +

    Implementation

    +
    Start and end data for annual weather data files

    - This model has no pressure drop. - See - AixLib.Fluid.HeatExchangers.PrescribedOutlet - for a model that instantiates this model and that has a pressure drop. + The TMY3 weather data, as well as the EnergyPlus weather data, start at 1:00 AM + on January 1, and provide hourly data until midnight on December 31. + Thus, the first entry for temperatures, humidity, wind speed etc. are values + at 1:00 AM and not at midnight. Furthermore, the TMY3 weather data files can have + values at midnight of December 31 that may be significantly different from the values + at 1:00 AM on January 1. + Since annual simulations require weather data that start at 0:00 on January 1, + data need to be provided for this hour. Due to the possibly large change in + weatherdata between 1:00 AM on January 1 and midnight at December 31, + the weather data files in the AixLib library do not use the data entry from + midnight at December 31 as the value for t=0. Rather, the + value from 1:00 AM on January 1 is duplicated and used for 0:00 on January 1. + To maintain a data record with 8760 hours, the weather data record from + midnight at December 31 is deleted. + These changes in the weather data file are done in the Java program + AixLib/Resources/bin/ConvertWeatherData.jar that converts + EnergyPlus weather data file to Modelica weather data files, and which is described + above. + The length of the weather data is calculated as the + end time stamp minus start time stamp plus average increment, where the + average increment is equal to the end time stamp minus start time stamp divided + by the number of rows minus 1. + This only works correctly for weather files with equidistant time stamps.

    +
    Time shift for solar radiation data

    - In case of reverse flow, - the fluid that leaves port_a has the same - properties as the fluid that enters port_b. + To read weather data from the TMY3 weather data file, there are + two data readers in this model. One data reader obtains all data + except solar radiation, and the other data reader reads only the + solar radiation data, shifted by 30 minutes. + The reason for this time shift is as follows: + The TMY3 weather data file contains for solar radiation the + \"...radiation received + on a horizontal surface during + the 60-minute period ending at + the timestamp.\" + + Thus, as the figure below shows, a more accurate interpolation is obtained if + time is shifted by 30 minutes prior to reading the weather data. +

    +

    + \"image\"

    +

    References

    +
      +
    • + Wilcox S. and W. Marion. Users Manual for TMY3 Data Sets. + Technical Report, NREL/TP-581-43156, revised May 2008. +
    • +
    • - March 3, 2022, by Michael Wetter:
      - Removed massDynamics.
      + September 6, 2021, by Ettore Zanetti:
      + Changed alt and lat to real inputs.
      This is for - issue 1542. + IBPSA, #1477.
    • - April 29, 2021, by Michael Wetter:
      - Removed duplicate declaration of m_flow_nominal which is already - declared in the base class.
      + May 2, 2021, by Ettore Zanetti:
      + Added altitude to parameters.
      + This is for + IBPSA, #1477.
    • - March 19, 2018, by Michael Wetter:
      - Added bugfix as the old model did not track TSet and X_wSet - simultaneously.
      + October 4, 2020, by Ettore Zanetti:
      + Updated documentation for Java weather file generator.
      This is for - #893. + #1396.
    • - May 3, 2017, by Michael Wetter:
      - Refactored model to allow X_wSet as an input.
      + August 20, 2019, by Filip Jorissen:
      + Better clarified the meaning of time in the documentation.
      This is for - #763. + #1192.
    • - January 26, 2016, by Michael Wetter:
      - Removed inequality comparison of real numbers in restrictCool - and in restrictHeat as this is not allowed in Modelica. + March 5, 2019, by Michael Wetter:
      + Updated documentation.
      + This is for + #842.
    • - November 10, 2014, by Michael Wetter:
      - First implementation. + September 20, 2018, by Michael Wetter:
      + Corrected documentation.
      + This is for + #1022. +
    • +
    • + December 4, 2017, by Michael Wetter:
      + Removed function call to getAbsolutePath, as this causes in Dymola 2018FD01 + the error + \"A call of loadResource with a non-literal string remains in the generated code; it will not work for an URI.\" + when exporting + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone + as an FMU. Instead, if the weather file is specified as a Modelica, URI, syntax such as + Modelica.Utilities.Files.loadResource(\"modelica://AixLib/Resources/weatherdata/USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.mos\") + should be used.
      + This is for + #867.
    • -
    - --------- Corrected Code -------- -

    - This model sets the temperature or the water vapor mass fraction of - the medium that leaves port_a to the value given by the - input TSet or X_wSet, subject to optional - limitations on the capacity for heating and cooling, or limitations - on the humidification or dehumidification moisture mass flow rate. - Also, optionally the model allows to take into account first order - dynamics. -

    -

    - If the parameters energyDynamics is not equal to - Modelica.Fluid.Types.Dynamics.SteadyState, the component - models the dynamic response using a first order differential - equation. The time constant of the component is equal to the - parameter tau. This time constant is adjusted based on - the mass flow rate using -

    -

    - τeff = τ |ṁ| ⁄ ṁnom -

    -

    - where τeff is the effective time constant for the - given mass flow rate and τ is the time constant at - the nominal mass flow rate nom. This type of - dynamics is equal to the dynamics that a completely mixed control - volume would have. -

    -

    - This model has no pressure drop. See AixLib.Fluid.HeatExchangers.PrescribedOutlet - for a model that instantiates this model and that has a pressure - drop. -

    -

    - In case of reverse flow, the fluid that leaves port_a - has the same properties as the fluid that enters port_b. -

    -
      -
    • March 3, 2022, by Michael Wetter:
      - Removed massDynamics.
      - This is for issue - 1542. -
    • -
    • April 29, 2021, by Michael Wetter:
      - Removed duplicate declaration of m_flow_nominal which - is already declared in the base class.
      -
    • -
    • March 19, 2018, by Michael Wetter:
      - Added bugfix as the old model did not track TSet and - X_wSet simultaneously.
      - This is for #893. -
    • -
    • May 3, 2017, by Michael Wetter:
      - Refactored model to allow X_wSet as an input.
      - This is for #763. -
    • -
    • January 26, 2016, by Michael Wetter:
      - Removed inequality comparison of real numbers in - restrictCool and in restrictHeat as this - is not allowed in Modelica. -
    • -
    • November 10, 2014, by Michael Wetter:
      - First implementation. -
    • -
    - --------- Errors -------- -line 18 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlow.mo ---- --------- HTML Code -------- - -

    • - October 20, 2017, by Michael Wetter:
      - Deleted various parameters and variables that were not used. -
      - Revised documentation to follow the guidelines. + February 18, 2017, by Filip Jorissen:
      + Infrared radiation on horizontal surface is now delayed by 30 minutes + such that the results in + TBlaSky + are consistent. + This is for + #648.
    • - May 19, 2016 by Marcus Fuchs:
      - Remove condition on show_V_flow for calculation of - V_flow to conform with pedantic checking. + December 06, 2016, by Thierry S. Nouidui:
      + Constrained the direct normal radiation to not be bigger than the solar constant when using + global and diffuse solar radiation data provided via the inputs connectors. + This is for + #608.
    • - October 10, 2015 by Marcus Fuchs:
      - Copy Icon from KUL implementation and rename model. + April 21, 2016, by Michael Wetter:
      + Introduced absFilNam to avoid multiple calls to + + AixLib.BoundaryConditions.WeatherData.BaseClasses.getAbsolutePath. + This is for + Buildings, #506.
    • - June 23, 2015 by Marcus Fuchs:
      - First implementation. + January 6, 2016, by Moritz Lauster:
      + Changed output radHorIR to HHorIR. + This is for + #376.
    • -
    - -

    - Model that computes the temperature propagation of - a fluid flow through a pipe, idealized as a plug flow. -

    -

    Main equation

    -

    - The transport delay is computed using the one-dimensional wave equation - without source or sink terms, -

    - ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0, -

    -

    where z(x,t) is the spatial distribution as a function of time of any - property z of the fluid. - For the temperature propagation, z will be replaced by T. -

    -

    Assumptions

    -

    - This model is based on the following assumptions: -

    -
    • - Axial diffusion in water is assumed to be negligibe. + January 4, 2016, by Moritz Lauster:
      + Added a table in documentation with output variables accessible via weaBus. + This is for + #376.
    • - The water temperature is assumed uniform in a cross section. + December 15, 2015, by Michael Wetter:
      + Added the block cheTemBlaSky. This also allows to graphically + connect the black body sky temperature to the weather bus, which is required + in Dymola 2016 for the variable weaBus.TBlaSky to appear + in the graphical editor. + This is for + #377. +
    • +
    • + September 24, 2015, by Marcus Fuchs:
      + Replace Dymola specific annotation by loadSelector + for MSL compliancy as reported by @tbeu at + RWTH-EBC/AixLib#107 +
    • +
    • + June 6, 2015, by Michael Wetter:
      + Removed redundant but consistent + connect(TBlaSkyCom.TBlaSky, weaBus.TBlaSky) + statement. + This avoids a warning if + + AixLib.BoundaryConditions.SolarIrradiation.BaseClasses.Examples.SkyClearness + is translated in pedantic mode in Dymola 2016. + This is for + #266. +
    • +
    • + March 26, 2015, by Michael Wetter:
      + Added option to obtain the black body sky temperature + from a parameter or an input signal. +
    • +
    • + October 17, 2014, by Michael Wetter:
      + Corrected error that led the total and opaque sky cover to be ten times + too low if its value was obtained from the parameter or the input connector. + For the standard configuration in which the sky cover is obtained from + the weather data file, the model was correct. This error only affected + the other two possible configurations. +
    • +
    • + September 12, 2014, by Michael Wetter:
      + Removed redundant connection connect(conHorRad.HOut, cheHorRad.HIn);. +
    • +
    • + May 30, 2014, by Michael Wetter:
      + Removed undesirable annotation Evaluate=true. +
    • +
    • + May 5, 2013, by Thierry S. Nouidui:
      + Added the option to use a constant, an input signal or the weather file as the source + for the ceiling height, the total sky cover, the opaque sky cover, the dew point temperature, + and the infrared horizontal radiation HInfHor. +
    • +
    • + October 8, 2013, by Michael Wetter:
      + Improved the algorithm that determines the absolute path of the file. + Now weather files are searched in the path specified, and if not found, the urls + file://, modelica:// and modelica://AixLib + are added in this order to search for the weather file. + This allows using the data reader without having to specify an absolute path, + as long as the AixLib library + is on the MODELICAPATH. + This change was implemented in + + AixLib.BoundaryConditions.WeatherData.BaseClasses.getAbsolutePath + and improves this weather data reader. +
    • +
    • + May 2, 2013, by Michael Wetter:
      + Added function call to getAbsolutePath. +
    • +
    • + October 16, 2012, by Michael Wetter:
      + Added computation of the wet bulb temperature. + Computing the wet bulb temperature introduces a nonlinear + equation. As we have not observed an increase in computing time + because of computing the wet bulb temperature, it is computed + by default. By setting the parameter + computeWetBulbTemperature=false, the computation of the + wet bulb temperature can be removed. + Revised documentation.
    • -
    - --------- Corrected Code -------- -
      -
    • October 20, 2017, by Michael Wetter:
      - Deleted various parameters and variables that were not used.
      - Revised documentation to follow the guidelines. -
    • -
    • May 19, 2016 by Marcus Fuchs:
      - Remove condition on show_V_flow for calculation of - V_flow to conform with pedantic checking. -
    • -
    • October 10, 2015 by Marcus Fuchs:
      - Copy Icon from KUL implementation and rename model. -
    • -
    • June 23, 2015 by Marcus Fuchs:
      - First implementation. -
    • -
    -

    - Model that computes the temperature propagation of a fluid flow - through a pipe, idealized as a plug flow. -

    -

    - Main equation -

    -

    - The transport delay is computed using the one-dimensional wave - equation without source or sink terms, -

    -

    - ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0, -

    -

    - where z(x,t) is the spatial distribution as a function of time - of any property z of the fluid. For the temperature - propagation, z will be replaced by T. -

    -

    - Assumptions -

    -

    - This model is based on the following assumptions: -

    -
      -
    • Axial diffusion in water is assumed to be negligibe. -
    • -
    • The water temperature is assumed uniform in a cross section. -
    • -
    - --------- Errors -------- -line 10 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Actuators/Valves/ThreeWayTable.mo ---- --------- HTML Code -------- - -

    - Three way valve with table-specified opening characteristics. - A separate characteristic for each flow path is used. -

    -

    - Each flow path uses an instance of the model - - AixLib.Fluid.Actuators.Valves.TwoWayTable. - Therefore, this model needs to be parameterized the same way as - - AixLib.Fluid.Actuators.Valves.TwoWayTable. - Specifically, - the mass flow rate for the fully open valve is determined based - on the value of the parameter CvData. - For the different valve positions y ∈ [0, 1], this nominal flow rate is - scaled by the values of the parameter - flowCharacteristics1 and flowCharacteristics3, respectively. - These parameters declare a table of the form -

    - - - - - - - -
    y 0 ... 1
    φ l ... 1
    -

    - where l = Kv(y=0)/Kv(y=1) > 0 is the valve leakage. - The first row is the valve opening, and the second row is the - mass flow rate, relative to the mass flow rate of the fully open - valve, under the assumption of a constant pressure difference across the - valve. - A suggested value for the valve leakage is l=0.0001. - If l = 0, then this model will replace it with - l = 10-8 for numerical reasons. - For example, if a valve has Kv=0.5 [m3/h/bar1/2] and - a linear opening characteristics and - a valve leakage of l=0.0001, then one would set -

    -
    -  CvData=AixLib.Fluid.Types.CvTypes.Kv
    -  Kv = 0.5
    -  flowCharacteristics1(y={0,1}, phi={0.0001,1})
    -  flowCharacteristics3(y={0,1}, phi={0.0001,1})
    - 
    -

    - Note, however, that - - AixLib.Fluid.Actuators.Valves.ThreeWayLinear provides a more - efficient implementation for this simple case. -

    -

    - The parameters flowCharacteristics1 and flowCharacteristics3 must meet the following - requirements, otherwise the model stops with an error: -

    -
    • - Their arrays - y and phi - must be strictly monotonic increasing. + August 11, 2012, by Wangda Zuo:
      + Renamed radHor to radHorIR and + improved the optional inputs for radiation data.
    • - The first value must satisfy - y[1]=0, and - phi[1] must be equal to the - leakage flow rate, which must be bigger than zero. - Otherwise, a default value of 1E-8 is used. + July 24, 2012, by Wangda Zuo:
      + Corrected the notes of SI unit requirements for input files.
    • - The last values must satisfy - y[end]=1 and - phi[end]=1. + July 13, 2012, by Michael Wetter:
      + Removed assignment of HGloHor_in in its declaration, + because this gives an overdetermined system if the input connector + is used. + Removed non-required assignments of attribute displayUnit.
    • -
    -

    - This model is based on the partial valve model - - AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve. - Check this model for more information, such - as the regularization near the origin. -

    -

    - For an example that specifies an opening characteristics, see - - AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable. -

    - - -
    • - March 7, 2022, by Michael Wetter:
      - Set final massDynamics=energyDynamics.
      - This is for - #1542. + February 25, 2012, by Michael Wetter:
      + Added subbus for solar position, which is needed by irradition and + shading model.
    • - June 10, 2021, by Michael Wetter:
      - Changed implementation of the filter and changed the parameter order to a constant - as most users need not change this value.
      - This is for - #1498. + November 29, 2011, by Michael Wetter:
      + Fixed wrong display unit for pAtm_in_internal and + made propagation of parameter final.
    • - November 28, 2019, by Michael Wetter:
      - Revised implementation. + October 27, 2011, by Wangda Zuo:
      +
        +
      1. + Added optional connectors for dry bulb temperature, relative humidity, wind speed, wind direction, global horizontal radiation, diffuse horizontal radiation.
      2. - November 15, 2019, by Alexander Kümpel:
        + Separate the unit conversion for TMY3 data and data validity check. +
      3. +
      +
    • +
    • + October 3, 2011, by Michael Wetter:
      + Propagated value for sky temperature calculation to make it accessible as a parameter. +
    • +
    • + July 20, 2011, by Michael Wetter:
      + Added the option to use a constant, an input signal or the weather file as the source + for the atmospheric pressure. +
    • + March 15, 2011, by Wangda Zuo:
      + Delete the wet bulb temperature since it may cause numerical problem. +
    • +
    • + March 7, 2011, by Wangda Zuo:
      + Added wet bulb temperature. Changed reader to read only needed columns. + Added explanation for 30 minutes shift for radiation data. +
    • +
    • + March 5, 2011, by Michael Wetter:
      + Changed implementation to obtain longitude and time zone directly + from weather file. +
    • +
    • + June 25, 2010, by Wangda Zuo:
      First implementation.
    -------- Corrected Code --------

    - Three way valve with table-specified opening characteristics. A - separate characteristic for each flow path is used. + Block to output the latitude of the location. This block is added so + that the latitude is displayed with a comment in the GUI of the + weather bus connector.

    +

    + Implementation +

    - Each flow path uses an instance of the model AixLib.Fluid.Actuators.Valves.TwoWayTable. - Therefore, this model needs to be parameterized the same way as - AixLib.Fluid.Actuators.Valves.TwoWayTable. - Specifically, the mass flow rate for the fully open valve is - determined based on the value of the parameter CvData. - For the different valve positions y ∈ [0, 1], this nominal - flow rate is scaled by the values of the parameter - flowCharacteristics1 and - flowCharacteristics3, respectively. These parameters - declare a table of the form + If Modelica.Blocks.Sources.Constant + where used, then the comment for the latitude would be \"Connector of + Real output signal\". As this documentation string cannot be + overwritten, a new block was implemented. +

    +
      +
    • January 4, 2016, by Michael Wetter:
      + First implementation. +
    • +
    +

    + Block to output the longitude of the location. This block is added so + that the longitude is displayed with a comment in the GUI of the + weather bus connector. +

    +

    + Implementation +

    +

    + If Modelica.Blocks.Sources.Constant + where used, then the comment for the longitude would be \"Connector of + Real output signal\". As this documentation string cannot be + overwritten, a new block was implemented. +

    +
      +
    • January 4, 2016, by Michael Wetter:
      + First implementation. +
    • +
    +

    + Block to output the altitude of the location. This block is added so + that the altitude is displayed with a comment in the GUI of the + weather bus connector. +

    +

    + Implementation +

    +

    + If Modelica.Blocks.Sources.Constant + where used, then the comment for the Altitude would be \"Connector of + Real output signal\". As this documentation string cannot be + overwritten, a new block was implemented. +

    +
      +
    • May 2, 2021, by Ettore Zanetti:
      + First implementation. +
    • +
    +

    + This component reads TMY3 weather data (Wilcox and Marion, 2008) or + user specified weather data. The Modelica built-in variable + time determines what row of the weather file is read. + The value of time is the number of seconds that have + passed since January 1st at midnight (00:00) in the local time zone. + The local time zone value, longitude and latitute are also read from + the weather data, such that the solar position computations are + consistent with the weather data. +

    +

    + The weather data format is the Typical Meteorological Year (TMY3) as + obtained from the EnergyPlus web site at http://energyplus.net/weather. + These data, which are in the EnergyPlus format, need to be converted + as described below. +

    +

    + Output to weaBus +

    +

    + The following variables serve as output and are accessible via + weaBus:

    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + -
    + Name + + Unit + + Description +
    + HDifHor + + W/m2 + + Horizontal diffuse solar radiation. +
    + HDifNor + + W/m2 + + Direct normal radiation. +
    + HGloHor + + W/m2 + + Horizontal global radiation. +
    + HHorIR + + W/m2 + + Horizontal infrared irradiation. +
    + TBlaSky + + K + + Output temperature. +
    - y + TDewPoi - 0 + K - ... + Dew point temperature. +
    + TDryBul + + K + + Dry bulb temperature at ground level. +
    + TWetBul + + K + + Wet bulb temperature. +
    + celHei + + m + + Ceiling height. +
    + cloTim + + s + + One-based day number in seconds. +
    + lat + + rad + + Latitude of the location. +
    + lon + + rad + + Longitude of the location. +
    + nOpa 1
    + Opaque sky cover [0, 1]. +
    - φ + nTot - l + 1 - ... + Total sky Cover [0, 1]. +
    + pAtm + + Pa + + Atmospheric pressure. +
    + relHum 1 + Relative humidity. +
    + solAlt + + rad + + Altitude angle. +
    + solDec + + rad + + Declination angle. +
    + solHouAng + + rad + + Solar hour angle. +
    + solTim + + s + + Solar time. +
    + solZen + + rad + + Zenith angle. +
    + winDir + + rad + + Wind direction. +
    + winSpe + + m/s + + Wind speed. +
    +
    +

    + Adding new weather data +

    - where l = Kv(y=0)/Kv(y=1) > 0 is the - valve leakage. The first row is the valve opening, and the second row - is the mass flow rate, relative to the mass flow rate of the fully - open valve, under the assumption of a constant pressure difference - across the valve. A suggested value for the valve leakage is - l=0.0001. If l = 0, then this model will replace it - with l = 10-8 for numerical reasons. For example, - if a valve has Kv=0.5 - [m3/h/bar1/2] and a linear opening - characteristics and a valve leakage of l=0.0001, then one - would set + To add new weather data, proceed as follows:

    -
    -  CvData=AixLib.Fluid.Types.CvTypes.Kv
    -  Kv = 0.5
    -  flowCharacteristics1(y={0,1}, phi={0.0001,1})
    -  flowCharacteristics3(y={0,1}, phi={0.0001,1})
    - 
    +
      +
    1. Download the weather data file with the epw + extension from http://energyplus.net/weather. +
    2. +
    3. Add the file to AixLib/Resources/weatherdata (or to + any directory for which you have write permission). +
    4. +
    5. On a console window, type +
      +   cd AixLib/Resources/weatherdata
      +   java -jar ../bin/ConvertWeatherData.jar inputFile.epw
      + 
      if inputFile contains space in the name: +
      +   java -jar ../bin/ConvertWeatherData.jar \"inputFile .epw\"
      + 
      This will generate the weather data file +inputFile.mos, which can be read by the model AixLib.BoundaryConditions.WeatherData.ReaderTMY3. +
    6. +
    +

    + Location data that are read automatically from the weather data file +

    - Note, however, that AixLib.Fluid.Actuators.Valves.ThreeWayLinear - provides a more efficient implementation for this simple case. + The following location data are automatically read from the weather + file:

    + +

    + Wet bulb temperature +

    +

    + By default, the data bus contains the wet bulb temperature. This + introduces a nonlinear equation. However, we have not observed an + increase in computing time because of this equation. To disable the + computation of the wet bulb temperature, set + computeWetBulbTemperature=false. +

    +

    + Using constant or user-defined input signals for weather data +

    - The parameters flowCharacteristics1 and - flowCharacteristics3 must meet the following - requirements, otherwise the model stops with an error: + This model has the option of using a constant value, using the data + from the weather file, or using data from an input connector for the + following variables:

    -

    - This model is based on the partial valve model AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve. - Check this model for more information, such as the regularization - near the origin. -

    -

    - For an example that specifies an opening characteristics, see - - AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable. -

    - - --------- Errors -------- -line 21 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/Fluid/HeatExchangers/BaseClasses/WetCoilDryWetRegime.mo ---- --------- HTML Code -------- - - - -

    - This model implements the switching algorithm for the dry and wet regime. -

    -

    - The switching criteria for (counter-flow) cooling coil modes are as follows.

    -

    - R1: If the coil surface temperature at the air inlet is lower than the dew-point - temperature at the inlet to the coil, then the cooling coil surface is fully-wet.

    -

    - R2: If the surface temperature at the air outlet section is higher than - the dew-point temperature of the air at the inlet, then the cooling coil surface is fully-dry.

    -

    - At each point of a simulation time step, the fuzzy-modeling approach determines - the weights for R1 and R2 respectively (namely μFW and μFD) - from the dew-point and coil surface temperatures.

    -

    - It calculates total and sensible heat transfer rates according to the weights as follows. -

    -

    - Q̇totFDtot,FDFW Qtot,FW -

    -

    - Q̇senFDsen,FDFW Qsen,FW -

    -

    - The fuzzy-modeling ensures μFW + μFD = 1, - μFW >=0 and μFD >=0, which means the fuzzy - model outcomes of sen and tot are always convex combinations of heat transfer - rates for fully-dry and fully-wet modes and therefore are always bounded by them. -

    -

    - The modeling approach also results in n-th order differentiable model - depending on the selection of the underlying membership functions. This cooling - coil model is once continuously differentiable at the mode switches. -

    - --------- Corrected Code -------- - -

    - This model implements the switching algorithm for the dry and wet - regime. -

    -

    - The switching criteria for (counter-flow) cooling coil modes are as - follows. -

    -

    - R1: If the coil surface temperature at the air inlet is lower than - the dew-point temperature at the inlet to the coil, then the cooling - coil surface is fully-wet. -

    -

    - R2: If the surface temperature at the air outlet section is higher - than the dew-point temperature of the air at the inlet, then the - cooling coil surface is fully-dry. -

    -

    - At each point of a simulation time step, the fuzzy-modeling approach - determines the weights for R1 and R2 respectively (namely - μFW and μFD) from the dew-point - and coil surface temperatures. -

    -

    - It calculates total and sensible heat transfer rates according to the - weights as follows. -

    -

    - Q̇totFDtot,FDFW - Qtot,FW -

    -

    - Q̇senFDsen,FDFW - Qsen,FW -

    -

    - The fuzzy-modeling ensures μFW + μFD = - 1, μFW >=0 and μFD >=0, - which means the fuzzy model outcomes of sen and - tot are always convex combinations of heat - transfer rates for fully-dry and fully-wet modes and therefore are - always bounded by them. -

    -

    - The modeling approach also results in n-th order - differentiable model depending on the selection of the underlying - membership functions. This cooling coil model is once continuously - differentiable at the mode switches. -

    - --------- Errors -------- -line 20 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 23 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/BoundaryConditions/Validation/BESTEST/WD300.mo ---- --------- HTML Code -------- - -

    - -

    WD300: Southern Hemisphere Case

    -

    Weather data file : WD300.epw

    -

    Table 1: Site Data for Weather file WD300.epw

    -
    - - - - - - - - - - - - - - - -

    Latitude

    33.393° south

    Longitude

    70.786° west

    Altitude

    474 m

    Time Zone

    -4

    - --------- Corrected Code -------- - -

    - WD300: Southern Hemisphere Case -

    - Weather data file : WD300.epw + By default, all data are obtained from the weather data file, except + for the atmospheric pressure, which is set to the parameter + pAtm=101325 Pascals. +

    +

    + The parameter *Sou configures the source of the data. + For the atmospheric pressure, temperatures, relative humidity, wind + speed and wind direction, the enumeration AixLib.BoundaryConditions.Types.DataSource + is used as follows:

    + + + + + + + + + + + + + + + + + + +
    + Parameter *Sou + + Data used to compute weather data. +
    + File + + Use data from file. +
    + Parameter + + Use value specified by the parameter. +
    + Input + + Use value from the input connector. +

    - Table 1: Site Data for Weather file WD300.epw + Because global, diffuse and direct radiation are related to each + other, the parameter HSou is treated differently. It is + set to a value of the enumeration AixLib.BoundaryConditions.Types.RadiationDataSource, + and allows the following configurations:

    - +
    + + + + + - + -
    + Parameter HSou + + Data used to compute weather data. +
    -

    - Latitude -

    + File
    -

    - 33.393° south -

    + Use data from file.
    -

    - Longitude -

    + Input_HGloHor_HDifHor
    -

    - 70.786° west -

    + Use global horizontal and diffuse horizontal radiation from input + connector.
    -

    - Altitude -

    + Input_HDirNor_HDifHor
    -

    - 474 m -

    + Use direct normal and diffuse horizontal radiation from input + connector.
    -

    - Time Zone -

    + Input_HDirNor_HGloHor
    -

    - -4 -

    + Use direct normal and global horizontal radiation from input + connector.
    - --------- Errors -------- -line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/Utilities/Math/Polynomial.mo ---- --------- HTML Code -------- - -

    This block computes a polynomial of arbitrary order. The polynomial has the form

    -

    y = a1 + a2 x + a3 x2 + ...

    - - - --------- Corrected Code -------- +
    +

    + Length of weather data and simulation period +

    - This block computes a polynomial of arbitrary order. The polynomial - has the form + If weather data span a year, which is the default for TMY3 data, or + multiple years, then this model can be used for simulations that span + multiple years. The simulation start time needs to be set to the + clock time of the respective start time. For example, to start at + January 2 at 10am, set start time to t=(24+10)*3600 + seconds. For this computation, the used date and time (here January + 2, 10 am) must be expressed in the same time zone as the one that is + used to define the TMY3 file. This is usually the local (winter) time + zone. The parameter `timZon` represents the TMY3 file time zone, + expressed in seconds compared to UTC. +

    +

    + Moreover, weather data need not span a whole year, or it can span + across New Year. In this case, the simulation cannot exceed the time + of the weather data file. Otherwise, the simulation stops with an + error. +

    +

    + As weather data have one entry at the start of the time interval, the + end time of the weather data file is computed as the last time entry + plus the average time increment of the file. For example, an hourly + weather data file has 8760 entries, starting on January 1 at 0:00. + The last entry in the file will be for December 31 at 23:00. As the + time increment is 1 hour, the model assumes the weather file to end + at December 31 at 23:00 plus 1 hour, e.g., at January 1 at 0:00. +

    +

    + Notes +

    +
      +
    1. +

      + In HVAC systems, when the fan is off, changes in atmospheric + pressure can cause small air flow rates in the duct system due to + change in pressure and hence in the mass of air that is stored in + air volumes (such as in fluid junctions or in the room model). + This may increase computing time. Therefore, the default value + for the atmospheric pressure is set to a constant. Furthermore, + if the initial pressure of air volumes are different from the + atmospheric pressure, then fast pressure transients can happen in + the first few seconds of the simulation. This can cause numerical + problems for the solver. To avoid this problem, set the + atmospheric pressure to the same value as the medium default + pressure, which is typically set to the parameter + Medium.p_default. For medium models for moist air + and dry air, the default is Medium.p_default=101325 + Pascals. +

      +
    2. +
    3. +

      + Different units apply depending on whether data are obtained from + a file, or from a parameter or an input connector: +

      +
        +
      • When using TMY3 data from a file (e.g. + USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.mos), the + units must be the same as the original TMY3 file used by + EnergyPlus (e.g. + USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.epw). The + TMY3 data used by EnergyPlus are in both SI units and non-SI + units. If Resources/bin/ConvertWeatherData.jar is + used to convert the .epw file to an + .mos file, the units of the TMY3 data are preserved + and the file can be directly used by this data reader. The data + reader will automatically convert units to the SI units used by + Modelica. For example, the dry bulb temperature + TDryBul in TMY3 is in degree Celsius. The data + reader will automatically convert the data to Kelvin. The wind + direction winDir in TMY3 is degrees and will be + automatically converted to radians. +
      • +
      • When using data from a parameter or from an input connector, + the data must be in the SI units used by Modelica. For instance, + the unit must be Pa for pressure, K for + temperature, W/m2 for solar radiations and + rad for wind direction. +
      • +
      +
    4. +
    5. +

      + Hourly and subhourly timestamp are handled in a different way in + .epw files. From the EnergyPlus Auxiliary Programs + Document (v9.3.0, p. 63): In hourly data the minute field can be + 00 or 60. In this case as mentioned in + the previous section, the weather data is reported at the hourly + value and the minute field has to be ignored, writing 1, + 60 or 1, 00 is equivalent. If the minute + field is between 00 and 60, the file + becomes subhourly, in this case the timestamp corresponds to the + minute field in the considered hour. For example: 1, + 30 is equivalent to 00:30 and 3, 45 is + equivalent to 02:45.
      + (Note the offset in the hour digit.) +

      +
    6. +
    7. The ReaderTMY3 should only be used with TMY3 data. It contains a + time shift for solar radiation data that is explained below. This + time shift needs to be removed if the user may want to use the + ReaderTMY3 for other weather data types. +
    8. +
    +

    + Implementation +

    +
    + Start and end data for annual weather data files +
    +

    + The TMY3 weather data, as well as the EnergyPlus weather data, start + at 1:00 AM on January 1, and provide hourly data until midnight on + December 31. Thus, the first entry for temperatures, humidity, wind + speed etc. are values at 1:00 AM and not at midnight. Furthermore, + the TMY3 weather data files can have values at midnight of December + 31 that may be significantly different from the values at 1:00 AM on + January 1. Since annual simulations require weather data that start + at 0:00 on January 1, data need to be provided for this hour. Due to + the possibly large change in weatherdata between 1:00 AM on January 1 + and midnight at December 31, the weather data files in the AixLib + library do not use the data entry from midnight at December 31 as the + value for t=0. Rather, the value from 1:00 AM on January 1 is + duplicated and used for 0:00 on January 1. To maintain a data record + with 8760 hours, the weather data record from midnight at + December 31 is deleted. These changes in the weather data file are + done in the Java program + AixLib/Resources/bin/ConvertWeatherData.jar that + converts EnergyPlus weather data file to Modelica weather data files, + and which is described above. The length of the weather data is + calculated as the end time stamp minus start time stamp plus average + increment, where the average increment is equal to the end time stamp + minus start time stamp divided by the number of rows minus 1. This + only works correctly for weather files with equidistant time stamps. +

    +
    + Time shift for solar radiation data +
    +

    + To read weather data from the TMY3 weather data file, there are two + data readers in this model. One data reader obtains all data except + solar radiation, and the other data reader reads only the solar + radiation data, shifted by 30 minutes. The reason for this + time shift is as follows: The TMY3 weather data file contains for + solar radiation the \"...radiation received on a horizontal surface + during the 60-minute period ending at the timestamp.\" Thus, as the + figure below shows, a more accurate interpolation is obtained if time + is shifted by 30 minutes prior to reading the weather data.

    - y = a1 + a2 x + a3 x2 + ... + \"image\"

    +

    + References +

    + - --------- Errors -------- -line 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FMI/ExportContainers/HVACZone.mo ---- --------- HTML Code -------- - -

    - Model that is used as a container for an HVAC system that is - to be exported as an FMU and that serves a single zone. -

    -

    Typical use and important parameters

    -

    - To use this model as a container for an FMU, extend - from this model, rather than instantiate it, - and add your HVAC system. By extending from this model, the top-level - signal connectors on the right stay at the top-level, and hence - will be visible at the FMI interface. - The example - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone - shows how a simple HVAC system can be implemented and exported as - an FMU. - -

    -

    - The conversion between the fluid ports and signal ports is done - in the HVAC adapter hvacAda. - This adapter has a vector of fluid ports called ports. - The supply and return air ducts, including any resistance model for the inlet - diffusor or exhaust grill, need to be connected to these ports. - Also, if a thermal zone has interzonal air exchange or air infiltration, - these flows need to be connected to ports. - This model outputs at the port fluPor the mass flow rate for - each flow that is connected to ports, together with its - temperature, water vapor mass fraction per total mass of the air (not per kg dry - air), and trace substances. These quantities are always as if the flow - enters the room, even if the flow is zero or negative. - If a medium has no moisture, e.g., if Medium.nXi=0, or - if it has no trace substances, e.g., if Medium.nC=0, then - the output signal for these properties are removed. - These quantities are always as if the flow - enters the room, even if the flow is zero or negative. - Thus, a thermal zone model that uses these signals to compute the - heat added by the HVAC system needs to implement an equation such as -

    -

    - Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), -

    -

    - where - Qsen is the sensible heat flow rate added to the thermal zone, - sup is the supply air mass flow rate from - the port fluPor (which is negative if it is an exhaust), - cp is the specific heat capacity at constant pressure, - Tsup is the supply air temperature and - Tair,zon is the zone air temperature. - Note that without the max(·, ·), the energy - balance would be wrong. -

    -

    - The input signals of this model are the zone radiative temperature. - The the zone air temperature, - the water vapor mass fraction per total mass of the air (unless Medium.nXi=0) - and trace substances (unless Medium.nC=0) are obtained from the connector - fluPor.backward. - The outflowing fluid stream(s) at the port ports will be at the - states obtained from fluPor.backward. - All fluid streams at port ports are at the same - pressure. - For convenience, the instance hvacAda also outputs the - properties obtained from fluPor.backward. These can be used - to connect a controller. The properties are available for each flow path in - fluPor.backward. For a thermal zone with mixed air, these are - all equal, while for a stratified room model, they can be different. -

    - -

    - See - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone - for a model that uses this model. -

    -

    - For models that multiple thermal zones connected to the HVAC system, - use the model - - AixLib.Fluid.FMI.ExportContainers.HVACZones. -

    -

    Assumption and limitations

    -

    - The mass flow rates at ports sum to zero, hence this - model conserves mass. -

    +
  • October 4, 2020, by Ettore Zanetti:
    + Updated documentation for Java weather file generator.
    + This is for #1396. +
  • +
  • August 20, 2019, by Filip Jorissen:
    + Better clarified the meaning of time in the + documentation.
    + This is for #1192. +
  • +
  • March 5, 2019, by Michael Wetter:
    + Updated documentation.
    + This is for #842. +
  • +
  • September 20, 2018, by Michael Wetter:
    + Corrected documentation.
    + This is for #1022. +
  • +
  • December 4, 2017, by Michael Wetter:
    + Removed function call to getAbsolutePath, as this + causes in Dymola 2018FD01 the error \"A call of loadResource with a + non-literal string remains in the generated code; it will not work + for an URI.\" when exporting + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone as + an FMU. Instead, if the weather file is specified as a Modelica, + URI, syntax such as + Modelica.Utilities.Files.loadResource(\"modelica://AixLib/Resources/weatherdata/USA_IL_Chicago-OHare.Intl.AP.725300_TMY3.mos\") + should be used.
    + This is for #867. +
  • +
  • February 18, 2017, by Filip Jorissen:
    + Infrared radiation on horizontal surface is now delayed by 30 + minutes such that the results in + TBlaSky are consistent. This is for #648. +
  • +
  • December 06, 2016, by Thierry S. Nouidui:
    + Constrained the direct normal radiation to not be bigger than the + solar constant when using global and diffuse solar radiation data + provided via the inputs connectors. This is for #608. +
  • +
  • April 21, 2016, by Michael Wetter:
    + Introduced absFilNam to avoid multiple calls to + + AixLib.BoundaryConditions.WeatherData.BaseClasses.getAbsolutePath. + This is for Buildings, + #506. +
  • +
  • January 6, 2016, by Moritz Lauster:
    + Changed output radHorIR to HHorIR. This + is for #376. +
  • +
  • January 4, 2016, by Moritz Lauster:
    + Added a table in documentation with output variables accessible via + weaBus. This is for #376. +
  • +
  • December 15, 2015, by Michael Wetter:
    + Added the block cheTemBlaSky. This also allows to + graphically connect the black body sky temperature to the weather + bus, which is required in Dymola 2016 for the variable + weaBus.TBlaSky to appear in the graphical editor. This + is for #377. +
  • +
  • September 24, 2015, by Marcus Fuchs:
    + Replace Dymola specific annotation by loadSelector for + MSL compliancy as reported by @tbeu at RWTH-EBC/AixLib#107 +
  • +
  • June 6, 2015, by Michael Wetter:
    + Removed redundant but consistent connect(TBlaSkyCom.TBlaSky, + weaBus.TBlaSky) statement. This avoids a warning if + AixLib.BoundaryConditions.SolarIrradiation.BaseClasses.Examples.SkyClearness + is translated in pedantic mode in Dymola 2016. This is for #266. +
  • +
  • March 26, 2015, by Michael Wetter:
    + Added option to obtain the black body sky temperature from a + parameter or an input signal. +
  • +
  • October 17, 2014, by Michael Wetter:
    + Corrected error that led the total and opaque sky cover to be ten + times too low if its value was obtained from the parameter or the + input connector. For the standard configuration in which the sky + cover is obtained from the weather data file, the model was + correct. This error only affected the other two possible + configurations. +
  • +
  • September 12, 2014, by Michael Wetter:
    + Removed redundant connection connect(conHorRad.HOut, + cheHorRad.HIn);. +
  • +
  • May 30, 2014, by Michael Wetter:
    + Removed undesirable annotation Evaluate=true. +
  • +
  • May 5, 2013, by Thierry S. Nouidui:
    + Added the option to use a constant, an input signal or the weather + file as the source for the ceiling height, the total sky cover, the + opaque sky cover, the dew point temperature, and the infrared + horizontal radiation HInfHor. +
  • +
  • October 8, 2013, by Michael Wetter:
    + Improved the algorithm that determines the absolute path of the + file. Now weather files are searched in the path specified, and if + not found, the urls file://, modelica:// + and modelica://AixLib are added in this order to + search for the weather file. This allows using the data reader + without having to specify an absolute path, as long as the + AixLib library is on the MODELICAPATH. + This change was implemented in + AixLib.BoundaryConditions.WeatherData.BaseClasses.getAbsolutePath + and improves this weather data reader. +
  • +
  • May 2, 2013, by Michael Wetter:
    + Added function call to getAbsolutePath. +
  • +
  • October 16, 2012, by Michael Wetter:
    + Added computation of the wet bulb temperature. Computing the wet + bulb temperature introduces a nonlinear equation. As we have not + observed an increase in computing time because of computing the wet + bulb temperature, it is computed by default. By setting the + parameter computeWetBulbTemperature=false, the + computation of the wet bulb temperature can be removed. Revised + documentation. +
  • +
  • August 11, 2012, by Wangda Zuo:
    + Renamed radHor to radHorIR and improved + the optional inputs for radiation data. +
  • +
  • July 24, 2012, by Wangda Zuo:
    + Corrected the notes of SI unit requirements for input files. +
  • +
  • July 13, 2012, by Michael Wetter:
    + Removed assignment of HGloHor_in in its declaration, + because this gives an overdetermined system if the input connector + is used. Removed non-required assignments of attribute + displayUnit. +
  • +
  • February 25, 2012, by Michael Wetter:
    + Added subbus for solar position, which is needed by irradition and + shading model. +
  • +
  • November 29, 2011, by Michael Wetter:
    + Fixed wrong display unit for pAtm_in_internal and made + propagation of parameter final. +
  • +
  • October 27, 2011, by Wangda Zuo:
    +
      +
    1. Added optional connectors for dry bulb temperature, relative + humidity, wind speed, wind direction, global horizontal + radiation, diffuse horizontal radiation.
      +
    2. +
    3. Separate the unit conversion for TMY3 data and data validity + check. +
    4. +
    +
  • +
  • October 3, 2011, by Michael Wetter:
    + Propagated value for sky temperature calculation to make it + accessible as a parameter. +
  • +
  • July 20, 2011, by Michael Wetter:
    + Added the option to use a constant, an input signal or the weather + file as the source for the atmospheric pressure. +
  • +
  • March 15, 2011, by Wangda Zuo:
    + Delete the wet bulb temperature since it may cause numerical + problem. +
  • +
  • March 7, 2011, by Wangda Zuo:
    + Added wet bulb temperature. Changed reader to read only needed + columns. Added explanation for 30 minutes shift for radiation data. +
  • +
  • March 5, 2011, by Michael Wetter:
    + Changed implementation to obtain longitude and time zone directly + from weather file. +
  • +
  • June 25, 2010, by Wangda Zuo:
    + First implementation. +
  • + + +-------- Errors -------- +line 24 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 425 column 2 - Warning: The summary attribute on the
    element is obsolete in HTML5 +line 469 column 2 - Warning: The summary attribute on the
    element is obsolete in HTML5 +line 640 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Movers/Validation/PowerExact.mo ---- +-------- HTML Code -------- +

    - This model does not impose any pressure, other than setting the pressure - of all fluid connections to ports to be equal. - The reason is that setting a pressure can lead to non-physical system models, - for example if a mass flow rate is imposed and the HVAC system is connected - to a model that sets a pressure boundary condition such as - - AixLib.Fluid.Sources.Outside. - Also, setting a pressure would make it impossible to use multiple instances - of this model (one for each thermal zone) and build in Modelica an airflow network - model with pressure driven mass flow rates. + This example is identical to + + AixLib.Fluid.Movers.Validation.PowerSimplified, except that the + performance data for the flow controlled pumps + pump_dp and pump_m_flow contain + the pressure curves and efficiency curves. + The plot below shows that this leads to a computation of the power consumption + that is identical to the one from the speed controlled pump pump_Nrpm.

    -

    - The model has no pressure drop. Hence, the pressure drop - of an air diffuser or of an exhaust grill needs to be modelled - in models that are connected to ports. +

    + \"image\"

    -------- Corrected Code --------

    - Model that is used as a container for an HVAC system that is to be - exported as an FMU and that serves a single zone. -

    -

    - Typical use and important parameters -

    -

    - To use this model as a container for an FMU, extend from this model, - rather than instantiate it, and add your HVAC system. By extending - from this model, the top-level signal connectors on the right stay at - the top-level, and hence will be visible at the FMI interface. The - example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone shows - how a simple HVAC system can be implemented and exported as an FMU. - -

    -

    - The conversion between the fluid ports and signal ports is done in - the HVAC adapter hvacAda. This adapter has a vector of - fluid ports called ports. The supply and return air - ducts, including any resistance model for the inlet diffusor or - exhaust grill, need to be connected to these ports. Also, if a - thermal zone has interzonal air exchange or air infiltration, these - flows need to be connected to ports. This model outputs - at the port fluPor the mass flow rate for each flow that - is connected to ports, together with its temperature, - water vapor mass fraction per total mass of the air (not per kg dry - air), and trace substances. These quantities are always as if the - flow enters the room, even if the flow is zero or negative. If a - medium has no moisture, e.g., if Medium.nXi=0, or if it - has no trace substances, e.g., if Medium.nC=0, then the - output signal for these properties are removed. These quantities are - always as if the flow enters the room, even if the flow is zero or - negative. Thus, a thermal zone model that uses these signals to - compute the heat added by the HVAC system needs to implement an - equation such as -

    -

    - Qsen = max(0, ṁsup)   cp   - (Tsup - Tair,zon), -

    -

    - where Qsen is the sensible heat flow rate added to - the thermal zone, sup is the supply air mass flow - rate from the port fluPor (which is negative if it is an - exhaust), cp is the specific heat capacity at - constant pressure, Tsup is the supply air - temperature and Tair,zon is the zone air - temperature. Note that without the max(·, ·), the energy - balance would be wrong. -

    -

    - The input signals of this model are the zone radiative temperature. - The the zone air temperature, the water vapor mass fraction per total - mass of the air (unless Medium.nXi=0) and trace - substances (unless Medium.nC=0) are obtained from the - connector fluPor.backward. The outflowing fluid - stream(s) at the port ports will be at the states - obtained from fluPor.backward. All fluid streams at port - ports are at the same pressure. For convenience, the - instance hvacAda also outputs the properties obtained - from fluPor.backward. These can be used to connect a - controller. The properties are available for each flow path in - fluPor.backward. For a thermal zone with mixed air, - these are all equal, while for a stratified room model, they can be - different. -

    -

    - See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone for a - model that uses this model. -

    -

    - For models that multiple thermal zones connected to the HVAC system, - use the model AixLib.Fluid.FMI.ExportContainers.HVACZones. -

    -

    - Assumption and limitations -

    -

    - The mass flow rates at ports sum to zero, hence this - model conserves mass. -

    -

    - This model does not impose any pressure, other than setting the - pressure of all fluid connections to ports to be equal. - The reason is that setting a pressure can lead to non-physical system - models, for example if a mass flow rate is imposed and the HVAC - system is connected to a model that sets a pressure boundary - condition such as AixLib.Fluid.Sources.Outside. - Also, setting a pressure would make it impossible to use multiple - instances of this model (one for each thermal zone) and build in - Modelica an airflow network model with pressure driven mass flow - rates. + This example is identical to AixLib.Fluid.Movers.Validation.PowerSimplified, + except that the performance data for the flow controlled pumps + pump_dp and pump_m_flow contain the + pressure curves and efficiency curves. The plot below shows that this + leads to a computation of the power consumption that is identical to + the one from the speed controlled pump pump_Nrpm.

    -

    - The model has no pressure drop. Hence, the pressure drop of an air - diffuser or of an exhaust grill needs to be modelled in models that - are connected to ports. +

    + \"image\"

    -------- Errors -------- -line 47 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 12 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Utilities/IO/SignalExchange/SignalTypes/SignalsForKPIs.mo ---- +---- AixLib/Fluid/HeatExchangers/ActiveBeams/BaseClasses/Convector.mo ---- -------- HTML Code --------

    - This enumeration defines the signal types that are used by BOPTEST - to compute the key performance indices (KPI). + In cooling mode, this model adds heat to the water stream. The heat added is equal to: +

    +

    + QBeam = Qrated fΔT fSA fW

    - The following signal types are supported. + In heating mode, the heat is removed from the water stream.

    -
    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    ValueDescription
    NoneNot used for KPI
    AirZoneTemperatureAir zone temperature
    RadiativeZoneTemperatureRadiative zone temperature
    OperativeZoneTemperatureOperative zone temperature
    RelativeHumidityRelative humidity
    CO2ConcentrationCO2 concentration
    ElectricPowerElectric power from grid
    DistrictHeatingPowerThermal power from district heating
    GasPowerThermal power from natural gas
    BiomassPowerThermal power from biomass
    SolarThermalPowerThermal power from solar thermal
    FreshWaterFlowRateFreshWaterFlowRate
    -------- Corrected Code --------

    - This enumeration defines the signal types that are used by BOPTEST to - compute the key performance indices (KPI). + In cooling mode, this model adds heat to the water stream. The heat + added is equal to: +

    +

    + QBeam = Qrated fΔT + fSA fW

    - The following signal types are supported. + In heating mode, the heat is removed from the water stream.

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - Value - - Description -
    - None - - Not used for KPI -
    - AirZoneTemperature - - Air zone temperature -
    - RadiativeZoneTemperature - - Radiative zone temperature -
    - OperativeZoneTemperature - - Operative zone temperature -
    - RelativeHumidity - - Relative humidity -
    - CO2Concentration - - CO2 concentration -
    - ElectricPower - - Electric power from grid -
    - DistrictHeatingPower - - Thermal power from district heating -
    - GasPower - - Thermal power from natural gas -
    - BiomassPower - - Thermal power from biomass -
    - SolarThermalPower - - Thermal power from solar thermal -
    - FreshWaterFlowRate - - FreshWaterFlowRate -
    -------- Errors -------- -line 9 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sources/Outside_CpData.mo ---- +---- AixLib/Fluid/Chillers/Carnot_TEva.mo ---- -------- HTML Code --------

    - This model describes boundary conditions for - pressure, enthalpy, and species concentration that can be obtained - from weather data. The model is identical to - - AixLib.Fluid.Sources.Outside, - except that it adds the wind pressure to the - pressure at the fluid ports ports. + This is a model of a chiller whose coefficient of performance COP changes + with temperatures in the same way as the Carnot efficiency changes. + The control input is the setpoint of the evaporator leaving temperature, which + is met exactly at steady state if the chiller has sufficient capacity.

    - The pressure p at the fluid ports is computed as: + The model allows to either specify the Carnot effectivness + ηCarnot,0, or + a COP0 + at the nominal conditions, together with + the evaporator temperature Teva,0 and + the condenser temperature Tcon,0, in which + case the model computes the Carnot effectivness as

    - p = pw + Cp,act Cs v2 ρ ⁄ 2, + ηCarnot,0 = + COP0 + ⁄ (Teva,0 ⁄ (Tcon,0-Teva,0)).

    - where pw is the atmospheric pressure from the weather bus, - v is the wind speed from the weather bus, and - ρ is the fluid density. + On the Advanced tab, a user can specify the temperatures that + will be used as the evaporator and condenser temperature.

    - The wind pressure coefficient Cp,act is a function of the surface wind incidence - angle and is defined relative to the surface azimuth (normal to the surface is 0). - The wind incidence angle incAng is computed from the wind direction obtained from the weather file - with the surface azimuth azi as the base of the angle. - The relation between the wind pressure coefficient Cp,act and the incidence angle incAng - is defined by a cubic hermite interpolation of the users table input. - Typical table values can be obtained from the "AIVC guide to energy efficient ventilation", - appendix 2 (1996). The default table is appendix 2, table 2.2, face 1. + During the simulation, the chiller COP is computed as the product +

    +

    + COP = ηCarnot,0 COPCarnot ηPL, +

    +

    + where COPCarnot is the Carnot efficiency and + ηPL is a polynomial in the cooling part load ratio yPL + that can be used to take into account a change in COP at part load + conditions. + This polynomial has the form +

    +

    + ηPL = a1 + a2 yPL + a3 yPL2 + ...

    - The wind speed modifier Cs can be used to incorporate the effect of the surroundings on the local wind speed. + where the coefficients ai + are declared by the parameter a.

    -

    Definition of angles

    - The angles incAngSurNor for the wind incidence angle relative to the surface normal - are measured counter-clock wise. - The figure below shows an example entry, which is also used in the model - - AixLib.Fluid.Sources.Examples.Outside_CpData_Specification. + On the Dynamics tag, the model can be parametrized to compute a transient + or steady-state response. + The transient response of the model is computed using a first + order differential equation for the evaporator and condenser fluid volumes. + The chiller outlet temperatures are equal to the temperatures of these lumped volumes.

    -

    \"image\"

    - +

    Typical use and important parameters

    - The wind incidence angle and surface azimuths are defined as follows: - The wind indicience angle is obtained directly from the weather data bus weaBus.winDir. - This variable contains the data from the weather data file that was read, such as a TMY3 file. - In accordance to TMY3, the data is as shown in the table below. + When using this component, make sure that the condenser has sufficient mass flow rate. + Based on the evaporator mass flow rate, temperature difference and the efficiencies, + the model computes how much heat will be added to the condenser. + If the mass flow rate is too small, very high outlet temperatures can result.

    -
    - - - - -
    Value of winDir if the wind blows from different directions.
    Wind from North:
    0
    Wind from West:
    3π/2
    270°
    Wind from East:
    π/2
    90°
    Wind from South:
    π
    180°

    - For the surface azimuth azi, the specification from - AixLib.Types.Azimuth is - used, which is as shown in the table below. + The evaporator heat flow rate QEva_flow_nominal is used to assign + the default value for the mass flow rates, which are used for the pressure drop + calculations. + It is also used to compute the part load efficiency. + Hence, make sure that QEva_flow_nominal is set to a reasonable value.

    - - - - - - -
    Value of azi if the exterior wall faces in the different directions.
    Wall facing north:
    π
    180°
    Wall facing West:
    π/2
    90°
    Wall facing east:
    3π/2
    270°
    Wall facing South:
    0;
    - -

    Related model

    - This model differs from - AixLib.Fluid.Sources.Outside_CpLowRise by the calculation of the wind pressure coefficient - Cp,act. - The wind pressure coefficient is defined by a user-defined table instead of a generalized equation - such that it can be used for all building sizes and situations, for shielded buildings, - and for buildings with non-rectangular shapes. + The maximum cooling capacity is set by the parameter QEva_flow_min, + which is by default set to negative infinity.

    - References + The coefficient of performance depends on the + evaporator and condenser leaving temperature + since otherwise the second law of thermodynamics may be violated. +

    +

    Notes

    +

    + For a similar model that can be used as a heat pump, see + + AixLib.Fluid.HeatPumps.Examples.Carnot_TCon.

    - -------- Corrected Code --------

    - This model describes boundary conditions for pressure, enthalpy, and - species concentration that can be obtained from weather data. The - model is identical to AixLib.Fluid.Sources.Outside, - except that it adds the wind pressure to the pressure at the fluid - ports ports. + This is a model of a chiller whose coefficient of performance COP + changes with temperatures in the same way as the Carnot efficiency + changes. The control input is the setpoint of the evaporator leaving + temperature, which is met exactly at steady state if the chiller has + sufficient capacity.

    - The pressure p at the fluid ports is computed as: + The model allows to either specify the Carnot effectivness + ηCarnot,0, or a COP0 at the + nominal conditions, together with the evaporator temperature + Teva,0 and the condenser temperature + Tcon,0, in which case the model computes the Carnot + effectivness as

    - p = pw + Cp,act Cs v2 ρ ⁄ - 2, + ηCarnot,0 = COP0 ⁄ (Teva,0 ⁄ + (Tcon,0-Teva,0)).

    - where pw is the atmospheric pressure from the - weather bus, v is the wind speed from the weather bus, and - ρ is the fluid density. + On the Advanced tab, a user can specify the temperatures + that will be used as the evaporator and condenser temperature.

    - The wind pressure coefficient Cp,act is a function - of the surface wind incidence angle and is defined relative to the - surface azimuth (normal to the surface is 0). The wind - incidence angle incAng is computed from the wind - direction obtained from the weather file with the surface azimuth - azi as the base of the angle. The relation between the - wind pressure coefficient Cp,act and the incidence - angle incAng is defined by a cubic hermite interpolation - of the users table input. Typical table values can be obtained from - the \"AIVC guide to energy efficient ventilation\", appendix 2 (1996). - The default table is appendix 2, table 2.2, face 1. + During the simulation, the chiller COP is computed as the product

    -

    - The wind speed modifier Cs can be used to - incorporate the effect of the surroundings on the local wind speed. +

    + COP = ηCarnot,0 COPCarnot ηPL,

    -

    - Definition of angles -

    - The angles incAngSurNor for the wind incidence angle - relative to the surface normal are measured counter-clock wise. The - figure below shows an example entry, which is also used in the model - - AixLib.Fluid.Sources.Examples.Outside_CpData_Specification. + where COPCarnot is the Carnot efficiency and + ηPL is a polynomial in the cooling part load ratio + yPL that can be used to take into account a change + in COP at part load conditions. This polynomial has the form

    -

    - \"image\" +

    + ηPL = a1 + a2 yPL + + a3 yPL2 + ...

    - The wind incidence angle and surface azimuths are defined as follows: - The wind indicience angle is obtained directly from the weather data - bus weaBus.winDir. This variable contains the data from - the weather data file that was read, such as a TMY3 file. In - accordance to TMY3, the data is as shown in the table below. + where the coefficients ai are declared by the + parameter a.

    - - - - - - - - - - - - - - - - - -
    - Value of winDir if the wind blows from different - directions. -
    - Wind from North:
    - 0
    - 0° -
    - Wind from West:
    - 3π/2
    - 270° -
    - Wind from East:
    - π/2
    - 90° -
    - Wind from South:
    - π
    - 180° -

    - For the surface azimuth azi, the specification from - AixLib.Types.Azimuth is - used, which is as shown in the table below. + On the Dynamics tag, the model can be parametrized to + compute a transient or steady-state response. The transient response + of the model is computed using a first order differential equation + for the evaporator and condenser fluid volumes. The chiller outlet + temperatures are equal to the temperatures of these lumped volumes.

    - - - - - - - - - - - - - - - - - -
    - Value of azi if the exterior wall faces in the - different directions. -
    - Wall facing north:
    - π
    - 180° -
    - Wall facing West:
    - π/2
    - 90° -
    - Wall facing east:
    - 3π/2
    - 270° -
    - Wall facing South:
    - 0;
    - 0° -

    - Related model + Typical use and important parameters

    - This model differs from AixLib.Fluid.Sources.Outside_CpLowRise - by the calculation of the wind pressure coefficient - Cp,act. The wind pressure coefficient is defined by - a user-defined table instead of a generalized equation such that it - can be used for all building sizes and situations, for shielded - buildings, and for buildings with non-rectangular shapes. + When using this component, make sure that the condenser has + sufficient mass flow rate. Based on the evaporator mass flow rate, + temperature difference and the efficiencies, the model computes how + much heat will be added to the condenser. If the mass flow rate is + too small, very high outlet temperatures can result.

    - References + The evaporator heat flow rate QEva_flow_nominal is used + to assign the default value for the mass flow rates, which are used + for the pressure drop calculations. It is also used to compute the + part load efficiency. Hence, make sure that + QEva_flow_nominal is set to a reasonable value. +

    +

    + The maximum cooling capacity is set by the parameter + QEva_flow_min, which is by default set to negative + infinity. +

    +

    + The coefficient of performance depends on the evaporator and + condenser leaving temperature since otherwise the second law of + thermodynamics may be violated. +

    +

    + Notes +

    +

    + For a similar model that can be used as a heat pump, see AixLib.Fluid.HeatPumps.Examples.Carnot_TCon.

    - -------- Errors -------- -line 51 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 -line 63 column 2 - Warning: The summary attribute on the
    element is obsolete in HTML5 -line 14 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 43 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 17 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 39 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/Heater_T.mo ---- +---- AixLib/ThermalZones/ReducedOrder/RC/OneElement.mo ---- -------- HTML Code --------

    - Model for an ideal heater that controls its outlet temperature to - a prescribed outlet temperature. -

    -

    - This model forces the outlet temperature at port_b to be - no lower than the temperature of the input signal - TSet, subject to optional limits on the - capacity. - By default, the model has unlimited heating capacity. -

    -

    - The output signal Q_flow is the heat added - to the medium if the mass flow rate is from port_a to port_b. - If the flow is reversed, then Q_flow=0. -

    -

    - The outlet conditions at port_a are not affected by this model, - other than for a possible pressure difference due to flow friction. -

    -

    - If the parameter energyDynamics is different from - Modelica.Fluid.Types.Dynamics.SteadyState, - the component models the dynamic response using a first order differential equation. - The time constant of the component is equal to the parameter tau. - This time constant is adjusted based on the mass flow rate using -

    -

    - τeff = τ |ṁ| ⁄ ṁnom -

    -

    - where - τeff is the effective time constant for the given mass flow rate - and - τ is the time constant at the nominal mass flow rate - nom. - This type of dynamics is equal to the dynamics that a completely mixed - control volume would have. -

    -

    - Optionally, this model can have a flow resistance. - Set dp_nominal = 0 to disable the flow friction calculation. -

    -

    - For a similar model that is a sensible cooling device, use - - AixLib.Fluid.HeatExchangers.SensibleCooler_T. - For a model that uses a control signal u ∈ [0, 1] and multiplies - this with the nominal heating or cooling power, use - - AixLib.Fluid.HeatExchangers.HeaterCooler_u - + This model merges all thermal masses into one + element, parameterized by the length of the RC-chain + nExt, the vector of the capacities CExt[nExt] that is + connected via the vector of resistances RExt[nExt] and + RExtRem to the ambient and indoor air. + By default, the model neglects all + internal thermal masses that are not directly connected to the ambient. + However, the thermal capacity of the room air can be increased by + using the parameter mSenFac.

    -

    Limitations

    - If the flow is from port_b to port_a, - then the enthalpy of the medium is not affected by this model. + The image below shows the RC-network of this model.

    -

    Validation

    -

    - The model has been validated against the analytical solution in - the examples - - AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet - and - - AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic. +

    + \"image\"/

    - + + +-------- Corrected Code -------- +

    + This model merges all thermal masses into one element, parameterized + by the length of the RC-chain nExt, the vector of the + capacities CExt[nExt] that is connected via the vector + of resistances RExt[nExt] and RExtRem to + the ambient and indoor air. By default, the model neglects all + internal thermal masses that are not directly connected to the + ambient. However, the thermal capacity of the room air can be + increased by using the parameter mSenFac. +

    +

    + The image below shows the RC-network of this model. +

    +

    + \"image\" +

    + + +-------- Errors -------- +line 16 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/ThermalZones/ReducedOrder/RC/TwoElements.mo ---- +-------- HTML Code -------- + +

    +

    This model distinguishes between internal + thermal masses and exterior walls. While exterior walls contribute to heat + transfer to the ambient, adiabatic conditions apply to internal masses. + Parameters for the internal wall element are the length of the RC-chain + nInt, the vector of the capacities + CInt[nInt] and the vector of the resistances RInt[nInt]. + This approach allows considering the dynamic behaviour induced by internal + heat storage. +

    +

    + The image below shows the RC-network of this model. +

    +

    + \"image\"/ +

    + -------- Corrected Code -------- -

    - Model for an ideal heater that controls its outlet temperature to a - prescribed outlet temperature. -

    -

    - This model forces the outlet temperature at port_b to be - no lower than the temperature of the input signal TSet, - subject to optional limits on the capacity. By default, the model has - unlimited heating capacity. -

    -

    - The output signal Q_flow is the heat added to the medium - if the mass flow rate is from port_a to - port_b. If the flow is reversed, then - Q_flow=0. -

    -

    - The outlet conditions at port_a are not affected by this - model, other than for a possible pressure difference due to flow - friction. -

    -

    - If the parameter energyDynamics is different from - Modelica.Fluid.Types.Dynamics.SteadyState, the component - models the dynamic response using a first order differential - equation. The time constant of the component is equal to the - parameter tau. This time constant is adjusted based on - the mass flow rate using -

    -

    - τeff = τ |ṁ| ⁄ ṁnom -

    -

    - where τeff is the effective time constant for the - given mass flow rate and τ is the time constant at - the nominal mass flow rate nom. This type of - dynamics is equal to the dynamics that a completely mixed control - volume would have. -

    -

    - Optionally, this model can have a flow resistance. Set - dp_nominal = 0 to disable the flow friction calculation. -

    -

    - For a similar model that is a sensible cooling device, use AixLib.Fluid.HeatExchangers.SensibleCooler_T. - For a model that uses a control signal u ∈ [0, 1] and - multiplies this with the nominal heating or cooling power, use - AixLib.Fluid.HeatExchangers.HeaterCooler_u -

    -

    - Limitations -

    -

    - If the flow is from port_b to port_a, then - the enthalpy of the medium is not affected by this model. -

    -

    - Validation -

    -

    - The model has been validated against the analytical solution in the - examples AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet - and - AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic. -

    +

    + This model distinguishes between internal thermal masses and exterior + walls. While exterior walls contribute to heat transfer to the + ambient, adiabatic conditions apply to internal masses. Parameters + for the internal wall element are the length of the RC-chain + nInt, the vector of the capacities + CInt[nInt] and the vector of the resistances + RInt[nInt]. This approach allows considering the dynamic + behaviour induced by internal heat storage. +

    +

    + The image below shows the RC-network of this model. +

    +

    + \"image\" +

    -------- Errors -------- -line 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 14 column 4 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/SensibleCooler_T.mo ---- +---- AixLib/Fluid/HeatPumps/ScrollWaterToWater.mo ---- -------- HTML Code --------

    - Model for an ideal sensible-only cooler that controls its outlet temperature to - a prescribed outlet temperature. + Model for a water to water heat pump with a scroll compressor, as described + in Jin (2002). The thermodynamic heat pump cycle is represented below.

    -

    - This model forces the outlet temperature at port_b to be - no higher than the temperature of the input signal - TSet, subject to optional limits on the - capacity. - By default, the model has unlimited cooling capacity. +

    + \"image\"

    - The output signal Q_flow ≤ 0 is the heat added - to the medium if the mass flow rate is from port_a to port_b. - If the flow is reversed, then Q_flow=0. + The rate of heat transferred to the evaporator is given by:

    -

    - The outlet conditions at port_a are not affected by this model, - other than for a possible pressure difference due to flow friction. +

    + Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ).

    - If the parameter energyDynamics is different from - Modelica.Fluid.Types.Dynamics.SteadyState, - the component models the dynamic response using a first order differential equation. - The time constant of the component is equal to the parameter tau. - This time constant is adjusted based on the mass flow rate using + The power consumed by the compressor is given by a linear efficiency relation:

    - τeff = τ |ṁ| ⁄ ṁnom + P = PTheoretical / η + PLoss,constant.

    - where - τeff is the effective time constant for the given mass flow rate - and - τ is the time constant at the nominal mass flow rate - nom. - This type of dynamics is equal to the dynamics that a completely mixed - control volume would have. + Heat transfer in the evaporator and condenser is calculated using an + ε-NTU method, assuming constant refrigerant temperature and constant heat + transfer coefficient between fluid and refrigerant.

    - Optionally, this model can have a flow resistance. - Set dp_nominal = 0 to disable the flow friction calculation. + Variable speed is achieved by multiplying the full load suction volume flow rate + by the normalized compressor speed. The power and heat transfer rates are forced + to zero if the resulting heat pump state has higher evaporating pressure than + condensing pressure.

    - For a similar model that is a heater, use - - AixLib.Fluid.HeatExchangers.Heater_T. - For a model that uses a control signal u ∈ [0, 1] and multiplies - this with the nominal heating or cooling power, use - - AixLib.Fluid.HeatExchangers.HeaterCooler_u. + The model parameters are obtained by calibration of the heat pump model to + manufacturer performance data. Calibrated model parameters for various heat + pumps from different manufacturers are found in + + AixLib.Fluid.HeatPumps.Data.ScrollWaterToWater. The calibrated model is + located in + + AixLib.Fluid.HeatPumps.Calibration.ScrollWaterToWater.

    -

    Limitations

    +

    Options

    - If the flow is from port_b to port_a, - then the enthalpy of the medium is not affected by this model. + Parameters TConMax and TEvaMin + may be used to set an upper or lower bound for the + condenser and evaporator. + The compressor is disabled when these conditions + are not satisfied, or when the + evaporator temperature is larger + than the condenser temperature. + This mimics the temperature protection + of heat pumps and moreover it avoids + non-converging algebraic loops of equations, + or freezing of evaporator medium. + This option can be disabled by setting + enable_temperature_protection = false.

    +

    Assumptions and limitations

    - This model does not affect the humidity of the air. Therefore, - if used to cool air below the dew point temperature, the water mass fraction - will not change. + The compression process is assumed isentropic. The thermal energy + of superheating is ignored in the evaluation of the heat transferred to the refrigerant + in the evaporator. There is no supercooling.

    -

    Validation

    +

    References

    - The model has been validated against the analytical solution in - the examples - - AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet - and - - AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic. + H. Jin. + + Parameter estimation based models of water source heat pumps. + + PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002.

    - -
    + + + + + + + + + + + + + + + +

    Latitude

    39.833° north

    Longitude

    104.65° west

    Altitude

    1650 m

    Time Zone

    -7

    +

    This model is a template for all the other test cases. + It allows to extrapolate all the weather data from the Reader TMY3 for a specific location, incliation and azimuth. + The model + AixLib.BoundaryConditions.Validation.IsotropicAndPerezDiffuseRadiation + outputs radiation data using the available Isotropic and Perez methodlogies. + The sky temperature is calculated using both the Horizontal radiation model, + from data reader weaBusHorRad and the dew point temperature plus sky cover model from the datareader weaBusSkyCovDewTem.

    + + + +-------- Corrected Code -------- +

    + WD100: Base Case +

    +

    + Weather data file : WD100.epw +

    +

    + Table 1: Site Data for Weather file WD100.epw +

    + + + + + + + + + + + + + + + + + +
    +

    + Latitude +

    +
    +

    + 39.833° north +

    +
    +

    + Longitude +

    +
    +

    + 104.65° west +

    +
    +

    + Altitude +

    +
    +

    + 1650 m +

    +
    +

    + Time Zone +

    +
    +

    + -7 +

    +
    +

    + This model is a template for all the other test cases. It allows to + extrapolate all the weather data from the Reader TMY3 for a specific + location, incliation and azimuth. The model + AixLib.BoundaryConditions.Validation.IsotropicAndPerezDiffuseRadiation + outputs radiation data using the available Isotropic and Perez + methodlogies. The sky temperature is calculated using both the + Horizontal radiation model, from data reader weaBusHorRad and the dew + point temperature plus sky cover model from the datareader + weaBusSkyCovDewTem. +

    + -------- Errors -------- -line 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/Boreholes/BaseClasses/Functions/convectionResistanceCircularPipe.mo ---- +---- AixLib/Media/Specialized/Air/PerfectGas.mo ---- -------- HTML Code -------- + Function to set the state for given pressure, enthalpy and species concentration. + + The thermodynamic state record + is computed from density d, temperature T and composition X. + + Saturation pressure of water above the triple point temperature is computed from temperature. It's range of validity is between + 273.16 and 373.16 K. Outside these limits a less accurate result is returned. + + Derivative function of + + AixLib.Media.Specialized.Air.PerfectGas.saturationPressureLiquid + + Pressure is returned from the thermodynamic state record input as a simple assignment. + + Temperature is returned from the thermodynamic state record input as a simple assignment. + + Density is computed from pressure, temperature and composition in the thermodynamic state record applying the ideal gas law. + + Specific entropy is calculated from the thermodynamic state record, assuming ideal gas behavior and including entropy of mixing. Liquid or solid water is not taken into account, the entire water content X[1] is assumed to be in the vapor state (relative humidity below 1.0). + + Temperature as a function of specific enthalpy and species concentration. + The pressure is input for compatibility with the medium models, but the temperature + is independent of the pressure. +

    - This model computes the convection resistance in the pipes of a borehole segment - with heigth hSeg using correlations suggested by Bergman et al. (2011). -

    -

    - If the flow is laminar (Re ≤ 2300, with Re being the Reynolds number of the flow), - the Nusselt number of the flow is assumed to be constant at 3.66. If the flow is turbulent (Re > 2300), - the correlation of Dittus-Boelter is used to find the convection heat transfer coefficient as -

    -

    - Nu = 0.023   Re0.8   Prn, -

    -

    - where Nu is the Nusselt number and - Pr is the Prandlt number. - A value of n=0.35 is used, as the reference uses n=0.4 for heating and - n=0.3 for cooling. To ensure that the function is continuously differentiable, - a smooth transition between the laminar and turbulent values is created for the - range 2300 < Re < 2400. -

    -

    References

    -

    - Bergman, T. L., Incropera, F. P., DeWitt, D. P., & Lavine, A. S. (2011). Fundamentals of heat and mass - transfer (7th ed.). New York: John Wiley & Sons. + This data record contains the coefficients for perfect gases.

    --------- Corrected Code -------- -

    - This model computes the convection resistance in the pipes of a - borehole segment with heigth hSeg using - correlations suggested by Bergman et al. (2011). -

    -

    - If the flow is laminar (Re ≤ 2300, with Re being the - Reynolds number of the flow), the Nusselt number of the flow is - assumed to be constant at 3.66. If the flow is turbulent (Re > - 2300), the correlation of Dittus-Boelter is used to find the - convection heat transfer coefficient as -

    -

    - Nu = 0.023   Re0.8   Prn, -

    -

    - where Nu is the Nusselt number and Pr is the Prandlt - number. A value of n=0.35 is used, as the reference uses - n=0.4 for heating and n=0.3 for cooling. To ensure that - the function is continuously differentiable, a smooth transition - between the laminar and turbulent values is created for the range - 2300 < Re < 2400. -

    -

    - References -

    -

    - Bergman, T. L., Incropera, F. P., DeWitt, D. P., & Lavine, A. S. - (2011). Fundamentals of heat and mass transfer (7th ed.). New - York: John Wiley & Sons. -

    - - --------- Errors -------- -line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/cylindricalHeatSource.mo ---- --------- HTML Code -------- - -

    - This function evaluates the cylindrical heat source solution. This solution - gives the relation between the constant heat transfer rate (per unit length) - injected by a cylindrical heat source of infinite length and the temperature - raise in the medium. The cylindrical heat source solution is defined by -

    -

    - \"image\" -

    -

    - where ΔT(t,r) is the temperature raise after a time t of - constant heat injection and at a distance r from the cylindrical source, - Q' is the heat injection rate per unit length, ks is - the soil thermal conductivity, Fo is the Fourier number, - aSois is the ground thermal diffusivity, - rb is the radius of the cylindrical source and G - is the cylindrical heat source solution. -

    - The cylindrical heat source solution is given by: -

    -

    - \"image\" + This package contains a thermally perfect model of moist air.

    - The integral is solved numerically, with the integrand defined in - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource_Integrand. + A medium is called thermally perfect if

    - - - --------- Corrected Code -------- -

    - This function evaluates the cylindrical heat source solution. This - solution gives the relation between the constant heat transfer rate - (per unit length) injected by a cylindrical heat source of infinite - length and the temperature raise in the medium. The cylindrical heat - source solution is defined by -

    -

    - \"image\" -

    -

    - where ΔT(t,r) is the temperature raise after a time t - of constant heat injection and at a distance r from the - cylindrical source, Q' is the heat injection rate per unit - length, ks is the soil thermal conductivity, - Fo is the Fourier number, aSois is the - ground thermal diffusivity, rb is the radius of the - cylindrical source and G is the cylindrical heat source - solution. -

    -

    - The cylindrical heat source solution is given by: -

    -

    - \"image\" -

    -

    - The integral is solved numerically, with the integrand defined in - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource_Integrand. -

    - - --------- Errors -------- -line 8 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 23 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Controls/Continuous/Examples/NumberOfRequests.mo ---- --------- HTML Code -------- -

    -

    - Example that demonstrates the use of the block - - AixLib.Controls.Continuous.NumberOfRequests. - The parameters of the block are such that the output is incremented - for each input signal that is strictly larger than 0. - The figure below shows the inputs and the output of the block. -

    -

    - \"Simulation + In addition, this medium model is calorically perfect, i.e., the + specific heat capacities at constant pressure cp + and constant volume cv are both constant (Bower 1998).

    - --------- Corrected Code -------- - -

    - Example that demonstrates the use of the block AixLib.Controls.Continuous.NumberOfRequests. - The parameters of the block are such that the output is incremented - for each input signal that is strictly larger than 0. The - figure below shows the inputs and the output of the block. -

    -

    - \"Simulation -

    - --------- Errors -------- -line 10 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowTransportDelay.mo ---- --------- HTML Code -------- -

    - Calculates time delay at both sides of the pipe as the difference between the - current simulation time and the inlet time of the fluid at both ends of the pipe. + This medium uses the ideal gas law

    -

    Main equation

    -

    - ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0, +

    + ρ = p ⁄(R T),

    - where z(x,t) is the spatial distribution as a function of time of any - property z of the fluid. For the inlet time propagation, z will - be replaced by the inlet time of the fluid tin. + where + ρ is the density, + p is the pressure, + R is the gas constant and + T is the temperature.

    -

    Implementation

    - The inlet time is approached as a fluid property and its propagation follows - the one-dimensional wave equation, implemented using the spatialDistribution - function. This components requires the mass flow through the pipe and the pipe - dimensions in order to derive information about the fluid propagation. + The enthalpy is computed using the convention that h=0 + if T=0 °C and no water vapor is present.

    - The component calculates the delay time at the inlet and the outlet port of the pipe. - For the forward flow, the time delay is exposed at the output tau, - and for the backward flow, the time delay is exposed at the output tauRev. + Note that for typical building simulations, the media + AixLib.Media.Air + should be used as it leads generally to faster simulation.

    -

    Assumption

    +

    References

    - No axial mixing takes place in the pipe. + Bower, William B. A primer in fluid mechanics: Dynamics of flows in one + space dimension. CRC Press. 1998.

    -------- Corrected Code -------- +Function to set the state for given pressure, enthalpy and species +concentration. +The thermodynamic state record is computed from density d, temperature +T and composition X. +Saturation pressure of water above the triple point temperature is +computed from temperature. It's range of validity is between 273.16 and +373.16 K. Outside these limits a less accurate result is returned. +Derivative function of +AixLib.Media.Specialized.Air.PerfectGas.saturationPressureLiquid +Pressure is returned from the thermodynamic state record input as a +simple assignment. +Temperature is returned from the thermodynamic state record input as a +simple assignment. +Density is computed from pressure, temperature and composition in the +thermodynamic state record applying the ideal gas law. +Specific entropy is calculated from the thermodynamic state record, +assuming ideal gas behavior and including entropy of mixing. Liquid or +solid water is not taken into account, the entire water content X[1] is +assumed to be in the vapor state (relative humidity below 1.0). +Temperature as a function of specific enthalpy and species +concentration. The pressure is input for compatibility with the medium +models, but the temperature is independent of the pressure.

    - Calculates time delay at both sides of the pipe as the difference - between the current simulation time and the inlet time of the fluid - at both ends of the pipe. + This data record contains the coefficients for perfect gases.

    -

    - Main equation -

    -

    - ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0, +

    +

    + This package contains a thermally perfect model of moist air.

    - where z(x,t) is the spatial distribution as a function of time - of any property z of the fluid. For the inlet time - propagation, z will be replaced by the inlet time of the fluid - tin. + A medium is called thermally perfect if

    -

    - Implementation -

    +

    - The inlet time is approached as a fluid property and its propagation - follows the one-dimensional wave equation, implemented using the - spatialDistribution function. This components requires the mass flow - through the pipe and the pipe dimensions in order to derive - information about the fluid propagation. + In addition, this medium model is calorically perfect, i.e., + the specific heat capacities at constant pressure + cp and constant volume cv are + both constant (Bower 1998).

    - The component calculates the delay time at the inlet and the outlet - port of the pipe. For the forward flow, the time delay is exposed at - the output tau, and for the backward flow, the time - delay is exposed at the output tauRev. + This medium uses the ideal gas law +

    +

    + ρ = p ⁄(R T), +

    +

    + where ρ is the density, p is the pressure, R is + the gas constant and T is the temperature. +

    +

    + The enthalpy is computed using the convention that h=0 if + T=0 °C and no water vapor is present. +

    +

    + Note that for typical building simulations, the media AixLib.Media.Air should be used as + it leads generally to faster simulation.

    - Assumption + References

    - No axial mixing takes place in the pipe. + Bower, William B. A primer in fluid mechanics: Dynamics of flows + in one space dimension. CRC Press. 1998.

    -------- Errors -------- -line 7 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 25 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Media/Specialized/Water/TemperatureDependentDensity.mo ---- +---- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_dp.mo ---- -------- HTML Code -------- -

    - Base properties of the medium. -

    - -

    - This function computes the density as a function of temperature. -

    -

    Implementation

    -

    - The function is based on the IDA implementation in therpro.nmf, which - implements -

    -
    - d := 1000.12 + 1.43711e-2*T_degC -
    -  5.83576e-3*T_degC^2 + 1.5009e-5*T_degC^3;
    -  
    -

    - This has been converted to Kelvin, which resulted in the above expression. - In addition, below 5 °C and above 100 °C, the density is replaced - by a linear function to avoid inflection points. - This linear extension is such that the density is once continuously differentiable. -

    - - - -

    - This function computes the dynamic viscosity. -

    - - - -

    - This function computes the specific enthalpy. -

    - - - -

    - This function computes the specific enthalpy of liquid water. -

    - - - -

    - This function computes the specific internal energy. -

    - - - -

    - This function computes the specific entropy. -

    -

    - To obtain the state for a given pressure, entropy and mass fraction, use - - AixLib.Media.Air.setState_psX. -

    - - - -

    - This function computes the specific Gibbs energy. -

    - - - -

    - This function computes the specific Helmholtz energy. -

    - - - -

    - This function computes the specific enthalpy for - an isentropic state change from the temperature - that corresponds to the state refState - to reference_T. -

    - - -

    - This function returns the isobaric expansion coefficient, + Function that computes the pressure drop of flow elements as

    - βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p, -

    -

    - where - v is the specific volume, - T is the temperature and - p is the pressure. + m = sign(Δp) k √ Δp  

    - - -

    - This function returns the isothermal compressibility coefficient, - which is zero as this medium is incompressible. - The isothermal compressibility is defined as + with regularization near the origin. + Therefore, the flow coefficient is

    - κT = - 1 ⁄ v   (∂ v ⁄ ∂ p)T, + k = m ⁄ √ Δp  

    - where - v is the specific volume, - T is the temperature and - p is the pressure. + The input m_flow_turbulent determines the location of the regularization.

    - -

    - This function returns the partial derivative of density - with respect to pressure at constant temperature, - which is zero as the medium is incompressible. -

    - - - -

    - This function computes the derivative of density with respect to temperature - at constant pressure. -

    - - - -

    - This function returns the partial derivative of density - with respect to mass fraction, - which is zero as the medium is a single substance. -

    - - - -

    - This function returns the specific heat capacity at constant pressure. -

    - - - -

    - This function computes the specific heat capacity at constant volume. -

    - - - -

    - This function returns the thermal conductivity. - The expression is obtained from Ramires et al. (1995). -

    -

    References

    -

    - Ramires, Maria L. V. and Nieto de Castro, Carlos A. and Nagasaka, Yuchi - and Nagashima, Akira and Assael, Marc J. and Wakeham, William A. - Standard Reference Data for the Thermal Conductivity of Water. - Journal of Physical and Chemical Reference Data, 24, p. 1377-1381, 1995. - DOI:10.1063/1.555963. -

    - - - -

    - This function returns the pressure. -

    - - - -

    - This function returns the temperature. -

    - - - -

    - This function returns the molar mass, - which is assumed to be constant. -

    - - - -

    - This function returns the thermodynamic state for a given pressure, - specific enthalpy and composition. -

    - - +-------- Corrected Code -------- +

    + Function that computes the pressure drop of flow elements as +

    +

    + m = sign(Δp) k √ Δp +   +

    +

    + with regularization near the origin. Therefore, the flow coefficient + is +

    +

    + k = m ⁄ √ Δp +   +

    +

    + The input m_flow_turbulent determines the location of + the regularization. +

    + + +-------- Errors -------- +line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 12 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/ExteriorWall.mo ---- +-------- HTML Code -------- + +

    ExteriorWall represents heat conduction and heat storage + within walls. It links a variable number n of thermal resistances + and capacities to a series connection. n thus defines the spatial + discretization of thermal effects within the wall. All effects are considered + as one-dimensional normal to the wall's surface. This model is thought + for exterior wall elements that contribute to heat transfer to the outdoor. + The RC-chain is defined via a vector of capacities CExt[n] and a + vector of resistances RExt[n]. Resistances and capacities are + connected alternately, starting with the first resistance RExt[1], + from heat port_a to heat port_b. RExtRem + is the resistance between the last capacity CExt[end] and the + heat port_b.

    +

    \"image\"/

    + + + +-------- Corrected Code -------- +

    + ExteriorWall represents heat conduction and heat storage + within walls. It links a variable number n of thermal + resistances and capacities to a series connection. n + thus defines the spatial discretization of thermal effects within the + wall. All effects are considered as one-dimensional normal to the + wall's surface. This model is thought for exterior wall elements that + contribute to heat transfer to the outdoor. The RC-chain is defined + via a vector of capacities CExt[n] and a vector of + resistances RExt[n]. Resistances and capacities are + connected alternately, starting with the first resistance + RExt[1], from heat port_a to heat + port_b. RExtRem is the resistance between + the last capacity CExt[end] and the heat + port_b. +

    +

    + \"image\" +

    + + +-------- Errors -------- +line 14 column 4 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/BoundaryConditions/UsersGuide.mo ---- +-------- HTML Code -------- + +

    This package contains models to read or compute boundary conditions, such as weather data, solar irradition and sky temperatures. +The calculations follow the description in Wetter (2004), Appendix A.4.2.

    +

    Accessing weather data

    +

    +The model + +AixLib.BoundaryConditions.WeatherData.ReaderTMY3 +can read TMY3 weather data for different locations. +The documentation of that model explains how to add +weather data for locations that are not distributed with the +AixLib library. +

    +

    +To access these weather data from the graphical model editor, +proceed as follows: +

    +
      +
    1. +

      +Create an instance of + +AixLib.BoundaryConditions.WeatherData.ReaderTMY3. +

      +
    2. +
    3. +

      +Create an instance of + +AixLib.BoundaryConditions.WeatherData.Bus. +

      +
    4. +
    5. +

      +Draw a connection between these two instances. +

      +
    6. +
    7. +

      +Finally, to send weather data to an input connector of a model, +connect the input connector of that model with the instance of + +AixLib.BoundaryConditions.WeatherData.Bus. +Some models connect to the whole weather data bus, such as + +AixLib.BoundaryConditions.SolarGeometry.Examples.IncidenceAngle, +in which case the connection will directly be drawn. +Other models require only an individual signal from the weather data bus, +such as + +AixLib.BoundaryConditions.SkyTemperature.Examples.BlackBody. +In this situation, Modelica modeling environments typically show a window that allows you to +select what data from this weather data bus you want to connect +with your model. +

      +
    8. +
    +

    Conventions for surface azimuth and tilt

    +

    To compute the solar irradiation, parameters such as the surface azimuth and the surface tilt are defined as shown in the following three figures.

    +

    \"image\"

    +

    \"image\"

    +

    \"image\"

    +

    +For the surface azimuth and tilt, the enumerations + +AixLib.Types.Azimuth +and + +AixLib.Types.Tilt +can be used. +

    +

    +Note that a ceiling has a tilt of 0 + +if they are facing straight upwards. +This is correct because +the solar irradiation on a ceiling construction is on the other-side surface, +which faces upwards toward the sky. Hence, a construction is considered +a ceiling from the view point of a person standing inside a room. +

    + +

    References

    + + +-------- Corrected Code -------- +

    + This package contains models to read or compute boundary conditions, + such as weather data, solar irradition and sky temperatures. The + calculations follow the description in Wetter (2004), Appendix A.4.2. +

    +

    + Accessing weather data +

    +

    + The model AixLib.BoundaryConditions.WeatherData.ReaderTMY3 + can read TMY3 weather data for different locations. The documentation + of that model explains how to add weather data for locations that are + not distributed with the AixLib library. +

    +

    + To access these weather data from the graphical model editor, proceed + as follows: +

    +
      +
    1. +

      + Create an instance of AixLib.BoundaryConditions.WeatherData.ReaderTMY3. +

      +
    2. +
    3. +

      + Create an instance of AixLib.BoundaryConditions.WeatherData.Bus. +

      +
    4. +
    5. +

      + Draw a connection between these two instances. +

      +
    6. +
    7. +

      + Finally, to send weather data to an input connector of a model, + connect the input connector of that model with the instance of + AixLib.BoundaryConditions.WeatherData.Bus. + Some models connect to the whole weather data bus, such as + + AixLib.BoundaryConditions.SolarGeometry.Examples.IncidenceAngle, + in which case the connection will directly be drawn. Other models + require only an individual signal from the weather data bus, such + as + AixLib.BoundaryConditions.SkyTemperature.Examples.BlackBody. + In this situation, Modelica modeling environments typically show + a window that allows you to select what data from this weather + data bus you want to connect with your model. +

      +
    8. +
    +

    + Conventions for surface azimuth and tilt +

    +

    + To compute the solar irradiation, parameters such as the surface + azimuth and the surface tilt are defined as shown in the following + three figures. +

    +

    + \"image\" +

    +

    + \"image\" +

    +

    + \"image\" +

    +

    + For the surface azimuth and tilt, the enumerations AixLib.Types.Azimuth and + AixLib.Types.Tilt can be + used. +

    +

    + Note that a ceiling has a tilt of 0 + if they are facing straight upwards. This is correct because the + solar irradiation on a ceiling construction is on the other-side + surface, which faces upwards toward the sky. Hence, a construction is + considered a ceiling from the view point of a person standing inside + a room. +

    +

    + References +

    + + +-------- Errors -------- +line 60 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 61 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 62 column 1 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Actuators/Valves/Examples/TwoWayValveTable.mo ---- +-------- HTML Code -------- +

    - This function returns the thermodynamic state for a given pressure, - temperature and composition. + Test model for a two way valve in which a table is used to specify the + opening characteristics. + The valve has the following opening characteristics, which is taken from a test case + of the IEA EBC Annex 60 project.

    - - - +
    + + + + + +
    y0 0.1667 0.3333 0.5 0.6667 1
    Kv0 0.19 0.35 0.45 0.5 0.65

    - This function returns the thermodynamic state based on pressure, - specific entropy and mass fraction. + The Kv value is the volume flow rate in m3/h at a pressure difference + of 1 bar. + Hence, the Kv value of the fully open valve is Kv=0.65.

    - The state is computed by symbolically solving - - AixLib.Media.Specialized.Water.TemperatureDependentDensity.specificEntropy - for temperature. -

    - - - + Plotting the variables kv.y versus y.y shows that the valve + reproduces the Kv values shown in the above table. +

    +

    + \"image\" +

    - This function computes the derivative of the specific heat capacity - at constant pressure with respect to the state. + The parameter filterOpening is set to false, + as this model is used to plot the flow at different opening signals + without taking into account the travel time of the actuator.

    - -

    - This function computes the temperature derivative of the enthalpy of liquid water - per unit mass. -

    - - +-------- Corrected Code -------- +

    + Test model for a two way valve in which a table is used to specify + the opening characteristics. The valve has the following opening + characteristics, which is taken from a test case of the IEA EBC Annex + 60 project. +

    + + + + + + + + + + + + + + + + + + + +
    + y + + 0 + + 0.1667 + + 0.3333 + + 0.5 + + 0.6667 + + 1 +
    + Kv + + 0 + + 0.19 + + 0.35 + + 0.45 + + 0.5 + + 0.65 +
    +

    + The Kv value is the volume flow rate in + m3/h at a pressure difference of 1 bar. Hence, the + Kv value of the fully open valve is + Kv=0.65. +

    +

    + Plotting the variables kv.y versus y.y + shows that the valve reproduces the Kv values shown + in the above table. +

    +

    + \"image\" +

    +

    + The parameter filterOpening is set to + false, as this model is used to plot the flow at + different opening signals without taking into account the travel time + of the actuator. +

    + + +-------- Errors -------- +line 8 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 24 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Actuators/BaseClasses/exponentialDamper.mo ---- +-------- HTML Code -------- +

    - This function computes the kinematic viscosity as a function of temperature. + This function computes the opening characteristics of an exponential damper. +

    + The function is used by the model + + AixLib.Fluid.Actuators.Dampers.Exponential. +

    + For yL < y < yU, the damper characteristics is +

    +

    + kd(y) = exp(a+b (1-y)).

    -

    Implementation

    - The function is based on the IDA implementation in therpro.nmf. - The original equation is + Outside this range, the damper characteristic is defined by a quadratic polynomial.

    -
    - kinVis :=1E-6*Modelica.Math.exp(0.577449 - 3.253945e-2*T_degC + 2.17369e-4*
    -       T_degC^2 - 7.22111e-7*T_degC^3);
    -       

    - This has been converted to Kelvin, which resulted in the above expression. - In addition, at 5 °C the kinematic viscosity is linearly extrapolated - to avoid a large gradient at very low temperatures. - We selected the same point for the linearization as we used for the density, - as the density and the kinematic viscosity are combined in - - AixLib.Media.Specialized.Water.TemperatureDependentDensity.dynamicViscosity. + Note that this implementation returns sqrt(kd(y)) instead of kd(y). + This is done for numerical reason since otherwise kd(y) may be an iteration + variable, which may cause a lot of warnings and slower convergence if the solver + attempts kd(y) < 0 during the iterative solution procedure.

    -

    - This medium package models liquid water. -

    -

    - The mass density is computed using a 3rd order polynomial, which yields the - density as a function of temperature as shown in the figure below. Note, however, - that computing density as a function of temperature can lead to considerably - slower computing time compared to using - - AixLib.Media.Water - in which the density is a constant. We therefore recommend to use - - AixLib.Media.Water - for typical building energy simulations. -

    -

    - \"Mass -

    -

    - For the specific heat capacities at constant pressure and at constant volume, - a constant value of 4184 J/(kg K), which corresponds to 20°C - is used. - The figure below shows the relative error of the specific heat capacity that - is introduced by this simplification. - Using a constant value for the specific heat capacity allows to compute - temperature from enthalpy without having to solve an implicit equation, - and therefore leads to faster simulation. -

    -

    - \"Relative -

    +-------- Corrected Code -------- +

    + This function computes the opening characteristics of an exponential + damper. +

    +

    + The function is used by the model AixLib.Fluid.Actuators.Dampers.Exponential. +

    +

    + For yL < y < yU, the damper characteristics is +

    +

    + kd(y) = exp(a+b (1-y)). +

    +

    + Outside this range, the damper characteristic is defined by a + quadratic polynomial. +

    +

    + Note that this implementation returns sqrt(kd(y)) + instead of kd(y). This is done for numerical reason + since otherwise kd(y) may be an iteration variable, + which may cause a lot of warnings and slower convergence if the + solver attempts kd(y) < 0 during the iterative + solution procedure. +

    + + +-------- Errors -------- +line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Utilities/Math/QuadraticLinear.mo ---- +-------- HTML Code -------- + +

    Block for function quadraticLinear, which computes

    +

    y = a1 + a2 x1 + a3 x12 + (a4 + a5 x1 + a6 x12) x2

    + +-------- Corrected Code -------- +

    + Block for function quadraticLinear, which computes +

    +

    + y = a1 + a2 x1 + a3 x12 + (a4 + a5 x1 + a6 x12) x2 +

    + + +-------- Errors -------- +line 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/HeatExchangers/BaseClasses/PartialEffectivenessNTU.mo ---- +-------- HTML Code -------- +

    - Thermal conductivity is calculated as a function of temperature as shown in the figure below. - The correlation used to calculate the thermal conductivity is + Partial model of a heat exchanger without humidity condensation. + This model transfers heat in the amount of

    -

    - λ(T) = λ(298.15 K) ⋅ (-1.48445+4.12292⋅(T/298.15)-1.63866⋅(T/298.15)2), -

    -

    - where λ(298.15 K) = 0.6065 W/(m ⋅ K) is the adopted standard value - of the thermal conductivity of water at 298.15 K and 0.1 MPa. -

    -

    - \"Thermal + Q = Qmax ε
    + ε = f(NTU, Z, flowRegime),

    -

    - Dynamic viscosity is calculated as the product of density and kinematic viscosity, - both temperature dependent. However, the kinematic viscosity - has its own temperature dependent correlation, implemented at - - AixLib.Media.Specialized.Water.TemperatureDependentDensity.kinematicViscosity. - Results of the kinematic viscosity as a function of temperature are shown in the figure below. -

    -

    - \"Kinematic + where + Qmax is the maximum heat that can be transferred, + ε is the heat transfer effectiveness, + NTU is the Number of Transfer Units, + Z is the ratio of minimum to maximum capacity flow rate and + flowRegime is the heat exchanger flow regime. + such as + parallel flow, cross flow or counter flow.

    -

    - The enthalpy is computed using the convention that h=0 - if T=0 °C. + The flow regimes depend on the heat exchanger configuration. All configurations + defined in + + AixLib.Fluid.Types.HeatExchangerConfiguration + are supported.

    -

    Limitations

    - Phase changes are not modeled. + Models that extend from this partial model need to provide an assignment + for UA.

    -------- Corrected Code --------

    - Base properties of the medium. + Partial model of a heat exchanger without humidity condensation. This + model transfers heat in the amount of

    -

    - This function computes the density as a function of temperature. +

    + Q = Qmax ε
    + ε = f(NTU, Z, flowRegime),

    -

    - Implementation -

    - The function is based on the IDA implementation in - therpro.nmf, which implements + where Qmax is the maximum heat that can be + transferred, ε is the heat transfer effectiveness, NTU + is the Number of Transfer Units, Z is the ratio of minimum to + maximum capacity flow rate and flowRegime is the heat + exchanger flow regime. such as parallel flow, cross flow or counter + flow.

    -
    - d := 1000.12 + 1.43711e-2*T_degC -
    -  5.83576e-3*T_degC^2 + 1.5009e-5*T_degC^3;
    -  

    - This has been converted to Kelvin, which resulted in the above - expression. In addition, below 5 °C and above 100 °C, the density is - replaced by a linear function to avoid inflection points. This linear - extension is such that the density is once continuously - differentiable. + The flow regimes depend on the heat exchanger configuration. All + configurations defined in AixLib.Fluid.Types.HeatExchangerConfiguration + are supported.

    -

    - This function computes the dynamic viscosity. + Models that extend from this partial model need to provide an + assignment for UA.

    -

    - This function computes the specific enthalpy. -

    - -

    - This function computes the specific enthalpy of liquid water. -

    - -

    - This function computes the specific internal energy. -

    - -

    - This function computes the specific entropy. -

    -

    - To obtain the state for a given pressure, entropy and mass fraction, - use AixLib.Media.Air.setState_psX. -

    - -

    - This function computes the specific Gibbs energy. -

    - -

    - This function computes the specific Helmholtz energy. -

    - + +-------- Errors -------- +line 6 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/HeatExchangers/BaseClasses/HANaturalCylinder.mo ---- +-------- HTML Code -------- + +

    + This model calculates the convection coefficient h for natural convection + from a cylinder submerged in fluid. h is calcualted using Eq 9.34 from + Incropera and DeWitt (1996). + Output of the block is the hA value. +

    +

    + The Nusselt number is computed as +

    +

    + NuD = (0.6 + (0.387 RaD(1/6))/(1+(0.559 Pr) + (9/16))(8/27))2); +

    +

    + where NuD is the Nusselt number, RaD is the + Rayleigh number and + Pr is the Prandtl number.
    + This correclation is accurate for RaD less than 1012. +

    +

    + h is then calculated from the Nusselt number. The equation is +

    +

    + h = NuD k/D +

    +

    + where k is the thermal conductivity of the fluid and D is the diameter + of the submerged cylinder. +

    +

    References

    +

    + Fundamentals of Heat and Mass Transfer (Fourth Edition), Frank Incropera and David + DeWitt, John Wiley and Sons, 1996 +

    + + + +-------- Corrected Code --------

    - This function computes the specific enthalpy for an isentropic state - change from the temperature that corresponds to the state - refState to reference_T. + This model calculates the convection coefficient h for natural + convection from a cylinder submerged in fluid. h is calcualted + using Eq 9.34 from Incropera and DeWitt (1996). Output of the block + is the hA value.

    -

    - This function returns the isobaric expansion coefficient, + The Nusselt number is computed as

    - βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p, + NuD = (0.6 + (0.387 + RaD(1/6))/(1+(0.559 Pr) + (9/16))(8/27))2);

    - where v is the specific volume, T is the temperature - and p is the pressure. + where NuD is the Nusselt number, + RaD is the Rayleigh number and Pr is the + Prandtl number.
    + This correclation is accurate for RaD less than + 1012.

    -

    - This function returns the isothermal compressibility coefficient, - which is zero as this medium is incompressible. The isothermal - compressibility is defined as + h is then calculated from the Nusselt number. The equation is

    - κT = - 1 ⁄ v   (∂ v ⁄ ∂ p)T, + h = NuD k/D

    - where v is the specific volume, T is the temperature - and p is the pressure. + where k is the thermal conductivity of the fluid and D + is the diameter of the submerged cylinder.

    - +

    + References +

    - This function returns the partial derivative of density with respect - to pressure at constant temperature, which is zero as the medium is - incompressible. + Fundamentals of Heat and Mass Transfer (Fourth Edition), Frank + Incropera and David DeWitt, John Wiley and Sons, 1996

    -

    - This function computes the derivative of density with respect to - temperature at constant pressure. -

    - + +-------- Errors -------- +line 11 column 14 - Warning:

    attribute "align" not allowed for HTML5 +line 24 column 14 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource_Erfint.mo ---- +-------- HTML Code -------- + +

    + This function evaluates the integral of the error function, given by: +

    +

    + \"image\" +

    + + + +-------- Corrected Code --------

    - This function returns the partial derivative of density with respect - to mass fraction, which is zero as the medium is a single substance. + This function evaluates the integral of the error function, given by: +

    +

    + \"image\"

    + +-------- Errors -------- +line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/HeatPumps/ReciprocatingWaterToWater.mo ---- +-------- HTML Code -------- + +

    + Model for a water to water heat pump with a reciprocating compressor, as + described in Jin (2002). The thermodynamic heat pump cycle is represented below. +

    +

    + \"image\" +

    +

    + The rate of heat transferred to the evaporator is given by: +

    +

    + Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ). +

    +

    + The power consumed by the compressor is given by a linear efficiency relation: +

    +

    + P = PTheoretical / η + PLoss,constant. +

    +

    + Heat transfer in the evaporator and condenser is calculated using an + ε-NTU method, assuming constant refrigerant temperature and constant heat + transfer coefficient between fluid and refrigerant. +

    +

    + Variable speed is acheived by multiplying the full load piston displacement + by the normalized compressor speed. The power and heat transfer rates are forced + to zero if the resulting heat pump state has higher evaporating pressure than + condensing pressure. +

    +

    Options

    +

    + Parameters TConMax and TEvaMin + may be used to set an upper or lower bound for the + condenser and evaporator. + The compressor is disabled when these conditions + are not satisfied, or when the + evaporator temperature is larger + than the condenser temperature. + This mimics the temperature protection + of heat pumps and moreover it avoids + non-converging algebraic loops of equations, + or freezing of evaporator medium. + This option can be disabled by setting + enable_temperature_protection = false. +

    +

    Assumptions and limitations

    +

    + The compression process is assumed isentropic. The thermal energy + of superheating is ignored in the evaluation of the heat transferred to the refrigerant + in the evaporator. There is no supercooling. +

    +

    References

    +

    + H. Jin. + + Parameter estimation based models of water source heat pumps. + + PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002. +

    + + + +-------- Corrected Code --------

    - This function returns the specific heat capacity at constant - pressure. + Model for a water to water heat pump with a reciprocating compressor, + as described in Jin (2002). The thermodynamic heat pump cycle is + represented below.

    - -

    - This function computes the specific heat capacity at constant volume. +

    + \"image\"

    -

    - This function returns the thermal conductivity. The expression is - obtained from Ramires et al. (1995). + The rate of heat transferred to the evaporator is given by:

    -

    - References -

    -

    - Ramires, Maria L. V. and Nieto de Castro, Carlos A. and Nagasaka, - Yuchi and Nagashima, Akira and Assael, Marc J. and Wakeham, William - A. Standard Reference Data for the Thermal Conductivity of Water. - Journal of Physical and Chemical Reference Data, 24, p. - 1377-1381, 1995. DOI:10.1063/1.555963. +

    + Q̇Eva = ṁref ( + hVap(TEva) - hLiq(TCon) + ).

    -

    - This function returns the pressure. + The power consumed by the compressor is given by a linear efficiency + relation:

    - -

    - This function returns the temperature. +

    + P = PTheoretical / η + PLoss,constant.

    -

    - This function returns the molar mass, which is assumed to be - constant. + Heat transfer in the evaporator and condenser is calculated using an + ε-NTU method, assuming constant refrigerant temperature and constant + heat transfer coefficient between fluid and refrigerant.

    -

    - This function returns the thermodynamic state for a given pressure, - specific enthalpy and composition. + Variable speed is acheived by multiplying the full load piston + displacement by the normalized compressor speed. The power and heat + transfer rates are forced to zero if the resulting heat pump state + has higher evaporating pressure than condensing pressure.

    - +

    + Options +

    - This function returns the thermodynamic state for a given pressure, - temperature and composition. + Parameters TConMax and TEvaMin may be used + to set an upper or lower bound for the condenser and evaporator. The + compressor is disabled when these conditions are not satisfied, or + when the evaporator temperature is larger than the condenser + temperature. This mimics the temperature protection of heat pumps and + moreover it avoids non-converging algebraic loops of equations, or + freezing of evaporator medium. This option can be disabled by setting + enable_temperature_protection = false.

    - +

    + Assumptions and limitations +

    - This function returns the thermodynamic state based on pressure, - specific entropy and mass fraction. + The compression process is assumed isentropic. The thermal energy of + superheating is ignored in the evaluation of the heat transferred to + the refrigerant in the evaporator. There is no supercooling.

    +

    + References +

    - The state is computed by symbolically solving - AixLib.Media.Specialized.Water.TemperatureDependentDensity.specificEntropy - for temperature. + H. Jin. Parameter estimation based models of water source heat + pumps. PhD Thesis. Oklahoma State University. Stillwater, + Oklahoma, USA. 2002.

    -

    - This function computes the derivative of the specific heat capacity - at constant pressure with respect to the state. -

    + +-------- Errors -------- +line 6 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 12 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 18 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/BoundaryConditions/Validation/BESTEST/WD200.mo ---- +-------- HTML Code -------- + +

    + +

    WD200: Low Elevation, Hot and Humid Case.

    +

    Weather data file : WD200.epw

    +

    Table 1: Site Data for Weather file WD200.epw

    +
    + + + + + + + + + + + + + + + +

    Latitude

    33.633° north

    Longitude

    84.433° west

    Altitude

    308 m

    Time Zone

    -5

    + +-------- Corrected Code -------- -

    - This function computes the temperature derivative of the enthalpy of - liquid water per unit mass. -

    - -

    - This function computes the kinematic viscosity as a function of - temperature. -

    -

    - Implementation -

    -

    - The function is based on the IDA implementation in - therpro.nmf. The original equation is -

    -
    - kinVis :=1E-6*Modelica.Math.exp(0.577449 - 3.253945e-2*T_degC + 2.17369e-4*
    -       T_degC^2 - 7.22111e-7*T_degC^3);
    -       
    -

    - This has been converted to Kelvin, which resulted in the above - expression. In addition, at 5 °C the kinematic viscosity is linearly - extrapolated to avoid a large gradient at very low temperatures. We - selected the same point for the linearization as we used for the - density, as the density and the kinematic viscosity are combined in - - AixLib.Media.Specialized.Water.TemperatureDependentDensity.dynamicViscosity. -

    - +

    + WD200: Low Elevation, Hot and Humid Case. +

    - This medium package models liquid water. + Weather data file : WD200.epw

    - The mass density is computed using a 3rd order polynomial, which - yields the density as a function of temperature as shown in the - figure below. Note, however, that computing density as a function of - temperature can lead to considerably slower computing time compared - to using AixLib.Media.Water in which the - density is a constant. We therefore recommend to use AixLib.Media.Water for typical - building energy simulations. -

    -

    - \"Mass + Table 1: Site Data for Weather file WD200.epw

    + + + + + + + + + + + + + + + + + +
    +

    + Latitude +

    +
    +

    + 33.633° north +

    +
    +

    + Longitude +

    +
    +

    + 84.433° west +

    +
    +

    + Altitude +

    +
    +

    + 308 m +

    +
    +

    + Time Zone +

    +
    +

    + -5 +

    +
    + +-------- Errors -------- +line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- AixLib/Fluid/FMI/ExportContainers/HVACZone.mo ---- +-------- HTML Code -------- + +

    + Model that is used as a container for an HVAC system that is + to be exported as an FMU and that serves a single zone. +

    +

    Typical use and important parameters

    +

    + To use this model as a container for an FMU, extend + from this model, rather than instantiate it, + and add your HVAC system. By extending from this model, the top-level + signal connectors on the right stay at the top-level, and hence + will be visible at the FMI interface. + The example + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone + shows how a simple HVAC system can be implemented and exported as + an FMU. + +

    +

    + The conversion between the fluid ports and signal ports is done + in the HVAC adapter hvacAda. + This adapter has a vector of fluid ports called ports. + The supply and return air ducts, including any resistance model for the inlet + diffusor or exhaust grill, need to be connected to these ports. + Also, if a thermal zone has interzonal air exchange or air infiltration, + these flows need to be connected to ports. + This model outputs at the port fluPor the mass flow rate for + each flow that is connected to ports, together with its + temperature, water vapor mass fraction per total mass of the air (not per kg dry + air), and trace substances. These quantities are always as if the flow + enters the room, even if the flow is zero or negative. + If a medium has no moisture, e.g., if Medium.nXi=0, or + if it has no trace substances, e.g., if Medium.nC=0, then + the output signal for these properties are removed. + These quantities are always as if the flow + enters the room, even if the flow is zero or negative. + Thus, a thermal zone model that uses these signals to compute the + heat added by the HVAC system needs to implement an equation such as +

    +

    + Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), +

    +

    + where + Qsen is the sensible heat flow rate added to the thermal zone, + sup is the supply air mass flow rate from + the port fluPor (which is negative if it is an exhaust), + cp is the specific heat capacity at constant pressure, + Tsup is the supply air temperature and + Tair,zon is the zone air temperature. + Note that without the max(·, ·), the energy + balance would be wrong. +

    +

    + The input signals of this model are the zone radiative temperature. + The the zone air temperature, + the water vapor mass fraction per total mass of the air (unless Medium.nXi=0) + and trace substances (unless Medium.nC=0) are obtained from the connector + fluPor.backward. + The outflowing fluid stream(s) at the port ports will be at the + states obtained from fluPor.backward. + All fluid streams at port ports are at the same + pressure. + For convenience, the instance hvacAda also outputs the + properties obtained from fluPor.backward. These can be used + to connect a controller. The properties are available for each flow path in + fluPor.backward. For a thermal zone with mixed air, these are + all equal, while for a stratified room model, they can be different. +

    + +

    + See + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone + for a model that uses this model. +

    +

    + For models that multiple thermal zones connected to the HVAC system, + use the model + + AixLib.Fluid.FMI.ExportContainers.HVACZones. +

    +

    Assumption and limitations

    +

    + The mass flow rates at ports sum to zero, hence this + model conserves mass. +

    +

    + This model does not impose any pressure, other than setting the pressure + of all fluid connections to ports to be equal. + The reason is that setting a pressure can lead to non-physical system models, + for example if a mass flow rate is imposed and the HVAC system is connected + to a model that sets a pressure boundary condition such as + + AixLib.Fluid.Sources.Outside. + Also, setting a pressure would make it impossible to use multiple instances + of this model (one for each thermal zone) and build in Modelica an airflow network + model with pressure driven mass flow rates. +

    +

    + The model has no pressure drop. Hence, the pressure drop + of an air diffuser or of an exhaust grill needs to be modelled + in models that are connected to ports. +

    + + + +-------- Corrected Code --------

    - For the specific heat capacities at constant pressure and at constant - volume, a constant value of 4184 J/(kg K), which corresponds - to 20°C is used. The figure below shows the relative error of - the specific heat capacity that is introduced by this simplification. - Using a constant value for the specific heat capacity allows to - compute temperature from enthalpy without having to solve an implicit - equation, and therefore leads to faster simulation. + Model that is used as a container for an HVAC system that is to be + exported as an FMU and that serves a single zone.

    -

    - - +

    + Typical use and important parameters +

    +

    + To use this model as a container for an FMU, extend from this model, + rather than instantiate it, and add your HVAC system. By extending + from this model, the top-level signal connectors on the right stay at + the top-level, and hence will be visible at the FMI interface. The + example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone shows + how a simple HVAC system can be implemented and exported as an FMU. +

    - Thermal conductivity is calculated as a function of temperature as - shown in the figure below. The correlation used to calculate the - thermal conductivity is + The conversion between the fluid ports and signal ports is done in + the HVAC adapter hvacAda. This adapter has a vector of + fluid ports called ports. The supply and return air + ducts, including any resistance model for the inlet diffusor or + exhaust grill, need to be connected to these ports. Also, if a + thermal zone has interzonal air exchange or air infiltration, these + flows need to be connected to ports. This model outputs + at the port fluPor the mass flow rate for each flow that + is connected to ports, together with its temperature, + water vapor mass fraction per total mass of the air (not per kg dry + air), and trace substances. These quantities are always as if the + flow enters the room, even if the flow is zero or negative. If a + medium has no moisture, e.g., if Medium.nXi=0, or if it + has no trace substances, e.g., if Medium.nC=0, then the + output signal for these properties are removed. These quantities are + always as if the flow enters the room, even if the flow is zero or + negative. Thus, a thermal zone model that uses these signals to + compute the heat added by the HVAC system needs to implement an + equation such as

    - λ(T) = λ(298.15 K) ⋅ - (-1.48445+4.12292⋅(T/298.15)-1.63866⋅(T/298.15)2), + Qsen = max(0, ṁsup)   cp   + (Tsup - Tair,zon),

    - where λ(298.15 K) = 0.6065 W/(m ⋅ K) is the adopted standard - value of the thermal conductivity of water at 298.15 K and - 0.1 MPa. -

    -

    - \"Thermal + where Qsen is the sensible heat flow rate added to + the thermal zone, sup is the supply air mass flow + rate from the port fluPor (which is negative if it is an + exhaust), cp is the specific heat capacity at + constant pressure, Tsup is the supply air + temperature and Tair,zon is the zone air + temperature. Note that without the max(·, ·), the energy + balance would be wrong.

    - Dynamic viscosity is calculated as the product of density and - kinematic viscosity, both temperature dependent. However, the - kinematic viscosity has its own temperature dependent correlation, - implemented at - AixLib.Media.Specialized.Water.TemperatureDependentDensity.kinematicViscosity. - Results of the kinematic viscosity as a function of temperature are - shown in the figure below. + The input signals of this model are the zone radiative temperature. + The the zone air temperature, the water vapor mass fraction per total + mass of the air (unless Medium.nXi=0) and trace + substances (unless Medium.nC=0) are obtained from the + connector fluPor.backward. The outflowing fluid + stream(s) at the port ports will be at the states + obtained from fluPor.backward. All fluid streams at port + ports are at the same pressure. For convenience, the + instance hvacAda also outputs the properties obtained + from fluPor.backward. These can be used to connect a + controller. The properties are available for each flow path in + fluPor.backward. For a thermal zone with mixed air, + these are all equal, while for a stratified room model, they can be + different.

    -

    - \"Kinematic +

    + See + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone for a + model that uses this model.

    - The enthalpy is computed using the convention that h=0 if - T=0 °C. + For models that multiple thermal zones connected to the HVAC system, + use the model AixLib.Fluid.FMI.ExportContainers.HVACZones.

    - Limitations + Assumption and limitations

    - Phase changes are not modeled. + The mass flow rates at ports sum to zero, hence this + model conserves mass. +

    +

    + This model does not impose any pressure, other than setting the + pressure of all fluid connections to ports to be equal. + The reason is that setting a pressure can lead to non-physical system + models, for example if a mass flow rate is imposed and the HVAC + system is connected to a model that sets a pressure boundary + condition such as AixLib.Fluid.Sources.Outside. + Also, setting a pressure would make it impossible to use multiple + instances of this model (one for each thermal zone) and build in + Modelica an airflow network model with pressure driven mass flow + rates. +

    +

    + The model has no pressure drop. Hence, the pressure drop of an air + diffuser or of an exhaust grill needs to be modelled in models that + are connected to ports.

    + +-------- Errors -------- +line 47 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Controls/Discrete/BooleanDelay.mo ---- +-------- HTML Code -------- + +

    + Block that delays the boolean input signal by + one sampling interval. + For example, + if u denotes the input, + y denotes the output, and + ti and ti+1 + denote subsequent sampling + instants, then the model outputs +

    +

    + y(ti+1) = u(ti). +

    + + + +-------- Corrected Code -------- +

    + Block that delays the boolean input signal by one sampling interval. + For example, if u denotes the input, y denotes the + output, and ti and ti+1 denote + subsequent sampling instants, then the model outputs +

    +

    + y(ti+1) = u(ti). +

    + + +-------- Errors -------- +line 12 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/ThermalZones/ReducedOrder/RC/ThreeElements.mo ---- +-------- HTML Code -------- + +

    + +

    This model adds one further element for + the floor plate. Long-term effects dominate the excitation of the floor plate + and thus the excitation fundamentally differs from excitation of outer walls. + Adding an extra element for the floor plate leads to a finer resolution of the + dynamic behaviour but increases calculation times. The floor plate is + parameterized via the length of the RC-chain nFloor, + the vector of the capacities + CFloor[nFloor], the vector of the resistances + RFloor[nFloor] + and the remaining resistance RFloorRem. +

    +

    + The image below shows the RC-network of this model. +

    +

    + \"image\"/ +

    + +-------- Corrected Code -------- + +

    + This model adds one further element for the floor plate. Long-term + effects dominate the excitation of the floor plate and thus the + excitation fundamentally differs from excitation of outer walls. + Adding an extra element for the floor plate leads to a finer + resolution of the dynamic behaviour but increases calculation times. + The floor plate is parameterized via the length of the RC-chain + nFloor, the vector of the capacities + CFloor[nFloor], the vector of the resistances + RFloor[nFloor] and the remaining resistance + RFloorRem. +

    +

    + The image below shows the RC-network of this model. +

    +

    + \"image\" +

    -------- Errors -------- -line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - -line 7 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - -line 17 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 31 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 42 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 49 column 2 - Warning:

    attribute "align" not allowed for HTML5 -line 62 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 16 column 4 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sensors/UsersGuide.mo ---- +---- AixLib/Media/Antifreeze/PropyleneGlycolWater.mo ---- -------- HTML Code -------- +

    + This base properties model is identical to + + Modelica.Media.Water.ConstantPropertyLiquidWater, + except that the equation + u = cv_const*(T - reference_T) + has been replaced by u=h because + cp_const=cv_const. + Also, the model checks if the mass fraction of the mixture is within the + allowed limits. +

    + +

    + Density of propylene antifreeze-water mixture at specified mass fraction + and temperature, based on Melinder (2010). +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + + +

    + Dynamic viscosity of antifreeze-water mixture at specified mass fraction and + temperature, based on Melinder (2010). +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + + +

    + Fusion temperature of antifreeze-water mixture at specified mass fraction and + temperature, based on Melinder (2010). +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + + +

    + Evaluates a thermophysical property of a mixture, based on correlations proposed + by Melinder (2010). +

    +

    + The polynomial has the form +

    +

    + f = a1 (x-xm)0(y-ym)0 + + a2 (x-xm)0(y-ym)1 + + ... + + any[1] (x-xm)0(y-ym)ny[1]-1 + + ... + + any[1])+1 (x-xm)1(y-ym)0 + + ... + + any[1]+ny[2] (x-xm)1(y-ym)ny[2]-1 + + ... +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + + +

    + Specific heat capacity of antifreeze-water mixture at specified mass fraction + and temperature, based on Melinder (2010). +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + + +

    + Thermal conductivity of antifreeze-water mixture at specified mass fraction and + temperature, based on Melinder (2010). +

    +

    References

    +

    + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

    + + + +

    + This medium package models propylene glycol - water mixtures. +

    +

    + The mass density, specific heat capacity, thermal conductivity and viscosity + are assumed constant and evaluated at a set temperature and mass fraction of + propylene glycol within the mixture. The dependence of the four properties + are shown on the figure below. +

    +

    + \"Relative +

    +

    + The accuracy of the thermophysical properties is dependent on the temperature + variations encountered during simulations. + The figure below shows the relative error of the the four properties over a + 10 °C range around the temperature used to evaluate the constant + properties. The maximum errors are 0.8 % for mass density, 1.5 % + for specific heat capacity, 3.2 % for thermal conductivity and 250 + % for dynamic viscosity. +

    +

    + \"Relative +

    +

    + The figure below shows the relative error of the the four properties over a + 20 °C range around the temperature used to evaluate the constant + proepties. The maximum errors are 1.6 % for mass density, 3.0 % + for specific heat capacity, 6.2 % for thermal conductivity and 950 + % for dynamic viscosity. +

    +

    + \"Relative +

    +

    + The enthalpy is computed using the convention that h=0 + if T=0 °C. +

    +

    Limitations

    +

    + Density, specific heat capacity, thermal conductivity and viscosity are constant. + The propylene glycol/water mixture is modeled as an incompressible liquid. + There are no phase changes. The medium is limited to temperatures below + 100 °C and mass fractions below 0.60. + As is the case for AixLib.Media.Water, + this medium package should not be used if + the simulation relies on the dynamic viscosity. +

    +

    Typical use and important parameters

    +

    + The temperature and mass fraction must be specified for the evaluation of the + constant thermophysical properties. A typical use of the package is (e.g. for + a temperature of 20 °C and a mass fraction of 0.40): +

    +

    + Medium = AixLib.Media.Antifreeze.PropyleneGlycolWater(property_T=293.15, X_a=0.40) +

    + + + +-------- Corrected Code --------

    -This package contains models of sensors. -There are models with one and with two fluid ports. -

    - -

    Selection and parameterization of sensor models

    -

    -When selecting a sensor model, a distinction needs to be made -whether the measured quantity depends on the direction of the flow or -not, and whether the sensor output signal is the product of the mass flow rate -and a medium property. + This base properties model is identical to Modelica.Media.Water.ConstantPropertyLiquidWater, + except that the equation u = cv_const*(T - reference_T) + has been replaced by u=h because + cp_const=cv_const. Also, the model checks if the mass + fraction of the mixture is within the allowed limits.

    -

    -Output signals that depend on the flow direction and are not multiplied by -the mass flow rate are temperature, relative humidity, -water vapor concentration X, trace substances C and density. -For such quantities, sensors with two fluid ports need to be used. -An exception is if the quantity is measured directly in a fluid volume, which is the case -for models from the package - -AixLib.Fluid.MixingVolumes. -Therefore, to measure for example the outlet temperature of a heat exchanger, the -configuration labelled correct use in the figure below should be used, and not the configuration -labelled not recommended. -For an explanation, see - -Modelica.Fluid.Examples.Explanatory.MeasuringTemperature. + Density of propylene antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    - -
    - - - - - - -
    Correct use - \"image\" -
    Not recommended - \"image\" -
    - +

    + References +

    -Except for the mass flow rate sensor, -all sensors with two ports can be -configured as dynamic sensors or as steady-state sensor. -The list below advices on how to configure sensors. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    -The table below summarizes the recommendations for the use of sensors. -

    - - - - - - - - - - - - - - - - - - - - - - - -
    Measured quantityOne port sensorTwo port sensor
    steady-state (tau=0)dynamic (tau > 0)
    temperature
    - relative humidity
    - mass fraction
    - trace substances
    - specific enthalpy
    - specific entropy
    use only if connected to a volumeavoidrecommended
    volume flow rate
    - enthalpy flow rate
    - entropy flow rate
    -recommendedrecommended
    pressurerecommendedrecommendedrecommended
    - -

    Sensor Dynamics

    -
    Dynamic response to fluid flowing through the sensor
    -

    -If a sensor is configured as a dynamic sensor by setting tau > 0, -then the measured quantity, say the temperature T, is -computed as -

    -

    - τ   dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T), -

    -

    -where τ is a user-defined time constant of the sensor (a suggested value is around 10 seconds, -which is the default setting for the components), -dT ⁄ dt is the time derivative of the sensor output signal, -|ṁ| is the absolute value of the mass flow rate, -0 is the user-specified nominal value of the mass flow rate and -θ is the temperature of the medium inside the sensor. -An equivalent physical model of such a sensor would be a perfectly mixed volume -with a sensor that outputs the temperature of this volume. In this situation, the size of the volume would -be V=τ   ṁ0 ⁄ ρ, where -ρ is the density of the fluid. -

    -
    Dynamic response to ambient temperature
    -

    -For the sensor - -AixLib.Fluid.Sensors.TemperatureTwoPort, -by setting transferHeat = true, heat transfer to a -fixed ambient can be approximated. The heat transfer is computed as -

    -

    - τHeaTra   dT ⁄ dt = (TAmb-T), -

    -

    -where τHeaTra is a fixed time constant and -TAmb is a fixed ambient temperature. -Setting transferHeat = true is useful if the sensor output T -is used to switch the mass flow rate on again. If transferHeat = false, -then the sensor output T remains constant if the mass flow rate is zero -and hence a fan or pump controller that uses this signal may never switch the device -on again. -If the sensor output T is not used to switch on the mass flow rate, then -in general one can use transferHeat=false. + Dynamic viscosity of antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    +

    + References +

    -Note that since in practice the heat transfer is due to a combination of ambient -temperature and upstream or downstream fluid temperature, for example by two-way -buoyancy-driven flow inside the duct or pipe, the model uses as an approximation -a fixed ambient temperature. -Since the sensor is not affecting the temperature of the medium, this approximation -of the heat transfer does not add or remove heat from the fluid. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    -
    Combined dynamic response
    +

    -For the sensor - -AixLib.Fluid.Sensors.TemperatureTwoPort, -if both dynamic effects are enabled, then -the output T is computed as -

    -

    -dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T) ⁄ τ + -(TAmb-T) ⁄ τHeaTra. + Fusion temperature of antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    -

    Implementation

    +

    + References +

    -The above equation is implemented in such a way that it is differentiable in the mass flow rate. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    +

    -Note that the implementation of the dynamic sensors does not use the model - -AixLib.Fluid.MixingVolumes. -The reason is that depending on the selected medium model, the -mixing volume may introduce states for the pressure, species concentration, -trace substance, specific enthalpy and specific entropy. Not all states are typically needed to -model the dynamics of a sensor. Moreover, in many building system applications, -the sensor dynamics is not of concern, but is rather used here to avoid numerical -problems that steady-state models of sensors cause when flow rates are -very close to zero. + Evaluates a thermophysical property of a mixture, based on + correlations proposed by Melinder (2010).

    - --------- Corrected Code --------

    - This package contains models of sensors. There are models with one - and with two fluid ports. + The polynomial has the form +

    +

    + f = a1 (x-xm)0(y-ym)0 + + a2 (x-xm)0(y-ym)1 + ... + + any[1] (x-xm)0(y-ym)ny[1]-1 + ... + + any[1])+1 (x-xm)1(y-ym)0 + ... + + any[1]+ny[2] (x-xm)1(y-ym)ny[2]-1 + + ...

    - Selection and parameterization of sensor models + References

    - When selecting a sensor model, a distinction needs to be made whether - the measured quantity depends on the direction of the flow or not, - and whether the sensor output signal is the product of the mass flow - rate and a medium property. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    +

    - Output signals that depend on the flow direction and are not - multiplied by the mass flow rate are temperature, relative humidity, - water vapor concentration X, trace substances C and - density. For such quantities, sensors with two fluid ports need to be - used. An exception is if the quantity is measured directly in a fluid - volume, which is the case for models from the package AixLib.Fluid.MixingVolumes. - Therefore, to measure for example the outlet temperature of a heat - exchanger, the configuration labelled correct use in the - figure below should be used, and not the configuration labelled - not recommended. For an explanation, see - Modelica.Fluid.Examples.Explanatory.MeasuringTemperature. + Specific heat capacity of antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    - - - - - - - - - -
    - Correct use - - \"image\" -
    - Not recommended - - \"image\" -
    +

    + References +

    - Except for the mass flow rate sensor, all sensors with two ports can - be configured as dynamic sensors or as steady-state sensor. The list - below advices on how to configure sensors. + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    - The table below summarizes the recommendations for the use of - sensors. + Thermal conductivity of antifreeze-water mixture at specified mass + fraction and temperature, based on Melinder (2010).

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    - Measured quantity - - One port sensor - - Two port sensor -
    - steady-state (tau=0) - - dynamic (tau > 0) -
    - temperature
    - relative humidity
    - mass fraction
    - trace substances
    - specific enthalpy
    - specific entropy -
    - use only if connected to a volume - - avoid - - recommended -
    - volume flow rate
    - enthalpy flow rate
    - entropy flow rate -
    - - - - recommended - - recommended -
    - pressure - - recommended - - recommended - - recommended -

    - Sensor Dynamics + References

    -
    - Dynamic response to fluid flowing through the sensor -

    - If a sensor is configured as a dynamic sensor by setting tau - > 0, then the measured quantity, say the temperature - T, is computed as + Melinder, Åke. 2010. Properties of Secondary Working Fluids + (Secondary Refrigerants or Coolants, Heat Transfer Fluids) for + Indirect Systems. Paris: IIR/IIF.

    -

    - τ   dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T), +

    +

    + This medium package models propylene glycol - water mixtures. +

    +

    + The mass density, specific heat capacity, thermal conductivity and + viscosity are assumed constant and evaluated at a set temperature and + mass fraction of propylene glycol within the mixture. The dependence + of the four properties are shown on the figure below. +

    +

    + + +

    +

    + The accuracy of the thermophysical properties is dependent on the + temperature variations encountered during simulations. The figure + below shows the relative error of the the four properties over a + 10 °C range around the temperature used to evaluate the + constant properties. The maximum errors are 0.8 % for mass + density, 1.5 % for specific heat capacity, 3.2 % for + thermal conductivity and 250 % for dynamic viscosity. +

    +

    + + +

    +

    + The figure below shows the relative error of the the four properties + over a 20 °C range around the temperature used to evaluate the + constant proepties. The maximum errors are 1.6 % for mass + density, 3.0 % for specific heat capacity, 6.2 % for + thermal conductivity and 950 % for dynamic viscosity. +

    +

    + +

    - where τ is a user-defined time constant of the sensor (a - suggested value is around 10 seconds, which is the default setting - for the components), dT ⁄ dt is the time derivative of the - sensor output signal, |ṁ| is the absolute value of the mass - flow rate, 0 is the user-specified nominal value - of the mass flow rate and θ is the temperature of the medium - inside the sensor. An equivalent physical model of such a sensor - would be a perfectly mixed volume with a sensor that outputs the - temperature of this volume. In this situation, the size of the volume - would be V=τ   ṁ0 ⁄ ρ, where ρ is the - density of the fluid. + The enthalpy is computed using the convention that h=0 if + T=0 °C.

    -
    - Dynamic response to ambient temperature -
    +

    + Limitations +

    - For the sensor AixLib.Fluid.Sensors.TemperatureTwoPort, - by setting transferHeat = true, heat transfer to a fixed - ambient can be approximated. The heat transfer is computed as + Density, specific heat capacity, thermal conductivity and viscosity + are constant. The propylene glycol/water mixture is modeled as an + incompressible liquid. There are no phase changes. The medium is + limited to temperatures below 100 °C and mass fractions below + 0.60. As is the case for AixLib.Media.Water, this medium + package should not be used if the simulation relies on the dynamic + viscosity.

    -

    - τHeaTra   dT ⁄ dt = (TAmb-T), +

    + Typical use and important parameters +

    +

    + The temperature and mass fraction must be specified for the + evaluation of the constant thermophysical properties. A typical use + of the package is (e.g. for a temperature of 20 °C and a mass + fraction of 0.40):

    - where τHeaTra is a fixed time constant and - TAmb is a fixed ambient temperature. Setting - transferHeat = true is useful if the sensor output - T is used to switch the mass flow rate on again. If - transferHeat = false, then the sensor output T - remains constant if the mass flow rate is zero and hence a fan or - pump controller that uses this signal may never switch the device on - again. If the sensor output T is not used to switch on the - mass flow rate, then in general one can use - transferHeat=false. + Medium = + AixLib.Media.Antifreeze.PropyleneGlycolWater(property_T=293.15, + X_a=0.40)

    + + +-------- Errors -------- +line 9 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 24 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 35 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/Boreholes/BaseClasses/Functions/convectionResistanceCircularPipe.mo ---- +-------- HTML Code -------- + +

    + This model computes the convection resistance in the pipes of a borehole segment + with heigth hSeg using correlations suggested by Bergman et al. (2011). +

    +

    + If the flow is laminar (Re ≤ 2300, with Re being the Reynolds number of the flow), + the Nusselt number of the flow is assumed to be constant at 3.66. If the flow is turbulent (Re > 2300), + the correlation of Dittus-Boelter is used to find the convection heat transfer coefficient as +

    +

    + Nu = 0.023   Re0.8   Prn, +

    +

    + where Nu is the Nusselt number and + Pr is the Prandlt number. + A value of n=0.35 is used, as the reference uses n=0.4 for heating and + n=0.3 for cooling. To ensure that the function is continuously differentiable, + a smooth transition between the laminar and turbulent values is created for the + range 2300 < Re < 2400. +

    +

    References

    +

    + Bergman, T. L., Incropera, F. P., DeWitt, D. P., & Lavine, A. S. (2011). Fundamentals of heat and mass + transfer (7th ed.). New York: John Wiley & Sons. +

    + + + +-------- Corrected Code --------

    - Note that since in practice the heat transfer is due to a combination - of ambient temperature and upstream or downstream fluid temperature, - for example by two-way buoyancy-driven flow inside the duct or pipe, - the model uses as an approximation a fixed ambient temperature. Since - the sensor is not affecting the temperature of the medium, this - approximation of the heat transfer does not add or remove heat from - the fluid. + This model computes the convection resistance in the pipes of a + borehole segment with heigth hSeg using + correlations suggested by Bergman et al. (2011).

    -
    - Combined dynamic response -

    - For the sensor AixLib.Fluid.Sensors.TemperatureTwoPort, - if both dynamic effects are enabled, then the output T is - computed as + If the flow is laminar (Re ≤ 2300, with Re being the + Reynolds number of the flow), the Nusselt number of the flow is + assumed to be constant at 3.66. If the flow is turbulent (Re > + 2300), the correlation of Dittus-Boelter is used to find the + convection heat transfer coefficient as

    - dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T) ⁄ τ + - (TAmb-T) ⁄ τHeaTra. + Nu = 0.023   Re0.8   Prn,

    -

    - Implementation -

    - The above equation is implemented in such a way that it is - differentiable in the mass flow rate. + where Nu is the Nusselt number and Pr is the Prandlt + number. A value of n=0.35 is used, as the reference uses + n=0.4 for heating and n=0.3 for cooling. To ensure that + the function is continuously differentiable, a smooth transition + between the laminar and turbulent values is created for the range + 2300 < Re < 2400.

    +

    + References +

    - Note that the implementation of the dynamic sensors does not use the - model AixLib.Fluid.MixingVolumes. - The reason is that depending on the selected medium model, the mixing - volume may introduce states for the pressure, species concentration, - trace substance, specific enthalpy and specific entropy. Not all - states are typically needed to model the dynamics of a sensor. - Moreover, in many building system applications, the sensor dynamics - is not of concern, but is rather used here to avoid numerical - problems that steady-state models of sensors cause when flow rates - are very close to zero. + Bergman, T. L., Incropera, F. P., DeWitt, D. P., & Lavine, A. S. + (2011). Fundamentals of heat and mass transfer (7th ed.). New + York: John Wiley & Sons.

    + -------- Errors -------- -line 32 column 1 - Warning: The summary attribute on the element is obsolete in HTML5 -line 105 column 1 - Warning: The summary attribute on the
    element is obsolete in HTML5 -line 33 column 5 - Warning:
    attribute "align" not allowed for HTML5 -line 38 column 5 - Warning: attribute "align" not allowed for HTML5 -line 144 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 167 column 1 - Warning:

    attribute "align" not allowed for HTML5 -line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 +line 11 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/Bicubic.mo ---- +---- AixLib/Controls/Continuous/LimPID.mo ---- -------- HTML Code --------

    - This block computes -

    -

    - y = a1 - + a2 x1 + a3 x12 - + a4 x2 + a5 x22 - + a6 x1 x2 - + a7 x1^3 - + a8 x2^3 - + a9 x12 x2 - + a10 x1 x22 + PID controller in the standard form +

    +

    + y = k   ( e(t) + 1 ⁄ Ti   ∫ e(s) ds + Td de(t)⁄dt ), +

    +

    + where + y is the control signal, + e(t) = us - um is the control error, + with us being the set point and um being + the measured quantity, + k is the gain, + Ti is the time constant of the integral term and + Td is the time constant of the derivative term. +

    +

    + Note that the units of k are the inverse of the units of the control error, + while the units of Ti and Td are seconds. +

    +

    + For detailed treatment of integrator anti-windup, set-point weights and output limitation, see + Modelica.Blocks.Continuous.LimPID. +

    +

    Options

    + This controller can be configured as follows. +
    P, PI, PD, or PID action
    +

    + Through the parameter controllerType, the controller can be configured + as P, PI, PD or PID controller. The default configuration is PI. +

    +
    Direct or reverse acting
    +

    + Through the parameter reverseActing, the controller can be configured to + be reverse or direct acting. + The above standard form is reverse acting, which is the default configuration. + For a reverse acting controller, for a constant set point, + an increase in measurement signal u_m decreases the control output signal y + (Montgomery and McDowall, 2008). + Thus, +

    +
      +
    • + for a heating coil with a two-way valve, leave reverseActing = true, but +
    • +
    • + for a cooling coil with a two-way valve, set reverseActing = false. +
    • +
    +
    Reset of the controller output
    +

    + The controller can be configured to enable an input port that allows resetting the controller + output. The controller output can be reset as follows:

    -
      -
    • - Sep 17, 2010 by Michael Wetter:
      - First implementation. -
    • +
    • + If reset = AixLib.Types.Reset.Disabled, which is the default, + then the controller output is never reset. +
    • +
    • + If reset = AixLib.Types.Reset.Parameter, then a boolean + input signal trigger is enabled. Whenever the value of + this input changes from false to true, + the controller output is reset by setting y + to the value of the parameter y_reset. +
    • +
    • + If reset = AixLib.Types.Reset.Input, then a boolean + input signal trigger and a real input signal y_reset_in + are enabled. Whenever the value of + trigger changes from false to true, + the controller output is reset by setting the value of y + to y_reset_in. +
    - --------- Corrected Code -------- -

    - This block computes -

    -

    - y = a1 + a2 x1 + a3 - x12 + a4 x2 + - a5 x22 + a6 x1 - x2 + a7 x1^3 + a8 - x2^3 + a9 x12 - x2 + a10 x1 - x22 -

    -
      -
    • Sep 17, 2010 by Michael Wetter:
      - First implementation. -
    • -
    - --------- Errors -------- -line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Controls/Discrete/BooleanDelay.mo ---- --------- HTML Code -------- -

    - Block that delays the boolean input signal by - one sampling interval. - For example, - if u denotes the input, - y denotes the output, and - ti and ti+1 - denote subsequent sampling - instants, then the model outputs + Note that this controller implements an integrator anti-windup. Therefore, + for most applications, keeping the default setting of + reset = AixLib.Types.Reset.Disabled is sufficient. + However, if the controller is used in conjuction with equipment that is being + switched on, better control performance may be achieved by resetting the controller + output when the equipment is switched on. + This is in particular the case in situations + where the equipment control input should continuously increase as the equipment is + switched on, such as a light dimmer that may slowly increase the luminance, or + a variable speed drive of a motor that should continuously increase the speed.

    -

    - y(ti+1) = u(ti). +

    References

    +

    + R. Montgomery and R. McDowall (2008). + \"Fundamentals of HVAC Control Systems.\" + American Society of Heating Refrigerating and Air-Conditioning Engineers Inc. Atlanta, GA.

    +
    • - June 6, 2015, by Michael Wetter:
      - Set start value and fixed attribute - for firstTrigger - to avoid a translation warning in pedantic mode - in Dymola 2016. - This is for - #266. + June 1, 2020, by Michael Wetter:
      + Corrected wrong convention of reverse and direct action.
      + Changed default configuration from PID to PI.
      + This is for issue 1365.
    • - November 21, 2011, by Michael Wetter:
      - Improved documentation. + March 9, 2020, by Michael Wetter:
      + Corrected wrong unit declaration for parameter k.
      + This is for issue 1316.
    • - November 26, 2008, by Michael Wetter:
      + October 19, 2019, by Filip Jorissen:
      + Disabled homotopy to ensure bounded outputs + by copying the implementation from MSL 3.2.3 and by + hardcoding the implementation for homotopyType=NoHomotopy. + See issue 1221. +
    • +
    • + September 29, 2016, by Michael Wetter:
      + Refactored model. +
    • +
    • + August 25, 2016, by Michael Wetter:
      + Removed parameter limitsAtInit because it was only propagated to + the instance limiter, but this block no longer makes use of this parameter. + This is a non-backward compatible change.
      + Revised implemenentation, added comments, made some parameter in the instances final. +
    • +
    • July 18, 2016, by Philipp Mehrfeld:
      + Added integrator reset. + This is for issue 494. +
    • +
    • + March 15, 2016, by Michael Wetter:
      + Changed the default value to strict=true in order to avoid events + when the controller saturates. + This is for issue 433. +
    • +
    • + February 24, 2010, by Michael Wetter:
      First implementation.
    -------- Corrected Code --------

    - Block that delays the boolean input signal by one sampling interval. - For example, if u denotes the input, y denotes the - output, and ti and ti+1 denote - subsequent sampling instants, then the model outputs + PID controller in the standard form

    - y(ti+1) = u(ti). + y = k   ( e(t) + 1 ⁄ Ti   ∫ e(s) ds + + Td de(t)⁄dt ), +

    +

    + where y is the control signal, e(t) = us - + um is the control error, with us + being the set point and um being the measured + quantity, k is the gain, Ti is the time + constant of the integral term and Td is the time + constant of the derivative term. +

    +

    + Note that the units of k are the inverse of the units of the + control error, while the units of Ti and + Td are seconds. +

    +

    + For detailed treatment of integrator anti-windup, set-point weights + and output limitation, see Modelica.Blocks.Continuous.LimPID. +

    +

    + Options +

    This controller can be configured as follows. +
    + P, PI, PD, or PID action +
    +

    + Through the parameter controllerType, the controller can + be configured as P, PI, PD or PID controller. The default + configuration is PI. +

    +
    + Direct or reverse acting +
    +

    + Through the parameter reverseActing, the controller can + be configured to be reverse or direct acting. The above standard form + is reverse acting, which is the default configuration. For a reverse + acting controller, for a constant set point, an increase in + measurement signal u_m decreases the control output + signal y (Montgomery and McDowall, 2008). Thus,

      -
    • June 6, 2015, by Michael Wetter:
      - Set start value and fixed attribute for - firstTrigger to avoid a translation warning in - pedantic mode in Dymola 2016. This is for #266. +
    • for a heating coil with a two-way valve, leave + reverseActing = true, but +
    • +
    • for a cooling coil with a two-way valve, set reverseActing + = false. +
    • +
    +
    + Reset of the controller output +
    +

    + The controller can be configured to enable an input port that allows + resetting the controller output. The controller output can be reset + as follows: +

    +
      +
    • If reset = AixLib.Types.Reset.Disabled, which is the + default, then the controller output is never reset. +
    • +
    • If reset = AixLib.Types.Reset.Parameter, then a + boolean input signal trigger is enabled. Whenever the + value of this input changes from false to + true, the controller output is reset by setting + y to the value of the parameter y_reset. +
    • +
    • If reset = AixLib.Types.Reset.Input, then a boolean + input signal trigger and a real input signal + y_reset_in are enabled. Whenever the value of + trigger changes from false to + true, the controller output is reset by setting the + value of y to y_reset_in. +
    • +
    +

    + Note that this controller implements an integrator anti-windup. + Therefore, for most applications, keeping the default setting of + reset = AixLib.Types.Reset.Disabled is sufficient. + However, if the controller is used in conjuction with equipment that + is being switched on, better control performance may be achieved by + resetting the controller output when the equipment is switched on. + This is in particular the case in situations where the equipment + control input should continuously increase as the equipment is + switched on, such as a light dimmer that may slowly increase the + luminance, or a variable speed drive of a motor that should + continuously increase the speed. +

    +

    + References +

    +

    + R. Montgomery and R. McDowall (2008). \"Fundamentals of HVAC Control + Systems.\" American Society of Heating Refrigerating and + Air-Conditioning Engineers Inc. Atlanta, GA. +

    +
      +
    • June 1, 2020, by Michael Wetter:
      + Corrected wrong convention of reverse and direct action.
      + Changed default configuration from PID to PI.
      + This is for issue + 1365.
    • -
    • November 21, 2011, by Michael Wetter:
      - Improved documentation. +
    • March 9, 2020, by Michael Wetter:
      + Corrected wrong unit declaration for parameter k.
      + This is for issue + 1316.
    • -
    • November 26, 2008, by Michael Wetter:
      +
    • October 19, 2019, by Filip Jorissen:
      + Disabled homotopy to ensure bounded outputs by copying the + implementation from MSL 3.2.3 and by hardcoding the implementation + for homotopyType=NoHomotopy. See issue + 1221. +
    • +
    • September 29, 2016, by Michael Wetter:
      + Refactored model. +
    • +
    • August 25, 2016, by Michael Wetter:
      + Removed parameter limitsAtInit because it was only + propagated to the instance limiter, but this block no + longer makes use of this parameter. This is a non-backward + compatible change.
      + Revised implemenentation, added comments, made some parameter in + the instances final. +
    • +
    • July 18, 2016, by Philipp Mehrfeld:
      + Added integrator reset. This is for issue 494. +
    • +
    • March 15, 2016, by Michael Wetter:
      + Changed the default value to strict=true in order to + avoid events when the controller saturates. This is for issue 433. +
    • +
    • February 24, 2010, by Michael Wetter:
      First implementation.
    -------- Errors -------- -line 12 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/Adaptors/HVAC.mo ---- +---- AixLib/Fluid/HeatExchangers/Heater_T.mo ---- -------- HTML Code --------

    - The (time varying) vector Real output signal of this block can be defined in its - parameter menu via variable y. The purpose is to support the - easy definition of vector-valued Real expressions in a block diagram. + Model for an ideal heater that controls its outlet temperature to + a prescribed outlet temperature.

    -

    - Adaptor that can be used to connect an HVAC system (with acausal ports) - to input/output signals, which then can be exposed in an FMI interface. + This model forces the outlet temperature at port_b to be + no lower than the temperature of the input signal + TSet, subject to optional limits on the + capacity. + By default, the model has unlimited heating capacity.

    - The adaptor has a vector of fluid ports called ports. - The supply and return air ducts need to be connected to these ports. - Also, if a thermal zone has interzonal air exchange or air infiltration, - these flow paths also need be connected to ports. + The output signal Q_flow is the heat added + to the medium if the mass flow rate is from port_a to port_b. + If the flow is reversed, then Q_flow=0.

    - This model outputs at the port fluPor the mass flow rate for - each flow that is connected to ports, together with its - temperature, water vapor mass fraction per total mass of the air (not per kg dry - air), and trace substances. These quantities are always as if the flow - enters the room, even if the flow is zero or negative. - If a medium has no moisture, e.g., if Medium.nXi=0, or - if it has no trace substances, e.g., if Medium.nC=0, then - the output signal for these properties are removed. - These quantities are always as if the flow - enters the room, even if the flow is zero or negative. - Thus, a thermal zone model that uses these signals to compute the - heat added by the HVAC system need to implement an equation such as + The outlet conditions at port_a are not affected by this model, + other than for a possible pressure difference due to flow friction. +

    +

    + If the parameter energyDynamics is different from + Modelica.Fluid.Types.Dynamics.SteadyState, + the component models the dynamic response using a first order differential equation. + The time constant of the component is equal to the parameter tau. + This time constant is adjusted based on the mass flow rate using

    - Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), + τeff = τ |ṁ| ⁄ ṁnom

    where - Qsen is the sensible heat flow rate added to the thermal zone, - sup is the supply air mass flow rate from - the port fluPor (which is negative if it is an exhaust), - cp is the specific heat capacity at constant pressure, - Tsup is the supply air temperature and - Tair,zon is the zone air temperature. - Note that without the max(·, ·) function, the energy - balance would be wrong. -

    -

    - The output signals of this model are the zone air temperature, - the water vapor mass fraction per total mass of the air (unless Medium.nXi=0) - and trace substances (unless Medium.nC=0). - These output connectors can be used to connect to a controller. - These values are obtained from the fluid stream(s) that flow into this component - at the port fluPor, e.g., from the connector - fluPor.backward. - Note that there are nPorts of these signals. - For a completely mixed room, they will all have the same value, but - for a room with non-uniform temperatures, they can have different values. + τeff is the effective time constant for the given mass flow rate + and + τ is the time constant at the nominal mass flow rate + nom. + This type of dynamics is equal to the dynamics that a completely mixed + control volume would have.

    -

    Assumption and limitations

    - The mass flow rates at ports sum to zero, hence this - model conserves mass. + Optionally, this model can have a flow resistance. + Set dp_nominal = 0 to disable the flow friction calculation.

    - This model does not impose any pressure, other than setting the pressure - of all fluid connections to ports to be equal. - The reason is that setting a pressure can lead to non-physical system models, - for example if a mass flow rate is imposed and the HVAC system is connected - to a model that sets a pressure boundary condition such as - - AixLib.Fluid.Sources.Outside. - Also, setting a pressure would make it impossible to use multiple instances - of this model (one for each thermal zone) and build in Modelica an airflow network - model with pressure driven mass flow rates. + For a similar model that is a sensible cooling device, use + + AixLib.Fluid.HeatExchangers.SensibleCooler_T. + For a model that uses a control signal u ∈ [0, 1] and multiplies + this with the nominal heating or cooling power, use + + AixLib.Fluid.HeatExchangers.HeaterCooler_u +

    +

    Limitations

    - The model has no pressure drop. Hence, the pressure drop - of an air diffuser or of an exhaust grill need to be modelled - in models that are connected to ports. + If the flow is from port_b to port_a, + then the enthalpy of the medium is not affected by this model.

    -

    Typical use and important parameters

    +

    Validation

    - See - - AixLib.Fluid.FMI.ExportContainers.HVACZone - for a model that uses this model. + The model has been validated against the analytical solution in + the examples + + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet + and + + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic.

    • - January 18, 2019, by Jianjun Hu:
      - Limited the media choice to moist air only. - See #1050. -
    • -
    • - September 13, 2017, by Michael Wetter:
      - Removed erroneous each. -
    • -
    • - October 4, 2016, by Michael Wetter:
      - Corrected assignment of quantity in CZon. -
    • -
    • - June 29, 2016, by Michael Wetter:
      - Revised implementation. + September 10, 2018, by Michael Wetter:
      + Corrected missing propagation of initial conditions.
      + This is for + + AixLib, #1016.
    • - April 14, 2016, by Michael Wetter:
      - First implementation. + May 3, 2017, by Michael Wetter:
      + First implementation.
      + This is for + + AixLib, #763.
    -------- Corrected Code --------

    - The (time varying) vector Real output signal of this - block can be defined in its parameter menu via variable - y. The purpose is to support the easy definition of - vector-valued Real expressions in a block diagram. + Model for an ideal heater that controls its outlet temperature to a + prescribed outlet temperature.

    - Adaptor that can be used to connect an HVAC system (with acausal - ports) to input/output signals, which then can be exposed in an FMI - interface. + This model forces the outlet temperature at port_b to be + no lower than the temperature of the input signal TSet, + subject to optional limits on the capacity. By default, the model has + unlimited heating capacity.

    - The adaptor has a vector of fluid ports called ports. - The supply and return air ducts need to be connected to these ports. - Also, if a thermal zone has interzonal air exchange or air - infiltration, these flow paths also need be connected to - ports. + The output signal Q_flow is the heat added to the medium + if the mass flow rate is from port_a to + port_b. If the flow is reversed, then + Q_flow=0.

    - This model outputs at the port fluPor the mass flow rate - for each flow that is connected to ports, together with - its temperature, water vapor mass fraction per total mass of the air - (not per kg dry air), and trace substances. These quantities are - always as if the flow enters the room, even if the flow is zero or - negative. If a medium has no moisture, e.g., if - Medium.nXi=0, or if it has no trace substances, e.g., if - Medium.nC=0, then the output signal for these properties - are removed. These quantities are always as if the flow enters the - room, even if the flow is zero or negative. Thus, a thermal zone - model that uses these signals to compute the heat added by the HVAC - system need to implement an equation such as -

    -

    - Qsen = max(0, ṁsup)   cp   - (Tsup - Tair,zon), + The outlet conditions at port_a are not affected by this + model, other than for a possible pressure difference due to flow + friction.

    - where Qsen is the sensible heat flow rate added to - the thermal zone, sup is the supply air mass flow - rate from the port fluPor (which is negative if it is an - exhaust), cp is the specific heat capacity at - constant pressure, Tsup is the supply air - temperature and Tair,zon is the zone air - temperature. Note that without the max(·, ·) function, the - energy balance would be wrong. + If the parameter energyDynamics is different from + Modelica.Fluid.Types.Dynamics.SteadyState, the component + models the dynamic response using a first order differential + equation. The time constant of the component is equal to the + parameter tau. This time constant is adjusted based on + the mass flow rate using

    -

    - The output signals of this model are the zone air temperature, the - water vapor mass fraction per total mass of the air (unless - Medium.nXi=0) and trace substances (unless - Medium.nC=0). These output connectors can be used to - connect to a controller. These values are obtained from the fluid - stream(s) that flow into this component at the port - fluPor, e.g., from the connector - fluPor.backward. Note that there are nPorts - of these signals. For a completely mixed room, they will all have the - same value, but for a room with non-uniform temperatures, they can - have different values. +

    + τeff = τ |ṁ| ⁄ ṁnom +

    +

    + where τeff is the effective time constant for the + given mass flow rate and τ is the time constant at + the nominal mass flow rate nom. This type of + dynamics is equal to the dynamics that a completely mixed control + volume would have.

    -

    - Assumption and limitations -

    - The mass flow rates at ports sum to zero, hence this - model conserves mass. + Optionally, this model can have a flow resistance. Set + dp_nominal = 0 to disable the flow friction calculation.

    - This model does not impose any pressure, other than setting the - pressure of all fluid connections to ports to be equal. - The reason is that setting a pressure can lead to non-physical system - models, for example if a mass flow rate is imposed and the HVAC - system is connected to a model that sets a pressure boundary - condition such as AixLib.Fluid.Sources.Outside. - Also, setting a pressure would make it impossible to use multiple - instances of this model (one for each thermal zone) and build in - Modelica an airflow network model with pressure driven mass flow - rates. + For a similar model that is a sensible cooling device, use AixLib.Fluid.HeatExchangers.SensibleCooler_T. + For a model that uses a control signal u ∈ [0, 1] and + multiplies this with the nominal heating or cooling power, use + AixLib.Fluid.HeatExchangers.HeaterCooler_u

    +

    + Limitations +

    - The model has no pressure drop. Hence, the pressure drop of an air - diffuser or of an exhaust grill need to be modelled in models that - are connected to ports. + If the flow is from port_b to port_a, then + the enthalpy of the medium is not affected by this model.

    - Typical use and important parameters + Validation

    - See AixLib.Fluid.FMI.ExportContainers.HVACZone - for a model that uses this model. + The model has been validated against the analytical solution in the + examples AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet + and + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic.

      -
    • January 18, 2019, by Jianjun Hu:
      - Limited the media choice to moist air only. See #1050. -
    • -
    • September 13, 2017, by Michael Wetter:
      - Removed erroneous each. -
    • -
    • October 4, 2016, by Michael Wetter:
      - Corrected assignment of quantity in CZon. -
    • -
    • June 29, 2016, by Michael Wetter:
      - Revised implementation. +
    • September 10, 2018, by Michael Wetter:
      + Corrected missing propagation of initial conditions.
      + This is for AixLib, + #1016.
    • -
    • April 14, 2016, by Michael Wetter:
      - First implementation. +
    • May 3, 2017, by Michael Wetter:
      + First implementation.
      + This is for AixLib, + #763.
    -------- Errors -------- -line 26 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Controls/SetPoints/Examples/SupplyReturnTemperatureReset.mo ---- +---- AixLib/Controls/Continuous/Examples/OffTimer.mo ---- -------- HTML Code --------

    - Example that demonstrates the use of the hot water temperature reset - for a heating system. - The parameters of the block heaCur - are for a heating system with - 60°C supply water temperature and - 40°C return water temperature at - an outside temperature of - -10°C and a room temperature of - 20°C. The offset for the temperature reset is - 8 Kelvin, i.e., above - 12°C outside temperature, there is no heating load. - The figure below shows the computed supply and return water temperatures. + Example that demonstrates the use of the model + + AixLib.Controls.Continuous.OffTimer. + The input to the two timers are alternating boolean values. + Whenever the input becomes false(=0), the timer is reset. + The figures below show the input and output of the blocks.

    - \"Supply + \"Input
    + \"Input

      @@ -20196,19 +20070,19 @@ line 26 column 2 - Warning:

      attribute "align" not allowed for HTML5 -------- Corrected Code --------

      - Example that demonstrates the use of the hot water temperature reset - for a heating system. The parameters of the block heaCur - are for a heating system with 60°C supply water temperature - and 40°C return water temperature at an outside temperature of - -10°C and a room temperature of 20°C. The offset for - the temperature reset is 8 Kelvin, i.e., above 12°C - outside temperature, there is no heating load. The figure below shows - the computed supply and return water temperatures. + Example that demonstrates the use of the model AixLib.Controls.Continuous.OffTimer. + The input to the two timers are alternating boolean values. Whenever + the input becomes false(=0), the timer is reset. The + figures below show the input and output of the blocks.

      \"Supply + \"modelica://AixLib/Resources/Images/Controls/Continuous/Examples/OffTimer1.png\" + border=\"1\" alt=\"Input and output of the OffTimer offTim1.\">
      + \"Input

      • November 21, 2011, by Michael Wetter:
        @@ -20217,4797 +20091,4923 @@ line 26 column 2 - Warning:

        attribute "align" not allowed for HTML5

      -------- Errors -------- -line 16 column 2 - Warning:

      attribute "align" not allowed for HTML5 - - ----- AixLib/Utilities/Math/Functions/biquadratic.mo ---- --------- HTML Code -------- - - This function computes -

      - y = a1 + a2 x1 - + a3 x12 - + a4 x2 + a5 x22 - + a6 x1 x2 -

      - -
        -
      • - Sep 8, 2010 by Michael Wetter:
        - First implementation. -
      • -
      - --------- Corrected Code -------- -This function computes -

      - y = a1 + a2 x1 + a3 - x12 + a4 x2 + - a5 x22 + a6 x1 - x2 -

      -
        -
      • Sep 8, 2010 by Michael Wetter:
        - First implementation. -
      • -
      - --------- Errors -------- -line 3 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 10 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatPumps/Compressors/ScrollCompressor.mo ---- +---- AixLib/Fluid/Humidifiers/Humidifier_u.mo ---- -------- HTML Code --------

      - Model for a scroll processor, as detailed in Jin (2002). The rate of heat transferred to the evaporator is given by: -

      -

      - Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ). + Model for an air humidifier or dehumidifier.

      - The power consumed by the compressor is given by a linear efficiency relation: + This model adds (or removes) moisture from the air stream. + The amount of exchanged moisture is equal to

      - P = PTheoretical / η + PLoss,constant. -

      -

      - Variable speed is achieved by multiplying the full load suction volume flow rate - by the normalized compressor speed. The power and heat transfer rates are forced - to zero if the resulting heat pump state has higher evaporating pressure than - condensing pressure. + ṁwat = u ṁwat,nom,

      -

      Assumptions and limitations

      - The compression process is assumed isentropic. The thermal energy - of superheating is ignored in the evaluation of the heat transferred to the refrigerant - in the evaporator. There is no supercooling. + where u is the control input signal and + wat,nom is equal to the parameter mWat_flow_nominal. + The parameter mWat_flow_nominal can be positive or negative. + If wat is positive, then moisture is added + to the air stream, otherwise it is removed.

      -

      References

      - H. Jin. - - Parameter estimation based models of water source heat pumps. - - PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002. + If the heat port heatPort is unconnected, then the enthalpy of the + air that flows through the device remains unchanged, e.g., the humidification + is adiabatic. To change the enthalpy of the air, add heat flow to the connector + heatPort.

      • - January 25, 2019, by Michael Wetter:
        - Added start value to avoid warning in JModelica. + March 7, 2022, by Michael Wetter:
        + Removed massDynamics.
        + This is for + #1542.
      • - May 30, 2017, by Filip Jorissen:
        - Removed pressure_error as - this is replaced by - - AixLib.Fluid.HeatPumps.Compressors.BaseClasses.TemperatureProtection. - See #769. + April 12, 2017, by Michael Wetter:
        + Removed parameters use_T_in and T. + This removes the optional specification of temperature through the parameter T + or the input connector T_in. + Exposed the heat port of the control volume to allow adding heat, + for example, to use the model as a steam humidifier.
        + This is for issue + + Buildings #704.
      • - November 11, 2016, by Massimo Cimmino:
        + May 6, 2015, by Michael Wetter:
        + Set prescribedHeatFlowRate=true. + This is for issue + + #412. +
      • +
      • + May 29, 2014, by Michael Wetter:
        + Removed undesirable annotation Evaluate=true. +
      • +
      • + February 11, 2014 by Michael Wetter:
        + Corrected issue #197 + which led to twice the amount of latent heat being added to the fluid stream. +
      • +
      • + October 14, 2013 by Michael Wetter:
        + Constrained medium to be a subclass of + Modelica.Media.Interfaces.PartialCondensingGases, + as this base class declares the function + enthalpyOfCondensingGas. +
      • +
      • + July 30, 2013 by Michael Wetter:
        + Updated model to use new variable mWat_flow + in the base class. +
      • +
      • + May 24, 2011, by Michael Wetter:
        + Changed base class to allow using the model as a dynamic or a steady-state model. +
      • +
      • + April 14, 2010, by Michael Wetter:
        + Converted temperature input to a conditional connector. +
      • +
      • + April 17, 2008, by Michael Wetter:
        First implementation.
      -------- Corrected Code --------

      - Model for a scroll processor, as detailed in Jin (2002). The rate of - heat transferred to the evaporator is given by: -

      -

      - Q̇Eva = ṁref ( - hVap(TEva) - hLiq(TCon) - ). + Model for an air humidifier or dehumidifier.

      - The power consumed by the compressor is given by a linear efficiency - relation: + This model adds (or removes) moisture from the air stream. The amount + of exchanged moisture is equal to

      - P = PTheoretical / η + PLoss,constant. -

      -

      - Variable speed is achieved by multiplying the full load suction - volume flow rate by the normalized compressor speed. The power and - heat transfer rates are forced to zero if the resulting heat pump - state has higher evaporating pressure than condensing pressure. + ṁwat = u ṁwat,nom,

      -

      - Assumptions and limitations -

      - The compression process is assumed isentropic. The thermal energy of - superheating is ignored in the evaluation of the heat transferred to - the refrigerant in the evaporator. There is no supercooling. + where u is the control input signal and + wat,nom is equal to the parameter + mWat_flow_nominal. The parameter + mWat_flow_nominal can be positive or negative. If + wat is positive, then moisture is added to the + air stream, otherwise it is removed.

      -

      - References -

      - H. Jin. Parameter estimation based models of water source heat - pumps. PhD Thesis. Oklahoma State University. Stillwater, - Oklahoma, USA. 2002. + If the heat port heatPort is unconnected, then the + enthalpy of the air that flows through the device remains unchanged, + e.g., the humidification is adiabatic. To change the enthalpy of the + air, add heat flow to the connector heatPort.

        -
      • January 25, 2019, by Michael Wetter:
        - Added start value to avoid warning in JModelica. +
      • March 7, 2022, by Michael Wetter:
        + Removed massDynamics.
        + This is for #1542.
      • -
      • May 30, 2017, by Filip Jorissen:
        - Removed pressure_error as this is replaced by - AixLib.Fluid.HeatPumps.Compressors.BaseClasses.TemperatureProtection. - See #769. +
      • April 12, 2017, by Michael Wetter:
        + Removed parameters use_T_in and T. This + removes the optional specification of temperature through the + parameter T or the input connector T_in. + Exposed the heat port of the control volume to allow adding heat, + for example, to use the model as a steam humidifier.
        + This is for issue Buildings + #704.
      • -
      • November 11, 2016, by Massimo Cimmino:
        +
      • May 6, 2015, by Michael Wetter:
        + Set prescribedHeatFlowRate=true. This is for issue + #412. +
      • +
      • May 29, 2014, by Michael Wetter:
        + Removed undesirable annotation Evaluate=true. +
      • +
      • February 11, 2014 by Michael Wetter:
        + Corrected issue #197 + which led to twice the amount of latent heat being added to the + fluid stream. +
      • +
      • October 14, 2013 by Michael Wetter:
        + Constrained medium to be a subclass of + Modelica.Media.Interfaces.PartialCondensingGases, as + this base class declares the function + enthalpyOfCondensingGas. +
      • +
      • July 30, 2013 by Michael Wetter:
        + Updated model to use new variable mWat_flow in the + base class. +
      • +
      • May 24, 2011, by Michael Wetter:
        + Changed base class to allow using the model as a dynamic or a + steady-state model. +
      • +
      • April 14, 2010, by Michael Wetter:
        + Converted temperature input to a conditional connector. +
      • +
      • April 17, 2008, by Michael Wetter:
        First implementation.
      -------- Errors -------- -line 5 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 11 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 9 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Humidifiers/SprayAirWasher_X.mo ---- +---- AixLib/Fluid/Movers/BaseClasses/Characteristics/power.mo ---- -------- HTML Code --------

      - Model for a spray air washer with a prescribed outlet water vapor mass fraction - in kg/kg total air. -

      -

      - This model forces the outlet water mass fraction at port_b to be - no lower than the - input signal X_wSet, subject to optional limits on the - maximum water vapor mass flow rate that is added, as - described by the parameter mWatMax_flow. - By default, the model has unlimited capacity. -

      -

      - The output signal mWat_flow ≥ 0 is the moisture added - to the medium if the flow rate is from port_a to port_b. - If the flow is reversed, then mWat_flow = 0. - The outlet specific enthalpy at port_b is increased by - the enthalpy of liquid water at 10°C times the mass of water that was added. - Therefore, the temperature of the leaving fluid is below the inlet temperature. -

      -

      - The outlet conditions at port_a are not affected by this model, - other than for a possible pressure difference due to flow friction. -

      -

      - If the parameter energyDynamics is different from - Modelica.Fluid.Types.Dynamics.SteadyState, - the component models the dynamic response using a first order differential equation. - The time constant of the component is equal to the parameter tau. - This time constant is adjusted based on the mass flow rate using + This function computes the fan power consumption for given volume flow rate, + speed and performance data. The power consumption is

      - τeff = τ |ṁ| ⁄ ṁnom + P = rN3   s(V̇/rN, d),

      where - τeff is the effective time constant for the given mass flow rate - and - τ is the time constant at the nominal mass flow rate - nom. - This type of dynamics is equal to the dynamics that a completely mixed - control volume would have. -

      -

      - Optionally, this model can have a flow resistance. - Set dp_nominal = 0 to disable the flow friction calculation. -

      -

      - For a model that uses a control signal u ∈ [0, 1] and multiplies - this with the nominal water mass flow rate, use - - AixLib.Fluid.Humidifiers.Humidifier_u - -

      -

      Limitations

      -

      - This model only adds water vapor for the flow from - port_a to port_b. - The water vapor of the reverse flow is not affected by this model. + P is the power consumption, + rN is the normalized fan speed, + is the volume flow rate and + d are performance data for fan or pump power consumption at rN=1.

      +

      Implementation

      - This model does not affect the enthalpy of the air. Therefore, - if water is added, the temperature will decrease, e.g., the humidification - is adiabatic. + The function s(·, ·) is a cubic hermite spline. + If the data d define a monotone decreasing sequence, then + s(·, d) is a monotone decreasing function.

      • - March 8, 2022, by Michael Wetter:
        - Renamed parameter massDynamics to energyDynamics for consistency with other models. -
      • -
      • - December 14, 2018, by Michael Wetter:
        - Restricted base class for medium to one that implements - the function enthalpyOfLiquid.
        - This is for - #1057. + February 26, 2014, by Filip Jorissen:
        + Changed polynomial to be evaluated at V_flow/r_N + instead of V_flow to properly account for the + scaling law. See + #202 + for a discussion and validation.
      • - May 3, 2017, by Michael Wetter:
        + September 28, 2011, by Michael Wetter:
        First implementation.
      -------- Corrected Code --------

      - Model for a spray air washer with a prescribed outlet water vapor - mass fraction in kg/kg total air. -

      -

      - This model forces the outlet water mass fraction at - port_b to be no lower than the input signal - X_wSet, subject to optional limits on the maximum water - vapor mass flow rate that is added, as described by the parameter - mWatMax_flow. By default, the model has unlimited - capacity. -

      -

      - The output signal mWat_flow ≥ 0 is the moisture added to - the medium if the flow rate is from port_a to - port_b. If the flow is reversed, then mWat_flow = - 0. The outlet specific enthalpy at port_b is - increased by the enthalpy of liquid water at 10°C times the - mass of water that was added. Therefore, the temperature of the - leaving fluid is below the inlet temperature. -

      -

      - The outlet conditions at port_a are not affected by this - model, other than for a possible pressure difference due to flow - friction. -

      -

      - If the parameter energyDynamics is different from - Modelica.Fluid.Types.Dynamics.SteadyState, the component - models the dynamic response using a first order differential - equation. The time constant of the component is equal to the - parameter tau. This time constant is adjusted based on - the mass flow rate using + This function computes the fan power consumption for given volume + flow rate, speed and performance data. The power consumption is

      - τeff = τ |ṁ| ⁄ ṁnom -

      -

      - where τeff is the effective time constant for the - given mass flow rate and τ is the time constant at - the nominal mass flow rate nom. This type of - dynamics is equal to the dynamics that a completely mixed control - volume would have. -

      -

      - Optionally, this model can have a flow resistance. Set - dp_nominal = 0 to disable the flow friction calculation. + P = rN3   s(V̇/rN, d),

      - For a model that uses a control signal u ∈ [0, 1] and - multiplies this with the nominal water mass flow rate, use AixLib.Fluid.Humidifiers.Humidifier_u + where P is the power consumption, rN is the + normalized fan speed, is the volume flow rate and d + are performance data for fan or pump power consumption at + rN=1.

      - Limitations + Implementation

      - This model only adds water vapor for the flow from - port_a to port_b. The water vapor of the - reverse flow is not affected by this model. -

      -

      - This model does not affect the enthalpy of the air. Therefore, if - water is added, the temperature will decrease, e.g., the - humidification is adiabatic. + The function s(·, ·) is a cubic hermite spline. If the data + d define a monotone decreasing sequence, then s(·, d) + is a monotone decreasing function.

        -
      • March 8, 2022, by Michael Wetter:
        - Renamed parameter massDynamics to - energyDynamics for consistency with other models. -
      • -
      • December 14, 2018, by Michael Wetter:
        - Restricted base class for medium to one that implements the - function enthalpyOfLiquid.
        - This is for #1057. +
      • February 26, 2014, by Filip Jorissen:
        + Changed polynomial to be evaluated at V_flow/r_N + instead of V_flow to properly account for the scaling + law. See #202 + for a discussion and validation.
      • -
      • May 3, 2017, by Michael Wetter:
        +
      • September 28, 2011, by Michael Wetter:
        First implementation.
      -------- Errors -------- -line 33 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/UsersGuide.mo ---- +---- AixLib/Utilities/Math/Functions/Examples/CubicHermite.mo ---- -------- HTML Code -------- +

      + This example demonstrates the use of the function for cubic hermite interpolation + and linear extrapolation. + The example use interpolation with two different settings: One settings + produces a monotone cubic hermite, whereas the other setting + does not enforce monotonicity. + The resulting plot should look as shown below, where for better visibility, the support points have been marked with black dots. + Notice that the red curve is monotone increasing. +

      +

      \"image\"

      + +
        +
      • + March 8, 2013, by Michael Wetter:
        + First implementation. +
      • +
      + +-------- Corrected Code --------

      -This package contains borefield models. These models can simulate any arbitrary -configuration of vertical boreholes with equal lengths with both short and -long-term accuracy with an aggregation method to speed up the calculations of the ground heat transfer. Examples -of how to use the borefield models and validation cases can be found in - -AixLib.Fluid.Geothermal.Borefields.Examples -and - -AixLib.Fluid.Geothermal.Borefields.Validation, -respectively. -

      -

      -The major features and configurations currently supported are: -

        -
      • User-defined borefield characteristics and geometry (borehole radius, pipe radius, shank spacing, etc.), -including single U-tube, double U-tube in parallel and double U-tube in series configurations. -
      • -
      • The resistances Rb and Ra are -either automatically calculated using the multipole method, -or the resistance Rb can be directly provided by the user. -In this case, the resistances Rb and Ra are -still evaluated internally, but their values are weighted so that the borehole -resistance matches the specified value. -
      • -
      • -User-defined vertical discretization of boreholes are supported. -However, the borehole wall temperature -is identical for each borehole, as the ground temperature response model only computes the average borehole wall temperature -for all boreholes combined. -
      • -
      • -Borefields can consist of one or many boreholes. Each borehole can be positioned -at an arbitrary position in the field using cartesian coordinates. -
      • -
      • -The resolution and precision of the load aggregation method for the ground heat transfer can be adapted. -
      • -
      • -The thermal response of the ground heat transfer is stored locally to avoid -having to recalculate it for future simulations with the same borefield configuration. -
      • -
      • -Pressure losses are calculated if the dp_nominal parameter is set to a non-zero value. -
      • -
      - -

      -The model is limited to the simulation of borefields with boreholes connected in -parallel, as shown on the figure below for a single U-tube configuration. All -boreholes have the same length hBor, the same radius -rBor, and are buried at the same depth dBor below the -ground surface (also known as the inactive borehole length). + This example demonstrates the use of the function for cubic hermite + interpolation and linear extrapolation. The example use interpolation + with two different settings: One settings produces a monotone cubic + hermite, whereas the other setting does not enforce monotonicity. The + resulting plot should look as shown below, where for better + visibility, the support points have been marked with black dots. + Notice that the red curve is monotone increasing.

      -\"image\" -

      - -

      How to use the borefield models

      -
      Borefield data record
      -

      -Most of the parameter values of the model are contained in the record called borFieDat. -This record is composed of three subrecords: -filDat (containing the thermal characteristics of the borehole filling material), -soiDat (containing the thermal characteristics of the surrounding soil), -and conDat (containing all others parameters, namely parameters -defining the configuration of the borefield). -The structure and default values of the record are in the package: -AixLib.Fluid.Geothermal.Borefields.Data. -The borFieDat record -can be found in the -AixLib.Fluid.Geothermal.Borefields.Data.Borefield subpackage therein. -Examples of the subrecords conDat, filDat and soiDat -can be found in - -AixLib.Fluid.Geothermal.Borefields.Data.Configuration, - -AixLib.Fluid.Geothermal.Borefields.Data.Filling and - -AixLib.Fluid.Geothermal.Borefields.Data.Soil, respectively. -

      -

      -It is important to make sure that the borCon parameter within -the conDat subrecord is compatible with the chosen borefield model. -For example, if a double U-tube -borefield model is chosen, the borCon parameter could be set -to both a parallel double U-tube configuration and a double U-tube configuration in series, -but could not be set to a single U-tube configuration. An incompatible borehole -configuration will stop the simulation. -

      -
      Ground heat transfer parameters
      -

      -Other than the parameters contained in the borFieDat record, -the borefield models have other parameters which can be modified by the user. -The tLoaAgg parameter is the time resolution of the load aggregation -for the calculation of the ground heat transfer. It represents the -frequency at which the load aggregation procedure is performed in the simulation. -Therefore, smaller values of tLoaAgg will improve -the accuracy of the model, at the cost of increased simulation times -due to a higher number of events occuring in the simulation. While a default value -is provided for this parameter, it is advisable to ensure that it is lower -than a fraction (e.g. half) of the time required for the fluid to completely circulate -through the borefield, -as increasing the value of tLoaAgg beyond this -will result in non-physical borehole wall temperatures. -

      -

      -The nCel parameter also affects the accuracy and simulation time -of the ground heat transfer calculations. As this parameter sets the number -of consecutive equal-size aggregation cells before increasing the size of cells, -increasing its value will result in less load aggregation, which will increase -accuracy at the cost of computation time. On the other hand, -decreasing the value of nCel (down to a minimum of 1) -will decrease accuracy but improve -computation time. The default value is chosen as a compromise between the two. -

      -

      -Further information on the tLoaAgg and nCel parameters can -be found in the documentation of - -AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse. -

      -
      Other parameters
      -

      -Other parameters which can be modified include the dynamics, initial conditions, -and further information regarding the fluid flow, for example whether the flow is reversible. -It is worth noting that regardless of the energyDynamics chosen, -the dynFil parameter can be set to false -to remove the effect of the thermal capacitance -of the filling material in the borehole(s). -The nSeg parameter specifies the number of segments for the vertical discretization of the borehole(s). -Further information on this discretization can be found in the "Model description" section below. -

      -
      Running simulations
      -

      -When running simulations using the borefield models, -the tmp/temperatureResponseMatrix directory within the current directory -will be checked to see if any of the -borefield configurations used in the simulation have already -had their ground temperature response calculated previously -If the data doesn't exist in the tmp/temperatureResponseMatrix folder, -it will be calculated during the initialization of the model -and will be saved there for future use. + \"image\"

      -

      Model description

      -

      -The borefield models rely on the following key assumptions:

        -
      • The thermal properties of the soil (conductivity and diffusivity) are constant, -homogenous and isotropic. -
      • -
      • -The conductivity, capacitance and density of the grout and pipe material are constant, homogenous and isotropic. -
      • -
      • -There is no heat extraction or injection prior to the simulation start. -
      • -
      • -All of the boreholes in the borefield have uniform dimensions (including the pipe dimensions). -
      • -
      • -Inside the boreholes, the non-advective heat transfer is only in the radial direction. -
      • +
      • March 8, 2013, by Michael Wetter:
        + First implementation. +
      + +-------- Errors -------- +line 11 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Movers/BaseClasses/Characteristics/efficiency.mo ---- +-------- HTML Code -------- + +

      + This function computes the fan or pump efficiency for given normalized volume flow rate + and performance data. The efficiency is +

      +

      + η = s(V̇/rN, d), +

      +

      + where + η is the efficiency, + rN is the normalized fan speed, + is the volume flow rate, and + d are performance data for fan or pump efficiency. +

      +

      Implementation

      +

      + The function s(·, ·) is a cubic hermite spline. + If the data d define a monotone decreasing sequence, then + s(·, d) is a monotone decreasing function. +

      + +
        +
      • + December 2, 2016, by Michael Wetter:
        + Removed min attribute as otherwise numerical noise can cause + the assertion on the limit to fail.
        + This is for + #606. +
      • +
      • + November 22, 2014, by Michael Wetter:
        + Corrected documentation as curve uses + as an independent variable. +
      • +
      • + September 30, 2014, by Filip Jorissen:
        + Changed polynomial to be evaluated at V_flow + instead of r_V. +
      • +
      • + April 19, 2014, by Filip Jorissen:
        + Changed polynomial to be evaluated at r_V/r_N + instead of r_V to properly account for the + scaling law. See + #202 + for a discussion and validation. +
      • +
      • + September 28, 2011, by Michael Wetter:
        + First implementation. +
      • +
      + +-------- Corrected Code --------

      -The borefield models are constructed in two main parts: the borehole(s) and the ground heat transfer. -The former is modeled as a vertical discretization of borehole segments, where a uniform temperature increase or decrease -(due to heat injection or extraction) is superimposed to the far-field ground temperature to obtain the borehole wall -temperature. The thermal effects of the circulating fluid (including the convection resistance), -of the pipes and of the filling material are all taken into consideration, which allows modeling -short-term thermal effects in the borehole. The borehole segments do not take into account axial effects, -thus only radial (horizontal) effects are considered within the borehole(s). The thermal -behavior between the pipes and borehole wall are modeled as a resistance-capacitance network, with -the grout capacitance being split in the number of pipes present in a borehole section. -The capacitance is only present if the dynFil parameter is set to true. -The figure below shows an example for a borehole section within a single U-tube configuration. -

      -

      -\"image\" -

      -

      -The second main part of the borefield models is the ground heat transfer, which shares a thermal boundary -condition at the uniform borehole wall with all of the borehole segments. The heat transfer in the ground -is modeled analytically as a convolution integral between the heat flux at the borehole wall -and the borefield's thermal response factor. -

      -

      -\"image\" + This function computes the fan or pump efficiency for given + normalized volume flow rate and performance data. The efficiency is

      -

      -The model uses a load aggregation technique to reduce the time required to calculate -the borehole wall temperature changes resulting from heat injection or extraction. +

      + η = s(V̇/rN, d),

      -The ground heat transfer takes into account both the borehole axial effects and -the borehole radial effects which are a result of its cylindrical geometry. The borefield's -thermal response to a constant load, also known as its g-function, is used -to calculate the thermal response in the simulation. This g-function -is stored in the tmp/temperatureResponseMatrix subdirectory, -as discussed previously in the -"How to use the borefield models" section. Further information on the -ground heat transfer model and the thermal temperature response calculations can -be found in - -AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse -and - -AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.gFunction. + where η is the efficiency, rN is the + normalized fan speed, is the volume flow rate, and d + are performance data for fan or pump efficiency.

      -

      References

      +

      + Implementation +

      -D. Picard, L. Helsen. -Advanced Hybrid Model for Borefield Heat -Exchanger Performance Evaluation; an Implementation in Modelica -Proc. of the 10th Intertional ModelicaConference, p. 857-866. Lund, Sweden. March 2014. -https://lirias.kuleuven.be/retrieve/270880. + The function s(·, ·) is a cubic hermite spline. If the data + d define a monotone decreasing sequence, then s(·, d) + is a monotone decreasing function.

      +
        +
      • December 2, 2016, by Michael Wetter:
        + Removed min attribute as otherwise numerical noise can + cause the assertion on the limit to fail.
        + This is for #606. +
      • +
      • November 22, 2014, by Michael Wetter:
        + Corrected documentation as curve uses as an independent + variable. +
      • +
      • September 30, 2014, by Filip Jorissen:
        + Changed polynomial to be evaluated at V_flow instead + of r_V. +
      • +
      • April 19, 2014, by Filip Jorissen:
        + Changed polynomial to be evaluated at r_V/r_N instead + of r_V to properly account for the scaling law. See + #202 + for a discussion and validation. +
      • +
      • September 28, 2011, by Michael Wetter:
        + First implementation. +
      • +
      + +-------- Errors -------- +line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 + +---- AixLib/Media/Water.mo ---- +-------- HTML Code -------- + +

      + Model with basic thermodynamic properties. +

      +

      + This base properties model is identical to + + Modelica.Media.Water.ConstantPropertyLiquidWater, + except that the equation + u = cv_const*(T - reference_T) + has been replaced by u=h because + cp_const=cv_const. +

      +

      + This model provides equation for the following thermodynamic properties: +

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      VariableUnitDescription
      TKtemperature
      pPaabsolute pressure
      dkg/m3density
      hJ/kgspecific enthalpy
      uJ/kgspecific internal energy
      Xi[nXi]kg/kgindependent mass fractions m_i/m
      RJ/kg.Kgas constant
      Mkg/molmolar mass
      + +

      + Enthalpy of the water. +

      + + + +

      + This medium package models liquid water. +

      +

      + The mass density is computed using a constant value of 995.586 kg/s. + For a medium model in which the density is a function of temperature, use + + AixLib.Media.Specialized.Water.TemperatureDependentDensity which may have considerably higher computing time. +

      +

      + For the specific heat capacities at constant pressure and at constant volume, + a constant value of 4184 J/(kg K), which corresponds to 20°C + is used. + The figure below shows the relative error of the specific heat capacity that + is introduced by this simplification. +

      +

      + \"Relative +

      +

      + The enthalpy is computed using the convention that h=0 + if T=0 °C. +

      +

      Limitations

      +

      + Density, specific heat capacity, thermal conductivity and viscosity are constant. + Water is modeled as an incompressible liquid. + There are no phase changes. +

      + +
        +
      • + September 28, 2020, by Michael Wetter:
        + Reformulated BaseProperties to avoid event-triggering assertions.
        + This is for + #1401. +
      • +
      • + October 26, 2018, by Filip Jorissen and Michael Wetter:
        + Now printing different messages if temperature is above or below its limit, + and adding instance name as JModelica does not print the full instance name in the assertion. + This is for + #1045. +
      • +
      • + June 6, 2015, by Michael Wetter:
        + Set AbsolutePressure(start=p_default) to avoid + a translation error if + + AixLib.Fluid.Sources.Examples.TraceSubstancesFlowSource + (if used with water instead of air) + is translated in pedantic mode in Dymola 2016. + The reason is that pressures use Medium.p_default as start values, + but + + Modelica.Media.Interfaces.Types + sets a default value of 1E-5. + A similar change has been done for pressure and density. + This fixes + #266. +
      • +
      • + June 6, 2015, by Michael Wetter:
        + Changed type of BaseProperties.T from + Modelica.Units.SI.Temperature to Temperature. + Otherwise, it has a different start value than Medium.T, which + causes an error if + + AixLib.Media.Examples.WaterProperties + is translated in pedantic mode. + This fixes + #266. +
      • +
      • + June 5, 2015, by Michael Wetter:
        + Added stateSelect attribute in BaseProperties.T + to allow correct use of preferredMediumState as + described in + + Modelica.Media.Interfaces.PartialMedium, + and set preferredMediumState=false + to keep the same states as were used before. + This is for + #260. +
      • +
      • + June 5, 2015, by Michael Wetter:
        + Removed ThermodynamicState declaration as this lead to + the error + \"Attempting to redeclare record ThermodynamicState when the original was not replaceable.\" + in Dymola 2016 using the pedantic model check. +
      • +
      • + May 1, 2015, by Michael Wetter:
        + Added Inline=true for + + issue 227. +
      • +
      • + February 25, 2015, by Michael Wetter:
        + Removed stateSelect attribute on pressure as this caused + + AixLib.Examples.Tutorial.SpaceCooling.System3 + to fail with the error message + \"differentiated if-then-else was not continuous\". +
      • +
      • + October 15, 2014, by Michael Wetter:
        + Reimplemented media based on + 446aa83. +
      • +
      • + November 15, 2013, by Michael Wetter:
        + Complete new reimplementation because the previous version + had the option to add a compressibility to the medium, which + has never been used. +
      • +
      + -------- Corrected Code --------

      - This package contains borefield models. These models can simulate any - arbitrary configuration of vertical boreholes with equal lengths with - both short and long-term accuracy with an aggregation method to speed - up the calculations of the ground heat transfer. Examples of how to - use the borefield models and validation cases can be found in - AixLib.Fluid.Geothermal.Borefields.Examples - and AixLib.Fluid.Geothermal.Borefields.Validation, - respectively. -

      -

      - The major features and configurations currently supported are: -

      -
        -
      • User-defined borefield characteristics and geometry (borehole - radius, pipe radius, shank spacing, etc.), including single U-tube, - double U-tube in parallel and double U-tube in series configurations. -
      • -
      • The resistances Rb and Ra are - either automatically calculated using the multipole method, or the - resistance Rb can be directly provided by the user. - In this case, the resistances Rb and - Ra are still evaluated internally, but their values - are weighted so that the borehole resistance matches the specified - value. -
      • -
      • User-defined vertical discretization of boreholes are supported. - However, the borehole wall temperature is identical for each - borehole, as the ground temperature response model only computes the - average borehole wall temperature for all boreholes combined. -
      • -
      • Borefields can consist of one or many boreholes. Each borehole - can be positioned at an arbitrary position in the field using - cartesian coordinates. -
      • -
      • The resolution and precision of the load aggregation method for - the ground heat transfer can be adapted. -
      • -
      • The thermal response of the ground heat transfer is stored - locally to avoid having to recalculate it for future simulations with - the same borefield configuration. -
      • -
      • Pressure losses are calculated if the dp_nominal - parameter is set to a non-zero value. -
      • -
      -

      - The model is limited to the simulation of borefields with boreholes - connected in parallel, as shown on the figure below for a single - U-tube configuration. All boreholes have the same length - hBor, the same radius rBor, and are buried - at the same depth dBor below the ground surface (also - known as the inactive borehole length). -

      -

      - \"image\" -

      -

      - How to use the borefield models -

      -
      - Borefield data record -
      -

      - Most of the parameter values of the model are contained in the record - called borFieDat. This record is composed of three - subrecords: filDat (containing the thermal - characteristics of the borehole filling material), - soiDat (containing the thermal characteristics of the - surrounding soil), and conDat (containing all others - parameters, namely parameters defining the configuration of the - borefield). The structure and default values of the record are in the - package: AixLib.Fluid.Geothermal.Borefields.Data. - The borFieDat record can be found in the AixLib.Fluid.Geothermal.Borefields.Data.Borefield - subpackage therein. Examples of the subrecords conDat, - filDat and soiDat can be found in AixLib.Fluid.Geothermal.Borefields.Data.Configuration, - AixLib.Fluid.Geothermal.Borefields.Data.Filling - and AixLib.Fluid.Geothermal.Borefields.Data.Soil, - respectively. -

      -

      - It is important to make sure that the borCon parameter - within the conDat subrecord is compatible with the - chosen borefield model. For example, if a double U-tube borefield - model is chosen, the borCon parameter could be set to - both a parallel double U-tube configuration and a double U-tube - configuration in series, but could not be set to a single U-tube - configuration. An incompatible borehole configuration will stop the - simulation. -

      -
      - Ground heat transfer parameters -
      -

      - Other than the parameters contained in the borFieDat - record, the borefield models have other parameters which can be - modified by the user. The tLoaAgg parameter is the time - resolution of the load aggregation for the calculation of the ground - heat transfer. It represents the frequency at which the load - aggregation procedure is performed in the simulation. Therefore, - smaller values of tLoaAgg will improve the accuracy of - the model, at the cost of increased simulation times due to a higher - number of events occuring in the simulation. While a default value is - provided for this parameter, it is advisable to ensure that it is - lower than a fraction (e.g. half) of the time required for the fluid - to completely circulate through the borefield, as increasing the - value of tLoaAgg beyond this will result in non-physical - borehole wall temperatures. -

      -

      - The nCel parameter also affects the accuracy and - simulation time of the ground heat transfer calculations. As this - parameter sets the number of consecutive equal-size aggregation cells - before increasing the size of cells, increasing its value will result - in less load aggregation, which will increase accuracy at the cost of - computation time. On the other hand, decreasing the value of - nCel (down to a minimum of 1) will decrease accuracy but - improve computation time. The default value is chosen as a compromise - between the two. -

      -

      - Further information on the tLoaAgg and nCel - parameters can be found in the documentation of - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse. + Model with basic thermodynamic properties.

      -
      - Other parameters -

      - Other parameters which can be modified include the dynamics, initial - conditions, and further information regarding the fluid flow, for - example whether the flow is reversible. It is worth noting that - regardless of the energyDynamics chosen, the - dynFil parameter can be set to false to - remove the effect of the thermal capacitance of the filling material - in the borehole(s). The nSeg parameter specifies the - number of segments for the vertical discretization of the - borehole(s). Further information on this discretization can be found - in the \"Model description\" section below. + This base properties model is identical to Modelica.Media.Water.ConstantPropertyLiquidWater, + except that the equation u = cv_const*(T - reference_T) + has been replaced by u=h because + cp_const=cv_const.

      -
      - Running simulations -

      - When running simulations using the borefield models, the - tmp/temperatureResponseMatrix directory within the - current directory will be checked to see if any of the borefield - configurations used in the simulation have already had their ground - temperature response calculated previously If the data doesn't exist - in the tmp/temperatureResponseMatrix folder, it will be - calculated during the initialization of the model and will be saved - there for future use. + This model provides equation for the following thermodynamic + properties:

      -

      - Model description -

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + Variable + + Unit + + Description +
      + T + + K + + temperature +
      + p + + Pa + + absolute pressure +
      + d + + kg/m3 + + density +
      + h + + J/kg + + specific enthalpy +
      + u + + J/kg + + specific internal energy +
      + Xi[nXi] + + kg/kg + + independent mass fractions m_i/m +
      + R + + J/kg.K + + gas constant +
      + M + + kg/mol + + molar mass +

      - The borefield models rely on the following key assumptions: + Enthalpy of the water.

        -
      • The thermal properties of the soil (conductivity and diffusivity) - are constant, homogenous and isotropic. -
      • -
      • The conductivity, capacitance and density of the grout and pipe - material are constant, homogenous and isotropic. -
      • -
      • There is no heat extraction or injection prior to the simulation - start. -
      • -
      • All of the boreholes in the borefield have uniform dimensions - (including the pipe dimensions). -
      • -
      • Inside the boreholes, the non-advective heat transfer is only in - the radial direction. +
      • October 16, 2014 by Michael Wetter:
        + First implementation. This function is used by AixLib.Fluid.MixingVolumes.MixingVolumeMoistAir.

      - The borefield models are constructed in two main parts: the - borehole(s) and the ground heat transfer. The former is modeled as a - vertical discretization of borehole segments, where a uniform - temperature increase or decrease (due to heat injection or - extraction) is superimposed to the far-field ground temperature to - obtain the borehole wall temperature. The thermal effects of the - circulating fluid (including the convection resistance), of the pipes - and of the filling material are all taken into consideration, which - allows modeling short-term thermal effects in the borehole. The - borehole segments do not take into account axial effects, thus only - radial (horizontal) effects are considered within the borehole(s). - The thermal behavior between the pipes and borehole wall are modeled - as a resistance-capacitance network, with the grout capacitance being - split in the number of pipes present in a borehole section. The - capacitance is only present if the dynFil parameter is - set to true. The figure below shows an example for a - borehole section within a single U-tube configuration. + This medium package models liquid water.

      -

      - \"image\" +

      + The mass density is computed using a constant value of 995.586 + kg/s. For a medium model in which the density is a function of + temperature, use + AixLib.Media.Specialized.Water.TemperatureDependentDensity which + may have considerably higher computing time.

      - The second main part of the borefield models is the ground heat - transfer, which shares a thermal boundary condition at the uniform - borehole wall with all of the borehole segments. The heat transfer in - the ground is modeled analytically as a convolution integral between - the heat flux at the borehole wall and the borefield's thermal - response factor. + For the specific heat capacities at constant pressure and at constant + volume, a constant value of 4184 J/(kg K), which corresponds + to 20°C is used. The figure below shows the relative error of + the specific heat capacity that is introduced by this simplification.

      - \"image\" -

      -

      - The model uses a load aggregation technique to reduce the time - required to calculate the borehole wall temperature changes resulting - from heat injection or extraction. + +

      - The ground heat transfer takes into account both the borehole axial - effects and the borehole radial effects which are a result of its - cylindrical geometry. The borefield's thermal response to a constant - load, also known as its g-function, is used to calculate the - thermal response in the simulation. This g-function is stored in the - tmp/temperatureResponseMatrix subdirectory, as discussed - previously in the \"How to use the borefield models\" section. Further - information on the ground heat transfer model and the thermal - temperature response calculations can be found in - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse - and - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.gFunction. + The enthalpy is computed using the convention that h=0 if + T=0 °C.

      - References + Limitations

      - D. Picard, L. Helsen. Advanced Hybrid Model for Borefield Heat - Exchanger Performance Evaluation; an Implementation in Modelica - Proc. of the 10th Intertional ModelicaConference, p. 857-866. Lund, - Sweden. March 2014. https://lirias.kuleuven.be/retrieve/270880. + Density, specific heat capacity, thermal conductivity and viscosity + are constant. Water is modeled as an incompressible liquid. There are + no phase changes.

      +
        +
      • September 28, 2020, by Michael Wetter:
        + Reformulated BaseProperties to avoid event-triggering + assertions.
        + This is for #1401. +
      • +
      • October 26, 2018, by Filip Jorissen and Michael Wetter:
        + Now printing different messages if temperature is above or below + its limit, and adding instance name as JModelica does not print the + full instance name in the assertion. This is for #1045. +
      • +
      • June 6, 2015, by Michael Wetter:
        + Set AbsolutePressure(start=p_default) to avoid a + translation error if + AixLib.Fluid.Sources.Examples.TraceSubstancesFlowSource (if + used with water instead of air) is translated in pedantic mode in + Dymola 2016. The reason is that pressures use + Medium.p_default as start values, but Modelica.Media.Interfaces.Types + sets a default value of 1E-5. A similar change has been done + for pressure and density. This fixes #266. +
      • +
      • June 6, 2015, by Michael Wetter:
        + Changed type of BaseProperties.T from + Modelica.Units.SI.Temperature to + Temperature. Otherwise, it has a different start value + than Medium.T, which causes an error if AixLib.Media.Examples.WaterProperties + is translated in pedantic mode. This fixes #266. +
      • +
      • June 5, 2015, by Michael Wetter:
        + Added stateSelect attribute in + BaseProperties.T to allow correct use of + preferredMediumState as described in Modelica.Media.Interfaces.PartialMedium, + and set preferredMediumState=false to keep the same + states as were used before. This is for #260. +
      • +
      • June 5, 2015, by Michael Wetter:
        + Removed ThermodynamicState declaration as this lead to + the error \"Attempting to redeclare record ThermodynamicState when + the original was not replaceable.\" in Dymola 2016 using the + pedantic model check. +
      • +
      • May 1, 2015, by Michael Wetter:
        + Added Inline=true for issue 227. +
      • +
      • February 25, 2015, by Michael Wetter:
        + Removed stateSelect attribute on pressure as this + caused AixLib.Examples.Tutorial.SpaceCooling.System3 + to fail with the error message \"differentiated if-then-else was not + continuous\". +
      • +
      • October 15, 2014, by Michael Wetter:
        + Reimplemented media based on + 446aa83. +
      • +
      • November 15, 2013, by Michael Wetter:
        + Complete new reimplementation because the previous version had the + option to add a compressibility to the medium, which has never been + used. +
      • +
      -------- Errors -------- -line 56 column 1 - Warning:

      attribute "align" not allowed for HTML5 -line 179 column 1 - Warning:

      attribute "align" not allowed for HTML5 -line 188 column 1 - Warning:

      attribute "align" not allowed for HTML5 +line 17 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Fluid/HeatExchangers/ActiveBeams/BaseClasses/Convector.mo ---- +line 18 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Utilities/Math/Functions/polynomial.mo ---- -------- HTML Code -------- -

      - In cooling mode, this model adds heat to the water stream. The heat added is equal to: -

      + This function computes a polynomial of arbitrary order. + The polynomial has the form

      - QBeam = Qrated fΔT fSA fW -

      -

      - In heating mode, the heat is removed from the water stream. + y = a1 + a2 x + a3 x2 + ...

      • - March 3, 2022, by Michael Wetter:
        - Removed massDynamics.
        - This is for - issue 1542. -
      • -
      • - April 14, 2020, by Michael Wetter:
        - Changed homotopyInitialization to a constant.
        + December 14, 2016, by Michael Wetter:
        + Removed derivative annotation.
        This is for - IBPSA, #1341. + issue 602.
      • - November 2, 2016, by Michael Wetter:
        - Made assignment of senTem.y final. + March 30, 2011, by Michael Wetter:
        + Added zeroDerivative keyword.
      • - June 13, 2016, by Michael Wetter:
        - Revised implementation. + March 2, by Michael Wetter:
        + Removed redundant smoothOrder annotation.
      • - May 20, 2016, by Alessandro Maccarini:
        + February 29, 2009 by Michael Wetter:
        First implementation.
      -------- Corrected Code -------- -

      - In cooling mode, this model adds heat to the water stream. The heat - added is equal to: -

      +This function computes a polynomial of arbitrary order. The polynomial +has the form

      - QBeam = Qrated fΔT - fSA fW -

      -

      - In heating mode, the heat is removed from the water stream. + y = a1 + a2 x + a3 x2 + + ...

      -
        -
      • March 3, 2022, by Michael Wetter:
        - Removed massDynamics.
        - This is for issue - 1542. -
      • -
      • April 14, 2020, by Michael Wetter:
        - Changed homotopyInitialization to a constant.
        +
          +
        • December 14, 2016, by Michael Wetter:
          + Removed derivative annotation.
          This is for IBPSA, - #1341. + \"https://github.com/ibpsa/modelica-ibpsa/issues/602\">issue 602.
        • -
        • November 2, 2016, by Michael Wetter:
          - Made assignment of senTem.y final. +
        • March 30, 2011, by Michael Wetter:
          + Added zeroDerivative keyword.
        • -
        • June 13, 2016, by Michael Wetter:
          - Revised implementation. +
        • March 2, by Michael Wetter:
          + Removed redundant smoothOrder annotation.
        • -
        • May 20, 2016, by Alessandro Maccarini:
          +
        • February 29, 2009 by Michael Wetter:
          First implementation.
        -------- Errors -------- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 4 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/CheckValve.mo ---- +---- AixLib/Fluid/FMI/ExportContainers/HVACZones.mo ---- -------- HTML Code --------

        - Implementation of a hydraulic check valve. - Note that the small reverse flows can still occur with this model. + Model that is used as a container for an HVAC system that is + to be exported as an FMU and that serves multiple zones.

        -

        Main equations

        +

        Typical use and important parameters

        - The basic flow function + To use this model as a container for an FMU, simply extend + from this model, rather than instantiate it, + and add your HVAC system. By extending from this model, the top-level + signal connectors on the right stay at the top-level, and hence + will be visible at the FMI interface. + The example + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones + shows how a simple HVAC system that serves two rooms can be implemented and exported as + an FMU. +

        -

        - m = sign(Δp) k √ Δp  , +

        + The following two parameters need to be assigned by the user: + Set nZon to the number of thermal zones to which the + FMU will be connected. + Set nPorts to the largest number of fluid ports + that the thermal zones has. For example, + if nZon=2 and zone 1 has one inlet and one outlet + (hence it has 2 ports), + and zone 2 has one inlets and two outlets + (hence it has 3 ports), then + set nPorts=3. This will add more fluid ports than are needed + for zone 1, but this causes no overhead if they are not connected.

        - with regularization near the origin, is used to compute the pressure drop. - The flow coefficient + The conversion between the fluid ports and signal ports is done + in the HVAC adapter hvacAda. + This adapter has a vector of fluid ports called ports. + The supply and return air ducts, including any resistance model for the inlet + diffusor or exhaust grill, need to be connected to these ports. + Also, if a thermal zone has interzonal air exchange or air infiltration, + these flows need to be connected to ports. + This model outputs at the port fluPor the mass flow rate for + each flow that is connected to ports, together with its + temperature, water vapor mass fraction per total mass of the air (not per kg dry + air), and trace substances. These quantities are always as if the flow + enters the room, even if the flow is zero or negative. + If a medium has no moisture, e.g., if Medium.nXi=0, or + if it has no trace substances, e.g., if Medium.nC=0, then + the output signal for these properties are removed. + These quantities are always as if the flow + enters the room, even if the flow is zero or negative. + Thus, a thermal zone model that uses these signals to compute the + heat added by the HVAC system need to implement an equation such as

        - k = m ⁄ √ Δp   + Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon),

        - is increased from l*KV_Si to KV_Si, - where KV_Si is equal to Kv but in SI units. - Therefore, the flow coefficient k is set to a value close to zero for negative pressure differences, thereby - restricting reverse flow to a small value. - The flow coefficient k saturates to its maximum value at the pressure dpValve_closing. - For larger pressure drops, the pressure drop is a quadratic function of the flow rate. + where + Qsen is the sensible heat flow rate added to the thermal zone, + sup is the supply air mass flow rate from + the port fluPor (which is negative if it is an exhaust), + cp is the specific heat capacity at constant pressure, + Tsup is the supply air temperature and + Tair,zon is the zone air temperature. + Note that without the max(·, ·), the energy + balance would be wrong.

        -

        Typical use and important parameters

        +

        - The parameters m_flow_nominal and dpValve_nominal - determine the flow coefficient of the check valve when it is fully opened. - A typical value for a nominal flow rate of 1 m/s is - dpValve_nominal = 3400 Pa. - The leakage ratio l determines the minimum flow coefficient, - for negative pressure differences. - The parameter dpFixed_nominal allows to include a series - pressure drop with a fixed flow coefficient into the model. - The parameter dpValve_closing determines when the - flow coefficient starts to increase, - which is typically in the order of dpValve_nominal. + The input signals of this model are the radiative temperature of each zone. + The the zone air temperatures, + the water vapor mass fractions per total mass of the air (unless Medium.nXi=0) + and trace substances (unless Medium.nC=0) are obtained from the connector + fluPor.backward. + The outflowing fluid stream(s) at the port ports will be at the + states obtained from fluPor.backward. + For any given izon ∈ {1, ..., nzon}, + for each iports ∈ {1, ..., nports} + all fluid streams at port ports[izon, iports] are at the same + pressure. + For convenience, the instance hvacAda also outputs the + properties obtained from fluPor.backward. These can be used + to connect a controller. The properties are available for each flow path in + fluPor.backward. For a thermal zone with mixed air, these are + all equal, while for a stratified room model, they can be different.

        -

        Implementation

        - The check valve implementation approximates the physics - where a forward pressure difference opens the valve such that - the valve opening increases, causing a growing orifice area - and thus increasing the flow coefficient. - Near dp=dpValve_closing, the valve is fully open and the flow coefficient saturates - to the flow coefficient value determined by dpValve_nominal and m_flow_nominal. - For typical valve diameters, the check valve is only fully open - near nominal mass flow rate. Therefore, the model sets dpValve_closing=dpValve_nominal/2 - by default. + See + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones + for a model that uses this model. +

        +

        + For models that only have one thermal zone connected to the HVAC system, + use the simpler model + + AixLib.Fluid.FMI.ExportContainers.HVACZone. +

        +

        Assumption and limitations

        +

        + The mass flow rates at ports sum to zero, hence this + model conserves mass for each thermal zone. +

        +

        + This model does not impose any pressure, other than, + for any given izon ∈ {1, ..., nzon} and + for each j,k ∈ {1, ..., nports}, + setting the pressure of ports[izon, j].p = ports[izon, k].p + to be the same. + The reason is that setting a pressure can lead to non-physical system models, + for example if a mass flow rate is imposed and the HVAC system is connected + to a model that sets a pressure boundary condition such as + + AixLib.Fluid.Sources.Outside. + Also, setting a pressure would make it impossible to use multiple instances + of this model (one for each thermal zone) and build in Modelica an airflow network + model with pressure driven mass flow rates. +

        +

        + The model has no pressure drop. Hence, the pressure drop + of an air diffuser or of an exhaust grill needs to be modelled + in models that are connected to ports.

        • - September 16, 2019, by Kristoff Six and Filip Jorissen:
          - Implementation of a hydraulic check valve. This is for - issue 1198. + January 18, 2019, by Jianjun Hu:
          + Limited the media choice to moist air only. + See #1050. +
        • +
        • + May 25, 2016, by Michael Wetter:
          + First implementation.
        -------- Corrected Code --------

        - Implementation of a hydraulic check valve. Note that the small - reverse flows can still occur with this model. + Model that is used as a container for an HVAC system that is to be + exported as an FMU and that serves multiple zones.

        - Main equations + Typical use and important parameters

        - The basic flow function + To use this model as a container for an FMU, simply extend from this + model, rather than instantiate it, and add your HVAC system. By + extending from this model, the top-level signal connectors on the + right stay at the top-level, and hence will be visible at the FMI + interface. The example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones shows + how a simple HVAC system that serves two rooms can be implemented and + exported as an FMU. +

        +

        + The following two parameters need to be assigned by the user: Set + nZon to the number of thermal zones to which the FMU + will be connected. Set nPorts to the largest number of + fluid ports that the thermal zones has. For example, if + nZon=2 and zone 1 has one inlet and one outlet + (hence it has 2 ports), and zone 2 has one inlets and two + outlets (hence it has 3 ports), then set nPorts=3. This + will add more fluid ports than are needed for zone 1, but this + causes no overhead if they are not connected. +

        +

        + The conversion between the fluid ports and signal ports is done in + the HVAC adapter hvacAda. This adapter has a vector of + fluid ports called ports. The supply and return air + ducts, including any resistance model for the inlet diffusor or + exhaust grill, need to be connected to these ports. Also, if a + thermal zone has interzonal air exchange or air infiltration, these + flows need to be connected to ports. This model outputs + at the port fluPor the mass flow rate for each flow that + is connected to ports, together with its temperature, + water vapor mass fraction per total mass of the air (not per kg dry + air), and trace substances. These quantities are always as if the + flow enters the room, even if the flow is zero or negative. If a + medium has no moisture, e.g., if Medium.nXi=0, or if it + has no trace substances, e.g., if Medium.nC=0, then the + output signal for these properties are removed. These quantities are + always as if the flow enters the room, even if the flow is zero or + negative. Thus, a thermal zone model that uses these signals to + compute the heat added by the HVAC system need to implement an + equation such as

        - m = sign(Δp) k √ Δp -  , + Qsen = max(0, ṁsup)   cp   + (Tsup - Tair,zon), +

        +

        + where Qsen is the sensible heat flow rate added to + the thermal zone, sup is the supply air mass flow + rate from the port fluPor (which is negative if it is an + exhaust), cp is the specific heat capacity at + constant pressure, Tsup is the supply air + temperature and Tair,zon is the zone air + temperature. Note that without the max(·, ·), the energy + balance would be wrong. +

        +

        + The input signals of this model are the radiative temperature of each + zone. The the zone air temperatures, the water vapor mass fractions + per total mass of the air (unless Medium.nXi=0) and + trace substances (unless Medium.nC=0) are obtained from + the connector fluPor.backward. The outflowing fluid + stream(s) at the port ports will be at the states + obtained from fluPor.backward. For any given + izon ∈ {1, ..., nzon}, for each + iports ∈ {1, ..., nports} all fluid + streams at port ports[izon, + iports] are at the same pressure. For convenience, + the instance hvacAda also outputs the properties + obtained from fluPor.backward. These can be used to + connect a controller. The properties are available for each flow path + in fluPor.backward. For a thermal zone with mixed air, + these are all equal, while for a stratified room model, they can be + different.

        - with regularization near the origin, is used to compute the pressure - drop. The flow coefficient -

        -

        - k = m ⁄ √ Δp -   + See + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones for a + model that uses this model.

        - is increased from l*KV_Si to KV_Si, where - KV_Si is equal to Kv but in SI units. - Therefore, the flow coefficient k is set to a value - close to zero for negative pressure differences, thereby restricting - reverse flow to a small value. The flow coefficient k - saturates to its maximum value at the pressure - dpValve_closing. For larger pressure drops, the pressure - drop is a quadratic function of the flow rate. + For models that only have one thermal zone connected to the HVAC + system, use the simpler model AixLib.Fluid.FMI.ExportContainers.HVACZone.

        - Typical use and important parameters + Assumption and limitations

        - The parameters m_flow_nominal and - dpValve_nominal determine the flow coefficient of the - check valve when it is fully opened. A typical value for a nominal - flow rate of 1 m/s is dpValve_nominal = 3400 Pa. - The leakage ratio l determines the minimum flow - coefficient, for negative pressure differences. The parameter - dpFixed_nominal allows to include a series pressure drop - with a fixed flow coefficient into the model. The parameter - dpValve_closing determines when the flow coefficient - starts to increase, which is typically in the order of - dpValve_nominal. + The mass flow rates at ports sum to zero, hence this + model conserves mass for each thermal zone.

        -

        - Implementation -

        - The check valve implementation approximates the physics where a - forward pressure difference opens the valve such that the valve - opening increases, causing a growing orifice area and thus increasing - the flow coefficient. Near dp=dpValve_closing, the valve - is fully open and the flow coefficient saturates to the flow - coefficient value determined by dpValve_nominal and - m_flow_nominal. For typical valve diameters, the check - valve is only fully open near nominal mass flow rate. Therefore, the - model sets dpValve_closing=dpValve_nominal/2 by default. + This model does not impose any pressure, other than, for any given + izon ∈ {1, ..., nzon} and for each + j,k ∈ {1, ..., nports}, setting the pressure of + ports[izon, j].p = ports[izon, + k].p to be the same. The reason is that setting a pressure can + lead to non-physical system models, for example if a mass flow rate + is imposed and the HVAC system is connected to a model that sets a + pressure boundary condition such as AixLib.Fluid.Sources.Outside. + Also, setting a pressure would make it impossible to use multiple + instances of this model (one for each thermal zone) and build in + Modelica an airflow network model with pressure driven mass flow + rates. +

        +

        + The model has no pressure drop. Hence, the pressure drop of an air + diffuser or of an exhaust grill needs to be modelled in models that + are connected to ports.

          -
        • September 16, 2019, by Kristoff Six and Filip Jorissen:
          - Implementation of a hydraulic check valve. This is for issue - 1198. +
        • January 18, 2019, by Jianjun Hu:
          + Limited the media choice to moist air only. See #1050. +
        • +
        • May 25, 2016, by Michael Wetter:
          + First implementation.
        -------- Errors -------- -line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 60 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Media/Air.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/Types.mo ---- -------- HTML Code --------

        - Model with basic thermodynamic properties. -

        -

        - This model provides equation for the following thermodynamic properties: -

        -
      - - - - - - - - - - - - - - - - - - - - - - - - - - - -
      VariableUnitDescription
      TKtemperature
      pPaabsolute pressure
      dkg/m3density
      hJ/kgspecific enthalpy
      uJ/kgspecific internal energy
      Xi[nXi]kg/kgindependent mass fractions m_i/m
      RJ/kg.Kgas constant
      Mkg/molmolar mass
      - -

        -
      • - September 22, 2020, by Michael Wetter:
        - First implementation based on Modelica Standard Library, - but with noEvent added to check of bounds. -
      • -
      - - Density is computed from pressure, temperature and composition in the thermodynamic state record applying the ideal gas law. - -

      - This function returns the dynamic viscosity. -

      -

      Implementation

      -

      - The function is based on the 5th order polynomial - of - - Modelica.Media.Air.MoistAir.dynamicViscosity. - However, for the typical range of temperatures encountered - in building applications, a linear function sufficies. - This implementation is therefore the above 5th order polynomial, - linearized around 20°C. - The relative error of this linearization is - 0.4% at -20°C, - and less then - 0.2% between -5°C and +50°C. -

      - -
        -
      • - December 19, 2013, by Michael Wetter:
        - First implementation. -
      • -
      - - The ideal gas constant for moist air is computed from thermodynamic state assuming that all water is in the gas phase. - - Pressure is returned from the thermodynamic state record input as a simple assignment. - -

      - This function returns the isobaric expansion coefficient at constant pressure, - which is zero for this medium. - The isobaric expansion coefficient at constant pressure is -

      -

      - βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p = 0, + Enumeration that defines the pipe configuration in the borehole.

      - where - v is the specific volume, - T is the temperature and - p is the pressure. + The following pipe configurations are available in this enumeration:

      + + + -
        -
      • - December 18, 2013, by Michael Wetter:
        - First implementation. -
      • -
      - -

      - This function returns the isothermal compressibility coefficient. - The isothermal compressibility is -

      -

      - κT = -1 ⁄ v   (∂ v ⁄ ∂ p)T - = -1 ⁄ p, -

      -

      - where - v is the specific volume, - T is the temperature and - p is the pressure. -

      + + +
      EnumerationDescription
      SingleUTubeSingle U-tube configuration
      DoubleUTubeParallelDouble U-tube configuration with pipes connected in parallel
      DoubleUTubeSeriesDouble U-tube configuration with pipes connected in series
      • - December 18, 2013, by Michael Wetter:
        + July 15, 2018, by Michael Wetter:
        First implementation.
      +

      + This package contains type definitions. +

      + +-------- Corrected Code -------- +

      + Enumeration that defines the pipe configuration in the borehole. +

      +

      + The following pipe configurations are available in this enumeration: +

      + + + + + + + + + + + + + + + + + +
      + Enumeration + + Description +
      + SingleUTube + + Single U-tube configuration +
      + DoubleUTubeParallel + + Double U-tube configuration with pipes connected in parallel +
      + DoubleUTubeSeries + + Double U-tube configuration with pipes connected in series +
      +
        +
      • July 15, 2018, by Michael Wetter:
        + First implementation. +
      • +
      +

      + This package contains type definitions. +

      + +-------- Errors -------- +line 8 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowTransportDelay.mo ---- +-------- HTML Code -------- +

      - This function computes the specific entropy. -

      -

      - The specific entropy of the mixture is obtained from -

      -

      - s = ss + sm, -

      -

      - where - ss is the entropy change due to the state change - (relative to the reference temperature) and - sm is the entropy change due to mixing - of the dry air and water vapor. -

      -

      - The entropy change due to change in state is obtained from -

      -

      - ss = cv ln(T/T0) + R ln(v/v0)
      - = cv ln(T/T0) + R ln(ρ0/ρ) -

      -

      If we assume ρ = p0/(R T), - and because cp = cv + R, - we can write + Calculates time delay at both sides of the pipe as the difference between the + current simulation time and the inlet time of the fluid at both ends of the pipe.

      -

      - ss = cv ln(T/T0) + R ln(T/T0)
      - =cp ln(T/T0). +

      Main equation

      +

      + ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0,

      - Next, the entropy of mixing is obtained from a reversible isothermal - expansion process. Hence, -

      -

      - sm = -R ∑i( Xi ⁄ Mi - ln(Yi p/p0)), + where z(x,t) is the spatial distribution as a function of time of any + property z of the fluid. For the inlet time propagation, z will + be replaced by the inlet time of the fluid tin.

      +

      Implementation

      - where R is the gas constant, - X is the mass fraction, - M is the molar mass, and - Y is the mole fraction. + The inlet time is approached as a fluid property and its propagation follows + the one-dimensional wave equation, implemented using the spatialDistribution + function. This components requires the mass flow through the pipe and the pipe + dimensions in order to derive information about the fluid propagation.

      - To obtain the state for a given pressure, entropy and mass fraction, use - - AixLib.Media.Air.setState_psX. + The component calculates the delay time at the inlet and the outlet port of the pipe. + For the forward flow, the time delay is exposed at the output tau, + and for the backward flow, the time delay is exposed at the output tauRev.

      -

      Limitations

      +

      Assumption

      - This function is only valid for a relative humidity below 100%. + No axial mixing takes place in the pipe.

      • - November 27, 2013, by Michael Wetter:
        - First implementation. + December 2, 2020, by Philipp Mehrfeld:
        + Corrected calculation of tau and tauRev to be be + only positive.
        + This is for + #1427.
      • -
      - -

      - This function returns the partial derivative of density - with respect to pressure at constant temperature. -

      - -
      • - December 18, 2013, by Michael Wetter:
        - First implementation. + December 14, 2018, by Michael Wetter:
        + Corrected argument of spatialDistribution operator to be a parameter + expression.
        + This is for + #1055.
      • -
      - -

      - This function computes the derivative of density with respect to temperature - at constant pressure. -

      - -
      • - December 18, 2013, by Michael Wetter:
        - First implementation. + September 9, 2016 by Bram van der Heijde:
        + Rename from PDETime_massFlowMod to PlugFlowTransportDelayMod
      • -
      - -

      - This function returns the partial derivative of density - with respect to mass fraction. - This value is zero because in this medium, density is proportional - to pressure, but independent of the species concentration. -

      - -
      • - December 18, 2013, by Michael Wetter:
        + December 2015 by Carles Ribas Tugores:
        + Modification in delay calculation to fix issues. +
      • +
      • + November 6, 2015 by Bram van der Heijde:
        + Adapted flow parameter to mass flow rate instead of velocity. + This change should also fix the reverse and zero flow issues. +
      • +
      • + October 13, 2015 by Marcus Fuchs:
        + Use abs() of normalized velocity input in order to avoid negative + delay times. +
      • +
      • + July 2015 by Arnout Aertgeerts:
        First implementation.
      +-------- Corrected Code -------- +

      + Calculates time delay at both sides of the pipe as the difference + between the current simulation time and the inlet time of the fluid + at both ends of the pipe. +

      +

      + Main equation +

      +

      + ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0, +

      +

      + where z(x,t) is the spatial distribution as a function of time + of any property z of the fluid. For the inlet time + propagation, z will be replaced by the inlet time of the fluid + tin. +

      +

      + Implementation +

      +

      + The inlet time is approached as a fluid property and its propagation + follows the one-dimensional wave equation, implemented using the + spatialDistribution function. This components requires the mass flow + through the pipe and the pipe dimensions in order to derive + information about the fluid propagation. +

      +

      + The component calculates the delay time at the inlet and the outlet + port of the pipe. For the forward flow, the time delay is exposed at + the output tau, and for the backward flow, the time + delay is exposed at the output tauRev. +

      +

      + Assumption +

      +

      + No axial mixing takes place in the pipe. +

      +
        +
      • December 2, 2020, by Philipp Mehrfeld:
        + Corrected calculation of tau and tauRev + to be be only positive.
        + This is for #1427. +
      • +
      • December 14, 2018, by Michael Wetter:
        + Corrected argument of spatialDistribution operator to + be a parameter expression.
        + This is for #1055. +
      • +
      • September 9, 2016 by Bram van der Heijde:
        + Rename from PDETime_massFlowMod to PlugFlowTransportDelayMod +
      • +
      • December 2015 by Carles Ribas Tugores:
        + Modification in delay calculation to fix issues. +
      • +
      • November 6, 2015 by Bram van der Heijde:
        + Adapted flow parameter to mass flow rate instead of velocity. This + change should also fix the reverse and zero flow issues. +
      • +
      • October 13, 2015 by Marcus Fuchs:
        + Use abs() of normalized velocity input in order to + avoid negative delay times. +
      • +
      • July 2015 by Arnout Aertgeerts:
        + First implementation. +
      • +
      + +-------- Errors -------- +line 7 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_m_flow.mo ---- +-------- HTML Code -------- +

      - The thermodynamic state record - is computed from density d, temperature T and composition X. + Function that computes the pressure drop of flow elements as

      - - The - thermodynamic state record is computed from pressure p, specific enthalpy h and composition X. - - The - thermodynamic state record is computed from pressure p, temperature T and composition X. - -

      - This function returns the thermodynamic state based on pressure, - specific entropy and mass fraction. +

      + Δp = sign(m) (m ⁄ k)2

      - The state is computed by symbolically solving - - AixLib.Media.Air.specificEntropy - for temperature. -

      - -
        -
      • - November 27, 2013, by Michael Wetter:
        - First implementation. -
      • -
      - - Specific enthalpy as a function of temperature and species concentration. - The pressure is input for compatibility with the medium models, but the specific enthalpy - is independent of the pressure. - -
        -
      • - April 30, 2015, by Filip Jorissen and Michael Wetter:
        - Added Inline=true for - - issue 227. -
      • -
      - + with regularization near the origin. + Therefore, the flow coefficient is +

      +

      + k = m ⁄ √ Δp   +

      - This function computes the specific enthalpy for - an isentropic state change from the temperature - that corresponds to the state refState - to reference_T. + The input m_flow_turbulent determines the location of the regularization.

      - - Temperature is returned from the thermodynamic state record input as a simple assignment. - -

      - This function returns the molar mass. -

      - -
      • - December 18, 2013, by Michael Wetter:
        - First implementation. + January 4, 2019, by Michael Wetter:
        + Set `Inline=false`.
        + See #1070.
      • -
      - - Temperature as a function of specific enthalpy and species concentration. - The pressure is input for compatibility with the medium models, but the temperature - is independent of the pressure. - - - -

      - This data record contains the coefficients for perfect gases. -

      - -
      • - September 12, 2014, by Michael Wetter:
        - Corrected the wrong location of the preferredView - and the revisions annotation. + January 22, 2016, by Michael Wetter:
        + Corrected type declaration of pressure difference. + This is + for #404.
      • - November 21, 2013, by Michael Wetter:
        + July 28, 2015, by Michael Wetter:
        + Removed double declaration of smooth(..) and smoothOrder + and changed Inline=true to LateInline=true. + This is for + issue 301. +
      • +
      • + July 15, 2015, by Filip Jorissen:
        + New, more efficient implementation based on regularisation using simple polynomial. + Expanded common subexpressions for function inlining to be possible. + Set Inline=true for inlining to occur. + This is for + #279. +
      • +
      • + August 10, 2011, by Michael Wetter:
        + Removed if-then optimization that set dp=0 if m_flow=0, + as this causes the derivative to be discontinuous at m_flow=0. +
      • +
      • + August 4, 2011, by Michael Wetter:
        + Removed option to use a linear function. The linear implementation is now done + in models that call this function. With the previous implementation, + the symbolic processor may not rearrange the equations, which can lead + to coupled equations instead of an explicit solution. +
      • +
      • + April 13, 2009, by Michael Wetter:
        First implementation.
      +-------- Corrected Code -------- +

      + Function that computes the pressure drop of flow elements as +

      +

      + Δp = sign(m) (m ⁄ k)2 +

      +

      + with regularization near the origin. Therefore, the flow coefficient + is +

      +

      + k = m ⁄ √ Δp +   +

      +

      + The input m_flow_turbulent determines the location of + the regularization. +

      +
        +
      • December 9, 2019, by Michael Wetter:
        + Added smooth(2, . ), similar to + AixLib.Fluid.BaseClasses.FlowModels.basicFlowFunction_dp.
        + See #1240. +
      • +
      • January 4, 2019, by Michael Wetter:
        + Set `Inline=false`.
        + See #1070. +
      • +
      • May 1, 2017, by Filip Jorissen:
        + Revised implementation such that + AixLib.Fluid.BaseClasses.FlowModels.basicFlowFunction_m_flow is + C2 continuous. See #725. +
      • +
      • January 22, 2016, by Michael Wetter:
        + Corrected type declaration of pressure difference. This is for + #404. +
      • +
      • July 28, 2015, by Michael Wetter:
        + Removed double declaration of smooth(..) and + smoothOrder and changed Inline=true to + LateInline=true. This is for issue 301. +
      • +
      • July 15, 2015, by Filip Jorissen:
        + New, more efficient implementation based on regularisation using + simple polynomial. Expanded common subexpressions for function + inlining to be possible. Set Inline=true for inlining + to occur. This is for #279. +
      • +
      • August 10, 2011, by Michael Wetter:
        + Removed if-then optimization that set + dp=0 if m_flow=0, as this causes the + derivative to be discontinuous at m_flow=0. +
      • +
      • August 4, 2011, by Michael Wetter:
        + Removed option to use a linear function. The linear implementation + is now done in models that call this function. With the previous + implementation, the symbolic processor may not rearrange the + equations, which can lead to coupled equations instead of an + explicit solution. +
      • +
      • April 13, 2009, by Michael Wetter:
        + First implementation. +
      • +
      + +-------- Errors -------- +line 5 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 12 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Actuators/Valves/ThreeWayTable.mo ---- +-------- HTML Code -------- +

      - This medium package models moist air using a gas law in which pressure and temperature - are independent, which often leads to significantly faster and more robust computations. - The specific heat capacities at constant pressure and at constant volume are constant. - The air is assumed to be not saturated. -

      -

      - This medium uses the gas law -

      -

      - ρ/ρstp = p/pstp, -

      -

      - where - pstd and ρstp are constant reference - temperature and density, rathern than the ideal gas law -

      -

      - ρ = p ⁄(R T), -

      -

      - where R is the gas constant and T is the temperature. -

      -

      - This formulation often leads to smaller systems of nonlinear equations - because equations for pressure and temperature are decoupled. - Therefore, if air inside a control volume such as room air is heated, it - does not increase its specific volume. Consequently, merely heating or cooling - a control volume does not affect the air flow calculations in a duct network - that may be connected to that volume. - Note that multizone air exchange simulation in which buoyancy drives the - air flow is still possible as the models in - - AixLib.Airflow.Multizone compute the mass density using the function - - AixLib.Utilities.Psychrometrics.Functions.density_pTX in which density - is a function of temperature. -

      -

      - Note that models in this package implement the equation for the internal energy as -

      -

      - u = h - pstp ⁄ ρstp, + Three way valve with table-specified opening characteristics. + A separate characteristic for each flow path is used.

      - where - u is the internal energy per unit mass, - h is the enthalpy per unit mass, - pstp is the static pressure and - ρstp is the mass density at standard pressure and temperature. - The reason for this implementation is that in general, -

      -

      - h = u + p v, + Each flow path uses an instance of the model + + AixLib.Fluid.Actuators.Valves.TwoWayTable. + Therefore, this model needs to be parameterized the same way as + + AixLib.Fluid.Actuators.Valves.TwoWayTable. + Specifically, + the mass flow rate for the fully open valve is determined based + on the value of the parameter CvData. + For the different valve positions y ∈ [0, 1], this nominal flow rate is + scaled by the values of the parameter + flowCharacteristics1 and flowCharacteristics3, respectively. + These parameters declare a table of the form

      +
      + + + + + + +
      y 0 ... 1
      φ l ... 1

      - from which follows that -

      -

      - u = h - p v = h - p ⁄ ρ = h - pstp ⁄ ρstd, + where l = Kv(y=0)/Kv(y=1) > 0 is the valve leakage. + The first row is the valve opening, and the second row is the + mass flow rate, relative to the mass flow rate of the fully open + valve, under the assumption of a constant pressure difference across the + valve. + A suggested value for the valve leakage is l=0.0001. + If l = 0, then this model will replace it with + l = 10-8 for numerical reasons. + For example, if a valve has Kv=0.5 [m3/h/bar1/2] and + a linear opening characteristics and + a valve leakage of l=0.0001, then one would set

      +
      +  CvData=AixLib.Fluid.Types.CvTypes.Kv
      +  Kv = 0.5
      +  flowCharacteristics1(y={0,1}, phi={0.0001,1})
      +  flowCharacteristics3(y={0,1}, phi={0.0001,1})
      + 

      - because p ⁄ ρ = pstp ⁄ ρstp in this medium model. + Note, however, that + + AixLib.Fluid.Actuators.Valves.ThreeWayLinear provides a more + efficient implementation for this simple case.

      - The enthalpy is computed using the convention that h=0 - if T=0 °C and no water vapor is present. + The parameters flowCharacteristics1 and flowCharacteristics3 must meet the following + requirements, otherwise the model stops with an error:

      -
      • - September 28, 2020, by Michael Wetter:
        - Reformulated BaseProperties to avoid event-triggering assertions.
        - This is for - #1401. -
      • -
      • - January 11, 2019 by Michael Wetter:
        - Reforulated assignment of X_int in setState_psX.
        - This is for - #1079. -
      • -
      • - October 26, 2018, by Filip Jorissen and Michael Wetter:
        - Now printing different messages if temperature is above or below its limit, - and adding instance name as JModelica does not print the full instance name in the assertion. - This is for - #1045. + Their arrays + y and phi + must be strictly monotonic increasing.
      • - November 4, 2016, by Michael Wetter:
        - Set default value for dT.start in base properties.
        - This is for - #575. + The first value must satisfy + y[1]=0, and + phi[1] must be equal to the + leakage flow rate, which must be bigger than zero. + Otherwise, a default value of 1E-8 is used.
      • - June 6, 2015, by Michael Wetter:
        - Set AbsolutePressure(start=p_default) to avoid - a translation error if - - AixLib.Fluid.Sources.Examples.TraceSubstancesFlowSource - is translated in pedantic mode in Dymola 2016. - The reason is that pressures use Medium.p_default as start values, - but - - Modelica.Media.Interfaces.Types - sets a default value of 1E-5. - A similar change has been done for pressure. - This fixes - #266. + The last values must satisfy + y[end]=1 and + phi[end]=1.
      • +
      +

      + This model is based on the partial valve model + + AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve. + Check this model for more information, such + as the regularization near the origin. +

      +

      + For an example that specifies an opening characteristics, see + + AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable. +

      + + +
      • - June 5, 2015, by Michael Wetter:
        - Added stateSelect attribute in BaseProperties.T - to allow correct use of preferredMediumState as - described in - - Modelica.Media.Interfaces.PartialMedium. - Note that the default is preferredMediumState=false - and hence the same states are used as were used before. + March 7, 2022, by Michael Wetter:
        + Set final massDynamics=energyDynamics.
        This is for - #260. -
      • -
      • - May 11, 2015, by Michael Wetter:
        - Removed - p(stateSelect=if preferredMediumStates then StateSelect.prefer else StateSelect.default) - in declaration of BaseProperties. - Otherwise, when models that contain a fluid volume - are exported as an FMU, their pressure would be - differentiated with respect to time. This would require - the time derivative of the inlet pressure, which is not available, - causing the translation to stop with an error. -
      • -
      • - May 1, 2015, by Michael Wetter:
        - Added Inline=true for - - issue 227. -
      • -
      • - March 20, 2015, by Michael Wetter:
        - Added missing term state.p/reference_p in function - specificEntropy. - #193. + #1542.
      • - February 3, 2015, by Michael Wetter:
        - Removed stateSelect.prefer for temperature. + June 10, 2021, by Michael Wetter:
        + Changed implementation of the filter and changed the parameter order to a constant + as most users need not change this value.
        This is for - #160. -
      • -
      • - July 24, 2014, by Michael Wetter:
        - Changed implementation to use - - AixLib.Utilities.Psychrometrics.Constants. - This was done to use consistent values throughout the library. -
      • -
      • - November 16, 2013, by Michael Wetter:
        - Revised and simplified the implementation. -
      • -
      • - November 14, 2013, by Michael Wetter:
        - Removed function - HeatCapacityOfWater - which is neither needed nor implemented in the - Modelica Standard Library. -
      • -
      • - November 13, 2013, by Michael Wetter:
        - Removed non-used computations in specificEnthalpy_pTX and - in temperature_phX. -
      • -
      • - March 29, 2013, by Michael Wetter:
        - Added final standardOrderComponents=true in the - BaseProperties declaration. This avoids an error - when models are checked in Dymola 2014 in the pedenatic mode. -
      • -
      • - April 12, 2012, by Michael Wetter:
        - Added keyword each to Xi(stateSelect=...). -
      • -
      • - April 4, 2012, by Michael Wetter:
        - Added redeclaration of ThermodynamicState to avoid a warning - during model check and translation. -
      • -
      • - August 3, 2011, by Michael Wetter:
        - Fixed bug in u=h-R*T, which is only valid for ideal gases. - For this medium, the function is u=h-pStd/dStp. -
      • -
      • - January 27, 2010, by Michael Wetter:
        - Fixed bug in else branch of function setState_phX - that lead to a run-time error when the constructor of this function was called. -
      • -
      • - January 22, 2010, by Michael Wetter:
        - Added implementation of function - - enthalpyOfNonCondensingGas and its derivative. + #1498.
      • - January 13, 2010, by Michael Wetter:
        - Fixed implementation of derivative functions. + November 28, 2019, by Michael Wetter:
        + Revised implementation.
      • - August 28, 2008, by Michael Wetter:
        + November 15, 2019, by Alexander Kümpel:
        First implementation.
      -------- Corrected Code --------

      - Model with basic thermodynamic properties. + Three way valve with table-specified opening characteristics. A + separate characteristic for each flow path is used.

      - This model provides equation for the following thermodynamic - properties: -

      - - - - - - - - - - - - - - - - - - - - - - - - - - + Each flow path uses an instance of the model AixLib.Fluid.Actuators.Valves.TwoWayTable. + Therefore, this model needs to be parameterized the same way as + AixLib.Fluid.Actuators.Valves.TwoWayTable. + Specifically, the mass flow rate for the fully open valve is + determined based on the value of the parameter CvData. + For the different valve positions y ∈ [0, 1], this nominal + flow rate is scaled by the values of the parameter + flowCharacteristics1 and + flowCharacteristics3, respectively. These parameters + declare a table of the form +

      +
      - Variable - - Unit - - Description -
      - T - - K - - temperature -
      - p - - Pa - - absolute pressure -
      - d - - kg/m3 - - density -
      - h - - J/kg - - specific enthalpy -
      - - - - - - - -
      - u - - J/kg - - specific internal energy + y
      - Xi[nXi] + 0 - kg/kg + ... - independent mass fractions m_i/m + 1
      - R - - J/kg.K - - gas constant + φ
      - M + l - kg/mol + ... - molar mass + 1
      -
        -
      • September 22, 2020, by Michael Wetter:
        - First implementation based on Modelica Standard Library, but with - noEvent added to check of bounds. -
      • -
      -Density is computed from pressure, temperature and composition in the -thermodynamic state record applying the ideal gas law.

      - This function returns the dynamic viscosity. -

      -

      - Implementation -

      -

      - The function is based on the 5th order polynomial of Modelica.Media.Air.MoistAir.dynamicViscosity. - However, for the typical range of temperatures encountered in - building applications, a linear function sufficies. This - implementation is therefore the above 5th order polynomial, - linearized around 20°C. The relative error of this - linearization is 0.4% at -20°C, and less then - 0.2% between -5°C and +50°C. + where l = Kv(y=0)/Kv(y=1) > 0 is the + valve leakage. The first row is the valve opening, and the second row + is the mass flow rate, relative to the mass flow rate of the fully + open valve, under the assumption of a constant pressure difference + across the valve. A suggested value for the valve leakage is + l=0.0001. If l = 0, then this model will replace it + with l = 10-8 for numerical reasons. For example, + if a valve has Kv=0.5 + [m3/h/bar1/2] and a linear opening + characteristics and a valve leakage of l=0.0001, then one + would set

      -
        -
      • December 19, 2013, by Michael Wetter:
        - First implementation. -
      • -
      -The ideal gas constant for moist air is computed from thermodynamic -state assuming that all water is in the gas phase. -Pressure is returned from the thermodynamic state record input as a -simple assignment. +
      +  CvData=AixLib.Fluid.Types.CvTypes.Kv
      +  Kv = 0.5
      +  flowCharacteristics1(y={0,1}, phi={0.0001,1})
      +  flowCharacteristics3(y={0,1}, phi={0.0001,1})
      + 

      - This function returns the isobaric expansion coefficient at constant - pressure, which is zero for this medium. The isobaric expansion - coefficient at constant pressure is -

      -

      - βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p = 0, + Note, however, that AixLib.Fluid.Actuators.Valves.ThreeWayLinear + provides a more efficient implementation for this simple case.

      - where v is the specific volume, T is the temperature - and p is the pressure. + The parameters flowCharacteristics1 and + flowCharacteristics3 must meet the following + requirements, otherwise the model stops with an error:

        -
      • December 18, 2013, by Michael Wetter:
        - First implementation. +
      • Their arrays y and phi must be strictly + monotonic increasing. +
      • +
      • The first value must satisfy y[1]=0, and + phi[1] must be equal to the leakage flow rate, which + must be bigger than zero. Otherwise, a default value of + 1E-8 is used. +
      • +
      • The last values must satisfy y[end]=1 and + phi[end]=1.

      - This function returns the isothermal compressibility coefficient. The - isothermal compressibility is -

      -

      - κT = -1 ⁄ v   (∂ v ⁄ ∂ p)T = -1 ⁄ p, + This model is based on the partial valve model AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve. + Check this model for more information, such as the regularization + near the origin.

      - where v is the specific volume, T is the temperature - and p is the pressure. + For an example that specifies an opening characteristics, see + + AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable.

        -
      • December 18, 2013, by Michael Wetter:
        +
      • March 7, 2022, by Michael Wetter:
        + Set final massDynamics=energyDynamics.
        + This is for #1542. +
      • +
      • June 10, 2021, by Michael Wetter:
        + Changed implementation of the filter and changed the parameter + order to a constant as most users need not change this + value.
        + This is for #1498. +
      • +
      • November 28, 2019, by Michael Wetter:
        + Revised implementation. +
      • +
      • November 15, 2019, by Alexander Kümpel:
        First implementation.
      + +-------- Errors -------- +line 21 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- AixLib/Fluid/Sensors/LatentEnthalpyFlowRate.mo ---- +-------- HTML Code -------- + +

      + This model outputs the latent enthalphy flow rate of the medium in the flow + between its fluid ports. In particular, if the total enthalpy flow rate is +

      +

      + Ḣtot = Ḣsen + Ḣlat, +

      +

      + where + sen = ṁ (1-Xw) cp,air, + then this sensor outputs Ḣ = Ḣlat. +

      +

      + If the parameter tau is non-zero, then the measured + specific latent enthalpy hout that is used to + compute the latent enthalpy flow rate + lat = ṁ hout + is computed using a first order differential equation. + See + AixLib.Fluid.Sensors.UsersGuide for an explanation. +

      +

      + For a sensor that measures + tot, use + + AixLib.Fluid.Sensors.EnthalpyFlowRate.
      + For a sensor that measures + sen, use + + AixLib.Fluid.Sensors.SensibleEnthalpyFlowRate. +

      +

      + The sensor is ideal, i.e., it does not influence the fluid. + The sensor can only be used with medium models that implement the function + enthalpyOfNonCondensingGas(T). +

      + +
        +
      • + October 19, 2020, by Antoine Gautier:
        + Changed default value for tau from 1 to 0.
        + This is for + #1406. +
      • +
      • + February 25, 2020, by Michael Wetter:
        + Changed icon to display its operating state.
        + This is for + #1294. +
      • +
      • + January 18, 2016 by Filip Jorissen:
        + Using parameter tauInv + since this now exists in + AixLib.Fluid.Sensors.BaseClasses.PartialDynamicFlowSensor. + This is for + #372. +
      • +
      • + September 10, 2013, by Michael Wetter:
        + Changed medium declaration in the extends statement + to replaceable to avoid a translation error in + OpenModelica. +
      • +
      • + August 31, 2013, by Michael Wetter:
        + Removed default value tau=0 as the base class + already sets tau=1. + This change was made so that all sensors use the same default value. +
      • +
      • + December 18, 2012, by Michael Wetter:
        + Moved computation of i_w to new base class + + AixLib.Fluid.BaseClasses.IndexWater. + The value of this parameter is now assigned dynamically and does not require to be specified + by the user. +
      • +
      • + November 3, 2011, by Michael Wetter:
        + Moved der(h_out) := 0; from the initial algorithm section to + the initial equation section + as this assignment does not conform to the Modelica specification. +
      • +
      • + August 10, 2011 by Michael Wetter:
        + Added parameter i_w and an assert statement to + make sure it is set correctly. Without this change, Dymola + cannot differentiate the model when reducing the index of the DAE. +
      • +
      • + June 3, 2011 by Michael Wetter:
        + Revised implementation to add dynamics in such a way that + the time constant increases as the mass flow rate tends to zero. + This can improve the numerics. +
      • +
      • + February 22, by Michael Wetter:
        + Improved code that searches for index of 'water' in medium model. +
      • +
      • + September 9, 2009 by Michael Wetter:
        + First implementation. + Implementation is based on enthalpy sensor of Modelica.Fluid. +
      • +
      + +-------- Corrected Code --------

      - This function computes the specific entropy. -

      -

      - The specific entropy of the mixture is obtained from -

      -

      - s = ss + sm, -

      -

      - where ss is the entropy change due to the state - change (relative to the reference temperature) and - sm is the entropy change due to mixing of the dry - air and water vapor. -

      -

      - The entropy change due to change in state is obtained from -

      -

      - ss = cv ln(T/T0) + R - ln(v/v0)
      - = cv ln(T/T0) + R ln(ρ0/ρ) -

      -

      - If we assume ρ = p0/(R T), and because - cp = cv + R, we can write + This model outputs the latent enthalphy flow rate of the + medium in the flow between its fluid ports. In particular, if the + total enthalpy flow rate is

      - ss = cv ln(T/T0) + R - ln(T/T0)
      - =cp ln(T/T0). + Ḣtot = Ḣsen + Ḣlat,

      - Next, the entropy of mixing is obtained from a reversible isothermal - expansion process. Hence, -

      -

      - sm = -R ∑i( Xi ⁄ Mi - ln(Yi p/p0)), + where sen = ṁ (1-Xw) + cp,air, then this sensor outputs Ḣ = + Ḣlat.

      - where R is the gas constant, X is the mass fraction, - M is the molar mass, and Y is the mole fraction. + If the parameter tau is non-zero, then the measured + specific latent enthalpy hout that is used to + compute the latent enthalpy flow rate lat = ṁ + hout is computed using a first order differential + equation. See AixLib.Fluid.Sensors.UsersGuide + for an explanation.

      - To obtain the state for a given pressure, entropy and mass fraction, - use AixLib.Media.Air.setState_psX. + For a sensor that measures tot, use AixLib.Fluid.Sensors.EnthalpyFlowRate.
      + + For a sensor that measures sen, use AixLib.Fluid.Sensors.SensibleEnthalpyFlowRate.

      -

      - Limitations -

      - This function is only valid for a relative humidity below 100%. + The sensor is ideal, i.e., it does not influence the fluid. The + sensor can only be used with medium models that implement the + function enthalpyOfNonCondensingGas(T).

        -
      • November 27, 2013, by Michael Wetter:
        - First implementation. +
      • October 19, 2020, by Antoine Gautier:
        + Changed default value for tau from 1 to + 0.
        + This is for #1406.
      • -
      -

      - This function returns the partial derivative of density with respect - to pressure at constant temperature. -

      -
        -
      • December 18, 2013, by Michael Wetter:
        - First implementation. +
      • February 25, 2020, by Michael Wetter:
        + Changed icon to display its operating state.
        + This is for #1294.
      • -
      -

      - This function computes the derivative of density with respect to - temperature at constant pressure. -

      - -

      - This function returns the partial derivative of density with respect - to mass fraction. This value is zero because in this medium, density - is proportional to pressure, but independent of the species - concentration. -

      -
        -
      • December 18, 2013, by Michael Wetter:
        - First implementation. +
      • September 10, 2013, by Michael Wetter:
        + Changed medium declaration in the extends statement to + replaceable to avoid a translation error in + OpenModelica.
      • -
      -

      - The - thermodynamic state record is computed from density - d, temperature T and composition - X. -

      -The -thermodynamic state record is computed from pressure p, specific -enthalpy h and composition X. -The -thermodynamic state record is computed from pressure p, temperature -T and composition X. -

      - This function returns the thermodynamic state based on pressure, - specific entropy and mass fraction. -

      -

      - The state is computed by symbolically solving AixLib.Media.Air.specificEntropy - for temperature. -

      -
        -
      • November 27, 2013, by Michael Wetter:
        - First implementation. +
      • August 31, 2013, by Michael Wetter:
        + Removed default value tau=0 as the base class already + sets tau=1. This change was made so that all sensors + use the same default value.
      • -
      -Specific enthalpy as a function of temperature and species -concentration. The pressure is input for compatibility with the medium -models, but the specific enthalpy is independent of the pressure. -
        -
      • April 30, 2015, by Filip Jorissen and Michael Wetter:
        - Added Inline=true for issue 227. +
      • December 18, 2012, by Michael Wetter:
        + Moved computation of i_w to new base class AixLib.Fluid.BaseClasses.IndexWater. + The value of this parameter is now assigned dynamically and does + not require to be specified by the user.
      • -
      -

      - This function computes the specific enthalpy for an isentropic state - change from the temperature that corresponds to the state - refState to reference_T. -

      -
        -
      • December 18, 2013, by Michael Wetter:
        - First implementation. +
      • November 3, 2011, by Michael Wetter:
        + Moved der(h_out) := 0; from the initial algorithm + section to the initial equation section as this assignment does not + conform to the Modelica specification.
      • -
      -Temperature is returned from the thermodynamic state record input as a -simple assignment. -

      - This function returns the molar mass. -

      -
        -
      • December 18, 2013, by Michael Wetter:
        - First implementation. +
      • August 10, 2011 by Michael Wetter:
        + Added parameter i_w and an assert statement to make + sure it is set correctly. Without this change, Dymola cannot + differentiate the model when reducing the index of the DAE.
      • -
      -Temperature as a function of specific enthalpy and species -concentration. The pressure is input for compatibility with the medium -models, but the temperature is independent of the pressure. -
        -
      • April 30, 2015, by Filip Jorissen and Michael Wetter:
        - Added Inline=true for issue 227. +
      • June 3, 2011 by Michael Wetter:
        + Revised implementation to add dynamics in such a way that the time + constant increases as the mass flow rate tends to zero. This can + improve the numerics. +
      • +
      • February 22, by Michael Wetter:
        + Improved code that searches for index of 'water' in medium model. +
      • +
      • September 9, 2009 by Michael Wetter:
        + First implementation. Implementation is based on enthalpy sensor of + Modelica.Fluid.
      -

      - This data record contains the coefficients for perfect gases. -

      + +-------- Errors -------- +line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/HeatExchangers/BaseClasses/WetCoilWetRegime.mo ---- +-------- HTML Code -------- + +

        +
      • + Jan 21, 2021, by Donghun Kim:
        First implementation. +
      • +
      + +

      + This model implements the calculation for a 100% wet coil. +

      +

      + The equations from Braun (1988) and Mitchell and Braun (2012a and b), + which are essentially the extension of the ε-NTU approach to + simultaneous sensible and latent heat transfer, are utilized. +

      +

      + The mathematical equations are analogous to that of the sensible heat exchanger. + However, the key distinction is that the heat transfer is driven by an enthalpy difference + not by an temperature difference. This change in the driving potential results in re-defining + capacitances and heat transfer coefficients accordingly. +

      + +

      + The total heat transfer rate is expressed as +

      +

      + Qtot=ε* C*min + (hair,in-hsat(Twat,in)), +

      +

      + where ε*=f(Cr*,NTU*) and f is the same ε-NTU relationships + (depending on the heat exchanger configuration) for the sensible heat exchanger. +

      +

      + hair,in and hsat(Twat,in) are + the specific enthalpies of the incoming moist air and saturated moist air + at the water inlet temperature. +

      +

      + The capacitances of water and air streams are defined as +

      +

      C*air=mair and + C*wat=mwatcp,wat/csat, +

      +

      + where csat is an specific heat capacity, which indicates the sensitivity + of the enthalpy of the staturated moist air w.r.t. the temperature, and is defined + here as csat=(hsat(Twat,out)-hsat(Twat,in)) + /(Twat,out-Twat,in). +

      +

      + The capacitance ratio and minimum capacitance are naturally defined as +

      +

      Cr*=min(C*air,C*wat)/max(C*air,C*wat) + and C*min=min(C*air,C*wat). +

      +


      + The number of transfer unit for the wet-coil is defined as NTU*=UA*/C*min, where +

      +

      + UA*=1/(1/(UAair/cp,air)+1/(UAwat/csat). +

      + +

      References

      +

      + Braun, James E. 1988. + "Methodologies for the Design and Control of Central Cooling Plants". + PhD Thesis. University of Wisconsin - Madison. + Available + + online. +

      +

      + Mitchell, John W., and James E. Braun. 2012a. + Principles of heating, ventilation, and air conditioning in buildings. + Hoboken, N.J.: Wiley. +

      +

      + Mitchell, John W., and James E. Braun. 2012b. + "Supplementary Material Chapter 2: Heat Exchangers for Cooling Applications". + Excerpt from Principles of heating, ventilation, and air conditioning in buildings. + Hoboken, N.J.: Wiley. + Available + + online. +

      + +-------- Corrected Code --------
        -
      • September 12, 2014, by Michael Wetter:
        - Corrected the wrong location of the preferredView and - the revisions annotation. -
      • -
      • November 21, 2013, by Michael Wetter:
        +
      • Jan 21, 2021, by Donghun Kim:
        First implementation.

      - This medium package models moist air using a gas law in which - pressure and temperature are independent, which often leads to - significantly faster and more robust computations. The specific heat - capacities at constant pressure and at constant volume are constant. - The air is assumed to be not saturated. + This model implements the calculation for a 100% wet coil.

      - This medium uses the gas law -

      -

      - ρ/ρstp = p/pstp, + The equations from Braun (1988) and Mitchell and Braun (2012a and b), + which are essentially the extension of the ε-NTU approach to + simultaneous sensible and latent heat transfer, are utilized.

      - where pstd and ρstp are constant - reference temperature and density, rathern than the ideal gas law -

      -

      - ρ = p ⁄(R T), + The mathematical equations are analogous to that of the sensible heat + exchanger. However, the key distinction is that the heat transfer is + driven by an enthalpy difference not by an temperature difference. + This change in the driving potential results in re-defining + capacitances and heat transfer coefficients accordingly.

      - where R is the gas constant and T is the temperature. + The total heat transfer rate is expressed as

      -

      - This formulation often leads to smaller systems of nonlinear - equations because equations for pressure and temperature are - decoupled. Therefore, if air inside a control volume such as room air - is heated, it does not increase its specific volume. Consequently, - merely heating or cooling a control volume does not affect the air - flow calculations in a duct network that may be connected to that - volume. Note that multizone air exchange simulation in which buoyancy - drives the air flow is still possible as the models in AixLib.Airflow.Multizone - compute the mass density using the function AixLib.Utilities.Psychrometrics.Functions.density_pTX - in which density is a function of temperature. +

      + Qtot=ε* C*min + (hair,in-hsat(Twat,in)),

      - Note that models in this package implement the equation for the - internal energy as -

      -

      - u = h - pstp ⁄ ρstp, + where ε*=f(Cr*,NTU*) and f is the same ε-NTU + relationships (depending on the heat exchanger configuration) for the + sensible heat exchanger.

      - where u is the internal energy per unit mass, h is the - enthalpy per unit mass, pstp is the static pressure - and ρstp is the mass density at standard pressure - and temperature. The reason for this implementation is that in - general, -

      -

      - h = u + p v, + hair,in and + hsat(Twat,in) are the specific + enthalpies of the incoming moist air and saturated moist air at the + water inlet temperature.

      - from which follows that + The capacitances of water and air streams are defined as

      -

      - u = h - p v = h - p ⁄ ρ = h - pstp ⁄ ρstd, +

      + C*air=mair and + C*wat=mwatcp,wat/csat,

      - because p ⁄ ρ = pstp ⁄ ρstp in this - medium model. + where csat is an specific heat capacity, which indicates the + sensitivity of the enthalpy of the staturated moist air w.r.t. the + temperature, and is defined here as + csat=(hsat(Twat,out)-hsat(Twat,in)) + /(Twat,out-Twat,in).

      - The enthalpy is computed using the convention that h=0 if - T=0 °C and no water vapor is present. + The capacitance ratio and minimum capacitance are naturally defined + as +

      +

      + Cr*=min(C*air,C*wat)/max(C*air,C*wat) + and C*min=min(C*air,C*wat). +

      +

      +
      + The number of transfer unit for the wet-coil is defined as + NTU*=UA*/C*min, where +

      +

      + UA*=1/(1/(UAair/cp,air)+1/(UAwat/csat). +

      +

      + References +

      +

      + Braun, James E. 1988. \"Methodologies for the Design and Control of + Central Cooling Plants\". PhD Thesis. University of Wisconsin - + Madison. Available online. +

      +

      + Mitchell, John W., and James E. Braun. 2012a. Principles of heating, + ventilation, and air conditioning in buildings. Hoboken, N.J.: Wiley. +

      +

      + Mitchell, John W., and James E. Braun. 2012b. \"Supplementary Material + Chapter 2: Heat Exchangers for Cooling Applications\". Excerpt from + Principles of heating, ventilation, and air conditioning in + buildings. Hoboken, N.J.: Wiley. Available + online.

      -
        -
      • September 28, 2020, by Michael Wetter:
        - Reformulated BaseProperties to avoid event-triggering - assertions.
        - This is for #1401. -
      • -
      • January 11, 2019 by Michael Wetter:
        - Reforulated assignment of X_int in - setState_psX.
        - This is for #1079. -
      • -
      • October 26, 2018, by Filip Jorissen and Michael Wetter:
        - Now printing different messages if temperature is above or below - its limit, and adding instance name as JModelica does not print the - full instance name in the assertion. This is for #1045. -
      • -
      • November 4, 2016, by Michael Wetter:
        - Set default value for dT.start in base properties.
        - This is for #575. -
      • -
      • June 6, 2015, by Michael Wetter:
        - Set AbsolutePressure(start=p_default) to avoid a - translation error if - AixLib.Fluid.Sources.Examples.TraceSubstancesFlowSource is - translated in pedantic mode in Dymola 2016. The reason is that - pressures use Medium.p_default as start values, but - Modelica.Media.Interfaces.Types - sets a default value of 1E-5. A similar change has been done - for pressure. This fixes #266. -
      • -
      • June 5, 2015, by Michael Wetter:
        - Added stateSelect attribute in - BaseProperties.T to allow correct use of - preferredMediumState as described in Modelica.Media.Interfaces.PartialMedium. - Note that the default is preferredMediumState=false - and hence the same states are used as were used before. This is for - #260. -
      • -
      • May 11, 2015, by Michael Wetter:
        - Removed p(stateSelect=if preferredMediumStates then - StateSelect.prefer else StateSelect.default) in declaration - of BaseProperties. Otherwise, when models that contain - a fluid volume are exported as an FMU, their pressure would be - differentiated with respect to time. This would require the time - derivative of the inlet pressure, which is not available, causing - the translation to stop with an error. -
      • -
      • May 1, 2015, by Michael Wetter:
        - Added Inline=true for issue 227. -
      • -
      • March 20, 2015, by Michael Wetter:
        - Added missing term state.p/reference_p in function - specificEntropy. #193. -
      • -
      • February 3, 2015, by Michael Wetter:
        - Removed stateSelect.prefer for temperature. This is - for #160. -
      • -
      • July 24, 2014, by Michael Wetter:
        - Changed implementation to use AixLib.Utilities.Psychrometrics.Constants. - This was done to use consistent values throughout the library. -
      • -
      • November 16, 2013, by Michael Wetter:
        - Revised and simplified the implementation. -
      • -
      • November 14, 2013, by Michael Wetter:
        - Removed function HeatCapacityOfWater which is neither - needed nor implemented in the Modelica Standard Library. -
      • -
      • November 13, 2013, by Michael Wetter:
        - Removed non-used computations in specificEnthalpy_pTX - and in temperature_phX. -
      • -
      • March 29, 2013, by Michael Wetter:
        - Added final standardOrderComponents=true in the - BaseProperties declaration. This avoids an error when - models are checked in Dymola 2014 in the pedenatic mode. -
      • -
      • April 12, 2012, by Michael Wetter:
        - Added keyword each to - Xi(stateSelect=...). -
      • -
      • April 4, 2012, by Michael Wetter:
        - Added redeclaration of ThermodynamicState to avoid a - warning during model check and translation. -
      • -
      • August 3, 2011, by Michael Wetter:
        - Fixed bug in u=h-R*T, which is only valid for ideal - gases. For this medium, the function is u=h-pStd/dStp. -
      • -
      • January 27, 2010, by Michael Wetter:
        - Fixed bug in else branch of function - setState_phX that lead to a run-time error when the - constructor of this function was called. -
      • -
      • January 22, 2010, by Michael Wetter:
        - Added implementation of function - enthalpyOfNonCondensingGas and its derivative. -
      • -
      • January 13, 2010, by Michael Wetter:
        - Fixed implementation of derivative functions. -
      • -
      • August 28, 2008, by Michael Wetter:
        - First implementation. -
      • -
      -------- Errors -------- -line 8 column 2 - Warning: The summary attribute on the
      element is obsolete in HTML5 - - -line 7 column 2 - Warning:

      attribute "align" not allowed for HTML5 - - -line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 - - -line 8 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 21 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 29 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 37 column 2 - Warning:

      attribute "align" not allowed for HTML5 - - -line 11 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 19 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 43 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 20 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 36 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 48 column 2 - Warning:

      attribute "align" not allowed for HTML5 line 54 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 60 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/HydraulicDiameter.mo ---- +---- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowHeatLoss.mo ---- -------- HTML Code --------

      - This is a model of a flow resistance with a fixed flow coefficient. - The mass flow rate is computed as -

      -

      - ṁ = k - √ΔP, -

      -

      - where - k is a constant and - ΔP is the pressure drop. - The constant k is equal to - k=m_flow_nominal/sqrt(dp_nominal), - where m_flow_nominal is a parameter. -

      -

      Assumptions

      -

      - In the region - abs(m_flow) < m_flow_turbulent, - the square root is replaced by a differentiable function - with finite slope. - The value of m_flow_turbulent is - computed as - m_flow_turbulent = eta_nominal*dh/4*π*ReC, - where - eta_nominal is the dynamic viscosity, obtained from - the medium model. The parameter - dh is the hydraulic diameter and - ReC=4000 is the critical Reynolds number, which both - can be set by the user. -

      -

      Important parameters

      -

      - By default, the pressure drop at nominal flow rate is computed as -

      -
      - dp_nominal = fac * dpStraightPipe_nominal,
      - 
      -

      - where dpStraightPipe_nominal is a parameter that is automatically computed - based on the - nominal mass flow rate, hydraulic diameter, pipe roughness and medium properties. - The hydraulic diameter dh is by default - computed based on the flow velocity v_nominal and the nominal - mass flow rate m_flow_nominal. Hence, users should change the - default values of dh or v_nominal - if they are not applicable for their model. -

      -

      - The factor fac takes into account additional resistances such as - for bends. The default value of 2 can be changed by the user. -

      -

      - The parameter from_dp is used to determine - whether the mass flow rate is computed as a function of the - pressure drop (if from_dp=true), or vice versa. - This setting can affect the size of the nonlinear system of equations. + Component that calculates the heat losses at the end of a plug flow pipe + when the flow goes in the design direction.

      +

      Main equations

      - If the parameter linearized is set to true, - then the pressure drop is computed as a linear function of the - mass flow rate. + The governing equations are

      -

      - Setting allowFlowReversal=false can lead to simpler - equations. However, this should only be set to false - if one can guarantee that the flow never reverses its direction. - This can be difficult to guarantee, as pressure imbalance after - the initialization, or due to medium expansion and contraction, - can lead to reverse flow. +

      + Tout = Tb + (Tin - Tb) + exp((tout - tin)/tauchar)

      - If the parameter - show_T is set to true, - then the model will compute the - temperature at its ports. Note that this can lead to state events - when the mass flow rate approaches zero, - which can increase computing time. + with

      -

      Notes

      -

      - For more detailed models that compute the actual flow friction, - models from the package - - Modelica.Fluid - can be used and combined with models from the - AixLib library. +

      + tauchar = R C

      +

      Assumptions and limitations

      - For a model that uses dp_nominal as a parameter rather than - geoemetric data, use - - AixLib.Fluid.FixedResistances.PressureDrop. + This model is based on the following assumptions:

      +
        +
      • The water temperature is uniform in the cross section.
      • +
      • There is no axial heat transfer in the water or surrounding.
      • +
      • The boundary temperature along the pipe is uniform.
      • +
      • Heat losses are steady-state.
      • +

      Implementation

      - The pressure drop is computed by calling a function in the package - - AixLib.Fluid.BaseClasses.FlowModels, - This package contains regularized implementations of the equation -

      -

      - m = sign(Δp) k √ Δp   -

      -

      - and its inverse function. + Heat losses are only considered in design flow direction. + For heat loss consideration in both directions, use one of these models at + both ends of a + + AixLib.Fluid.FixedResistances.BaseClasses.PlugFlow model. + The outlet temperature is calculated as in the equation above, + using the inlet temperature at port_a and the instantaneous + time delay and boundary temperature. + The boundary temperature can be either the air temperature + or the undisturbed ground temperature, depending on the definition of the + thermal resistance R.

      - To decouple the energy equation from the mass equations, - the pressure drop is a function of the mass flow rate, - and not the volume flow rate. - This leads to simpler equations. -

      + This component requires the delay time and the instantaneous ambient temperature + as an input. + This component is to be used in single pipes or in more advanced configurations + where no influence from other pipes is considered.

      • - September 21, 2021, by Michael Wetter:
        - Corrected typo in comments.
        + December 6, 2017, by Michael Wetter:
        + Reformulated call to medium function.
        This is for - #1525. + + issue 869.
      • - December 1, 2016, by Michael Wetter:
        - First implementation for - #480. + October 20, 2017, by Michael Wetter:
        + Revised implementation to avoid graphical and textual modeling. + Revised variable names and documentation to follow guidelines. +
      • +
      • + November 6, 2015 by Bram van der Heijde:
        + Make time delay input instead of calculation inside this model.
      • +
      • + September, 2015 by Marcus Fuchs:
        + First implementation.
      --------- Corrected Code -------- -

      - This is a model of a flow resistance with a fixed flow coefficient. - The mass flow rate is computed as -

      -

      - ṁ = k √ΔP, -

      -

      - where k is a constant and ΔP is the pressure drop. The - constant k is equal to - k=m_flow_nominal/sqrt(dp_nominal), where - m_flow_nominal is a parameter. -

      -

      - Assumptions -

      -

      - In the region abs(m_flow) < m_flow_turbulent, the - square root is replaced by a differentiable function with finite - slope. The value of m_flow_turbulent is computed as - m_flow_turbulent = eta_nominal*dh/4*π*ReC, where - eta_nominal is the dynamic viscosity, obtained from the - medium model. The parameter dh is the hydraulic diameter - and ReC=4000 is the critical Reynolds number, which both - can be set by the user. -

      -

      - Important parameters -

      -

      - By default, the pressure drop at nominal flow rate is computed as -

      -
      - dp_nominal = fac * dpStraightPipe_nominal,
      - 
      -

      - where dpStraightPipe_nominal is a parameter that is - automatically computed based on the nominal mass flow rate, hydraulic - diameter, pipe roughness and medium properties. The hydraulic - diameter dh is by default computed based on the flow - velocity v_nominal and the nominal mass flow rate - m_flow_nominal. Hence, users should change the default - values of dh or v_nominal if they are not - applicable for their model. -

      +-------- Corrected Code --------

      - The factor fac takes into account additional resistances - such as for bends. The default value of 2 can be changed - by the user. + Component that calculates the heat losses at the end of a plug flow + pipe when the flow goes in the design direction.

      +

      + Main equations +

      - The parameter from_dp is used to determine whether the - mass flow rate is computed as a function of the pressure drop (if - from_dp=true), or vice versa. This setting can affect - the size of the nonlinear system of equations. + The governing equations are

      -

      - If the parameter linearized is set to true, - then the pressure drop is computed as a linear function of the mass - flow rate. +

      + Tout = Tb + (Tin - Tb) + exp((tout - tin)/tauchar)

      - Setting allowFlowReversal=false can lead to simpler - equations. However, this should only be set to false if - one can guarantee that the flow never reverses its direction. This - can be difficult to guarantee, as pressure imbalance after the - initialization, or due to medium expansion and contraction, can lead - to reverse flow. + with

      -

      - If the parameter show_T is set to true, - then the model will compute the temperature at its ports. Note that - this can lead to state events when the mass flow rate approaches - zero, which can increase computing time. +

      + tauchar = R C

      - Notes + Assumptions and limitations

      - For more detailed models that compute the actual flow friction, - models from the package Modelica.Fluid can be used and - combined with models from the AixLib library. -

      -

      - For a model that uses dp_nominal as a parameter rather - than geoemetric data, use AixLib.Fluid.FixedResistances.PressureDrop. + This model is based on the following assumptions:

      +
        +
      • The water temperature is uniform in the cross section. +
      • +
      • There is no axial heat transfer in the water or surrounding. +
      • +
      • The boundary temperature along the pipe is uniform. +
      • +
      • Heat losses are steady-state. +
      • +

      Implementation

      - The pressure drop is computed by calling a function in the package - AixLib.Fluid.BaseClasses.FlowModels, - This package contains regularized implementations of the equation -

      -

      - m = sign(Δp) k √ Δp -   -

      -

      - and its inverse function. + Heat losses are only considered in design flow direction. For heat + loss consideration in both directions, use one of these models at + both ends of a AixLib.Fluid.FixedResistances.BaseClasses.PlugFlow + model. The outlet temperature is calculated as in the equation above, + using the inlet temperature at port_a and the + instantaneous time delay and boundary temperature. The boundary + temperature can be either the air temperature or the undisturbed + ground temperature, depending on the definition of the thermal + resistance R.

      - To decouple the energy equation from the mass equations, the pressure - drop is a function of the mass flow rate, and not the volume flow - rate. This leads to simpler equations. + This component requires the delay time and the instantaneous ambient + temperature as an input. This component is to be used in single pipes + or in more advanced configurations where no influence from other + pipes is considered.

        -
      • September 21, 2021, by Michael Wetter:
        - Corrected typo in comments.
        +
      • December 6, 2017, by Michael Wetter:
        + Reformulated call to medium function.
        This is for #1525. + \"https://github.com/ibpsa/modelica-ibpsa/issues/869\">issue 869.
      • -
      • December 1, 2016, by Michael Wetter:
        - First implementation for #480. +
      • October 20, 2017, by Michael Wetter:
        + Revised implementation to avoid graphical and textual modeling. + Revised variable names and documentation to follow guidelines. +
      • +
      • November 6, 2015 by Bram van der Heijde:
        + Make time delay input instead of calculation inside this model. +
      • +
      • September, 2015 by Marcus Fuchs:
        + First implementation.
      -------- Errors -------- -line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 104 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 10 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 17 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sensors/LatentEnthalpyFlowRate.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource.mo ---- -------- HTML Code --------

      - This model outputs the latent enthalphy flow rate of the medium in the flow - between its fluid ports. In particular, if the total enthalpy flow rate is + This function evaluates the finite line source solution. This solution + gives the relation between the constant heat transfer rate (per unit length) + injected by a line source of finite length H1 buried at a + distance D1 from a constant temperature surface + (T=0) and the average temperature raise over a line of finite length + H2 buried at a distance D2 from the constant + temperature surface. + The finite line source solution is defined by:

      -

      - Ḣtot = Ḣsen + Ḣlat, +

      + \"image\"

      - where - sen = ṁ (1-Xw) cp,air, - then this sensor outputs Ḣ = Ḣlat. + where ΔT1-2(t,r,H1,D1,H2,D2) + is the temperature raise after a time t of constant heat injection and at + a distance r from the line heat source, Q' is the heat injection + rate per unit length, ks is the soil thermal conductivity and + hFLS is the finite line source solution.

      - If the parameter tau is non-zero, then the measured - specific latent enthalpy hout that is used to - compute the latent enthalpy flow rate - lat = ṁ hout - is computed using a first order differential equation. - See - AixLib.Fluid.Sensors.UsersGuide for an explanation. + The finite line source solution is given by:

      -

      - For a sensor that measures - tot, use - - AixLib.Fluid.Sensors.EnthalpyFlowRate.
      - For a sensor that measures - sen, use - - AixLib.Fluid.Sensors.SensibleEnthalpyFlowRate. +

      + \"image\"

      - The sensor is ideal, i.e., it does not influence the fluid. - The sensor can only be used with medium models that implement the function - enthalpyOfNonCondensingGas(T). + where αs is the ground thermal diffusivity and + erfint is the integral of the error function, defined in + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource_erfint. + The integral is solved numerically, with the integrand defined in + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource_Integrand.

      • - October 19, 2020, by Antoine Gautier:
        - Changed default value for tau from 1 to 0.
        - This is for - #1406. -
      • -
      • - February 25, 2020, by Michael Wetter:
        - Changed icon to display its operating state.
        - This is for - #1294. -
      • -
      • - January 18, 2016 by Filip Jorissen:
        - Using parameter tauInv - since this now exists in - AixLib.Fluid.Sensors.BaseClasses.PartialDynamicFlowSensor. + March 17, 2019, by Massimo Cimmino:
        + Modified the upper bound of integration to avoid underestimating the value of + the integral. This is for - #372. -
      • -
      • - September 10, 2013, by Michael Wetter:
        - Changed medium declaration in the extends statement - to replaceable to avoid a translation error in - OpenModelica. -
      • -
      • - August 31, 2013, by Michael Wetter:
        - Removed default value tau=0 as the base class - already sets tau=1. - This change was made so that all sensors use the same default value. + IBPSA, issue 1107.
      • - December 18, 2012, by Michael Wetter:
        - Moved computation of i_w to new base class - - AixLib.Fluid.BaseClasses.IndexWater. - The value of this parameter is now assigned dynamically and does not require to be specified - by the user. + March 22, 2018 by Massimo Cimmino:
        + First implementation.
      • +
      + +-------- Corrected Code -------- +

      + This function evaluates the finite line source solution. This + solution gives the relation between the constant heat transfer rate + (per unit length) injected by a line source of finite length + H1 buried at a distance D1 from a + constant temperature surface (T=0) and the average temperature + raise over a line of finite length H2 buried at a + distance D2 from the constant temperature surface. + The finite line source solution is defined by: +

      +

      + \"image\" +

      +

      + where + ΔT1-2(t,r,H1,D1,H2,D2) + is the temperature raise after a time t of constant heat + injection and at a distance r from the line heat source, + Q' is the heat injection rate per unit length, + ks is the soil thermal conductivity and + hFLS is the finite line source solution. +

      +

      + The finite line source solution is given by: +

      +

      + \"image\" +

      +

      + where αs is the ground thermal diffusivity and + erfint is the integral of the error function, defined in + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource_erfint. + The integral is solved numerically, with the integrand defined in + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.finiteLineSource_Integrand. +

      +
        +
      • March 17, 2019, by Massimo Cimmino:
        + Modified the upper bound of integration to avoid underestimating + the value of the integral. This is for IBPSA, issue + 1107. +
      • +
      • March 22, 2018 by Massimo Cimmino:
        + First implementation. +
      • +
      + +-------- Errors -------- +line 12 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 25 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Movers/Validation/PowerSimplified.mo ---- +-------- HTML Code -------- + +

      + This example compares the power consumed by pumps that + take three different control signals. + Each pump has identical mass flow rate and pressure rise. +

      +

      + Note that for the instances + + AixLib.Fluid.Movers.FlowControlled_dp + and + + AixLib.Fluid.Movers.FlowControlled_m_flow, + we had to assign the efficiencies (otherwise the default constant + efficiency of 0.7 would have been used). + In these models, the power consumption is computed + using similarity laws, but using the mass flow rate as opposed + to the speed, because speed is not known in these two models. + This is an approximation at operating points in which + the speed is different from the nominal speed N_nominal + because similarity laws are valid for speed and not for + mass flow rate. +

      +

      + The figure below shows the approximation error for the + power calculation where the speed Nrpm differs from + the nominal speed Nnominal. +

      +

      + \"image\" +

      + +
      • - November 3, 2011, by Michael Wetter:
        - Moved der(h_out) := 0; from the initial algorithm section to - the initial equation section - as this assignment does not conform to the Modelica specification. + October 15, 2021, by Hongxiang Fu:
        + Fixed the image in the documentation which was cut off + at the y-axis. This is for + IBPSA, #1533.
      • - August 10, 2011 by Michael Wetter:
        - Added parameter i_w and an assert statement to - make sure it is set correctly. Without this change, Dymola - cannot differentiate the model when reducing the index of the DAE. + March 11, 2016, by Michael Wetter:
        + Revised implementation by assigning the data record directly in the + instances pump_dp and pump_m_flow, because + using a parameter and assigning this parameter leads + in OpenModelica to the error message + expected subtype of record AixLib.Fluid.Movers.Data.Generic.
      • - June 3, 2011 by Michael Wetter:
        - Revised implementation to add dynamics in such a way that - the time constant increases as the mass flow rate tends to zero. - This can improve the numerics. + March 2, 2016, by Filip Jorissen:
        + Revised implementation for + #417.
      • - February 22, by Michael Wetter:
        - Improved code that searches for index of 'water' in medium model. + November 5, 2015, by Michael Wetter:
        + Changed parameters since the power is no longer a parameter for the movers + that take mass flow rate or head as an input. + This is for + issue 457.
      • - September 9, 2009 by Michael Wetter:
        - First implementation. - Implementation is based on enthalpy sensor of Modelica.Fluid. + November 22, 2014, by Michael Wetter:
        + Revised implementation.
      -------- Corrected Code --------

      - This model outputs the latent enthalphy flow rate of the - medium in the flow between its fluid ports. In particular, if the - total enthalpy flow rate is -

      -

      - Ḣtot = Ḣsen + Ḣlat, -

      -

      - where sen = ṁ (1-Xw) - cp,air, then this sensor outputs Ḣ = - Ḣlat. + This example compares the power consumed by pumps that take three + different control signals. Each pump has identical mass flow rate and + pressure rise.

      - If the parameter tau is non-zero, then the measured - specific latent enthalpy hout that is used to - compute the latent enthalpy flow rate lat = ṁ - hout is computed using a first order differential - equation. See AixLib.Fluid.Sensors.UsersGuide - for an explanation. + Note that for the instances AixLib.Fluid.Movers.FlowControlled_dp + and AixLib.Fluid.Movers.FlowControlled_m_flow, + we had to assign the efficiencies (otherwise the default constant + efficiency of 0.7 would have been used). In these models, the + power consumption is computed using similarity laws, but using the + mass flow rate as opposed to the speed, because speed is not known in + these two models. This is an approximation at operating points in + which the speed is different from the nominal speed + N_nominal because similarity laws are valid for speed + and not for mass flow rate.

      - For a sensor that measures tot, use AixLib.Fluid.Sensors.EnthalpyFlowRate.
      - - For a sensor that measures sen, use AixLib.Fluid.Sensors.SensibleEnthalpyFlowRate. + The figure below shows the approximation error for the power + calculation where the speed Nrpm differs from the + nominal speed Nnominal.

      -

      - The sensor is ideal, i.e., it does not influence the fluid. The - sensor can only be used with medium models that implement the - function enthalpyOfNonCondensingGas(T). +

      + \"image\"

        -
      • October 19, 2020, by Antoine Gautier:
        - Changed default value for tau from 1 to - 0.
        - This is for #1406. -
      • -
      • February 25, 2020, by Michael Wetter:
        - Changed icon to display its operating state.
        - This is for #1294. -
      • -
      • January 18, 2016 by Filip Jorissen:
        - Using parameter tauInv since this now exists in - - AixLib.Fluid.Sensors.BaseClasses.PartialDynamicFlowSensor. This - is for #372. -
      • -
      • September 10, 2013, by Michael Wetter:
        - Changed medium declaration in the extends statement to - replaceable to avoid a translation error in - OpenModelica. -
      • -
      • August 31, 2013, by Michael Wetter:
        - Removed default value tau=0 as the base class already - sets tau=1. This change was made so that all sensors - use the same default value. -
      • -
      • December 18, 2012, by Michael Wetter:
        - Moved computation of i_w to new base class AixLib.Fluid.BaseClasses.IndexWater. - The value of this parameter is now assigned dynamically and does - not require to be specified by the user. -
      • -
      • November 3, 2011, by Michael Wetter:
        - Moved der(h_out) := 0; from the initial algorithm - section to the initial equation section as this assignment does not - conform to the Modelica specification. +
      • October 15, 2021, by Hongxiang Fu:
        + Fixed the image in the documentation which was cut off at the + y-axis. This is for IBPSA, + #1533.
      • -
      • August 10, 2011 by Michael Wetter:
        - Added parameter i_w and an assert statement to make - sure it is set correctly. Without this change, Dymola cannot - differentiate the model when reducing the index of the DAE. +
      • March 11, 2016, by Michael Wetter:
        + Revised implementation by assigning the data record directly in the + instances pump_dp and pump_m_flow, + because using a parameter and assigning this + parameter leads in OpenModelica to the error message + expected subtype of record + AixLib.Fluid.Movers.Data.Generic.
      • -
      • June 3, 2011 by Michael Wetter:
        - Revised implementation to add dynamics in such a way that the time - constant increases as the mass flow rate tends to zero. This can - improve the numerics. +
      • March 2, 2016, by Filip Jorissen:
        + Revised implementation for #417.
      • -
      • February 22, by Michael Wetter:
        - Improved code that searches for index of 'water' in medium model. +
      • November 5, 2015, by Michael Wetter:
        + Changed parameters since the power is no longer a parameter for the + movers that take mass flow rate or head as an input. This is for + issue + 457.
      • -
      • September 9, 2009 by Michael Wetter:
        - First implementation. Implementation is based on enthalpy sensor of - Modelica.Fluid. +
      • November 22, 2014, by Michael Wetter:
        + Revised implementation.
      -------- Errors -------- -line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 - +line 29 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Chillers/Carnot_TEva.mo ---- --------- HTML Code -------- + +---- AixLib/Fluid/HeatExchangers/EvaporatorCondenser.mo ---- +-------- HTML Code --------

      - This is a model of a chiller whose coefficient of performance COP changes - with temperatures in the same way as the Carnot efficiency changes. - The control input is the setpoint of the evaporator leaving temperature, which - is met exactly at steady state if the chiller has sufficient capacity. -

      -

      - The model allows to either specify the Carnot effectivness - ηCarnot,0, or - a COP0 - at the nominal conditions, together with - the evaporator temperature Teva,0 and - the condenser temperature Tcon,0, in which - case the model computes the Carnot effectivness as -

      -

      - ηCarnot,0 = - COP0 - ⁄ (Teva,0 ⁄ (Tcon,0-Teva,0)). -

      -

      - On the Advanced tab, a user can specify the temperatures that - will be used as the evaporator and condenser temperature. -

      -

      - During the simulation, the chiller COP is computed as the product -

      -

      - COP = ηCarnot,0 COPCarnot ηPL, -

      -

      - where COPCarnot is the Carnot efficiency and - ηPL is a polynomial in the cooling part load ratio yPL - that can be used to take into account a change in COP at part load - conditions. - This polynomial has the form -

      -

      - ηPL = a1 + a2 yPL + a3 yPL2 + ... -

      -

      - where the coefficients ai - are declared by the parameter a. -

      -

      - On the Dynamics tag, the model can be parametrized to compute a transient - or steady-state response. - The transient response of the model is computed using a first - order differential equation for the evaporator and condenser fluid volumes. - The chiller outlet temperatures are equal to the temperatures of these lumped volumes. -

      -

      Typical use and important parameters

      -

      - When using this component, make sure that the condenser has sufficient mass flow rate. - Based on the evaporator mass flow rate, temperature difference and the efficiencies, - the model computes how much heat will be added to the condenser. - If the mass flow rate is too small, very high outlet temperatures can result. + Model for a constant temperature evaporator or condenser based on a ε-NTU + heat exchanger model.

      - The evaporator heat flow rate QEva_flow_nominal is used to assign - the default value for the mass flow rates, which are used for the pressure drop - calculations. - It is also used to compute the part load efficiency. - Hence, make sure that QEva_flow_nominal is set to a reasonable value. + The heat exchanger effectiveness is calculated from the number of transfer units + (NTU):

      -

      - The maximum cooling capacity is set by the parameter QEva_flow_min, - which is by default set to negative infinity. +

      + ε = 1 - exp(UA ⁄ (ṁ cp))

      - The coefficient of performance depends on the - evaporator and condenser leaving temperature - since otherwise the second law of thermodynamics may be violated. + Optionally, this model can have a flow resistance. + If no flow resistance is requested, set dp_nominal=0.

      -

      Notes

      +

      Limitations

      - For a similar model that can be used as a heat pump, see - - AixLib.Fluid.HeatPumps.Examples.Carnot_TCon. + This model does not consider any superheating or supercooling on the refrigerant + side. The refrigerant is considered to exchange heat at a constant temperature + throughout the heat exchanger.

      • - May 8, 2017, by Michael Wetter:
        - Replaced model that interfaces with fluid stream.
        + March 7, 2022, by Michael Wetter:
        + Removed massDynamics.
        This is for - - AixLib, #763. + #1542.
      • - January 2, 2017, by Filip Jorissen:
        - Removed parameters - effInpEva and effInpCon - and updated documentation. + May 27, 2017, by Filip Jorissen:
        + Regularised heat transfer around zero flow.
        This is for - - issue 497. + #769.
      • - August 8, 2016, by Michael Wetter:
        - Changed default temperature to compute COP to be the leaving temperature as - use of the entering temperature can violate the 2nd law if the temperature - lift is small.
        + April 12, 2017, by Michael Wetter:
        + Corrected invalid syntax for computing the specific heat capacity.
        This is for - - Annex 60, issue 497. + #707.
      • - November 25, 2015 by Michael Wetter:
        + October 11, 2016, by Massimo Cimmino:
        First implementation.
      -------- Corrected Code --------

      - This is a model of a chiller whose coefficient of performance COP - changes with temperatures in the same way as the Carnot efficiency - changes. The control input is the setpoint of the evaporator leaving - temperature, which is met exactly at steady state if the chiller has - sufficient capacity. -

      -

      - The model allows to either specify the Carnot effectivness - ηCarnot,0, or a COP0 at the - nominal conditions, together with the evaporator temperature - Teva,0 and the condenser temperature - Tcon,0, in which case the model computes the Carnot - effectivness as -

      -

      - ηCarnot,0 = COP0 ⁄ (Teva,0 ⁄ - (Tcon,0-Teva,0)). -

      -

      - On the Advanced tab, a user can specify the temperatures - that will be used as the evaporator and condenser temperature. -

      -

      - During the simulation, the chiller COP is computed as the product -

      -

      - COP = ηCarnot,0 COPCarnot ηPL, + Model for a constant temperature evaporator or condenser based on a + ε-NTU heat exchanger model.

      - where COPCarnot is the Carnot efficiency and - ηPL is a polynomial in the cooling part load ratio - yPL that can be used to take into account a change - in COP at part load conditions. This polynomial has the form + The heat exchanger effectiveness is calculated from the number of + transfer units (NTU):

      - ηPL = a1 + a2 yPL + - a3 yPL2 + ... -

      -

      - where the coefficients ai are declared by the - parameter a. -

      -

      - On the Dynamics tag, the model can be parametrized to - compute a transient or steady-state response. The transient response - of the model is computed using a first order differential equation - for the evaporator and condenser fluid volumes. The chiller outlet - temperatures are equal to the temperatures of these lumped volumes. -

      -

      - Typical use and important parameters -

      -

      - When using this component, make sure that the condenser has - sufficient mass flow rate. Based on the evaporator mass flow rate, - temperature difference and the efficiencies, the model computes how - much heat will be added to the condenser. If the mass flow rate is - too small, very high outlet temperatures can result. -

      -

      - The evaporator heat flow rate QEva_flow_nominal is used - to assign the default value for the mass flow rates, which are used - for the pressure drop calculations. It is also used to compute the - part load efficiency. Hence, make sure that - QEva_flow_nominal is set to a reasonable value. -

      -

      - The maximum cooling capacity is set by the parameter - QEva_flow_min, which is by default set to negative - infinity. + ε = 1 - exp(UA ⁄ (ṁ cp))

      - The coefficient of performance depends on the evaporator and - condenser leaving temperature since otherwise the second law of - thermodynamics may be violated. + Optionally, this model can have a flow resistance. If no flow + resistance is requested, set dp_nominal=0.

      - Notes + Limitations

      - For a similar model that can be used as a heat pump, see AixLib.Fluid.HeatPumps.Examples.Carnot_TCon. + This model does not consider any superheating or supercooling on the + refrigerant side. The refrigerant is considered to exchange heat at a + constant temperature throughout the heat exchanger.

        -
      • May 8, 2017, by Michael Wetter:
        - Replaced model that interfaces with fluid stream.
        +
      • March 7, 2022, by Michael Wetter:
        + Removed massDynamics.
        This is for AixLib, - #763. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1542\">#1542.
      • -
      • January 2, 2017, by Filip Jorissen:
        - Removed parameters effInpEva and - effInpCon and updated documentation. This is for - issue - 497. +
      • May 27, 2017, by Filip Jorissen:
        + Regularised heat transfer around zero flow.
        + This is for #769.
      • -
      • August 8, 2016, by Michael Wetter:
        - Changed default temperature to compute COP to be the leaving - temperature as use of the entering temperature can violate the 2nd - law if the temperature lift is small.
        +
      • April 12, 2017, by Michael Wetter:
        + Corrected invalid syntax for computing the specific heat + capacity.
        This is for Annex 60, - issue 497. + \"https://github.com/lbl-srg/modelica-buildings/issues/707\">#707.
      • -
      • November 25, 2015 by Michael Wetter:
        +
      • October 11, 2016, by Massimo Cimmino:
        First implementation.
      -------- Errors -------- -line 17 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 29 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 39 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 10 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/DryCoilEffectivenessNTU.mo ---- +---- AixLib/Controls/SetPoints/Examples/SupplyReturnTemperatureReset.mo ---- -------- HTML Code --------

      - Model of a coil without humidity condensation. - This model transfers heat in the amount of -

      -

      - Q̇ = Q̇max ε
      - ε = f(NTU, Z, flowRegime), -

      -

      - where - max is the maximum heat that can be transferred, - ε is the heat transfer effectiveness, - NTU is the Number of Transfer Units, - Z is the ratio of minimum to maximum capacity flow rate and - flowRegime is the heat exchanger flow regime. - such as - parallel flow, cross flow or counter flow. -

      -

      - The flow regimes depend on the heat exchanger configuration. All configurations - defined in - - AixLib.Fluid.Types.HeatExchangerConfiguration - are supported. + Example that demonstrates the use of the hot water temperature reset + for a heating system. + The parameters of the block heaCur + are for a heating system with + 60°C supply water temperature and + 40°C return water temperature at + an outside temperature of + -10°C and a room temperature of + 20°C. The offset for the temperature reset is + 8 Kelvin, i.e., above + 12°C outside temperature, there is no heating load. + The figure below shows the computed supply and return water temperatures.

      -

      - The convective heat transfer coefficients scale proportional to - (ṁ/ṁ0)n, where - is the mass flow rate, - 0 is the nominal mass flow rate, and - n=0.8 on the air-side and n=0.85 on the water side. +

      + \"Supply

      + +
        +
      • + November 21, 2011, by Michael Wetter:
        + Added documentation. +
      • +
      + +-------- Corrected Code -------- +

      + Example that demonstrates the use of the hot water temperature reset + for a heating system. The parameters of the block heaCur + are for a heating system with 60°C supply water temperature + and 40°C return water temperature at an outside temperature of + -10°C and a room temperature of 20°C. The offset for + the temperature reset is 8 Kelvin, i.e., above 12°C + outside temperature, there is no heating load. The figure below shows + the computed supply and return water temperatures. +

      +

      + \"Supply +

      +
        +
      • November 21, 2011, by Michael Wetter:
        + Added documentation. +
      • +
      + +-------- Errors -------- +line 16 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Utilities/Math/Bicubic.mo ---- +-------- HTML Code -------- +

      - For a heat and moisture exchanger, use - - AixLib.Fluid.MassExchangers.ConstantEffectiveness. + This block computes +

      +

      + y = a1 + + a2 x1 + a3 x12 + + a4 x2 + a5 x22 + + a6 x1 x2 + + a7 x1^3 + + a8 x2^3 + + a9 x12 x2 + + a10 x1 x22

      • - September 25, 2018, by Michael Wetter:
        - Refactored model to use a common base class. + Sep 17, 2010 by Michael Wetter:
        + First implementation.
      -------- Corrected Code --------

      - Model of a coil without humidity condensation. This model transfers - heat in the amount of + This block computes

      - Q̇ = Q̇max ε
      - ε = f(NTU, Z, flowRegime), -

      -

      - where max is the maximum heat that can be - transferred, ε is the heat transfer effectiveness, NTU - is the Number of Transfer Units, Z is the ratio of minimum to - maximum capacity flow rate and flowRegime is the heat - exchanger flow regime. such as parallel flow, cross flow or counter - flow. -

      -

      - The flow regimes depend on the heat exchanger configuration. All - configurations defined in AixLib.Fluid.Types.HeatExchangerConfiguration - are supported. -

      -

      - The convective heat transfer coefficients scale proportional to - (ṁ/ṁ0)n, where is the mass - flow rate, 0 is the nominal mass flow rate, and - n=0.8 on the air-side and n=0.85 on the water side. -

      -

      - For a heat and moisture exchanger, use AixLib.Fluid.MassExchangers.ConstantEffectiveness. + y = a1 + a2 x1 + a3 + x12 + a4 x2 + + a5 x22 + a6 x1 + x2 + a7 x1^3 + a8 + x2^3 + a9 x12 + x2 + a10 x1 + x22

        -
      • September 25, 2018, by Michael Wetter:
        - Refactored model to use a common base class. +
      • Sep 17, 2010 by Michael Wetter:
        + First implementation.
      -------- Errors -------- -line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 5 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatPumps/ScrollWaterToWater.mo ---- +---- AixLib/Fluid/Types.mo ---- -------- HTML Code -------- +

      - Model for a water to water heat pump with a scroll compressor, as described - in Jin (2002). The thermodynamic heat pump cycle is represented below. -

      -

      - \"image\" -

      -

      - The rate of heat transferred to the evaporator is given by: -

      -

      - Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ). + Enumeration to define the choice of valve flow coefficient + (to be selected via choices menu):

      + +
      + + + + + + + + + + + + + + + +
      EnumerationDescription
      OpPointflow coefficient defined by ratio m_flow_nominal/sqrt(dp_nominal)
      KvKv (metric) flow coefficient
      CvCv (US) flow coefficient
      AvAv (metric) flow coefficient
      +

      - The power consumed by the compressor is given by a linear efficiency relation: -

      -

      - P = PTheoretical / η + PLoss,constant. + The details of the coefficients are explained in the + + Users Guide.

      + +

      - Heat transfer in the evaporator and condenser is calculated using an - ε-NTU method, assuming constant refrigerant temperature and constant heat - transfer coefficient between fluid and refrigerant. + Enumeration that defines the heat exchanger construction.

      - Variable speed is achieved by multiplying the full load suction volume flow rate - by the normalized compressor speed. The power and heat transfer rates are forced - to zero if the resulting heat pump state has higher evaporating pressure than - condensing pressure. + The following heat exchanger configurations are available in this enumeration:

      + + + + + + + + +
      EnumerationDescription
      ParallelFlowParallel flow
      CounterFlowCounter flow
      CrossFlowUnmixedCross flow, both streams unmixed
      CrossFlowStream1MixedStream2UnmixedCross flow, stream 1 mixed, stream 2 unmixed
      CrossFlowStream1UnmixedStream2MixedCross flow, stream 1 unmixed, stream 2 mixed
      ConstantTemperaturePhaseChangeConstant temperature phase change in one stream

      - The model parameters are obtained by calibration of the heat pump model to - manufacturer performance data. Calibrated model parameters for various heat - pumps from different manufacturers are found in - - AixLib.Fluid.HeatPumps.Data.ScrollWaterToWater. The calibrated model is - located in - - AixLib.Fluid.HeatPumps.Calibration.ScrollWaterToWater. -

      -

      Options

      + Note that for a given heat exchanger, the + HeatExchangerConfiguration is fixed. However, if the capacity + flow rates change, then the + + AixLib.Fluid.Types.HeatExchangerFlowRegime may change. For example, + a counter flow heat exchanger has HeatExchangerConfiguration=CounterFlow, + but the + AixLib.Fluid.Types.HeatExchangerFlowRegime can change to parallel flow if one of the two capacity flow rates reverts + its direction. +

      + +
        +
      • + March 27, 2017, by Michael Wetter:
        + Added ConstantTemperaturePhaseChange.
        + This is for + + AixLib #694. +
      • +
      • + February 18, 2009, by Michael Wetter:
        + First implementation. +
      • +
      +

      - Parameters TConMax and TEvaMin - may be used to set an upper or lower bound for the - condenser and evaporator. - The compressor is disabled when these conditions - are not satisfied, or when the - evaporator temperature is larger - than the condenser temperature. - This mimics the temperature protection - of heat pumps and moreover it avoids - non-converging algebraic loops of equations, - or freezing of evaporator medium. - This option can be disabled by setting - enable_temperature_protection = false. + Enumeration to define the heat exchanger flow regime.

      -

      Assumptions and limitations

      - The compression process is assumed isentropic. The thermal energy - of superheating is ignored in the evaluation of the heat transferred to the refrigerant - in the evaporator. There is no supercooling. + This enumeration defines for the current capacity flow rate the kind of + heat transfer relation that will be used to compute the relation between + effectiveness and Number of Transfer Units.

      -

      References

      - H. Jin. - - Parameter estimation based models of water source heat pumps. - - PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002. + The following heat exchanger flow regimes are available in this enumeration:

      + + + + + + + + +
      EnumerationDescription
      ParallelFlowParallel flow
      CounterFlowCounter flow
      CrossFlowUnmixedCross flow, both streams unmixed
      CrossFlowCMinMixedCMaxUnmixedCross flow, CMin mixed, CMax unmixed
      CrossFlowCMinUnmixedCMaxMixedCross flow, CMin unmixed, CMax mixed
      ConstantTemperaturePhaseChangeConstant temperature phase change in one stream
      • - May 30, 2017, by Filip Jorissen:
        - Revised documentation for temperature protection. - See #769. + March 27, 2017, by Michael Wetter:
        + Added ConstantTemperaturePhaseChange.
        + This is for + + AixLib #694.
      • - November 11, 2016, by Massimo Cimmino:
        + February 18, 2009, by Michael Wetter:
        + First implementation. +
      • +
      + +

      + This type allows defining which type of input should be used for movers. + This can either be +

      +
        +
      1. + a constant set point declared by a parameter, +
      2. +
      3. + a series of possible set points that can be switched using an integer input, or +
      4. +
      5. + a continuously variable set point. +
      6. +
      + +
        +
      • + April 2, 2015, by Filip Jorissen:
        First implementation.
      +

      + This package contains type definitions. +

      + -------- Corrected Code --------

      - Model for a water to water heat pump with a scroll compressor, as - described in Jin (2002). The thermodynamic heat pump cycle is - represented below. -

      -

      - \"image\" + Enumeration to define the choice of valve flow coefficient (to be + selected via choices menu):

      + + + + + + + + + + + + + + + + + + + + + +
      + Enumeration + + Description +
      + OpPoint + + flow coefficient defined by ratio m_flow_nominal/sqrt(dp_nominal) +
      + Kv + + Kv (metric) flow coefficient +
      + Cv + + Cv (US) flow coefficient +
      + Av + + Av (metric) flow coefficient +

      - The rate of heat transferred to the evaporator is given by: -

      -

      - Q̇Eva = ṁref ( - hVap(TEva) - hLiq(TCon) - ). + The details of the coefficients are explained in the + Users Guide.

      - The power consumed by the compressor is given by a linear efficiency - relation: -

      -

      - P = PTheoretical / η + PLoss,constant. + Enumeration that defines the heat exchanger construction.

      - Heat transfer in the evaporator and condenser is calculated using an - ε-NTU method, assuming constant refrigerant temperature and constant - heat transfer coefficient between fluid and refrigerant. + The following heat exchanger configurations are available in this + enumeration:

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + Enumeration + + Description +
      + ParallelFlow + + Parallel flow +
      + CounterFlow + + Counter flow +
      + CrossFlowUnmixed + + Cross flow, both streams unmixed +
      + CrossFlowStream1MixedStream2Unmixed + + Cross flow, stream 1 mixed, stream 2 unmixed +
      + CrossFlowStream1UnmixedStream2Mixed + + Cross flow, stream 1 unmixed, stream 2 mixed +
      + ConstantTemperaturePhaseChange + + Constant temperature phase change in one stream +

      - Variable speed is achieved by multiplying the full load suction - volume flow rate by the normalized compressor speed. The power and - heat transfer rates are forced to zero if the resulting heat pump - state has higher evaporating pressure than condensing pressure. + Note that for a given heat exchanger, the + HeatExchangerConfiguration is fixed. However, if the + capacity flow rates change, then the AixLib.Fluid.Types.HeatExchangerFlowRegime + may change. For example, a counter flow heat exchanger has + HeatExchangerConfiguration=CounterFlow, but the AixLib.Fluid.Types.HeatExchangerFlowRegime + can change to parallel flow if one of the two capacity flow rates + reverts its direction.

      +
        +
      • March 27, 2017, by Michael Wetter:
        + Added ConstantTemperaturePhaseChange.
        + This is for AixLib + #694. +
      • +
      • February 18, 2009, by Michael Wetter:
        + First implementation. +
      • +

      - The model parameters are obtained by calibration of the heat pump - model to manufacturer performance data. Calibrated model parameters - for various heat pumps from different manufacturers are found in - AixLib.Fluid.HeatPumps.Data.ScrollWaterToWater. - The calibrated model is located in AixLib.Fluid.HeatPumps.Calibration.ScrollWaterToWater. + Enumeration to define the heat exchanger flow regime.

      -

      - Options -

      - Parameters TConMax and TEvaMin may be used - to set an upper or lower bound for the condenser and evaporator. The - compressor is disabled when these conditions are not satisfied, or - when the evaporator temperature is larger than the condenser - temperature. This mimics the temperature protection of heat pumps and - moreover it avoids non-converging algebraic loops of equations, or - freezing of evaporator medium. This option can be disabled by setting - enable_temperature_protection = false. + This enumeration defines for the current capacity flow rate the kind + of heat transfer relation that will be used to compute the relation + between effectiveness and Number of Transfer Units.

      -

      - Assumptions and limitations -

      - The compression process is assumed isentropic. The thermal energy of - superheating is ignored in the evaluation of the heat transferred to - the refrigerant in the evaporator. There is no supercooling. + The following heat exchanger flow regimes are available in this + enumeration:

      -

      - References -

      + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
      + Enumeration + + Description +
      + ParallelFlow + + Parallel flow +
      + CounterFlow + + Counter flow +
      + CrossFlowUnmixed + + Cross flow, both streams unmixed +
      + CrossFlowCMinMixedCMaxUnmixed + + Cross flow, CMin mixed, CMax unmixed +
      + CrossFlowCMinUnmixedCMaxMixed + + Cross flow, CMin unmixed, CMax mixed +
      + ConstantTemperaturePhaseChange + + Constant temperature phase change in one stream +
      +
        +
      • March 27, 2017, by Michael Wetter:
        + Added ConstantTemperaturePhaseChange.
        + This is for AixLib + #694. +
      • +
      • February 18, 2009, by Michael Wetter:
        + First implementation. +
      • +

      - H. Jin. Parameter estimation based models of water source heat - pumps. PhD Thesis. Oklahoma State University. Stillwater, - Oklahoma, USA. 2002. + This type allows defining which type of input should be used for + movers. This can either be

      -
        -
      • May 30, 2017, by Filip Jorissen:
        - Revised documentation for temperature protection. See #769. +
          +
        1. a constant set point declared by a parameter,
        2. -
        3. November 11, 2016, by Massimo Cimmino:
          +
        4. a series of possible set points that can be switched using an + integer input, or +
        5. +
        6. a continuously variable set point. +
        7. +
        +
          +
        • April 2, 2015, by Filip Jorissen:
          First implementation.
        +

        + This package contains type definitions. +

        -------- Errors -------- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 8 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Fluid/HeatPumps/Carnot_y.mo ---- +line 8 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 + + +line 13 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 + + +---- AixLib/Media/Specialized/Water/TemperatureDependentDensity.mo ---- -------- HTML Code -------- +

        + Base properties of the medium. +

        +

        - This is model of a heat pump whose coefficient of performance COP changes - with temperatures in the same way as the Carnot efficiency changes. - The input signal y is the control signal for the compressor. + This function computes the density as a function of temperature.

        +

        Implementation

        - The model allows to either specify the Carnot effectivness - ηCarnot,0, or - a COP0 - at the nominal conditions, together with - the evaporator temperature Teva,0 and - the condenser temperature Tcon,0, in which - case the model computes the Carnot effectivness as -

        -

        - ηCarnot,0 = - COP0 - ⁄ (Tcon,0 ⁄ (Tcon,0-Teva,0)). + The function is based on the IDA implementation in therpro.nmf, which + implements

        +
        + d := 1000.12 + 1.43711e-2*T_degC -
        +  5.83576e-3*T_degC^2 + 1.5009e-5*T_degC^3;
        +  

        - The heat pump COP is computed as the product -

        -

        - COP = ηCarnot,0 COPCarnot ηPL, + This has been converted to Kelvin, which resulted in the above expression. + In addition, below 5 °C and above 100 °C, the density is replaced + by a linear function to avoid inflection points. + This linear extension is such that the density is once continuously differentiable.

        + +
          +
        • + December 18, 2013, by Michael Wetter:
          + First implementation, based on the IDA implementation in therpro.nmf, + but converted from Celsius to Kelvin and linearly extended. +
        • +
        +

        - where COPCarnot is the Carnot efficiency and - ηPL is a polynomial in the heating part load ratio yPL - that can be used to take into account a change in COP at part load - conditions. - This polynomial has the form -

        -

        - ηPL = a1 + a2 yPL + a3 yPL2 + ... + This function computes the dynamic viscosity.

        + +
          +
        • + December 2, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - where the coefficients ai are declared by the parameter a. + This function computes the specific enthalpy.

        + +
          +
        • + December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - On the Dynamics tag, the model can be parametrized to compute a transient - or steady-state response. - The transient response of the model is computed using a first - order differential equation for the evaporator and condenser fluid volumes. - The heat pump outlet temperatures are equal to the temperatures of these lumped volumes. + This function computes the specific enthalpy of liquid water.

        -

        Typical use and important parameters

        + +
          +
        • + December 2, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - When using this component, make sure that the evaporator and the condenser have sufficient mass flow rate. - Based on the mass flow rates, the compressor power, temperature difference and the efficiencies, - the model computes how much heat will be added to the condenser and removed at the evaporator. - If the mass flow rates are too small, very high temperature differences can result. + This function computes the specific internal energy.

        + +
          +
        • + December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - The condenser heat flow rate QCon_flow_nominal is used to assign - the default value for the mass flow rates, which are used for the pressure drop - calculations. - It is also used to compute the part load efficiency. - Hence, make sure that QCon_flow_nominal is set to a reasonable value. + This function computes the specific entropy.

        - The maximum heating capacity is set by the parameter QCon_flow_max, - which is by default set to infinity. + To obtain the state for a given pressure, entropy and mass fraction, use + + AixLib.Media.Air.setState_psX.

        + +
          +
        • + December 18, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - The coefficient of performance depends on the - evaporator and condenser leaving temperature - since otherwise the second law of thermodynamics may be violated. + This function computes the specific Gibbs energy.

        -

        Notes

        + +
          +
        • + December 2, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - For a similar model that can be used as a chiller, see - AixLib.Fluid.Chillers.Carnot_y. + This function computes the specific Helmholtz energy.

        • - January 3, 2017, by Michael Wetter:
          - Removed parameters - effInpEva and effInpCon - and updated documentation. - This is for - - issue 497. + December 2, 2013, by Michael Wetter:
          + First implementation.
        • +
        + +

        + This function computes the specific enthalpy for + an isentropic state change from the temperature + that corresponds to the state refState + to reference_T. +

        + +
        • - August 8, 2016, by Michael Wetter:
          - Changed default temperature to compute COP to be the leaving temperature as - use of the entering temperature can violate the 2nd law if the temperature - lift is small.
          - This is for - - Annex 60, issue 497. + December 18, 2013, by Michael Wetter:
          + First implementation.
        • +
        + +

        + This function returns the isobaric expansion coefficient, +

        +

        + βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p, +

        +

        + where + v is the specific volume, + T is the temperature and + p is the pressure. +

        + +
        • - January 26, 2016, by Michael Wetter:
          - Refactored model to use the same base class as - AixLib.Fluid.Chillers.Carnot_y.
          - Changed part load efficiency to depend on heating part load ratio rather than on the compressor - part load ratio. + December 18, 2013, by Michael Wetter:
          + First implementation.
        • +
        + +

        + This function returns the isothermal compressibility coefficient, + which is zero as this medium is incompressible. + The isothermal compressibility is defined as +

        +

        + κT = - 1 ⁄ v   (∂ v ⁄ ∂ p)T, +

        +

        + where + v is the specific volume, + T is the temperature and + p is the pressure. +

        + +
        • - January 20, 2015, by Damien Picard:
          - Add Carnot model to Annex 60 from the Buildings library.
          - Removed the flow direction dependency of - staA1, staB1, staA2 and staB2 as the - efficiency of the Carnot machine should only be computed in the design flow direction.
          + December 18, 2013, by Michael Wetter:
          + First implementation.
        • +
        + +

        + This function returns the partial derivative of density + with respect to pressure at constant temperature, + which is zero as the medium is incompressible. +

        + +
        • - December 18, 2015, by Michael Wetter:
          - Corrected wrong computation of staB1 and staB2 - which mistakenly used the inStream operator - for the configuration without flow reversal. - This is for - - issue 476. + December 18, 2013, by Michael Wetter:
          + First implementation.
        • -
        • - November 25, 2015 by Michael Wetter:
          - Changed sign convention for dTEva_nominal to be consistent with - other models. - The model will still work with the old values for dTEva_nominal, - but it will write a warning so that users can transition their models. -
          - Corrected assert statement for the efficiency curve. +
        + +

        + This function computes the derivative of density with respect to temperature + at constant pressure. +

        + +
          +
        • + August 17, 2015, by Michael Wetter:
          + Removed dublicate entry of smooth and smoothOrder. This is for - - issue 468. + issue 303.
        • - September 3, 2015 by Michael Wetter:
          - Expanded documentation. + December 18, 2013, by Michael Wetter:
          + First implementation, based on the IDA implementation in therpro.nmf, + but converted from Celsius to Kelvin.
        • +
        + +

        + This function returns the partial derivative of density + with respect to mass fraction, + which is zero as the medium is a single substance. +

        + +
        • - May 6, 2015 by Michael Wetter:
          - Added prescribedHeatFlowRate=true for vol2. + December 18, 2013, by Michael Wetter:
          + First implementation.
        • +
        + +

        + This function returns the specific heat capacity at constant pressure. +

        + +
        • - October 9, 2013 by Michael Wetter:
          - Reimplemented the computation of the port states to avoid using - the conditionally removed variables sta_a1, - sta_a2, sta_b1 and sta_b2. + December 11, 2013, by Michael Wetter:
          + First implementation.
        • +
        + +

        + This function computes the specific heat capacity at constant volume. +

        + +
        • - May 10, 2013 by Michael Wetter:
          - Added electric power P as an output signal. + December 11, 2013, by Michael Wetter:
          + First implementation.
        • +
        + +

        + This function returns the thermal conductivity. + The expression is obtained from Ramires et al. (1995). +

        +

        References

        +

        + Ramires, Maria L. V. and Nieto de Castro, Carlos A. and Nagasaka, Yuchi + and Nagashima, Akira and Assael, Marc J. and Wakeham, William A. + Standard Reference Data for the Thermal Conductivity of Water. + Journal of Physical and Chemical Reference Data, 24, p. 1377-1381, 1995. + DOI:10.1063/1.555963. +

        + +
        • - October 11, 2010 by Michael Wetter:
          - Fixed bug in energy balance. + December 18, 2013, by Michael Wetter:
          + First implementation.
        • +
        + +

        + This function returns the pressure. +

        + +
        • - March 3, 2009 by Michael Wetter:
          + December 18, 2013, by Michael Wetter:
          + First implementation. +
        • +
        + +

        + This function returns the temperature. +

        + +
          +
        • + December 18, 2013, by Michael Wetter:
          + First implementation. +
        • +
        + +

        + This function returns the molar mass, + which is assumed to be constant. +

        + +
          +
        • + December 18, 2013, by Michael Wetter:
          First implementation.
        --------- Corrected Code -------- -

        - This is model of a heat pump whose coefficient of performance COP - changes with temperatures in the same way as the Carnot efficiency - changes. The input signal y is the control signal for the - compressor. -

        -

        - The model allows to either specify the Carnot effectivness - ηCarnot,0, or a COP0 at the - nominal conditions, together with the evaporator temperature - Teva,0 and the condenser temperature - Tcon,0, in which case the model computes the Carnot - effectivness as -

        -

        - ηCarnot,0 = COP0 ⁄ (Tcon,0 ⁄ - (Tcon,0-Teva,0)). -

        -

        - The heat pump COP is computed as the product -

        -

        - COP = ηCarnot,0 COPCarnot ηPL, -

        -

        - where COPCarnot is the Carnot efficiency and - ηPL is a polynomial in the heating part load ratio - yPL that can be used to take into account a change - in COP at part load conditions. This polynomial has the form -

        -

        - ηPL = a1 + a2 yPL + - a3 yPL2 + ... -

        -

        - where the coefficients ai are declared by the - parameter a. -

        -

        - On the Dynamics tag, the model can be parametrized to - compute a transient or steady-state response. The transient response - of the model is computed using a first order differential equation - for the evaporator and condenser fluid volumes. The heat pump outlet - temperatures are equal to the temperatures of these lumped volumes. -

        -

        - Typical use and important parameters -

        -

        - When using this component, make sure that the evaporator and the - condenser have sufficient mass flow rate. Based on the mass flow - rates, the compressor power, temperature difference and the - efficiencies, the model computes how much heat will be added to the - condenser and removed at the evaporator. If the mass flow rates are - too small, very high temperature differences can result. -

        -

        - The condenser heat flow rate QCon_flow_nominal is used - to assign the default value for the mass flow rates, which are used - for the pressure drop calculations. It is also used to compute the - part load efficiency. Hence, make sure that - QCon_flow_nominal is set to a reasonable value. -

        -

        - The maximum heating capacity is set by the parameter - QCon_flow_max, which is by default set to infinity. -

        -

        - The coefficient of performance depends on the evaporator and - condenser leaving temperature since otherwise the second law of - thermodynamics may be violated. -

        -

        - Notes -

        -

        - For a similar model that can be used as a chiller, see AixLib.Fluid.Chillers.Carnot_y. -

        -
          -
        • January 3, 2017, by Michael Wetter:
          - Removed parameters effInpEva and - effInpCon and updated documentation. This is for - issue - 497. -
        • -
        • August 8, 2016, by Michael Wetter:
          - Changed default temperature to compute COP to be the leaving - temperature as use of the entering temperature can violate the 2nd - law if the temperature lift is small.
          - This is for Annex 60, - issue 497. -
        • -
        • January 26, 2016, by Michael Wetter:
          - Refactored model to use the same base class as AixLib.Fluid.Chillers.Carnot_y.
          - - Changed part load efficiency to depend on heating part load ratio - rather than on the compressor part load ratio. -
        • -
        • January 20, 2015, by Damien Picard:
          - Add Carnot model to Annex 60 from the Buildings library.
          - Removed the flow direction dependency of staA1, - staB1, staA2 and staB2 as - the efficiency of the Carnot machine should only be computed in the - design flow direction.
          -
        • -
        • December 18, 2015, by Michael Wetter:
          - Corrected wrong computation of staB1 and - staB2 which mistakenly used the inStream - operator for the configuration without flow reversal. This is for - issue - 476. -
        • -
        • November 25, 2015 by Michael Wetter:
          - Changed sign convention for dTEva_nominal to be - consistent with other models. The model will still work with the - old values for dTEva_nominal, but it will write a - warning so that users can transition their models.
          - Corrected assert statement for the efficiency curve. - This is for issue - 468. -
        • -
        • September 3, 2015 by Michael Wetter:
          - Expanded documentation. -
        • -
        • May 6, 2015 by Michael Wetter:
          - Added prescribedHeatFlowRate=true for - vol2. -
        • -
        • October 9, 2013 by Michael Wetter:
          - Reimplemented the computation of the port states to avoid using the - conditionally removed variables sta_a1, - sta_a2, sta_b1 and sta_b2. -
        • -
        • May 10, 2013 by Michael Wetter:
          - Added electric power P as an output signal. -
        • -
        • October 11, 2010 by Michael Wetter:
          - Fixed bug in energy balance. -
        • -
        • March 3, 2009 by Michael Wetter:
          - First implementation. -
        • -
        - --------- Errors -------- -line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 34 column 2 - Warning:

        attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Actuators/BaseClasses/PartialDamperExponential.mo ---- --------- HTML Code -------- -

        - Partial model for air dampers with exponential opening characteristics. - This is the base model for air dampers. - The model implements the functions that relate the opening signal and the - flow coefficient. - The model also defines parameters that are used by different air damper - models. + This function returns the thermodynamic state for a given pressure, + specific enthalpy and composition.

        + +
          +
        • + December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - The model is as in ASHRAE 825-RP except that a control signal of - y=0 means the damper is closed, and y=1 means - the damper is open. - This is opposite of the implementation of ASHRAE 825-RP, but used here - for consistency within this library. + This function returns the thermodynamic state for a given pressure, + temperature and composition.

        + +
          +
        • + December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - For yL < y < yU, the damper characteristics is: + This function returns the thermodynamic state based on pressure, + specific entropy and mass fraction.

        -

        - kd(y) = exp(a+b (1-y)) +

        + The state is computed by symbolically solving + + AixLib.Media.Specialized.Water.TemperatureDependentDensity.specificEntropy + for temperature. +

        + +
          +
        • + April 11, 2016 by Michael Wetter:
          + Corrected wrong hyperlink in documentation for + issue 450. +
        • +
        • + December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        + +

        + This function computes the derivative of the specific heat capacity + at constant pressure with respect to the state.

        + +
          +
        • + December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - where kd is the loss coefficient (total pressure drop divided - by dynamic pressure) and y is the fractional opening. + This function computes the temperature derivative of the enthalpy of liquid water + per unit mass.

        + +
          +
        • + December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        - Outside this range, the damper characteristics is defined by a quadratic polynomial that - matches the damper resistance at y=0 and y=yL or - y=yU and y=1, respectively. - In addition, the polynomials are such that kd(y) is differentiable in - y and the derivative is continuous. + This function computes the kinematic viscosity as a function of temperature.

        +

        Implementation

        - The damper characteristics is then used to compute the flow coefficient k(y) as: + The function is based on the IDA implementation in therpro.nmf. + The original equation is

        -

        - k(y) = (2 ρ ⁄ kd(y))1/2 A +

        + kinVis :=1E-6*Modelica.Math.exp(0.577449 - 3.253945e-2*T_degC + 2.17369e-4*
        +       T_degC^2 - 7.22111e-7*T_degC^3);
        +       
        +

        + This has been converted to Kelvin, which resulted in the above expression. + In addition, at 5 °C the kinematic viscosity is linearly extrapolated + to avoid a large gradient at very low temperatures. + We selected the same point for the linearization as we used for the density, + as the density and the kinematic viscosity are combined in + + AixLib.Media.Specialized.Water.TemperatureDependentDensity.dynamicViscosity.

        + +
          +
        • + April 11, 2016 by Michael Wetter:
          + Corrected wrong hyperlink in documentation for + issue 450. +
        • +
        • + December 18, 2013, by Michael Wetter:
          + First implementation, based on the IDA implementation in therpro.nmf, + but converted from Celsius to Kelvin. +
        • +
        +

        - where A is the face area, which is computed using the nominal - mass flow rate m_flow_nominal, the nominal velocity - v_nominal and the density of the medium. + This medium package models liquid water.

        - ASHRAE 825-RP lists the following parameter values as typical (note that the - default values in the model correspond to opposed blades). -
        + The mass density is computed using a 3rd order polynomial, which yields the + density as a function of temperature as shown in the figure below. Note, however, + that computing density as a function of temperature can lead to considerably + slower computing time compared to using + + AixLib.Media.Water + in which the density is a constant. We therefore recommend to use + + AixLib.Media.Water + for typical building energy simulations. +

        +

        + \"Mass

        -
        - - - - - - - - - - - - - - - - - - -
        opposed bladessingle blades
        yL15/9015/90
        yU55/9065/90
        k10.2 to 0.50.2 to 0.5
        a-1.51-1.51
        b0.105*900.0842*90

        - (The loss coefficient in fully closed position k0 is computed based on the leakage coefficient - and the coefficient in fully open position.) + For the specific heat capacities at constant pressure and at constant volume, + a constant value of 4184 J/(kg K), which corresponds to 20°C + is used. + The figure below shows the relative error of the specific heat capacity that + is introduced by this simplification. + Using a constant value for the specific heat capacity allows to compute + temperature from enthalpy without having to solve an implicit equation, + and therefore leads to faster simulation.

        -

        References

        +

        + \"Relative +

        + +

        - P. Haves, L. K. Norford, M. DeSimone and L. Mei, - A Standard Simulation Testbed for the Evaluation of Control Algorithms & Strategies, - ASHRAE Final Report 825-RP, Atlanta, GA. + Thermal conductivity is calculated as a function of temperature as shown in the figure below. + The correlation used to calculate the thermal conductivity is +

        + +

        + λ(T) = λ(298.15 K) ⋅ (-1.48445+4.12292⋅(T/298.15)-1.63866⋅(T/298.15)2), +

        +

        + where λ(298.15 K) = 0.6065 W/(m ⋅ K) is the adopted standard value + of the thermal conductivity of water at 298.15 K and 0.1 MPa. +

        +

        + \"Thermal +

        + +

        + Dynamic viscosity is calculated as the product of density and kinematic viscosity, + both temperature dependent. However, the kinematic viscosity + has its own temperature dependent correlation, implemented at + + AixLib.Media.Specialized.Water.TemperatureDependentDensity.kinematicViscosity. + Results of the kinematic viscosity as a function of temperature are shown in the figure below. +

        +

        + \"Kinematic +

        + +

        + The enthalpy is computed using the convention that h=0 + if T=0 °C. +

        +

        Limitations

        +

        + Phase changes are not modeled.

        • - September 21, 2021, by Michael Wetter:
          - Corrected typo in comments.
          - This is for - #1525. -
        • -
        • - December 23, 2019, by Antoine Gautier:
          - Removed the equations involving m_flow and dp that now need - to be added in each derived damper model.
          - Added the declaration of dpDamper_nominal and dpFixed_nominal.
          - Replaced k0 by leakage coefficient.
          - Modified the limiting values for k0 and k1.
          + April 5, 2022, by Michael Wetter:
          + Corrected assignment of R_s in BaseProperties to avoid a unit error.
          This is for - #1188. + #1603.
        • - March 22, 2017, by Michael Wetter:
          - Added back v_nominal, but set the assignment of A - to be final. This allows scaling the model with m_flow_nominal, - which is generally known in the flow leg, - and v_nominal, for which a default value can be specified.
          - This is for - #544. + July 7, 2016, by Carles Ribas Tugores:
          + Correct Documentation. This is for + #487.
        • - October 12, 2016 by David Blum:
          - Removed parameter v_nominal and variable area, - to simplify parameterization of the model. - Also added assertion statements upon initialization - for parameters k0 and k1 so that they fall within - suggested ranges found in ASHRAE 825-RP. This is for - #544. + June 6, 2015, by Michael Wetter:
          + Set AbsolutePressure(start=p_default) + and Temperature(start=T_default) + to have to have conistent start values. + See also revision notes of + + AixLib.Media.Water. + This is for + #266.
        • - January 27, 2015 by Michael Wetter:
          - Set Evaluate=true for use_constant_density. - This is a structural parameter. Adding this annotation leads to fewer - numerical Jacobians for - Buildings.Examples.VAVReheat.ClosedLoop - with - Buildings.Media.PerfectGases.MoistAirUnsaturated. + May 1, 2015, by Michael Wetter:
          + Added Inline=true for + + issue 227.
        • - December 14, 2012 by Michael Wetter:
          - Renamed protected parameters for consistency with the naming conventions. + February 25, 2015, by Michael Wetter:
          + Removed stateSelect attribute on pressure as this caused + + AixLib.Examples.Tutorial.SpaceCooling.System3 + to fail with the error message + \"differentiated if-then-else was not continuous\".
        • - January 16, 2012 by Michael Wetter:
          - To simplify object inheritance tree, revised base classes - AixLib.Fluid.BaseClasses.PartialResistance, - AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve, - AixLib.Fluid.Actuators.BaseClasses.PartialDamperExponential, - AixLib.Fluid.Actuators.BaseClasses.PartialActuator - and model - AixLib.Fluid.FixedResistances.PressureDrop. + February 3, 2015, by Michael Wetter:
          + Removed stateSelect.prefer for temperature. + This is for + #160.
        • - August 5, 2011, by Michael Wetter:
          - Moved linearized pressure drop equation from the function body to the equation - section. With the previous implementation, - the symbolic processor may not rearrange the equations, which can lead - to coupled equations instead of an explicit solution. + October 15, 2014, by Michael Wetter:
          + Renamed from AixLib.Media.Water to + AixLib.Media.Water.Detailed to allow addition of + AixLib.Media.Water.Simple.
        • - June 22, 2008 by Michael Wetter:
          - Extended range of control signal from 0 to 1 by implementing the function - - exponentialDamper. + September 12, 2014, by Michael Wetter:
          + Set T(start=T_default) and p(start=p_default) in the + ThermodynamicState record. Setting the start value for + T is required to avoid an error due to conflicting start values + when checking + AixLib.Examples.VAVReheat.ClosedLoop in pedantic mode.
        • - June 10, 2008 by Michael Wetter:
          + December 18, 2013, by Michael Wetter:
          First implementation.
        -------- Corrected Code --------

        - Partial model for air dampers with exponential opening - characteristics. This is the base model for air dampers. The model - implements the functions that relate the opening signal and the flow - coefficient. The model also defines parameters that are used by - different air damper models. + Base properties of the medium.

        - The model is as in ASHRAE 825-RP except that a control signal of - y=0 means the damper is closed, and y=1 - means the damper is open. This is opposite of the implementation of - ASHRAE 825-RP, but used here for consistency within this library. + This function computes the density as a function of temperature.

        +

        + Implementation +

        - For yL < y < yU, the damper characteristics is: + The function is based on the IDA implementation in + therpro.nmf, which implements

        -

        - kd(y) = exp(a+b (1-y)) +

        + d := 1000.12 + 1.43711e-2*T_degC -
        +  5.83576e-3*T_degC^2 + 1.5009e-5*T_degC^3;
        +  
        +

        + This has been converted to Kelvin, which resulted in the above + expression. In addition, below 5 °C and above 100 °C, the density is + replaced by a linear function to avoid inflection points. This linear + extension is such that the density is once continuously + differentiable.

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation, based on the IDA implementation in + therpro.nmf, but converted from Celsius to Kelvin and + linearly extended. +
        • +

        - where kd is the loss coefficient (total pressure drop divided - by dynamic pressure) and y is the fractional opening. + This function computes the dynamic viscosity. +

        +
          +
        • December 2, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        + This function computes the specific enthalpy.

        +
          +
        • December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +

        - Outside this range, the damper characteristics is defined by a - quadratic polynomial that matches the damper resistance at - y=0 and y=yL or y=yU and - y=1, respectively. In addition, the polynomials are such - that kd(y) is differentiable in y and the - derivative is continuous. + This function computes the specific enthalpy of liquid water.

        +
          +
        • December 2, 2013, by Michael Wetter:
          + First implementation. +
        • +

        - The damper characteristics is then used to compute the flow - coefficient k(y) as: + This function computes the specific internal energy.

        -

        - k(y) = (2 ρ ⁄ kd(y))1/2 A +

          +
        • December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        + This function computes the specific entropy.

        - where A is the face area, which is computed using the nominal - mass flow rate m_flow_nominal, the nominal velocity - v_nominal and the density of the medium. + To obtain the state for a given pressure, entropy and mass fraction, + use AixLib.Media.Air.setState_psX.

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation. +
        • +

        - ASHRAE 825-RP lists the following parameter values as typical (note - that the default values in the model correspond to opposed - blades).
        + This function computes the specific Gibbs energy.

        - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
        - opposed blades - - single blades -
        - yL - - 15/90 - - 15/90 -
        - yU - - 55/90 - - 65/90 -
        - k1 - - 0.2 to 0.5 - - 0.2 to 0.5 -
        - a - - -1.51 - - -1.51 -
        - b - - 0.105*90 - - 0.0842*90 -
        +
          +
        • December 2, 2013, by Michael Wetter:
          + First implementation. +
        • +

        - (The loss coefficient in fully closed position k0 is - computed based on the leakage coefficient and the coefficient in - fully open position.) + This function computes the specific Helmholtz energy. +

        +
          +
        • December 2, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        + This function computes the specific enthalpy for an isentropic state + change from the temperature that corresponds to the state + refState to reference_T. +

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        + This function returns the isobaric expansion coefficient, +

        +

        + βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p, +

        +

        + where v is the specific volume, T is the temperature + and p is the pressure. +

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        + This function returns the isothermal compressibility coefficient, + which is zero as this medium is incompressible. The isothermal + compressibility is defined as +

        +

        + κT = - 1 ⁄ v   (∂ v ⁄ ∂ p)T,

        -

        - References -

        - P. Haves, L. K. Norford, M. DeSimone and L. Mei, A Standard - Simulation Testbed for the Evaluation of Control Algorithms & - Strategies, ASHRAE Final Report 825-RP, Atlanta, GA. + where v is the specific volume, T is the temperature + and p is the pressure.

          -
        • September 21, 2021, by Michael Wetter:
          - Corrected typo in comments.
          - This is for #1525. +
        • December 18, 2013, by Michael Wetter:
          + First implementation.
        • -
        • December 23, 2019, by Antoine Gautier:
          - Removed the equations involving m_flow and - dp that now need to be added in each derived damper - model.
          - Added the declaration of dpDamper_nominal and - dpFixed_nominal.
          - Replaced k0 by leakage coefficient.
          - Modified the limiting values for k0 and - k1.
          - This is for #1188. +
        +

        + This function returns the partial derivative of density with respect + to pressure at constant temperature, which is zero as the medium is + incompressible. +

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation.
        • -
        • March 22, 2017, by Michael Wetter:
          - Added back v_nominal, but set the assignment of - A to be final. This allows scaling the model with - m_flow_nominal, which is generally known in the flow - leg, and v_nominal, for which a default value can be - specified.
          - This is for #544. +
        +

        + This function computes the derivative of density with respect to + temperature at constant pressure. +

        +
          +
        • August 17, 2015, by Michael Wetter:
          + Removed dublicate entry of smooth and + smoothOrder. This is for issue 303.
        • -
        • October 12, 2016 by David Blum:
          - Removed parameter v_nominal and variable - area, to simplify parameterization of the model. Also - added assertion statements upon initialization for parameters - k0 and k1 so that they fall within - suggested ranges found in ASHRAE 825-RP. This is for #544. +
        • December 18, 2013, by Michael Wetter:
          + First implementation, based on the IDA implementation in + therpro.nmf, but converted from Celsius to Kelvin.
        • -
        • January 27, 2015 by Michael Wetter:
          - Set Evaluate=true for - use_constant_density. This is a structural parameter. - Adding this annotation leads to fewer numerical Jacobians for - Buildings.Examples.VAVReheat.ClosedLoop with - Buildings.Media.PerfectGases.MoistAirUnsaturated. +
        +

        + This function returns the partial derivative of density with respect + to mass fraction, which is zero as the medium is a single substance. +

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation.
        • -
        • December 14, 2012 by Michael Wetter:
          - Renamed protected parameters for consistency with the naming - conventions. +
        +

        + This function returns the specific heat capacity at constant + pressure. +

        +
          +
        • December 11, 2013, by Michael Wetter:
          + First implementation.
        • -
        • January 16, 2012 by Michael Wetter:
          - To simplify object inheritance tree, revised base classes - AixLib.Fluid.BaseClasses.PartialResistance, - AixLib.Fluid.Actuators.BaseClasses.PartialTwoWayValve, - AixLib.Fluid.Actuators.BaseClasses.PartialDamperExponential, - AixLib.Fluid.Actuators.BaseClasses.PartialActuator and - model AixLib.Fluid.FixedResistances.PressureDrop. +
        +

        + This function computes the specific heat capacity at constant volume. +

        +
          +
        • December 11, 2013, by Michael Wetter:
          + First implementation.
        • -
        • August 5, 2011, by Michael Wetter:
          - Moved linearized pressure drop equation from the function body to - the equation section. With the previous implementation, the - symbolic processor may not rearrange the equations, which can lead - to coupled equations instead of an explicit solution. +
        +

        + This function returns the thermal conductivity. The expression is + obtained from Ramires et al. (1995). +

        +

        + References +

        +

        + Ramires, Maria L. V. and Nieto de Castro, Carlos A. and Nagasaka, + Yuchi and Nagashima, Akira and Assael, Marc J. and Wakeham, William + A. Standard Reference Data for the Thermal Conductivity of Water. + Journal of Physical and Chemical Reference Data, 24, p. + 1377-1381, 1995. DOI:10.1063/1.555963. +

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation.
        • -
        • June 22, 2008 by Michael Wetter:
          - Extended range of control signal from 0 to 1 by implementing the - function exponentialDamper. +
        +

        + This function returns the pressure. +

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation.
        • -
        • June 10, 2008 by Michael Wetter:
          +
        +

        + This function returns the temperature. +

        +
          +
        • December 18, 2013, by Michael Wetter:
          First implementation.
        - --------- Errors -------- -line 50 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/Fluid/HeatExchangers/ConstantEffectiveness.mo ---- --------- HTML Code -------- - -

        - Model for a heat exchanger with constant effectiveness. -

        -

        - This model transfers heat in the amount of -

        -

        - Q = Qmax ε, -

        -

        - where ε is a constant effectiveness and - Qmax is the maximum heat that can be transferred. -

        -

        - For a heat and moisture exchanger, use - - AixLib.Fluid.MassExchangers.ConstantEffectiveness - instead of this model. -

        - -
          -
        • - August 13, 2013 by Michael Wetter:
          - Corrected error in the documentation. -
        • -
        • - July 30, 2013 by Michael Wetter:
          - Updated model to use new variable mWat_flow - in the base class. -
        • -
        • - January 28, 2010, by Michael Wetter:
          - Added regularization near zero flow. -
        • -
        • - October 2, 2009, by Michael Wetter:
          - Changed computation of inlet temperatures to use - state_*_inflow which is already known in base class. -
        • -
        • - April 28, 2008, by Michael Wetter:
          - First implementation. -
        • -
        - --------- Corrected Code --------

        - Model for a heat exchanger with constant effectiveness. + This function returns the molar mass, which is assumed to be + constant.

        +
          +
        • December 18, 2013, by Michael Wetter:
          + First implementation. +
        • +

        - This model transfers heat in the amount of + This function returns the thermodynamic state for a given pressure, + specific enthalpy and composition.

        -

        - Q = Qmax ε, +

          +
        • December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +
        +

        + This function returns the thermodynamic state for a given pressure, + temperature and composition.

        +
          +
        • December 11, 2013, by Michael Wetter:
          + First implementation. +
        • +

        - where ε is a constant effectiveness and Qmax - is the maximum heat that can be transferred. + This function returns the thermodynamic state based on pressure, + specific entropy and mass fraction.

        - For a heat and moisture exchanger, use AixLib.Fluid.MassExchangers.ConstantEffectiveness - instead of this model. + The state is computed by symbolically solving + AixLib.Media.Specialized.Water.TemperatureDependentDensity.specificEntropy + for temperature.

          -
        • August 13, 2013 by Michael Wetter:
          - Corrected error in the documentation. -
        • -
        • July 30, 2013 by Michael Wetter:
          - Updated model to use new variable mWat_flow in the - base class. +
        • April 11, 2016 by Michael Wetter:
          + Corrected wrong hyperlink in documentation for issue 450.
        • -
        • January 28, 2010, by Michael Wetter:
          - Added regularization near zero flow. +
        • December 11, 2013, by Michael Wetter:
          + First implementation.
        • -
        • October 2, 2009, by Michael Wetter:
          - Changed computation of inlet temperatures to use - state_*_inflow which is already known in base class. +
        +

        + This function computes the derivative of the specific heat capacity + at constant pressure with respect to the state. +

        +
          +
        • December 11, 2013, by Michael Wetter:
          + First implementation.
        • -
        • April 28, 2008, by Michael Wetter:
          +
        +

        + This function computes the temperature derivative of the enthalpy of + liquid water per unit mass. +

        +
          +
        • December 11, 2013, by Michael Wetter:
          First implementation.
        - --------- Errors -------- -line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT2Nodes.mo ---- --------- HTML Code -------- - -

        The example contains - - experimental data from a real district heating network. - This data is used to validate this library's - plug flow pipe model - in - AixLib.Fluid.FixedResistances.Validation.PlugFlowPipes.PlugFlowAIT. -

        -

        - Note that these three models are identical, except for the pipe model that is used: -

        - -

        - This comparison between different discretization levels and pipe models is made - to check the influence of the discretization and pipe model on computation time - and simulation accuracy. -

        -

        The pipes' temperatures are not initialized, thus results of outflow temperature - before approximately the first 10000 seconds should not be considered. -

        -

        Test bench schematic

        -

        \"Schematic

        -

        Calibration

        -

        - To calculate the length specific thermal resistance R of the pipe, - the thermal resistance of the surrounding ground is added. -

        -

        - R=1/(0.208)+1/(2   lambdag Modelica.Constants.pi)   log(1/0.18) -

        -

        - Where the thermal conductivity of the ground lambda_g = 2.4 W/(m K). -

        - -
          -
        • - March 7, 2020, by Michael Wetter:
          - Replaced measured data from specification in Modelica file to external table, - as this reduces the computing time.
          - This is for - #1289. -
        • -
        • - May 15, 2019, by Jianjun Hu:
          - Replaced fluid source. This is for - #1072. -
        • -
        • November 28, 2016 by Bram van der Heijde:
          Remove pipVol. -
        • -
        • - August 24, 2016 by Bram van der Heijde:
          - Implement validation with MSL pipes for comparison, based on AIT validation. -
        • -
        • - July 4, 2016 by Bram van der Heijde:
          Added parameters to test the - influence of allowFlowReversal and the presence of explicit volumes in the pipe. -
        • -
        • January 26, 2016 by Carles Ribas:
          First implementation.
        • -
        - --------- Corrected Code --------

        - The example contains - experimental data from a real district heating network. This data - is used to validate this library's plug flow - pipe model in - AixLib.Fluid.FixedResistances.Validation.PlugFlowPipes.PlugFlowAIT. + This function computes the kinematic viscosity as a function of + temperature.

        +

        + Implementation +

        - Note that these three models are identical, except for the pipe model - that is used: + The function is based on the IDA implementation in + therpro.nmf. The original equation is +

        +
        + kinVis :=1E-6*Modelica.Math.exp(0.577449 - 3.253945e-2*T_degC + 2.17369e-4*
        +       T_degC^2 - 7.22111e-7*T_degC^3);
        +       
        +

        + This has been converted to Kelvin, which resulted in the above + expression. In addition, at 5 °C the kinematic viscosity is linearly + extrapolated to avoid a large gradient at very low temperatures. We + selected the same point for the linearization as we used for the + density, as the density and the kinematic viscosity are combined in + + AixLib.Media.Specialized.Water.TemperatureDependentDensity.dynamicViscosity.

        - This comparison between different discretization levels and pipe - models is made to check the influence of the discretization and pipe - model on computation time and simulation accuracy. + This medium package models liquid water.

        - The pipes' temperatures are not initialized, thus results of outflow - temperature before approximately the first 10000 seconds should not - be considered. + The mass density is computed using a 3rd order polynomial, which + yields the density as a function of temperature as shown in the + figure below. Note, however, that computing density as a function of + temperature can lead to considerably slower computing time compared + to using AixLib.Media.Water in which the + density is a constant. We therefore recommend to use AixLib.Media.Water for typical + building energy simulations. +

        +

        + \"Mass

        -

        - Test bench schematic -

        - \"Schematic + For the specific heat capacities at constant pressure and at constant + volume, a constant value of 4184 J/(kg K), which corresponds + to 20°C is used. The figure below shows the relative error of + the specific heat capacity that is introduced by this simplification. + Using a constant value for the specific heat capacity allows to + compute temperature from enthalpy without having to solve an implicit + equation, and therefore leads to faster simulation. +

        +

        + +

        -

        - Calibration -

        - To calculate the length specific thermal resistance R of - the pipe, the thermal resistance of the surrounding ground is added. + Thermal conductivity is calculated as a function of temperature as + shown in the figure below. The correlation used to calculate the + thermal conductivity is

        - R=1/(0.208)+1/(2   lambdag Modelica.Constants.pi) -   log(1/0.18) + λ(T) = λ(298.15 K) ⋅ + (-1.48445+4.12292⋅(T/298.15)-1.63866⋅(T/298.15)2),

        - Where the thermal conductivity of the ground lambda_g = - 2.4 W/(m K). + where λ(298.15 K) = 0.6065 W/(m ⋅ K) is the adopted standard + value of the thermal conductivity of water at 298.15 K and + 0.1 MPa. +

        +

        + \"Thermal +

        +

        + Dynamic viscosity is calculated as the product of density and + kinematic viscosity, both temperature dependent. However, the + kinematic viscosity has its own temperature dependent correlation, + implemented at + AixLib.Media.Specialized.Water.TemperatureDependentDensity.kinematicViscosity. + Results of the kinematic viscosity as a function of temperature are + shown in the figure below. +

        +

        + \"Kinematic +

        +

        + The enthalpy is computed using the convention that h=0 if + T=0 °C. +

        +

        + Limitations +

        +

        + Phase changes are not modeled.

          -
        • March 7, 2020, by Michael Wetter:
          - Replaced measured data from specification in Modelica file to - external table, as this reduces the computing time.
          +
        • April 5, 2022, by Michael Wetter:
          + Corrected assignment of R_s in + BaseProperties to avoid a unit error.
          This is for #1289. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1603\">#1603. +
        • +
        • July 7, 2016, by Carles Ribas Tugores:
          + Correct Documentation. This is for #487. +
        • +
        • June 6, 2015, by Michael Wetter:
          + Set AbsolutePressure(start=p_default) and + Temperature(start=T_default) to have to have conistent + start values. See also revision notes of AixLib.Media.Water. This is for + #266.
        • -
        • May 15, 2019, by Jianjun Hu:
          - Replaced fluid source. This is for #1072. +
        • May 1, 2015, by Michael Wetter:
          + Added Inline=true for issue 227.
        • -
        • November 28, 2016 by Bram van der Heijde:
          - Remove pipVol. +
        • February 25, 2015, by Michael Wetter:
          + Removed stateSelect attribute on pressure as this + caused AixLib.Examples.Tutorial.SpaceCooling.System3 + to fail with the error message \"differentiated if-then-else was not + continuous\".
        • -
        • August 24, 2016 by Bram van der Heijde:
          - Implement validation with MSL pipes for comparison, based on AIT - validation. +
        • February 3, 2015, by Michael Wetter:
          + Removed stateSelect.prefer for temperature. This is + for #160.
        • -
        • July 4, 2016 by Bram van der Heijde:
          - Added parameters to test the influence of allowFlowReversal and the - presence of explicit volumes in the pipe. +
        • October 15, 2014, by Michael Wetter:
          + Renamed from AixLib.Media.Water to + AixLib.Media.Water.Detailed to allow addition of + AixLib.Media.Water.Simple.
        • -
        • January 26, 2016 by Carles Ribas:
          +
        • September 12, 2014, by Michael Wetter:
          + Set T(start=T_default) and + p(start=p_default) in the + ThermodynamicState record. Setting the start value for + T is required to avoid an error due to conflicting + start values when checking AixLib.Examples.VAVReheat.ClosedLoop + in pedantic mode. +
        • +
        • December 18, 2013, by Michael Wetter:
          First implementation.
        -------- Errors -------- -line 51 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/ExportContainers/ThermalZone.mo ---- +line 7 column 2 - Warning:

        attribute "align" not allowed for HTML5 + + +line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 31 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 42 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 49 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 62 column 2 - Warning:

        attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Movers/BaseClasses/Characteristics/pressure.mo ---- -------- HTML Code --------

        - Model that is used as a container for a single thermal zone - that is to be exported as an FMU. -

        -

        Typical use and important parameters

        -

        - To use this model as a container for an FMU, extend - from this model, rather than instantiate it, - add your thermal zone and a vector of mass flow rate sensors. - By extending from this model, the top-level - signal connectors on the left stay at the top-level, and hence - will be visible at the FMI interface. -

        - - Note that -
          -
        • - The vector of mass flow rate sensors is used to connect - the thermal zone adapter and your thermal zone. -
        • -
        • - The vector of mass flow rate sensors must have the size nPorts. -
        • -
        • - All fluid ports of the mass flow rate sensor must be connected. -
        • -
        • - If the vector of mass flow rate sensors is not used, and your themal zone - has fluid ports which are autosized, then a direct connection between - the thermal zone adpater theZonAda and your thermal - zone will be rejected. The reason is because autosized fluid ports - can only be connected to vector of ports whose sizes are literal. -
        • -
        - -

        - The example - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone - shows how a simple thermal zone can be implemented and exported as - an FMU. - -

        - -

        - The conversion between the fluid ports and signal ports is done - in the thermal zone adapter theZonAda. - This adapter has a vector of fluid ports called ports[nPorts] - which needs to be connected to the air volume of the thermal zone. - At this port, air exchanged between the thermal zone, the HVAC system - and any infiltration flow paths. -

        -

        - This model has input signals fluPor[nPorts], which carry - the mass flow rate for each flow that is connected to ports, together with its - temperature, water vapor mass fraction per total mass of the air (not per kg dry - air), and trace substances. These quantities are always as if the flow - enters the room, even if the flow is zero or negative. - If a medium has no moisture, e.g., if Medium.nXi=0, or - if it has no trace substances, e.g., if Medium.nC=0, then - the output signal for these properties are removed. - Thus, a thermal zone model that uses these signals to compute the - heat added by the HVAC system need to implement an equation such as + This function computes the fan static + pressure raise as a function of volume flow rate and revolution in the form

        - Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), + Δp = rN2   s(V̇/rN, d),

        where - Qsen is the sensible heat flow rate added to the thermal zone, - sup is the supply air mass flow rate from - the port fluPor (which is negative if it is an exhaust), - cp is the specific heat capacity at constant pressure, - Tsup is the supply air temperature and - Tair,zon is the zone air temperature. - Note that without the max(·, ·), the energy - balance would be wrong. - For example, - - the control volumes in - - AixLib.Fluid.MixingVolumes - implement such a max(·, ·) function. -

        -

        - The zone air temperature, - the water vapor mass fraction per total mass of the air (unless Medium.nXi=0) - and trace substances (unless Medium.nC=0) - can be obtained from the outupt connector - fluPor.backward. - These signals are the same as the inflowing fluid stream(s) - at the port theAdaZon.ports[1:nPorts]. - The fluid connector ports[nPorts] has a prescribed mass flow rate, but - it does not set any pressure. -

        -

        - This model has a user-defined parameter nPorts - which sets the number of fluid ports, which in turn is used - for the ports fluPor and ports. - All nPorts - ports[1:nPorts] need to be connected as demonstrated in the example - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone. -

        -

        - + Δp is the pressure rise, + rN is the normalized fan speed, + is the volume flow rate and + d are performance data for fan or pump power consumption at rN=1.

        - -
          -
        • - January 18, 2019, by Jianjun Hu:
          - Limited the media choice to moist air. - See #1050. -
        • -
        • - September 20, 2016, by Thierry S. Nouidui:
          - Revised documentation to explain the rationale - of needing mass flow rate sensors. -
        • -
        • - June 29, 2016, by Michael Wetter:
          - Revised implementation and documentation. -
        • -
        • - April 27, 2016, by Thierry S. Nouidui:
          - First implementation. -
        • -
        - --------- Corrected Code -------- -

        - Model that is used as a container for a single thermal zone that is - to be exported as an FMU. -

        -

        - Typical use and important parameters -

        -

        - To use this model as a container for an FMU, extend from this model, - rather than instantiate it, add your thermal zone and a vector of - mass flow rate sensors. By extending from this model, the top-level - signal connectors on the left stay at the top-level, and hence will - be visible at the FMI interface. -

        Note that -
          -
        • The vector of mass flow rate sensors is used to connect the - thermal zone adapter and your thermal zone. -
        • -
        • The vector of mass flow rate sensors must have the size - nPorts. -
        • -
        • All fluid ports of the mass flow rate sensor must be connected. -
        • -
        • If the vector of mass flow rate sensors is not used, and your - themal zone has fluid ports which are autosized, then a direct - connection between the thermal zone adpater theZonAda - and your thermal zone will be rejected. The reason is because - autosized fluid ports can only be connected to vector of ports whose - sizes are literal. -
        • -
        -

        - The example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone shows - how a simple thermal zone can be implemented and exported as an FMU. - -

        -

        - The conversion between the fluid ports and signal ports is done in - the thermal zone adapter theZonAda. This adapter has a - vector of fluid ports called ports[nPorts] which needs - to be connected to the air volume of the thermal zone. At this port, - air exchanged between the thermal zone, the HVAC system and any - infiltration flow paths. -

        +

        Implementation

        +

        + The function s(·, ·) is a cubic hermite spline. + If the data d define a monotone decreasing sequence, then + s(·, d) is a monotone decreasing function. +

        +

        + The function allows rN to be zero. +

        + +
          +
        • + September 8, 2016, by Michael Wetter and Filip Jorissen:
          + Changed implementation to allow r_N = 0.
          + This is + for #458. +
        • +
        • + September 7, 2016, by Michael Wetter:
          + Moved function which was a protected function to make it public, as it + is now called by + + AixLib.Fluid.Movers.BaseClasses.FlowMachineInterface. +
        • +
        + +-------- Corrected Code --------

        - This model has input signals fluPor[nPorts], which carry - the mass flow rate for each flow that is connected to - ports, together with its temperature, water vapor mass - fraction per total mass of the air (not per kg dry air), and trace - substances. These quantities are always as if the flow enters the - room, even if the flow is zero or negative. If a medium has no - moisture, e.g., if Medium.nXi=0, or if it has no trace - substances, e.g., if Medium.nC=0, then the output signal - for these properties are removed. Thus, a thermal zone model that - uses these signals to compute the heat added by the HVAC system need - to implement an equation such as + This function computes the fan static pressure raise as a function of + volume flow rate and revolution in the form

        - Qsen = max(0, ṁsup)   cp   - (Tsup - Tair,zon), -

        -

        - where Qsen is the sensible heat flow rate added to - the thermal zone, sup is the supply air mass flow - rate from the port fluPor (which is negative if it is an - exhaust), cp is the specific heat capacity at - constant pressure, Tsup is the supply air - temperature and Tair,zon is the zone air - temperature. Note that without the max(·, ·), the energy - balance would be wrong. For example, - the control volumes in AixLib.Fluid.MixingVolumes - implement such a max(·, ·) function. + Δp = rN2   s(V̇/rN, d),

        - The zone air temperature, the water vapor mass fraction per total - mass of the air (unless Medium.nXi=0) and trace - substances (unless Medium.nC=0) can be obtained from the - outupt connector fluPor.backward. These signals are the - same as the inflowing fluid stream(s) at the port - theAdaZon.ports[1:nPorts]. The fluid connector - ports[nPorts] has a prescribed mass flow rate, but it - does not set any pressure. + where Δp is the pressure rise, rN is the + normalized fan speed, is the volume flow rate and d + are performance data for fan or pump power consumption at + rN=1.

        +

        + Implementation +

        - This model has a user-defined parameter nPorts which - sets the number of fluid ports, which in turn is used for the ports - fluPor and ports. All nPorts - ports[1:nPorts] need to be connected as demonstrated in - the example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone. + The function s(·, ·) is a cubic hermite spline. If the data + d define a monotone decreasing sequence, then s(·, d) + is a monotone decreasing function.

        - + The function allows rN to be zero.

          -
        • January 18, 2019, by Jianjun Hu:
          - Limited the media choice to moist air. See #1050. -
        • -
        • September 20, 2016, by Thierry S. Nouidui:
          - Revised documentation to explain the rationale of needing mass flow - rate sensors. -
        • -
        • June 29, 2016, by Michael Wetter:
          - Revised implementation and documentation. +
        • September 8, 2016, by Michael Wetter and Filip Jorissen:
          + Changed implementation to allow r_N = 0.
          + This is for #458.
        • -
        • April 27, 2016, by Thierry S. Nouidui:
          - First implementation. +
        • September 7, 2016, by Michael Wetter:
          + Moved function which was a protected function to make it public, as + it is now called by AixLib.Fluid.Movers.BaseClasses.FlowMachineInterface.
        -------- Errors -------- -line 72 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Actuators/Valves/Examples/TwoWayValveTable.mo ---- +---- AixLib/Fluid/HeatExchangers/BaseClasses/WetCoilDryWetRegime.mo ---- -------- HTML Code -------- +

          +
        • + Jan 21, 2021, by Donghun Kim:
          First implementation. +
        • +
        +

        - Test model for a two way valve in which a table is used to specify the - opening characteristics. - The valve has the following opening characteristics, which is taken from a test case - of the IEA EBC Annex 60 project. + This model implements the switching algorithm for the dry and wet regime.

        -
        - - - - - -
        y0 0.1667 0.3333 0.5 0.6667 1
        Kv0 0.19 0.35 0.45 0.5 0.65

        - The Kv value is the volume flow rate in m3/h at a pressure difference - of 1 bar. - Hence, the Kv value of the fully open valve is Kv=0.65. -

        + The switching criteria for (counter-flow) cooling coil modes are as follows.

        - Plotting the variables kv.y versus y.y shows that the valve - reproduces the Kv values shown in the above table. + R1: If the coil surface temperature at the air inlet is lower than the dew-point + temperature at the inlet to the coil, then the cooling coil surface is fully-wet.

        +

        + R2: If the surface temperature at the air outlet section is higher than + the dew-point temperature of the air at the inlet, then the cooling coil surface is fully-dry.

        +

        + At each point of a simulation time step, the fuzzy-modeling approach determines + the weights for R1 and R2 respectively (namely μFW and μFD) + from the dew-point and coil surface temperatures.

        +

        + It calculates total and sensible heat transfer rates according to the weights as follows.

        -

        - \"image\" +

        + Q̇totFDtot,FDFW Qtot,FW +

        +

        + Q̇senFDsen,FDFW Qsen,FW

        - The parameter filterOpening is set to false, - as this model is used to plot the flow at different opening signals - without taking into account the travel time of the actuator. + The fuzzy-modeling ensures μFW + μFD = 1, + μFW >=0 and μFD >=0, which means the fuzzy + model outcomes of sen and tot are always convex combinations of heat transfer + rates for fully-dry and fully-wet modes and therefore are always bounded by them. +

        +

        + The modeling approach also results in n-th order differentiable model + depending on the selection of the underlying membership functions. This cooling + coil model is once continuously differentiable at the mode switches.

        - -
          -
        • - August 12, 2014 by Michael Wetter:
          - Added parameter keyword to datVal, - as this is needed to asssign datVal to a parameter - in the instance valTab. - This also avoids an error in OpenModelica. -
        • -
        • - April 2, 2014 by Michael Wetter:
          - First implementation. -
        • -
        -------- Corrected Code -------- +
          +
        • Jan 21, 2021, by Donghun Kim:
          + First implementation. +
        • +

        - Test model for a two way valve in which a table is used to specify - the opening characteristics. The valve has the following opening - characteristics, which is taken from a test case of the IEA EBC Annex - 60 project. + This model implements the switching algorithm for the dry and wet + regime. +

        +

        + The switching criteria for (counter-flow) cooling coil modes are as + follows. +

        +

        + R1: If the coil surface temperature at the air inlet is lower than + the dew-point temperature at the inlet to the coil, then the cooling + coil surface is fully-wet. +

        +

        + R2: If the surface temperature at the air outlet section is higher + than the dew-point temperature of the air at the inlet, then the + cooling coil surface is fully-dry.

        - - - - - - - - - - - - - - - - - - - -
        - y - - 0 - - 0.1667 - - 0.3333 - - 0.5 - - 0.6667 - - 1 -
        - Kv - - 0 - - 0.19 - - 0.35 - - 0.45 - - 0.5 - - 0.65 -

        - The Kv value is the volume flow rate in - m3/h at a pressure difference of 1 bar. Hence, the - Kv value of the fully open valve is - Kv=0.65. + At each point of a simulation time step, the fuzzy-modeling approach + determines the weights for R1 and R2 respectively (namely + μFW and μFD) from the dew-point + and coil surface temperatures.

        - Plotting the variables kv.y versus y.y - shows that the valve reproduces the Kv values shown - in the above table. + It calculates total and sensible heat transfer rates according to the + weights as follows.

        -

        - \"image\" +

        + Q̇totFDtot,FDFW + Qtot,FW +

        +

        + Q̇senFDsen,FDFW + Qsen,FW

        - The parameter filterOpening is set to - false, as this model is used to plot the flow at - different opening signals without taking into account the travel time - of the actuator. + The fuzzy-modeling ensures μFW + μFD = + 1, μFW >=0 and μFD >=0, + which means the fuzzy model outcomes of sen and + tot are always convex combinations of heat + transfer rates for fully-dry and fully-wet modes and therefore are + always bounded by them. +

        +

        + The modeling approach also results in n-th order + differentiable model depending on the selection of the underlying + membership functions. This cooling coil model is once continuously + differentiable at the mode switches.

        -
          -
        • August 12, 2014 by Michael Wetter:
          - Added parameter keyword to datVal, as - this is needed to asssign datVal to a parameter in the - instance valTab. This also avoids an error in - OpenModelica. -
        • -
        • April 2, 2014 by Michael Wetter:
          - First implementation. -
        • -
        -------- Errors -------- -line 8 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 -line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 20 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 23 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/LoadAggregation/Validation/ShiftAggregationCells.mo ---- +---- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/splitFacVal.mo ---- -------- HTML Code -------- -

        - This validation case replicates the load-shifting procedure illustred in the figure below by Cimmino (2014). -

        -

        - \"image\" -

        -

        References

        -

        - Cimmino, M. 2014. Développement et validation expérimentale de facteurs de réponse - thermique pour champs de puits géothermiques, - Ph.D. Thesis, École Polytechnique de Montréal. -

        - -
          -
        • - July 18, 2018, by Alex Laferrière:
          - First implementation. -
        • -
        - +

        Calculates the ratio of the surface areas of a wall to the total wall area, + unless the area is zero. It subtracts the wall area AExt + for first entry in AArray and AWin for + second entry in AArray unless AArray[1] and/or + AArray[2] are not zero. This is done separately for each + orientation. Consequently, the function gives an nRow x nCol + array back as output. Each row stands for one area in + AArray and each column for one orientation in + AExt and AWin. The function is used to + calculate the split factors for + + AixLib.ThermalZones.ReducedOrder.RC.BaseClasses.ThermSplitter.

        + For internal gains, the calculation is: +

        + SplitFaci = AArray[i] + /ATot +

        + whereby ATot is the sum of AArray. To + perform this, + AExt and AWin can just be set to vectors of + zeros with length 1. + For solar radiation through windows, the window and wall area with the same + orientation as the incoming radiation should be subtracted as these areas + cannot be hit by the radiation. This needs to be done separately for each + orientation and for exterior walls and windows only, according to: +

        + SplitFaci,k = (AArray[i] + - AExt[k]) + /(ATot + - AExt[k] + -AWin[k]) +

        + and +

        + SplitFaci,k = (AArray[i] + - AWin[k]) + /(ATot + - AExt[k] + - AWin[k]) +

        + respectively. For all other walls, the equation is: +

        + SplitFaci,k = AArray[i] + /(ATot + - AExt[k] + - AWin[k]) +

        + +
          +
        • December 15, 2015 by Moritz Lauster:
          + First Implementation. +
        • +
        + -------- Corrected Code --------

        - This validation case replicates the load-shifting procedure illustred - in the figure below by Cimmino (2014). -

        -

        - \"image\" -

        -

        - References -

        -

        - Cimmino, M. 2014. Développement et validation expérimentale de - facteurs de réponse thermique pour champs de puits géothermiques, - Ph.D. Thesis, École Polytechnique de Montréal. + Calculates the ratio of the surface areas of a wall to the total wall + area, unless the area is zero. It subtracts the wall area + AExt for first entry in AArray and + AWin for second entry in AArray unless + AArray[1] and/or AArray[2] are not zero. + This is done separately for each orientation. Consequently, the + function gives an nRow x nCol array back as output. Each + row stands for one area in AArray and each column for + one orientation in AExt and AWin. The + function is used to calculate the split factors for AixLib.ThermalZones.ReducedOrder.RC.BaseClasses.ThermSplitter. +

        For internal gains, the calculation is: +

        + SplitFaci = AArray[i] /ATot +

        whereby ATot is the sum of AArray. To +perform this, AExt and AWin can just be set +to vectors of zeros with length 1. For solar radiation through windows, +the window and wall area with the same orientation as the incoming +radiation should be subtracted as these areas cannot be hit by the +radiation. This needs to be done separately for each orientation and +for exterior walls and windows only, according to: +

        + SplitFaci,k = (AArray[i] - AExt[k]) /(ATot - AExt[k] + -AWin[k]) +

        and +

        + SplitFaci,k = (AArray[i] - AWin[k]) /(ATot - AExt[k] - + AWin[k]) +

        respectively. For all other walls, the equation is: +

        + SplitFaci,k = AArray[i] /(ATot - AExt[k] - AWin[k])

          -
        • July 18, 2018, by Alex Laferrière:
          - First implementation. +
        • December 15, 2015 by Moritz Lauster:
          + First Implementation.
        -------- Errors -------- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 15 column 4 - Warning:

        attribute "align" not allowed for HTML5 +line 27 column 4 - Warning:

        attribute "align" not allowed for HTML5 +line 35 column 4 - Warning:

        attribute "align" not allowed for HTML5 +line 43 column 4 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/BaseClasses/PartialEffectivenessNTU.mo ---- +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowAIT.mo ---- -------- HTML Code --------

        - Partial model of a heat exchanger without humidity condensation. - This model transfers heat in the amount of -

        -

        - Q = Qmax ε
        - ε = f(NTU, Z, flowRegime), -

        -

        - where - Qmax is the maximum heat that can be transferred, - ε is the heat transfer effectiveness, - NTU is the Number of Transfer Units, - Z is the ratio of minimum to maximum capacity flow rate and - flowRegime is the heat exchanger flow regime. - such as - parallel flow, cross flow or counter flow. + The example contains + experimental data from a real district heating network.

        -

        - The flow regimes depend on the heat exchanger configuration. All configurations - defined in - - AixLib.Fluid.Types.HeatExchangerConfiguration - are supported. +

        The pipes' temperatures are not initialized. Therefore, results of + outflow temperature before approximately the first 10000 seconds should not be + considered.

        - Models that extend from this partial model need to provide an assignment - for UA. + Note that these three models are identical, except for the pipe model that is used:

        - +

        + This comparison between different discretization levels and pipe models is made + to check the influence of the discretization and pipe model on computation time + and simulation accuracy. +

        +

        Test bench schematic

        +

        \"Schematic +

        +

        Calibration

        +

        To calculate the length specific thermal resistance R of the pipe, + the thermal resistance of the surrounding ground is added, which yields

        +

        + R=1/(0.208)+1/(2   lambda_g   Modelica.Constants.pi)   log(1/0.18),

        +

        where the thermal conductivity of the ground lambda_g = 2.4 W/(m K). +

        + +
        • - February 27, 2016 by Michael Wetter:
          - Introduced sta1_default and sta2_default - to enable translation under OpenModelica. - Removed max=1 attribute for Z. This is needed as near - zero flow, Z can be larger than one due to the regularization. - As Z is not used in this model other than for reporting, this bound - need not be enforced (and the calculation of eps is fine at these small flow rates). + March 7, 2020, by Michael Wetter:
          + Replaced measured data from specification in Modelica file to external table, + as this reduces the computing time.
          This is for - issue 490. -
        • -
        • - April 29, 2014 by Michael Wetter:
          - Changed assert statement to avoid comparing - enumeration with an integer, which triggers a warning - in Dymola 2015. + #1289.
        • - July 30, 2013 by Michael Wetter:
          - Updated model to use new variable mWat_flow - in the base class. + May 15, 2019, by Jianjun Hu:
          + Replaced fluid source. This is for + #1072.
        • -
        • - February 12, 2010, by Michael Wetter:
          - First implementation. +
        • July 4, 2016 by Bram van der Heijde:
          Added parameters to test the + influence of allowFlowReversal and the presence of explicit volumes in the pipe.
        • +
        • January 26, 2016 by Carles Ribas:
          First implementation.
        -------- Corrected Code --------

        - Partial model of a heat exchanger without humidity condensation. This - model transfers heat in the amount of -

        -

        - Q = Qmax ε
        - ε = f(NTU, Z, flowRegime), -

        -

        - where Qmax is the maximum heat that can be - transferred, ε is the heat transfer effectiveness, NTU - is the Number of Transfer Units, Z is the ratio of minimum to - maximum capacity flow rate and flowRegime is the heat - exchanger flow regime. such as parallel flow, cross flow or counter - flow. + The example contains experimental data from a real district heating + network.

        - The flow regimes depend on the heat exchanger configuration. All - configurations defined in AixLib.Fluid.Types.HeatExchangerConfiguration - are supported. + The pipes' temperatures are not initialized. Therefore, results of + outflow temperature before approximately the first 10000 seconds + should not be considered.

        - Models that extend from this partial model need to provide an - assignment for UA. + Note that these three models are identical, except for the pipe model + that is used:

        +

        + This comparison between different discretization levels and pipe + models is made to check the influence of the discretization and pipe + model on computation time and simulation accuracy. +

        +

        + Test bench schematic +

        +

        + \"Schematic +

        +

        + Calibration +

        +

        + To calculate the length specific thermal resistance R of + the pipe, the thermal resistance of the surrounding ground is added, + which yields +

        +

        + R=1/(0.208)+1/(2   lambda_g   Modelica.Constants.pi)   + log(1/0.18), +

        +

        + where the thermal conductivity of the ground lambda_g = + 2.4 W/(m K). +

        +
          +
        • March 7, 2020, by Michael Wetter:
          + Replaced measured data from specification in Modelica file to + external table, as this reduces the computing time.
          This is for issue - 490. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1289\">#1289.
        • -
        • April 29, 2014 by Michael Wetter:
          - Changed assert statement to avoid comparing - enumeration with an integer, which triggers a warning in Dymola - 2015. +
        • May 15, 2019, by Jianjun Hu:
          + Replaced fluid source. This is for #1072.
        • -
        • July 30, 2013 by Michael Wetter:
          - Updated model to use new variable mWat_flow in the - base class. +
        • July 4, 2016 by Bram van der Heijde:
          + Added parameters to test the influence of allowFlowReversal and the + presence of explicit volumes in the pipe.
        • -
        • February 12, 2010, by Michael Wetter:
          +
        • January 26, 2016 by Carles Ribas:
          First implementation.
        -------- Errors -------- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 48 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD600.mo ---- +---- AixLib/Fluid/FMI/ExportContainers/ThermalZone.mo ---- -------- HTML Code -------- +

        + Model that is used as a container for a single thermal zone + that is to be exported as an FMU. +

        +

        Typical use and important parameters

        +

        + To use this model as a container for an FMU, extend + from this model, rather than instantiate it, + add your thermal zone and a vector of mass flow rate sensors. + By extending from this model, the top-level + signal connectors on the left stay at the top-level, and hence + will be visible at the FMI interface. +

        + + Note that +
          +
        • + The vector of mass flow rate sensors is used to connect + the thermal zone adapter and your thermal zone. +
        • +
        • + The vector of mass flow rate sensors must have the size nPorts. +
        • +
        • + All fluid ports of the mass flow rate sensor must be connected. +
        • +
        • + If the vector of mass flow rate sensors is not used, and your themal zone + has fluid ports which are autosized, then a direct connection between + the thermal zone adpater theZonAda and your thermal + zone will be rejected. The reason is because autosized fluid ports + can only be connected to vector of ports whose sizes are literal. +
        • +
        + +

        + The example + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone + shows how a simple thermal zone can be implemented and exported as + an FMU. + +

        + +

        + The conversion between the fluid ports and signal ports is done + in the thermal zone adapter theZonAda. + This adapter has a vector of fluid ports called ports[nPorts] + which needs to be connected to the air volume of the thermal zone. + At this port, air exchanged between the thermal zone, the HVAC system + and any infiltration flow paths. +

        +

        + This model has input signals fluPor[nPorts], which carry + the mass flow rate for each flow that is connected to ports, together with its + temperature, water vapor mass fraction per total mass of the air (not per kg dry + air), and trace substances. These quantities are always as if the flow + enters the room, even if the flow is zero or negative. + If a medium has no moisture, e.g., if Medium.nXi=0, or + if it has no trace substances, e.g., if Medium.nC=0, then + the output signal for these properties are removed. + Thus, a thermal zone model that uses these signals to compute the + heat added by the HVAC system need to implement an equation such as +

        +

        + Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), +

        +

        + where + Qsen is the sensible heat flow rate added to the thermal zone, + sup is the supply air mass flow rate from + the port fluPor (which is negative if it is an exhaust), + cp is the specific heat capacity at constant pressure, + Tsup is the supply air temperature and + Tair,zon is the zone air temperature. + Note that without the max(·, ·), the energy + balance would be wrong. + For example, + + the control volumes in + + AixLib.Fluid.MixingVolumes + implement such a max(·, ·) function. +

        +

        + The zone air temperature, + the water vapor mass fraction per total mass of the air (unless Medium.nXi=0) + and trace substances (unless Medium.nC=0) + can be obtained from the outupt connector + fluPor.backward. + These signals are the same as the inflowing fluid stream(s) + at the port theAdaZon.ports[1:nPorts]. + The fluid connector ports[nPorts] has a prescribed mass flow rate, but + it does not set any pressure. +

        +

        + This model has a user-defined parameter nPorts + which sets the number of fluid ports, which in turn is used + for the ports fluPor and ports. + All nPorts + ports[1:nPorts] need to be connected as demonstrated in the example + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone. +

        +

        + +

        +
        • - September 6, 2021, by Ettore Zanetti:
          - Removed parameter lat as it is now obtained from the weather data bus.
          - This is for - IBPSA, #1477. + January 18, 2019, by Jianjun Hu:
          + Limited the media choice to moist air. + See #1050.
        • - March 11, 2020, by Ettore Zanetti:
          - First implementation. + September 20, 2016, by Thierry S. Nouidui:
          + Revised documentation to explain the rationale + of needing mass flow rate sensors.
        • - April 14, 2020, by Ettore Zanetti:
          - Rework after comments from pull request - #1339. + June 29, 2016, by Michael Wetter:
          + Revised implementation and documentation. +
        • +
        • + April 27, 2016, by Thierry S. Nouidui:
          + First implementation.
        -

        WD600: Ground Reflactance

        -

        Weather data file : WD600.epw

        -

        Table 1: Site Data for Weather file WD600.epw

        -
        - - - - - - - - - - - - - - - -

        Latitude

        39.833° north

        Longitude

        104.65° west

        Altitude

        1650 m

        Time Zone

        -7

        - -------- Corrected Code -------- +

        + Model that is used as a container for a single thermal zone that is + to be exported as an FMU. +

        +

        + Typical use and important parameters +

        +

        + To use this model as a container for an FMU, extend from this model, + rather than instantiate it, add your thermal zone and a vector of + mass flow rate sensors. By extending from this model, the top-level + signal connectors on the left stay at the top-level, and hence will + be visible at the FMI interface. +

        Note that
          -
        • September 6, 2021, by Ettore Zanetti:
          - Removed parameter lat as it is now obtained from the - weather data bus.
          - This is for IBPSA, - #1477. +
        • The vector of mass flow rate sensors is used to connect the + thermal zone adapter and your thermal zone.
        • -
        • March 11, 2020, by Ettore Zanetti:
          - First implementation. +
        • The vector of mass flow rate sensors must have the size + nPorts.
        • -
        • April 14, 2020, by Ettore Zanetti:
          - Rework after comments from pull request #1339. +
        • All fluid ports of the mass flow rate sensor must be connected. +
        • +
        • If the vector of mass flow rate sensors is not used, and your + themal zone has fluid ports which are autosized, then a direct + connection between the thermal zone adpater theZonAda + and your thermal zone will be rejected. The reason is because + autosized fluid ports can only be connected to vector of ports whose + sizes are literal.
        -

        - WD600: Ground Reflactance -

        - Weather data file : WD600.epw + The example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone shows + how a simple thermal zone can be implemented and exported as an FMU. +

        - Table 1: Site Data for Weather file WD600.epw + The conversion between the fluid ports and signal ports is done in + the thermal zone adapter theZonAda. This adapter has a + vector of fluid ports called ports[nPorts] which needs + to be connected to the air volume of the thermal zone. At this port, + air exchanged between the thermal zone, the HVAC system and any + infiltration flow paths.

        - - - - - - - - - - - - - - - - - -
        -

        - Latitude -

        -
        -

        - 39.833° north -

        -
        -

        - Longitude -

        -
        -

        - 104.65° west -

        -
        -

        - Altitude -

        -
        -

        - 1650 m -

        -
        -

        - Time Zone -

        -
        -

        - -7 -

        -
        +

        + This model has input signals fluPor[nPorts], which carry + the mass flow rate for each flow that is connected to + ports, together with its temperature, water vapor mass + fraction per total mass of the air (not per kg dry air), and trace + substances. These quantities are always as if the flow enters the + room, even if the flow is zero or negative. If a medium has no + moisture, e.g., if Medium.nXi=0, or if it has no trace + substances, e.g., if Medium.nC=0, then the output signal + for these properties are removed. Thus, a thermal zone model that + uses these signals to compute the heat added by the HVAC system need + to implement an equation such as +

        +

        + Qsen = max(0, ṁsup)   cp   + (Tsup - Tair,zon), +

        +

        + where Qsen is the sensible heat flow rate added to + the thermal zone, sup is the supply air mass flow + rate from the port fluPor (which is negative if it is an + exhaust), cp is the specific heat capacity at + constant pressure, Tsup is the supply air + temperature and Tair,zon is the zone air + temperature. Note that without the max(·, ·), the energy + balance would be wrong. For example, + the control volumes in AixLib.Fluid.MixingVolumes + implement such a max(·, ·) function. +

        +

        + The zone air temperature, the water vapor mass fraction per total + mass of the air (unless Medium.nXi=0) and trace + substances (unless Medium.nC=0) can be obtained from the + outupt connector fluPor.backward. These signals are the + same as the inflowing fluid stream(s) at the port + theAdaZon.ports[1:nPorts]. The fluid connector + ports[nPorts] has a prescribed mass flow rate, but it + does not set any pressure. +

        +

        + This model has a user-defined parameter nPorts which + sets the number of fluid ports, which in turn is used for the ports + fluPor and ports. All nPorts + ports[1:nPorts] need to be connected as demonstrated in + the example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone. +

        +

        + +

        +
          +
        • January 18, 2019, by Jianjun Hu:
          + Limited the media choice to moist air. See #1050. +
        • +
        • September 20, 2016, by Thierry S. Nouidui:
          + Revised documentation to explain the rationale of needing mass flow + rate sensors. +
        • +
        • June 29, 2016, by Michael Wetter:
          + Revised implementation and documentation. +
        • +
        • April 27, 2016, by Thierry S. Nouidui:
          + First implementation. +
        • +
        -------- Errors -------- -line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 72 column 2 - Warning:

        attribute "align" not allowed for HTML5 diff --git a/docs/ci_updates/syntax/HTML_error_log.txt b/docs/ci_updates/syntax/HTML_error_log.txt index 2a08ac2684..166df054ec 100644 --- a/docs/ci_updates/syntax/HTML_error_log.txt +++ b/docs/ci_updates/syntax/HTML_error_log.txt @@ -1,62 +1,67 @@ ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/GroundTemperatureResponse.mo ---- -line 22 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 37 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 46 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 58 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 73 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 101 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 117 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 120 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 129 column 2 - Warning:

        attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource_Erfint.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FMI/UsersGuide.mo ---- +line 18 column 1 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD500.mo ---- -line 5 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/infiniteLineSource.mo ---- +line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 21 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Types.mo ---- -line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT.mo ---- +line 56 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/BoundaryConditions/Validation/BESTEST/WD500.mo ---- +line 5 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 13 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 +---- AixLib/Fluid/HeatPumps/Compressors/ReciprocatingCompressor.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/Data/Pumps/Wilo/Stratos25slash1to6.mo ---- -line 27 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Interfaces/PrescribedOutlet.mo ---- +line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/FourElements.mo ---- -line 15 column 4 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Chillers/BaseClasses/Carnot.mo ---- +line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 30 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 39 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/Validation/PowerExact.mo ---- -line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/InteriorWall.mo ---- +line 13 column 4 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/splitFacVal.mo ---- -line 15 column 4 - Warning:

        attribute "align" not allowed for HTML5 -line 27 column 4 - Warning:

        attribute "align" not allowed for HTML5 -line 35 column 4 - Warning:

        attribute "align" not allowed for HTML5 -line 43 column 4 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Movers/UsersGuide.mo ---- +line 38 column 1 - Warning: The summary attribute on the

        element is obsolete in HTML5 +line 126 column 3 - Warning: The summary attribute on the
        element is obsolete in HTML5 +line 205 column 3 - Warning: The summary attribute on the
        element is obsolete in HTML5 +line 254 column 3 - Warning: The summary attribute on the
        element is obsolete in HTML5 +line 15 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 158 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 380 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 425 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 435 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 444 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 448 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 465 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 473 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 484 column 1 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Media/Water.mo ---- -line 17 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/BoundaryConditions/Validation/BESTEST/WD400.mo ---- +line 5 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/SensibleCooler_T.mo ---- +line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Humidifiers/SteamHumidifier_X.mo ---- -line 33 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/Math/Polynomial.mo ---- +line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 ---- AixLib/Fluid/HeatPumps/Carnot_TCon.mo ---- @@ -65,69 +70,72 @@ line 25 column 2 - Warning:

        attribute "align" not allowed for HTML5 line 35 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/timeGeometric.mo ---- -line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Chillers/Carnot_y.mo ---- +line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 34 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_m_flow.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/Math/Functions/bicubic.mo ---- +line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sensors/SensibleEnthalpyFlowRate.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FixedResistances/CheckValve.mo ---- +line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Actuators/BaseClasses/exponentialDamper.mo ---- -line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/ActiveBeams/Data/BaseClasses/TemperatureDifference.mo ---- +line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowHeatLoss.mo ---- -line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FixedResistances/Junction.mo ---- +line 23 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/QuadraticLinear.mo ---- -line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT2Nodes.mo ---- +line 51 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/UsersGuide.mo ---- -line 38 column 1 - Warning: The summary attribute on the

        element is obsolete in HTML5 -line 126 column 3 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 205 column 3 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 254 column 3 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 15 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 158 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 380 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 425 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 435 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 444 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 448 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 465 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 473 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 484 column 1 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Movers/Data/Pumps/Wilo/Stratos25slash1to6.mo ---- +line 27 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowAIT.mo ---- -line 48 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Controls/SetPoints/Examples/OccupancySchedule.mo ---- +line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 + + +---- AixLib/Media/Air.mo ---- +line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 + + +line 7 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/BaseClasses/Characteristics/power.mo ---- line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/gFunction.mo ---- -line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 49 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 21 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 37 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/InteriorWall.mo ---- -line 13 column 4 - Warning:

        attribute "align" not allowed for HTML5 +line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 19 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 43 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 54 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 60 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Controls/Continuous/Examples/OffTimer.mo ---- -line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FixedResistances/HydraulicDiameter.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 104 column 2 - Warning:

        attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/cylindricalHeatSource.mo ---- +line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 23 column 2 - Warning:

        attribute "align" not allowed for HTML5 ---- AixLib/Fluid/Sources/Outside_CpLowRise.mo ---- @@ -135,466 +143,458 @@ line 28 column 2 - Warning:

        attribute "align" not allowed for HTML5 line 61 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD200.mo ---- -line 5 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Fluid/Storage/UsersGuide.mo ---- +line 6 column 1 - Warning: The summary attribute on the
        element is obsolete in HTML5 +line 17 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 129 column 1 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/ThreeElements.mo ---- -line 16 column 4 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/GroundTemperatureResponse.mo ---- +line 22 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 37 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 46 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 58 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 73 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 101 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 117 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 120 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 129 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/Validation/PowerSimplified.mo ---- -line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatPumps/Carnot_y.mo ---- +line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 34 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT.mo ---- -line 56 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FMI/ExportContainers/ThermalZones.mo ---- +line 78 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/Radiators/RadiatorEN442_2.mo ---- -line 26 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/DryCoilEffectivenessNTU.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/ExteriorWall.mo ---- -line 14 column 4 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Geothermal/Borefields/UsersGuide.mo ---- +line 56 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 179 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 188 column 1 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/Biquadratic.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/ConstantEffectiveness.mo ---- +line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/BaseClasses/WetCoilWetRegime.mo ---- -line 20 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 36 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 48 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 54 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/IO/SignalExchange/SignalTypes/SignalsForKPIs.mo ---- +line 9 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Utilities/Math/Functions/bicubic.mo ---- -line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/gFunction.mo ---- +line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 49 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/BaseClasses/Characteristics/efficiency.mo ---- +---- AixLib/Fluid/Sensors/SensibleEnthalpyFlowRate.mo ---- line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Chillers/Carnot_y.mo ---- -line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 34 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/BoundaryConditions/Validation/BESTEST/WD600.mo ---- +line 5 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Fluid/Storage/UsersGuide.mo ---- -line 6 column 1 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 17 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 129 column 1 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FMI/Adaptors/HVAC.mo ---- +line 26 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/TwoElements.mo ---- -line 14 column 4 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Controls/Continuous/Examples/SignalRanker.mo ---- +line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/UsersGuide.mo ---- -line 18 column 1 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlow.mo ---- +line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Controls/SetPoints/Examples/OccupancySchedule.mo ---- -line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Controls/Continuous/Examples/NumberOfRequests.mo ---- +line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatPumps/ReciprocatingWaterToWater.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/ActiveBeams/UsersGuide.mo ---- +line 7 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 59 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 72 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 87 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 115 column 1 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD100.mo ---- -line 5 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Fluid/Actuators/BaseClasses/PartialDamperExponential.mo ---- +line 50 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 ----- AixLib/Media/Antifreeze/PropyleneGlycolWater.mo ---- -line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Controls/Continuous/NumberOfRequests.mo ---- +line 7 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 -line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 35 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Humidifiers/SteamHumidifier_X.mo ---- +line 33 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/Cylindrical.mo ---- -line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/BoundaryConditions/Validation/UsersGuide.mo ---- +line 14 column 1 - Warning: The summary attribute on the

        element is obsolete in HTML5 +line 98 column 1 - Warning: The summary attribute on the
        element is obsolete in HTML5 ----- AixLib/Fluid/HeatExchangers/PrescribedOutlet.mo ---- -line 34 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/Radiators/RadiatorEN442_2.mo ---- +line 26 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/Functions/quadraticLinear.mo ---- -line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Sources/Outside_CpData.mo ---- +line 51 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +line 63 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 +line 14 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 43 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/BaseClasses/HANaturalCylinder.mo ---- -line 11 column 14 - Warning:

        attribute "align" not allowed for HTML5 -line 24 column 14 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatPumps/Compressors/ScrollCompressor.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/UsersGuide.mo ---- -line 14 column 1 - Warning: The summary attribute on the

        element is obsolete in HTML5 -line 98 column 1 - Warning: The summary attribute on the
        element is obsolete in HTML5 +---- AixLib/Fluid/HeatExchangers/PrescribedOutlet.mo ---- +line 34 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/ActiveBeams/Data/BaseClasses/TemperatureDifference.mo ---- -line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/LoadAggregation/Validation/ShiftAggregationCells.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/Types.mo ---- -line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Utilities/Math/Functions/biquadratic.mo ---- +line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Chillers/BaseClasses/Carnot.mo ---- -line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 30 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 39 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Media/Antifreeze/EthyleneGlycolWater.mo ---- +line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/PressureDrop.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 37 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 90 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 35 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_dp.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Humidifiers/SprayAirWasher_X.mo ---- +line 33 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Humidifiers/Humidifier_u.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/timeGeometric.mo ---- line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Media/Specialized/Air/PerfectGas.mo ---- +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowULg.mo ---- line 25 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 27 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/BaseClasses/Characteristics/pressure.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/Cylindrical.mo ---- +line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/WeatherData/ReaderTMY3.mo ---- -line 24 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 -line 425 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 469 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 640 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Sensors/UsersGuide.mo ---- +line 32 column 1 - Warning: The summary attribute on the

        element is obsolete in HTML5 +line 105 column 1 - Warning: The summary attribute on the
        element is obsolete in HTML5 +line 33 column 5 - Warning:
        attribute "align" not allowed for HTML5 +line 38 column 5 - Warning: attribute "align" not allowed for HTML5 +line 144 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 167 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 197 column 1 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/ExportContainers/HVACZones.mo ---- -line 60 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/Math/Biquadratic.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowULg.mo ---- -line 25 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 27 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Actuators/Valves/TwoWayTable.mo ---- +line 14 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Controls/Continuous/NumberOfRequests.mo ---- -line 7 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 +---- AixLib/BoundaryConditions/Validation/BESTEST/WD300.mo ---- +line 5 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 ----- AixLib/Fluid/FixedResistances/Junction.mo ---- -line 23 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/Math/Functions/quadraticLinear.mo ---- +line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/UsersGuide.mo ---- -line 60 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 61 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 62 column 1 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FixedResistances/PressureDrop.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 37 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 90 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/Functions/polynomial.mo ---- -line 4 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/ThermalZones/ReducedOrder/RC/FourElements.mo ---- +line 15 column 4 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/infiniteLineSource.mo ---- -line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 21 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/BoundaryConditions/WeatherData/ReaderTMY3.mo ---- +line 24 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +line 425 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 +line 469 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 +line 640 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatPumps/Compressors/ReciprocatingCompressor.mo ---- +---- AixLib/Fluid/Movers/Validation/PowerExact.mo ---- +line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/HeatExchangers/ActiveBeams/BaseClasses/Convector.mo ---- line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Actuators/Valves/TwoWayTable.mo ---- -line 14 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Fluid/Chillers/Carnot_TEva.mo ---- +line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 39 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/ActiveBeams/UsersGuide.mo ---- -line 7 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 59 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 72 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 87 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 115 column 1 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/ThermalZones/ReducedOrder/RC/OneElement.mo ---- +line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Controls/Continuous/LimPID.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/ThermalZones/ReducedOrder/RC/TwoElements.mo ---- +line 14 column 4 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Media/Antifreeze/EthyleneGlycolWater.mo ---- -line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatPumps/ScrollWaterToWater.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 35 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/BoundaryConditions/Validation/BESTEST/WD100.mo ---- +line 5 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Fluid/FMI/ExportContainers/ThermalZones.mo ---- -line 78 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Media/Specialized/Air/PerfectGas.mo ---- +line 25 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/EvaporatorCondenser.mo ---- -line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_dp.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/Functions/Examples/CubicHermite.mo ---- -line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/ExteriorWall.mo ---- +line 14 column 4 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD400.mo ---- -line 5 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/BoundaryConditions/UsersGuide.mo ---- +line 60 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 61 column 1 - Warning:

        attribute "align" not allowed for HTML5 +line 62 column 1 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Controls/Continuous/Examples/SignalRanker.mo ---- -line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Actuators/Valves/Examples/TwoWayValveTable.mo ---- +line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/OneElement.mo ---- -line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Actuators/BaseClasses/exponentialDamper.mo ---- +line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource.mo ---- -line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 25 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/Math/QuadraticLinear.mo ---- +line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Interfaces/PrescribedOutlet.mo ---- -line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/BaseClasses/PartialEffectivenessNTU.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlow.mo ---- -line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/BaseClasses/HANaturalCylinder.mo ---- +line 11 column 14 - Warning:

        attribute "align" not allowed for HTML5 +line 24 column 14 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Actuators/Valves/ThreeWayTable.mo ---- -line 21 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource_Erfint.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/BaseClasses/WetCoilDryWetRegime.mo ---- -line 20 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 23 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatPumps/ReciprocatingWaterToWater.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD300.mo ---- +---- AixLib/BoundaryConditions/Validation/BESTEST/WD200.mo ---- line 5 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Utilities/Math/Polynomial.mo ---- -line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 - - ---- AixLib/Fluid/FMI/ExportContainers/HVACZone.mo ---- line 47 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Utilities/IO/SignalExchange/SignalTypes/SignalsForKPIs.mo ---- -line 9 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Controls/Discrete/BooleanDelay.mo ---- +line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sources/Outside_CpData.mo ---- -line 51 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 -line 63 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 14 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 43 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/ThermalZones/ReducedOrder/RC/ThreeElements.mo ---- +line 16 column 4 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/Heater_T.mo ---- -line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Media/Antifreeze/PropyleneGlycolWater.mo ---- +line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/SensibleCooler_T.mo ---- -line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 35 column 2 - Warning:

        attribute "align" not allowed for HTML5 ---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/Boreholes/BaseClasses/Functions/convectionResistanceCircularPipe.mo ---- line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/cylindricalHeatSource.mo ---- -line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 23 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Controls/Continuous/LimPID.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Controls/Continuous/Examples/NumberOfRequests.mo ---- +---- AixLib/Fluid/HeatExchangers/Heater_T.mo ---- +line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 + + +---- AixLib/Controls/Continuous/Examples/OffTimer.mo ---- line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowTransportDelay.mo ---- -line 7 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Humidifiers/Humidifier_u.mo ---- +line 9 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Media/Specialized/Water/TemperatureDependentDensity.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Movers/BaseClasses/Characteristics/power.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 7 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/Math/Functions/Examples/CubicHermite.mo ---- +line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 31 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 42 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 49 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 62 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Movers/BaseClasses/Characteristics/efficiency.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sensors/UsersGuide.mo ---- -line 32 column 1 - Warning: The summary attribute on the

        element is obsolete in HTML5 -line 105 column 1 - Warning: The summary attribute on the
        element is obsolete in HTML5 -line 33 column 5 - Warning:
        attribute "align" not allowed for HTML5 -line 38 column 5 - Warning: attribute "align" not allowed for HTML5 -line 144 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 167 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 197 column 1 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Media/Water.mo ---- +line 17 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Utilities/Math/Bicubic.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Controls/Discrete/BooleanDelay.mo ---- -line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/Math/Functions/polynomial.mo ---- +line 4 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/Adaptors/HVAC.mo ---- -line 26 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FMI/ExportContainers/HVACZones.mo ---- +line 60 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Controls/SetPoints/Examples/SupplyReturnTemperatureReset.mo ---- -line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Geothermal/Borefields/Types.mo ---- +line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Utilities/Math/Functions/biquadratic.mo ---- -line 3 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowTransportDelay.mo ---- +line 7 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatPumps/Compressors/ScrollCompressor.mo ---- +---- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_m_flow.mo ---- line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Humidifiers/SprayAirWasher_X.mo ---- -line 33 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Actuators/Valves/ThreeWayTable.mo ---- +line 21 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Fluid/Geothermal/Borefields/UsersGuide.mo ---- -line 56 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 179 column 1 - Warning:

        attribute "align" not allowed for HTML5 -line 188 column 1 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Sensors/LatentEnthalpyFlowRate.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/ActiveBeams/BaseClasses/Convector.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/BaseClasses/WetCoilWetRegime.mo ---- +line 20 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 36 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 48 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 54 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/CheckValve.mo ---- +---- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowHeatLoss.mo ---- line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Media/Air.mo ---- -line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 - - -line 7 column 2 - Warning:

        attribute "align" not allowed for HTML5 - - -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource.mo ---- +line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 25 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 21 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Movers/Validation/PowerSimplified.mo ---- line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 37 column 2 - Warning:

        attribute "align" not allowed for HTML5 - - -line 11 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 19 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 43 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 54 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 60 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/HydraulicDiameter.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 104 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/EvaporatorCondenser.mo ---- +line 10 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sensors/LatentEnthalpyFlowRate.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Controls/SetPoints/Examples/SupplyReturnTemperatureReset.mo ---- +line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Chillers/Carnot_TEva.mo ---- -line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 29 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 39 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Utilities/Math/Bicubic.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/DryCoilEffectivenessNTU.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Types.mo ---- +line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Fluid/HeatPumps/ScrollWaterToWater.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 12 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 18 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Fluid/HeatPumps/Carnot_y.mo ---- -line 16 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 -line 34 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 13 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 ----- AixLib/Fluid/Actuators/BaseClasses/PartialDamperExponential.mo ---- -line 50 column 2 - Warning: The summary attribute on the
        element is obsolete in HTML5 +---- AixLib/Media/Specialized/Water/TemperatureDependentDensity.mo ---- +line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/ConstantEffectiveness.mo ---- -line 8 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 7 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT2Nodes.mo ---- -line 51 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 17 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 31 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 42 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 49 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 62 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/ExportContainers/ThermalZone.mo ---- -line 72 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Movers/BaseClasses/Characteristics/pressure.mo ---- +line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Actuators/Valves/Examples/TwoWayValveTable.mo ---- -line 8 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 -line 24 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/HeatExchangers/BaseClasses/WetCoilDryWetRegime.mo ---- +line 20 column 2 - Warning:

        attribute "align" not allowed for HTML5 +line 23 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/LoadAggregation/Validation/ShiftAggregationCells.mo ---- -line 5 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/splitFacVal.mo ---- +line 15 column 4 - Warning:

        attribute "align" not allowed for HTML5 +line 27 column 4 - Warning:

        attribute "align" not allowed for HTML5 +line 35 column 4 - Warning:

        attribute "align" not allowed for HTML5 +line 43 column 4 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/BaseClasses/PartialEffectivenessNTU.mo ---- -line 6 column 2 - Warning:

        attribute "align" not allowed for HTML5 +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowAIT.mo ---- +line 48 column 2 - Warning:

        attribute "align" not allowed for HTML5 ----- AixLib/BoundaryConditions/Validation/BESTEST/WD600.mo ---- -line 5 column 2 - Warning: The summary attribute on the

        element is obsolete in HTML5 +---- AixLib/Fluid/FMI/ExportContainers/ThermalZone.mo ---- +line 72 column 2 - Warning:

        attribute "align" not allowed for HTML5