diff --git a/docs/ci_updates/Dymola_check/AixLib.ThermalZones/AixLib.ThermalZones-check_log.txt b/docs/ci_updates/Dymola_check/AixLib.ThermalZones/AixLib.ThermalZones-check_log.txt new file mode 100644 index 0000000000..357fd50bdd --- /dev/null +++ b/docs/ci_updates/Dymola_check/AixLib.ThermalZones/AixLib.ThermalZones-check_log.txt @@ -0,0 +1,19 @@ + +Error in model: AixLib.ThermalZones.HighOrder.Validation.EmpiricalValidation.Warehouse +Check of AixLib.ThermalZones.HighOrder.Validation.EmpiricalValidation.Warehouse: +Error: The following parameters don't have any value: + room.absInnerWallSurf + room.coeffTableSolDistrFractions.coeffCeiling + room.coeffTableSolDistrFractions.coeffFloor + room.coeffTableSolDistrFractions.coeffOWEast + room.coeffTableSolDistrFractions.coeffOWNorth + room.coeffTableSolDistrFractions.coeffOWSouth + room.coeffTableSolDistrFractions.coeffOWWest + room.coeffTableSolDistrFractions.coeffWinAbs + room.coeffTableSolDistrFractions.coeffWinLost + +The model has the same number of unknowns and equations: 1161 +The model has the same number of unknowns and equations +for the given numerical settings of parameters: 1161 +Error: ERRORS have been issued. + diff --git a/docs/ci_updates/Dymola_check/AixLib.ThermalZones/AixLib.ThermalZones-error_log.txt b/docs/ci_updates/Dymola_check/AixLib.ThermalZones/AixLib.ThermalZones-error_log.txt new file mode 100644 index 0000000000..357fd50bdd --- /dev/null +++ b/docs/ci_updates/Dymola_check/AixLib.ThermalZones/AixLib.ThermalZones-error_log.txt @@ -0,0 +1,19 @@ + +Error in model: AixLib.ThermalZones.HighOrder.Validation.EmpiricalValidation.Warehouse +Check of AixLib.ThermalZones.HighOrder.Validation.EmpiricalValidation.Warehouse: +Error: The following parameters don't have any value: + room.absInnerWallSurf + room.coeffTableSolDistrFractions.coeffCeiling + room.coeffTableSolDistrFractions.coeffFloor + room.coeffTableSolDistrFractions.coeffOWEast + room.coeffTableSolDistrFractions.coeffOWNorth + room.coeffTableSolDistrFractions.coeffOWSouth + room.coeffTableSolDistrFractions.coeffOWWest + room.coeffTableSolDistrFractions.coeffWinAbs + room.coeffTableSolDistrFractions.coeffWinLost + +The model has the same number of unknowns and equations: 1161 +The model has the same number of unknowns and equations +for the given numerical settings of parameters: 1161 +Error: ERRORS have been issued. + diff --git a/docs/ci_updates/naming_violations.txt b/docs/ci_updates/naming_violations.txt new file mode 100644 index 0000000000..f6ae4a82a7 --- /dev/null +++ b/docs/ci_updates/naming_violations.txt @@ -0,0 +1,55 @@ + + + +AixLib/ThermalZones/HighOrder/Rooms/BaseClasses/PartialRoomFourWalls.mo +1: Name 'room_height' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: room_height. Affected line: parameter Modelica.Units.SI.Height room_height=2.7 "height" annotation (Dialog(group="Dimensions", descriptionLabel=true)); + +2: Name 'room_width' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: room_width. Affected line: parameter Modelica.Units.SI.Length room_width=8 "width" annotation (Dialog(group="Dimensions", descriptionLabel=true)); + +3: Name 'Win_Area' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: Win_, Area. Affected line: parameter Modelica.Units.SI.Area Win_Area=12 "Window area " annotation ( Dialog( group="Windows", descriptionLabel=true)); + +4: Name 'use_shortWaveRadIn' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: use_short, Wave, In. Affected line: parameter Boolean use_shortWaveRadIn=true "Use bus connector for incoming shortwave radiation" annotation (Dialog(tab="Inner walls", group="Shortwave Radiation")); + +5: Name 'use_shortWaveRadOut' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: use_short, Wave. Affected line: parameter Boolean use_shortWaveRadOut=true "Use bus connector for outgoing shortwave radiation" annotation (Dialog(tab="Inner walls", group="Shortwave Radiation", enable=use_shortWaveRadIn)); + +6: Name 'use_dynamicShortWaveRadMethod' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: use_dynamic, Short, Wave, Method. Affected line: parameter Boolean use_dynamicShortWaveRadMethod=false "True = dynamic as holistic approach, false = static approach to obtain the same values as provided in tables of the ASHREA" annotation (Dialog(tab="Inner walls", group="Shortwave Radiation", enable= use_shortWaveRadIn)); + +7: Could not extract name from line and check correctness, is your type specification correct (full library path)?. Affected line: parameter Components.Types.selectorCoefficients absInnerWallSurf "Coefficients for interior solar absorptance of wall surface abs={0.6, 0.9, 0.1}" annotation (Dialog(tab="Inner walls", group="Shortwave Radiation", enable= use_shortWaveRadIn and not use_dynamicShortWaveRadMethod));replaceable parameter ThermalZones.HighOrder.Components.Types.PartialCoeffTable coeffTableSolDistrFractions constrainedby AixLib.ThermalZones.HighOrder.Components.Types.PartialCoeffTable(final abs=absInnerWallSurf) "Record holding the values to reproduce the tables" annotation (choicesAllMatching=true, Dialog(tab="Inner walls", group="Shortwave Radiation", enable= use_shortWaveRadIn and not use_dynamicShortWaveRadMethod), Placement(transformation(extent={{78,78},{98,98}})));AixLib.ThermalZones.HighOrder.Components.Walls.Wall wallSouth( use_shortWaveRadIn=use_shortWaveRadIn, use_shortWaveRadOut=use_shortWaveRadOut, energyDynamics=energyDynamicsWalls, radLongCalcMethod=radLongCalcMethod, T_ref=T_ref, calcMethodIn=calcMethodIn, WindowType=Type_Win, redeclare model WindowModel = WindowModel, redeclare model CorrSolarGainWin = CorrSolarGainWin, T0=TWalls_start, wall_length=room_width, solar_absorptance=solar_absorptance_OW, calcMethodOut=calcMethodOut, withSunblind=use_sunblind, Blinding=1 - ratioSunblind, LimitSolIrr=solIrrThreshold, TOutAirLimit=TOutAirLimit, wall_height=room_height, surfaceType=AixLib.DataBase.Surfaces.RoughnessForHT.Brick_RoughPlaster()) annotation (Placement(transformation( extent={{-5,-35},{5,35}}, rotation=90, origin={18,-68})));AixLib.ThermalZones.HighOrder.Components.Walls.Wall wallWest( use_shortWaveRadIn=use_shortWaveRadIn, use_shortWaveRadOut=use_shortWaveRadOut, energyDynamics=energyDynamicsWalls, radLongCalcMethod=radLongCalcMethod, T_ref=T_ref, calcMethodIn=calcMethodIn, wall_length=room_length, wall_height=room_height, WindowType=Type_Win, redeclare model WindowModel = WindowModel, redeclare model CorrSolarGainWin = CorrSolarGainWin, T0=TWalls_start, withSunblind=use_sunblind, Blinding=1 - ratioSunblind, LimitSolIrr=solIrrThreshold, TOutAirLimit=TOutAirLimit, solar_absorptance=solar_absorptance_OW, surfaceType=DataBase.Surfaces.RoughnessForHT.Brick_RoughPlaster(), calcMethodOut=calcMethodOut) annotation (Placement(transformation( extent={{-5,-27},{5,27}}, rotation=0, origin={-83,13})));AixLib.ThermalZones.HighOrder.Components.Walls.Wall wallEast( use_shortWaveRadIn=use_shortWaveRadIn, use_shortWaveRadOut=use_shortWaveRadOut, energyDynamics=energyDynamicsWalls, radLongCalcMethod=radLongCalcMethod, T_ref=T_ref, calcMethodIn=calcMethodIn, wall_length=room_length, wall_height=room_height, WindowType=Type_Win, redeclare model WindowModel = WindowModel, redeclare model CorrSolarGainWin = CorrSolarGainWin, T0=TWalls_start, withSunblind=use_sunblind, Blinding=1 - ratioSunblind, LimitSolIrr=solIrrThreshold, TOutAirLimit=TOutAirLimit, solar_absorptance=solar_absorptance_OW, surfaceType=DataBase.Surfaces.RoughnessForHT.Brick_RoughPlaster(), calcMethodOut=calcMethodOut) annotation (Placement(transformation( extent={{-5,-27},{5,27}}, rotation=180, origin={69,13})));AixLib.ThermalZones.HighOrder.Components.Walls.Wall wallNorth( use_shortWaveRadIn=use_shortWaveRadIn, use_shortWaveRadOut=use_shortWaveRadOut, energyDynamics=energyDynamicsWalls, radLongCalcMethod=radLongCalcMethod, T_ref=T_ref, calcMethodIn=calcMethodIn, wall_height=room_height, WindowType=Type_Win, redeclare model WindowModel = WindowModel, redeclare model CorrSolarGainWin = CorrSolarGainWin, T0=TWalls_start, wall_length=room_width, withSunblind=use_sunblind, Blinding=1 - ratioSunblind, LimitSolIrr=solIrrThreshold, TOutAirLimit=TOutAirLimit, solar_absorptance=solar_absorptance_OW, surfaceType=DataBase.Surfaces.RoughnessForHT.Brick_RoughPlaster(), calcMethodOut=calcMethodOut) annotation (Placement(transformation( extent={{5.00001,-30},{-5.00001,30}}, rotation=90, origin={18,69})));AixLib.ThermalZones.HighOrder.Components.Walls.Wall ceiling( use_shortWaveRadIn=use_shortWaveRadIn, use_shortWaveRadOut=use_shortWaveRadOut, energyDynamics=energyDynamicsWalls, radLongCalcMethod=radLongCalcMethod, T_ref=T_ref, calcMethodIn=calcMethodIn, wall_length=room_length, wall_height=room_width, WindowType=Type_Win, redeclare model WindowModel = WindowModel, redeclare model CorrSolarGainWin = CorrSolarGainWin, T0=TWalls_start, withSunblind=use_sunblind, Blinding=1 - ratioSunblind, LimitSolIrr=solIrrThreshold, TOutAirLimit=TOutAirLimit, solar_absorptance=solar_absorptance_OW, surfaceType=DataBase.Surfaces.RoughnessForHT.Brick_RoughPlaster(), calcMethodOut=calcMethodOut) annotation (Placement(transformation( extent={{-2,-12},{2,12}}, rotation=270, origin={-42,80})));AixLib.ThermalZones.HighOrder.Components.Walls.Wall floor( use_shortWaveRadIn=use_shortWaveRadIn, use_shortWaveRadOut=use_shortWaveRadOut, outside=false, energyDynamics=energyDynamicsWalls, radLongCalcMethod=radLongCalcMethod, T_ref=T_ref, calcMethodIn=calcMethodIn, wall_length=room_length, wall_height=room_width, WindowType=Type_Win, redeclare model WindowModel = WindowModel, redeclare model CorrSolarGainWin = CorrSolarGainWin, T0=TWalls_start, solar_absorptance=solar_absorptance_OW, withSunblind=use_sunblind, Blinding=1 - ratioSunblind, LimitSolIrr=solIrrThreshold, TOutAirLimit=TOutAirLimit, calcMethodOut=calcMethodOut) annotation (Placement(transformation( extent={{-2.00031,-12},{2.00003,12}}, rotation=90, origin={-42,-68})));Utilities.Interfaces.SolarRad_in SolarRadiationPort[5] "N,E,S,W,Hor" annotation (Placement(transformation(extent={{-120,46},{-100,66}}), iconTransformation(extent={{-120,46},{-100,66}}))); + +8: Missing documentation, Name 'WindSpeedPort' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: Wind, Speed, Port. Affected line: Modelica.Blocks.Interfaces.RealInput WindSpeedPort annotation (Placement(transformation(extent={{-116,28},{-100,44}}), iconTransformation(extent={{-120,-16},{-100,4}}))); + +9: Missing documentation, Could not extract name from line and check correctness, is your type specification correct (full library path)?. Affected line: Utilities.HeatTransfer.SolarRadInRoom solarRadInRoom( final use_dynamicMethod=use_dynamicShortWaveRadMethod, final nWalls=4, final nWin=nWin, final nFloors=1, final nCei=1, final floor_length=room_length, final floor_width=room_height, final staticCoeffTable=coeffTableSolDistrFractions) if use_shortWaveRadIn and nWin > 0 annotation (Placement(transformation(extent={{-50,26},{-30,46}}))); + +10: Documentation too short, Name 'transShoWaveRadWin' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: trans, Wave. Affected line: Modelica.Blocks.Interfaces.RealOutput transShoWaveRadWin(final quantity="Power", final unit="W") if use_shortWaveRadOut annotation (Placement(transformation( extent={{-10,-10},{10,10}}, rotation=270, origin={60,-110}))); + +11: Missing documentation, Name 'multiSum' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: multi. Affected line: Modelica.Blocks.Math.MultiSum multiSum(nu=nWin) if use_shortWaveRadOut annotation (Placement(transformation( extent={{2,-2},{-2,2}}, rotation=90, origin={60,-96}))); + +12: Missing documentation, Could not extract name from line and check correctness, is your type specification correct (full library path)?. Affected line: protected Utilities.Interfaces.ShortRadSurf shortRadSurf[nWin] if use_shortWaveRadOut annotation (Placement(transformation(extent={{58,-92}, {62,-88}}), iconTransformation(extent={{58,-92}, {62,-88}}))); + +13: Missing documentation, Name 'usesWindow' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: uses, Window. Affected line: protected parameter Boolean usesWindow[4] = {wallEast.withWindow, wallSouth.withWindow, wallWest.withWindow, wallNorth.withWindow}; + +14: Missing documentation, Name 'usesWindowInt' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: uses, Window. Affected line: parameter Integer usesWindowInt[4] = {if usesWindow[i] then 1 else 0 for i in 1:size(usesWindow, 1)}; + + +AixLib/ThermalZones/HighOrder/Components/Walls/BaseClasses/ConvNLayerClearanceStar.mo +1: Name 'l' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: l. Affected line: parameter Modelica.Units.SI.Length l "Length" annotation (Dialog(group="Geometry")); + +2: Name 'clearance' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: clearance. Affected line: parameter Modelica.Units.SI.Area clearance=0 "Area of clearance" annotation (Dialog(group="Geometry")); + +3: Could not extract name from line and check correctness, is your type specification correct (full library path)?. Affected line: replaceable parameter AixLib.DataBase.Walls.WallBaseDataDefinition wallType constrainedby AixLib.DataBase.Walls.WallBaseDataDefinition "Type of wall" annotation(Dialog(group = "Structure of wall layers"), choicesAllMatching = true, Placement(transformation(extent={{48,-98},{68,-78}}))); + +4: Could not extract name from line and check correctness, is your type specification correct (full library path)?. Affected line: parameter AixLib.ThermalZones.HighOrder.Components.Types.CalcMethodRadiativeHeatTransfer radCalcMethod= AixLib.ThermalZones.HighOrder.Components.Types.CalcMethodRadiativeHeatTransfer.No_approx "Calculation method for radiation heat transfer" annotation ( Evaluate=true, Dialog(group = "Radiation", compact=true)); + +5: Name 'T_ref' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: T_ref. Affected line: parameter Modelica.Units.SI.Temperature T_ref= Modelica.Units.Conversions.from_degC(16) "Reference temperature for optional linearization" annotation (Dialog(group="Radiation", enable=radCalcMethod == AixLib.ThermalZones.HighOrder.Components.Types.CalcMethodRadiativeHeatTransfer.Linear_constant_T_ref)); + +6: Name 'T0' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: T0. Affected line: parameter Modelica.Units.SI.Temperature T0= Modelica.Units.Conversions.from_degC(16) "Initial temperature" annotation (Dialog(group="Thermal")); + +7: Missing documentation. Affected line: Modelica.Thermal.HeatTransfer.Interfaces.HeatPort_a port_a annotation ( Placement(transformation(extent={{-110,-10},{-90,10}}), iconTransformation(extent={{-110,-10},{-90,10}}))); + +8: Missing documentation. Affected line: Modelica.Thermal.HeatTransfer.Interfaces.HeatPort_b port_b annotation ( Placement(transformation(extent={{90,-10},{110,10}}), iconTransformation( extent={{90,-10},{110,10}}))); + +9: Missing documentation, Could not extract name from line and check correctness, is your type specification correct (full library path)?. Affected line: AixLib.ThermalZones.HighOrder.Components.Walls.BaseClasses.SimpleNLayer simpleNLayer( final A=A, each final T_start=fill(T0, n), final wallRec=wallType, final energyDynamics=energyDynamics) annotation (Placement(transformation(extent={{-14,-12},{12,12}}))); + +10: Missing documentation, Name 'port_b1' contains parts with more/less than 3 characters or which are not part of special cases. Affected parts: port_b. Affected line: Modelica.Thermal.HeatTransfer.Interfaces.HeatPort_b port_b1 annotation ( Placement(transformation(extent={{-10,88},{10,108}}), iconTransformation( extent={{-12,88},{8,108}}))); + +11: Missing documentation. Affected line: protected parameter Modelica.Units.SI.Area A=h*l - clearance; \ No newline at end of file diff --git a/docs/ci_updates/syntax/HTML_correct_log.txt b/docs/ci_updates/syntax/HTML_correct_log.txt index 295f105421..07cc5f90e7 100644 --- a/docs/ci_updates/syntax/HTML_correct_log.txt +++ b/docs/ci_updates/syntax/HTML_correct_log.txt @@ -1,1165 +1,918 @@ ----- 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/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 -

- - - --------- 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/Geothermal/Borefields/Types.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/GroundTemperatureResponse.mo ---- -------- HTML Code --------

- Enumeration that defines the pipe configuration in the borehole. + 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 following pipe configurations are available in this enumeration: + 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\"

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

- This package contains type definitions. -

- --------- Errors -------- -line 8 column 2 - Warning: The summary attribute on the element is obsolete in 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). - + 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.

- The wind pressure coefficient is computed based on the - side ratio of the walls, which is defined as + To determine the weighting factors, the borefield's temperature + step response at the borefield wall is determined as

-

- s = x ⁄ y +

+ \"image\"

- 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 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\"

- 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 ν refers to the vector nu in this model and + Tstep0)=0.

- The pressure p at the port ports is computed as + 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).

-

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

+ \"image\"

- where - pw is the atmospheric pressure from the weather bus, - v is the wind speed from the weather bus, and - ρ is the fluid density. + 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 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. + 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 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 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 wind pressure coefficient is computed based on the side ratio of - the walls, which is defined as + 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

-

- s = x ⁄ y +

+ \"image\"

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

- 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. + To determine the weighting factors, the borefield's temperature step + response at the borefield wall is determined as +

+

+ \"image\"

- The pressure p at the port ports is computed as + 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.

-

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

+ \"image\"

- 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 ν refers to the vector nu in this model and + Tstep0)=0.

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

- -------- Errors -------- -line 28 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 61 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/ThermalZones/ReducedOrder/RC/BaseClasses/splitFacVal.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource_Erfint.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]) -

- - - +

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

+

+ \"image\" +

+ + + -------- Corrected 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]) + This function evaluates the integral of the error function, given by:

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

Latitude

28.567° north

Longitude

77.103° east

Altitude

236.9 m

Time Zone

5.5

+ -------- 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 + WD500: Time Zone Case

- 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. + Weather data file : WD500.epw

-

- References -

- H. Jin. Parameter estimation based models of water source heat - pumps. PhD Thesis. Oklahoma State University. Stillwater, - Oklahoma, USA. 2002. + 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 5 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 11 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/Controls/Discrete/BooleanDelay.mo ---- +---- AixLib/Fluid/Types.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). + 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. +

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

- --------- 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/Validation/PlugFlowPipes/PlugFlowULg.mo ---- --------- HTML Code -------- - -

- The example contains - experimental data from a real district heating network. + Enumeration to define the heat exchanger flow regime.

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

-

Test bench schematic

-

\"Schematic

-

Calibration

- 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: + The following heat exchanger flow regimes are available in this enumeration:

-

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

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

- The example contains experimental data from a real district heating - network. + 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 +

- This model compares the results with the original Modelica Standard - Library pipes. + The details of the coefficients are explained in the + Users Guide.

- The pipes' temperatures are not initialized. Therefore, results of - outflow temperature before approximately the first 10000 seconds - should not be considered. + Enumeration that defines the heat exchanger construction.

-

- Test bench schematic -

- \"Schematic + The following heat exchanger configurations are available in this + enumeration:

-

- Calibration -

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

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

- --------- Errors -------- -line 25 column 2 - Warning:

attribute "align" not allowed for HTML5 -line 27 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 + Enumeration to define the heat exchanger flow regime.

- Table 1: Site Data for Weather file WD300.epw + 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: +

+
+ + + + -
+ Enumeration + + Description +
-

- Latitude -

+ ParallelFlow
-

- 33.393° south -

+ Parallel flow
-

- Longitude -

+ CounterFlow
-

- 70.786° west -

+ Counter flow
-

- Altitude -

+ CrossFlowUnmixed
-

- 474 m -

+ Cross flow, both streams unmixed
-

- Time Zone -

+ CrossFlowCMinMixedCMaxUnmixed
-

- -4 -

+ Cross flow, CMin mixed, CMax unmixed
- --------- Errors -------- -line 5 column 2 - Warning: The summary attribute on the element is obsolete in 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 -------- -

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

+ + + + + + + + +
+ CrossFlowCMinUnmixedCMaxMixed + + Cross flow, CMin unmixed, CMax mixed +
+ ConstantTemperaturePhaseChange + + Constant 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. May 3, 2017, by Michael Wetter:
    - Refactored model to allow X_wSet as an input.
    - This is for #763. +
  4. a series of possible set points that can be switched using an + integer input, or
  5. -
  6. January 26, 2016, by Michael Wetter:
    - Removed inequality comparison of real numbers in - restrictCool and in restrictHeat as this - is not allowed in Modelica. +
  7. a continuously variable set point.
  8. -
  9. November 10, 2014, by Michael Wetter:
    +
+ +

+ This package contains type definitions. +

-------- Errors -------- -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 + + +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/Fluid/Movers/Data/Pumps/Wilo/Stratos25slash1to6.mo ---- @@ -1260,1655 +1013,1485 @@ line 18 column 2 - Warning:

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

attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Humidifiers/SprayAirWasher_X.mo ---- +---- AixLib/ThermalZones/ReducedOrder/RC/FourElements.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 -

-

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

-

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

- +

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

-

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

-

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

+

+ 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 33 column 2 - Warning:

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

attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/BaseClasses/HANaturalCylinder.mo ---- +---- AixLib/Fluid/Movers/Validation/PowerExact.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 -

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

--------- 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/HeatExchangers/BaseClasses/WetCoilWetRegime.mo ---- --------- HTML 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, + This medium package models liquid water.

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

- 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. + \"Relative

- Mitchell, John W., and James E. Braun. 2012a. - Principles of heating, ventilation, and air conditioning in buildings. - Hoboken, N.J.: Wiley. + The enthalpy is computed using the convention that h=0 + if T=0 °C.

+

Limitations

- 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. + Density, specific heat capacity, thermal conductivity and viscosity are constant. + Water is modeled as an incompressible liquid. + There are no phase changes.

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

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

+ Model with basic thermodynamic properties.

- The capacitance ratio and minimum capacitance are naturally defined - as + 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.

-

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

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

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

-

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

+

+ This medium package models liquid water.

-

- References -

- Braun, James E. 1988. \"Methodologies for the Design and Control of - Central Cooling Plants\". PhD Thesis. University of Wisconsin - - Madison. Available online. + 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.

- Mitchell, John W., and James E. Braun. 2012a. Principles of heating, - ventilation, and air conditioning in buildings. Hoboken, N.J.: Wiley. + 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. +

+

+ +

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

+ -------- 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 +line 17 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Fluid/FMI/UsersGuide.mo ---- +line 18 column 2 - Warning:

attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/Humidifiers/SteamHumidifier_X.mo ---- -------- HTML 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. +

+ + + +-------- 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. + Model for a steam humidifier with a prescribed outlet water vapor + mass fraction in kg/kg total air.

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

-
-

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

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

-

Notes

-Note the following when exporting HVAC component models as an FMU: + The outlet conditions at port_a are not affected by this + model, other than for a possible pressure difference due to flow + friction.

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

    + τeff = τ |ṁ| ⁄ ṁnom

    -For -AixLib.Media.Water, this setting is not needed -as the mass is independent of pressure. + 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.

    -
  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. + Optionally, this model can have a flow resistance. Set + dp_nominal = 0 to disable the flow friction calculation.

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

-

References

+

+ Limitations +

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

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

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

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

-

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

-

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

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

- 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. + The heat pump COP is computed as the product +

+

+ COP = ηCarnot,0 COPCarnot ηPL,

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

-

- 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. + where the coefficients ai are declared by the + parameter a.

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

- Notes + Typical use and important parameters

- Note the following when exporting HVAC component models as an FMU: + 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.

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

- References + Notes

- 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. + For a similar model that can be used as a chiller, see AixLib.Fluid.Chillers.Examples.Carnot_TEva.

+ -------- Errors -------- -line 18 column 1 - Warning: The summary attribute on the element is obsolete in 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/Fluid/Chillers/Carnot_TEva.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/timeGeometric.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. + This function attemps to build a vector of length nTim with a geometric + expansion of the time variable between dt and t_max.

- 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 + If t_max > nTim*dt, then a geometrically expanding vector is built as

-

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

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

- On the Advanced tab, a user can specify the temperatures that - will be used as the evaporator and condenser temperature. + where r is the geometric expansion factor.

- During the simulation, the chiller COP is computed as the product + If t_max < nTim*dt, then a linearly expanding vector is built as

-

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

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

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

+

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

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

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

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

- 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 + Function that computes the pressure drop of flow elements as

- ηPL = a1 + a2 yPL + a3 yPL2 + ... + Δp = sign(m) (m ⁄ k)2

- where the coefficients ai - are declared by the parameter a. + with regularization near the origin. + Therefore, the flow coefficient is

-

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

+ k = m ⁄ √ Δp  

-

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

-

- 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. + The input m_flow_turbulent determines the location of the regularization.

-------- 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 + Function that computes the pressure drop of flow elements as

- COP = ηCarnot,0 COPCarnot ηPL, + Δp = sign(m) (m ⁄ k)2

- 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 + with regularization near the origin. Therefore, the flow coefficient + is

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

-

- The coefficient of performance depends on the evaporator and - condenser leaving temperature since otherwise the second law of - thermodynamics may be violated. + k = m ⁄ √ Δp +  

-

- Notes -

- For a similar model that can be used as a heat pump, see AixLib.Fluid.HeatPumps.Examples.Carnot_TCon. + The input m_flow_turbulent determines the location of + the regularization.

-------- 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 5 column 2 - Warning:

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

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

- Partial model of a heat exchanger without humidity condensation. - This model transfers heat in the amount of + 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

- Q = Qmax ε
- ε = f(NTU, Z, flowRegime), + Ḣtot = Ḣsen + Ḣlat,

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. + sen = ṁ (1-Xw) cp,air, + then this sensor outputs Ḣ = Ḣsen.

+

- The flow regimes depend on the heat exchanger configuration. All configurations - defined in - - AixLib.Fluid.Types.HeatExchangerConfiguration - are supported. + 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.

+

- Models that extend from this partial model need to provide an assignment - for UA. + 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 --------

- Partial model of a heat exchanger without humidity condensation. This - model transfers heat in the amount of + 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

- Q = Qmax ε
- ε = f(NTU, Z, flowRegime), + Ḣtot = Ḣsen + Ḣlat,

- 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. + where sen = ṁ (1-Xw) + cp,air, then this sensor outputs Ḣ = + Ḣsen.

- The flow regimes depend on the heat exchanger configuration. All - configurations defined in AixLib.Fluid.Types.HeatExchangerConfiguration - are supported. + 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.

- Models that extend from this partial model need to provide an - assignment for UA. + 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).

@@ -2916,2838 +2499,2303 @@ line 39 column 2 - Warning:

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

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

- Two way valve with opening characteristic that is configured through - a table. + 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)).

- 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 parameter flowCharacteristics must meet the following - requirements, otherwise the model stops with an error: -

- -

- 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. + Outside this range, the damper characteristic is defined by a quadratic polynomial.

- For an example that specifies an opening characteristics, see - - AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable. + 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 --------

- 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 + This function computes the opening characteristics of an exponential + damper.

- - - - - - - - - - - - - -
- 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 function is used by the model AixLib.Fluid.Actuators.Dampers.Exponential.

-
-  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. + For yL < y < yU, the damper characteristics is

-

- The parameter flowCharacteristics must meet the - following requirements, otherwise the model stops with an error: +

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

-

- 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. + Outside this range, the damper characteristic is defined by a + quadratic polynomial.

- For an example that specifies an opening characteristics, see - - AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable. + 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 14 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 +line 11 column 2 - Warning:

attribute "align" not allowed for HTML5 ----- AixLib/Controls/SetPoints/Examples/SupplyReturnTemperatureReset.mo ---- +---- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlowHeatLoss.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. + Component that calculates the heat losses at the end of a plug flow pipe + when the flow goes in the design direction.

-

- \"Supply +

Main equations

+

+ The governing equations are +

+

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

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

- - --------- Errors -------- -line 16 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. + with +

+

+ tauchar = R C

+

Assumptions and limitations

- The image below shows the RC-network of this model. + This model is based on the following assumptions:

-

- \"image\"/ +

+

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

- 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. + 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 image below shows the RC-network of this model. + The governing equations are

-

- \"image\" +

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

+ -------- Errors -------- -line 16 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/Actuators/Valves/ThreeWayTable.mo ---- +---- AixLib/Utilities/Math/QuadraticLinear.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: -

- -

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

- +

Block for function quadraticLinear, which computes

+

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

-------- Corrected 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: -

- -

- 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. + Block for function quadraticLinear, which computes

-

- For an example that specifies an opening characteristics, see - - AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable. +

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

-------- Errors -------- -line 21 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/Actuators/Valves/Examples/TwoWayValveTable.mo ---- +---- AixLib/Fluid/Movers/UsersGuide.mo ---- -------- HTML 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. -

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

-

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

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

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

- Plotting the variables kv.y versus y.y - shows that the valve reproduces the Kv values shown - in the above table. +Below, the models are briefly described.

-

- \"image\" +

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.

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

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

+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\";
+
+

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

+

+\"image\" +

----- 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 data record contains the coefficients for perfect gases. -

- - - -

- This package contains a thermally perfect model of moist air. -

-

- A medium is called thermally perfect if -

- -

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

-

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

-

References

-

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

- This data record contains the coefficients for perfect gases. -

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

- This package contains a thermally perfect model of moist air. +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.

- A medium is called thermally perfect if +These models can be configured for three different control inputs. +For + +AixLib.Fluid.Movers.FlowControlled_dp, +the head is as follows:

+
  • - 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). +If the parameter inputType==AixLib.Fluid.Types.InputType.Continuous, +the head is dp=dp_in, where dp_in is an input connector.

    +
  • +
  • - This medium uses the ideal gas law -

    -

    - ρ = p ⁄(R T), +If the parameter inputType==AixLib.Fluid.Types.InputType.Constant, +the head is dp=constantHead, where constantHead is a parameter.

    +
  • +
  • - where ρ is the density, p is the pressure, R is - the gas constant and T is the temperature. +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:

    -

    - The enthalpy is computed using the convention that h=0 if - T=0 °C and no water vapor is present. + + + + + + + + + + + + + + + + + +
    input signal stageHead [Pa]
    00
    10.6*dp_nominal
    2dp_nominal
    +

  • + +

    +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

    - --------- Errors -------- -line 25 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/HeatExchangers/DryCoilEffectivenessNTU.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. -

    -

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

    - Model of a coil without humidity condensation. This model transfers - heat in the amount of -

    -

    - Q̇ = Q̇max ε
    - ε = f(NTU, Z, flowRegime), +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.

    - 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 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 flow regimes depend on the heat exchanger configuration. All - configurations defined in AixLib.Fluid.Types.HeatExchangerConfiguration - are supported. +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:

    + +

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

    - For a heat and moisture exchanger, use AixLib.Fluid.MassExchangers.ConstantEffectiveness. +All models have a parameter use_inputFilter. This +parameter affects the fan output as follows: +

    +
      +
    1. +If use_inputFilter=false, then the input signal y (or +Nrpm, m_flow_in, or dp_in) +is equal to the fan speed (or the mass flow rate or pressure rise). +Thus, a step change in the input signal causes a step change in the fan speed (or mass flow rate or pressure rise). +
    2. +
    3. +If use_inputFilter=true, which is the default, +then the fan speed (or the mass flow rate or the pressure rise) +is equal to the output of a filter. This filter is implemented +as a 2nd order differential equation and can be thought of as +approximating the inertia of the rotor and the fluid. +Thus, a step change in the fan input signal will cause a gradual change +in the fan speed. +The filter has a parameter riseTime, which by default is set to +30 seconds. +The rise time is the time required to reach 99.6% of the full speed, or, +if the fan is switched off, to reach a fan speed of 0.4%. +
    4. +
    +

    +The figure below shows for a fan with use_inputFilter=true +and riseTime=30 seconds the +speed input signal and the actual speed.

    +

    +\"image\"

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

    attribute "align" not allowed for HTML5 +

    +Although many simulations do not require such a detailed model +that approximates the transients of fans or pumps, it turns +out that using this filter can reduce computing time and +can lead to fewer convergence problems in large system models. +With a filter, any sudden change in control signal, such as when +a fan switches on, is damped before it affects the air flow rate. +This continuous change in flow rate turns out to be easier, and in +some cases faster, to simulate compared to a step change. +For most simulations, we therefore recommend to use the default settings +of use_inputFilter=true and riseTime=30 seconds. +An exception are situations in which the fan or pump is operated at a fixed speed during +the whole simulation. In this case, set use_inputFilter=false. +

    +

    +Note that if the fan is part of a closed loop control, then the filter affects +the transient response of the control. +When changing the value of use_inputFilter, the control gains +may need to be retuned. +We now present values control parameters that seem to work in most cases. +Suppose there is a closed loop control with a PI-controller + +AixLib.Controls.Continuous.LimPID +and a fan or pump, configured with use_inputFilter=true and riseTime=30 seconds. +Assume that the transient response of the other dynamic elements in the control loop is fast +compared to the rise time of the filter. +Then, a proportional gain of k=0.5 and an integrator time constant of +Ti=15 seconds often yields satisfactory closed loop control performance. +These values may need to be changed for different applications as they are also a function +of the loop gain. +If the control loop shows oscillatory behavior, then reduce k and/or increase Ti. +If the control loop reacts too slow, do the opposite. +

    ----- AixLib/Fluid/HeatExchangers/EvaporatorCondenser.mo ---- --------- HTML Code -------- +
    Efficiency and electrical power consumption
    +

    +All models compute the motor power draw Pele, +the hydraulic power input Whyd, the flow work +Wflo and the heat dissipated into the medium +Q. Based on the first law, the flow work is +

    +

    + Wflo = | V̇ Δp |, +

    +

    +where is the volume flow rate and +Δp is the pressure rise. +The heat dissipated into the medium is as follows: +If the motor is cooled by the fluid, as indicated by +per.motorCooledByFluid=true, then the heat dissipated into the medium is +

    +

    + Q = Pele - Wflo. +

    -

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

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

    - Model for a constant temperature evaporator or condenser based on a - ε-NTU heat exchanger model. +If per.motorCooledByFluid=false, then the motor is outside the fluid stream, +and only the shaft, or hydraulic, work Whyd enters the thermodynamic +control volume. Hence, +

    +

    + Q = Whyd - Wflo. +

    +

    The efficiencies are computed as

    +

    + η = Wflo ⁄ Pele = ηhyd   ηmot
    + ηhyd = Wflo ⁄ Whyd
    + ηmot = Whyd ⁄ Pele
    +

    +

    where +ηhyd is the hydraulic efficiency, +ηmot is the motor efficiency and +Q is the heat released by the motor.

    - The heat exchanger effectiveness is calculated from the number of - transfer units (NTU): +If per.use_powerCharacteristic=true, +then a set of data points for the power Pele for different +volume flow rates at full speed needs to be provided by the user. +Using the flow work Wflo and the electrical power input +Pele, the total efficiency is computed as

    - ε = 1 - exp(UA ⁄ (ṁ cp)) + η = Wflo ⁄ Pele,

    - Optionally, this model can have a flow resistance. If no flow - resistance is requested, set dp_nominal=0. +and the two efficiencies +ηhyd +and ηmot are computed as +

    +

    + ηhyd = 1,
    + ηmot = η.

    -

    - 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. +However, if per.use_powerCharacteristic=false, then +performance data for +ηhyd and + ηmot need to be provided by the user, and hence +the model computes +

    +

    + η = ηhyd   ηmot
    + Pele = Wflo ⁄ η.

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

    attribute "align" not allowed for HTML5 +

    +The efficiency data for the motor are a list of points + and ηmot. +

    +
    Fluid volume of the component
    +

    +All models can be configured to have a fluid volume at the low-pressure side. +Adding such a volume sometimes helps the solver to find a solution during +initialization and time integration of large models. +

    ----- AixLib/Fluid/FMI/ExportContainers/ThermalZone.mo ---- --------- HTML Code -------- +
    Enthalpy change of the component
    +

    +If per.motorCooledByFluid=true, then +the enthalpy change between the inlet and outlet fluid port is equal +to the electrical power Pele that is consumed by the component. +Otherwise, it is equal to the hydraulic work Whyd. +The parameter addPowerToMedium, which is by default set to +true, can be used to simplify the equations. +If addPowerToMedium = false, then no enthalpy change occurs between +inlet and outlet. +This can lead to simpler equations, but the temperature rise across the component +will be zero. In particular for fans, this simplification may not be permissible. +

    -

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

    -

    - -

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

    Differences to models in Modelica.Fluid.Machines

    - Model that is used as a container for a single thermal zone that is - to be exported as an FMU. +The models in this package differ from +Modelica.Fluid.Machines +primarily in the following points:

    -

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

    References

    - The example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone shows - how a simple thermal zone can be implemented and exported as an FMU. - +Michael Wetter. + +Fan and pump model that has a unique solution for any pressure +boundary condition and control signal. +Proc. of the 13th Conference of the International Building Performance +Simulation Association, p. 3505-3512. Chambery, France. August 2013.

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

    - 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 package contains models for fans and pumps. The same models are + used for fans or pumps.

    +

    + Model description +

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

    - Qsen = max(0, ṁsup)   cp   - (Tsup - Tair,zon), + d Δp(r(t), V(t)) ⁄ d r(t)

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

    - 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. + Below, the models are briefly described.

    +
    + Performance data +

    - 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 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 variable + + Dependent variable + + Record for performance data + + Function +
    + Volume flow rate + + Pressure + + + flowParameters + + + pressure +
    + Volume flow rate + + Efficiency + + + efficiencyParameters + + + efficiency +
    + Volume flow rate + + Power* + + + 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.

    - - --------- Errors -------- -line 72 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 + 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.

    -

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

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

    -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 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.0003 + + 45000 +
    + 0.0006 + + 35000 +
    + 0.0008 + + 15000 +

    -Below, the models are briefly described. + Then, a declaration would be

    -
    Performance data
    +
    +  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\";
    +

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

    -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\";
    -
    - -

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

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

    - -
    Models that directly control the head or the mass flow rate
    +
    + 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. + 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: + These models can be configured for three different control inputs. + For AixLib.Fluid.Movers.FlowControlled_dp, + the head is as follows:

    -Similarly, for - -AixLib.Fluid.Movers.FlowControlled_m_flow, -the mass flow rate is as follows: + 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

    + 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. + 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 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: + 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
    +
    + Start-up and shut-down transients +

    -All models have a parameter use_inputFilter. This -parameter affects the fan output as follows: + All models have a parameter use_inputFilter. This + parameter affects the fan output as follows:

      -
    1. -If use_inputFilter=false, then the input signal y (or -Nrpm, m_flow_in, or dp_in) -is equal to the fan speed (or the mass flow rate or pressure rise). -Thus, a step change in the input signal causes a step change in the fan speed (or mass flow rate or pressure rise). -
    2. -
    3. -If use_inputFilter=true, which is the default, -then the fan speed (or the mass flow rate or the pressure rise) -is equal to the output of a filter. This filter is implemented -as a 2nd order differential equation and can be thought of as -approximating the inertia of the rotor and the fluid. -Thus, a step change in the fan input signal will cause a gradual change -in the fan speed. -The filter has a parameter riseTime, which by default is set to -30 seconds. -The rise time is the time required to reach 99.6% of the full speed, or, -if the fan is switched off, to reach a fan speed of 0.4%. -
    4. -
    -

    -The figure below shows for a fan with use_inputFilter=true -and riseTime=30 seconds the -speed input signal and the actual speed.

    -

    -\"image\" -

    - -

    -Although many simulations do not require such a detailed model -that approximates the transients of fans or pumps, it turns -out that using this filter can reduce computing time and -can lead to fewer convergence problems in large system models. -With a filter, any sudden change in control signal, such as when -a fan switches on, is damped before it affects the air flow rate. -This continuous change in flow rate turns out to be easier, and in -some cases faster, to simulate compared to a step change. -For most simulations, we therefore recommend to use the default settings -of use_inputFilter=true and riseTime=30 seconds. -An exception are situations in which the fan or pump is operated at a fixed speed during -the whole simulation. In this case, set use_inputFilter=false. +

  • If use_inputFilter=false, then the input signal + y (or Nrpm, m_flow_in, or + dp_in) is equal to the fan speed (or the mass flow rate + or pressure rise). Thus, a step change in the input signal causes a + step change in the fan speed (or mass flow rate or pressure rise). +
  • +
  • If use_inputFilter=true, which is the default, then + the fan speed (or the mass flow rate or the pressure rise) is equal + to the output of a filter. This filter is implemented as a 2nd order + differential equation and can be thought of as approximating the + inertia of the rotor and the fluid. Thus, a step change in the fan + input signal will cause a gradual change in the fan speed. The filter + has a parameter riseTime, which by default is set to + 30 seconds. The rise time is the time required to reach + 99.6% of the full speed, or, if the fan is switched off, to + reach a fan speed of 0.4%. +
  • + +

    + The figure below shows for a fan with + use_inputFilter=true and riseTime=30 + seconds the speed input signal and the actual speed. +

    +

    + \"image\"

    -Note that if the fan is part of a closed loop control, then the filter affects -the transient response of the control. -When changing the value of use_inputFilter, the control gains -may need to be retuned. -We now present values control parameters that seem to work in most cases. -Suppose there is a closed loop control with a PI-controller - -AixLib.Controls.Continuous.LimPID -and a fan or pump, configured with use_inputFilter=true and riseTime=30 seconds. -Assume that the transient response of the other dynamic elements in the control loop is fast -compared to the rise time of the filter. -Then, a proportional gain of k=0.5 and an integrator time constant of -Ti=15 seconds often yields satisfactory closed loop control performance. -These values may need to be changed for different applications as they are also a function -of the loop gain. -If the control loop shows oscillatory behavior, then reduce k and/or increase Ti. -If the control loop reacts too slow, do the opposite. + Although many simulations do not require such a detailed model that + approximates the transients of fans or pumps, it turns out that using + this filter can reduce computing time and can lead to fewer + convergence problems in large system models. With a filter, any + sudden change in control signal, such as when a fan switches on, is + damped before it affects the air flow rate. This continuous change in + flow rate turns out to be easier, and in some cases faster, to + simulate compared to a step change. For most simulations, we + therefore recommend to use the default settings of + use_inputFilter=true and riseTime=30 + seconds. An exception are situations in which the fan or pump is + operated at a fixed speed during the whole simulation. In this case, + set use_inputFilter=false.

    - -
    Efficiency and electrical power consumption

    -All models compute the motor power draw Pele, -the hydraulic power input Whyd, the flow work -Wflo and the heat dissipated into the medium -Q. Based on the first law, the flow work is + Note that if the fan is part of a closed loop control, then the + filter affects the transient response of the control. When changing + the value of use_inputFilter, the control gains may need + to be retuned. We now present values control parameters that seem to + work in most cases. Suppose there is a closed loop control with a + PI-controller AixLib.Controls.Continuous.LimPID + and a fan or pump, configured with use_inputFilter=true + and riseTime=30 seconds. Assume that the transient + response of the other dynamic elements in the control loop is fast + compared to the rise time of the filter. Then, a proportional gain of + k=0.5 and an integrator time constant of + Ti=15 seconds often yields satisfactory closed loop + control performance. These values may need to be changed for + different applications as they are also a function of the loop gain. + If the control loop shows oscillatory behavior, then reduce + k and/or increase Ti. If the control loop + reacts too slow, do the opposite. +

    +
    + Efficiency and electrical power consumption +
    +

    + All models compute the motor power draw Pele, the + hydraulic power input Whyd, the flow work + Wflo and the heat dissipated into the medium + Q. Based on the first law, the flow work is

    - Wflo = | V̇ Δp |, + Wflo = | V̇ Δp |,

    -where is the volume flow rate and -Δp is the pressure rise. -The heat dissipated into the medium is as follows: -If the motor is cooled by the fluid, as indicated by -per.motorCooledByFluid=true, then the heat dissipated into the medium is + where is the volume flow rate and Δp is the pressure + rise. The heat dissipated into the medium is as follows: If the motor + is cooled by the fluid, as indicated by + per.motorCooledByFluid=true, then the heat dissipated + into the medium is

    Q = Pele - Wflo.

    -

    -If per.motorCooledByFluid=false, then the motor is outside the fluid stream, -and only the shaft, or hydraulic, work Whyd enters the thermodynamic -control volume. Hence, + If per.motorCooledByFluid=false, then the motor is + outside the fluid stream, and only the shaft, or hydraulic, work + Whyd enters the thermodynamic control volume. + Hence,

    Q = Whyd - Wflo.

    -

    The efficiencies are computed as

    +

    + The efficiencies are computed as +

    - η = Wflo ⁄ Pele = ηhyd   ηmot
    - ηhyd = Wflo ⁄ Whyd
    - ηmot = Whyd ⁄ Pele
    + η = Wflo ⁄ Pele = ηhyd   + ηmot
    + ηhyd = Wflo ⁄ Whyd
    + ηmot = Whyd ⁄ Pele

    -

    where -ηhyd is the hydraulic efficiency, -ηmot is the motor efficiency and -Q is the heat released by the motor. +

    + where ηhyd is the hydraulic efficiency, + ηmot is the motor efficiency and Q is the + heat released by the motor.

    -If per.use_powerCharacteristic=true, -then a set of data points for the power Pele for different -volume flow rates at full speed needs to be provided by the user. -Using the flow work Wflo and the electrical power input -Pele, the total efficiency is computed as + If per.use_powerCharacteristic=true, then a set of data + points for the power Pele for different volume flow + rates at full speed needs to be provided by the user. Using the flow + work Wflo and the electrical power input + Pele, the total efficiency is computed as

    - η = Wflo ⁄ Pele,
    + η = Wflo ⁄ Pele,

    -and the two efficiencies -ηhyd -and ηmot are computed as + and the two efficiencies ηhyd and + ηmot are computed as

    - ηhyd = 1,
    - ηmot = η. + ηhyd = 1,
    + ηmot = η.

    -However, if per.use_powerCharacteristic=false, then -performance data for -ηhyd and - ηmot need to be provided by the user, and hence -the model computes + However, if per.use_powerCharacteristic=false, then + performance data for ηhyd and + ηmot need to be provided by the user, and hence the + model computes

    - η = ηhyd   ηmot
    - Pele = Wflo ⁄ η. + η = ηhyd   ηmot
    + Pele = Wflo ⁄ η.

    -

    -The efficiency data for the motor are a list of points - and ηmot. + The efficiency data for the motor are a list of points and + ηmot.

    - -
    Fluid volume of the component
    +
    + Fluid volume of the component +

    -All models can be configured to have a fluid volume at the low-pressure side. -Adding such a volume sometimes helps the solver to find a solution during -initialization and time integration of large models. + All models can be configured to have a fluid volume at the + low-pressure side. Adding such a volume sometimes helps the solver to + find a solution during initialization and time integration of large + models.

    - -
    Enthalpy change of the component
    +
    + Enthalpy change of the component +

    -If per.motorCooledByFluid=true, then -the enthalpy change between the inlet and outlet fluid port is equal -to the electrical power Pele that is consumed by the component. -Otherwise, it is equal to the hydraulic work Whyd. -The parameter addPowerToMedium, which is by default set to -true, can be used to simplify the equations. -If addPowerToMedium = false, then no enthalpy change occurs between -inlet and outlet. -This can lead to simpler equations, but the temperature rise across the component -will be zero. In particular for fans, this simplification may not be permissible. + If per.motorCooledByFluid=true, then the enthalpy change + between the inlet and outlet fluid port is equal to the electrical + power Pele that is consumed by the component. + Otherwise, it is equal to the hydraulic work Whyd. + The parameter addPowerToMedium, which is by default set + to true, can be used to simplify the equations. If + addPowerToMedium = false, then no enthalpy change occurs + between inlet and outlet. This can lead to simpler equations, but the + temperature rise across the component will be zero. In particular for + fans, this simplification may not be permissible.

    - -

    Differences to models in Modelica.Fluid.Machines

    +

    + Differences to models in Modelica.Fluid.Machines +

    -The models in this package differ from -Modelica.Fluid.Machines -primarily in the following points: + The models in this package differ from Modelica.Fluid.Machines primarily in + the following points:

    -

    References

    +
  • They use a different base class, which allows to have zero mass + flow rate. The models in Modelica.Fluid restrict the + number of revolutions, and hence the flow rate, to be non-zero. +
  • +
  • For the model with prescribed pressure, the input signal is the + pressure difference between the two ports, and not the absolute + pressure at port_b. +
  • +
  • The pressure calculations are based on total pressure in Pascals + instead of the pump head in meters. This change was done to avoid + ambiguities in the parameterization if the models are used as a fan + with air as the medium. The original formulation in Modelica.Fluid.Machines converts head + to pressure using the density medium.d. Therefore, for + fans, head would be converted to pressure using the density of air. + However, for pumps, manufacturers typically publish the head in + millimeters water (mmH2O). Therefore, to avoid confusion + when using these models with media other than water, we changed the + models to use total pressure in Pascals instead of head in meters. +
  • +
  • The performance data are interpolated using cubic hermite splines + instead of polynomials. These functions are implemented in AixLib.Fluid.Movers.BaseClasses.Characteristics. +
  • + +

    + References +

    -Michael Wetter. - -Fan and pump model that has a unique solution for any pressure -boundary condition and control signal. -Proc. of the 13th Conference of the International Building Performance -Simulation Association, p. 3505-3512. Chambery, France. August 2013. + Michael Wetter. + Fan and pump model that has a unique solution for any pressure + boundary condition and control signal. Proc. of the 13th + Conference of the International Building Performance Simulation + Association, p. 3505-3512. Chambery, France. August 2013.

    +-------- Errors -------- +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/FixedResistances/Validation/PlugFlowPipes/PlugFlowAIT.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). +

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

    - This package contains models for fans and pumps. The same models are - used for fans or pumps. + The example contains experimental data from a real district heating + network.

    -

    - 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 + The pipes' temperatures are not initialized. Therefore, results of + outflow temperature before approximately the first 10000 seconds + should not be considered.

    -

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

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

    +

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

    - Below, the models are briefly described. + \"Schematic

    -
    - Performance data -
    +

    + Calibration +

    - 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: + To calculate the length specific thermal resistance R of + the pipe, the thermal resistance of the surrounding ground is added, + which yields

    -
    - - - - - - - - - - - - - - - - - - - - - - - - -
    - Independent variable - - Dependent variable - - Record for performance data - - Function -
    - Volume flow rate - - Pressure - - - flowParameters - - - pressure -
    - Volume flow rate - - Efficiency - - - efficiencyParameters - - - efficiency -
    - Volume flow rate - - Power* - - - 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. +

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

    - - - - - - - - - - - - - - - - - -
    - Volume flow rate [m3⁄s] - - Head [Pa] -
    - 0.0003 - - 45000 -
    - 0.0006 - - 35000 -
    - 0.0008 - - 15000 -

    - Then, a declaration would be + where the thermal conductivity of the ground lambda_g = + 2.4 W/(m K).

    -
    -  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\";
    -
    + + +-------- Errors -------- +line 48 column 2 - Warning:

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

    + This function computes the fan power consumption for given volume flow rate, + speed and performance data. The power consumption is +

    +

    + P = rN3   s(V̇/rN, d), +

    +

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

    +

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

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

    - This will model the following pump curve for the pump input signal - y=1. + This function computes the fan power consumption for given volume + flow rate, speed and performance data. The power consumption is

    -

    - \"image\" +

    + P = rN3   s(V̇/rN, d),

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

    +

    + Implementation +

    - These models can be configured for three different control inputs. - For AixLib.Fluid.Movers.FlowControlled_dp, - the head is as follows: + 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/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/gFunction.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 +

    +

    + \"image\" +

    +

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

    +

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

    +

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

    +

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

    +

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

    +

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

    +

    + Eskilson, P. 1987. Thermal analysis of heat extraction boreholes. Ph.D. + Thesis. Department of Mathematical Physics. University of Lund. Sweden. +

    +

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

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

    - Similarly, for AixLib.Fluid.Movers.FlowControlled_m_flow, - the mass flow rate is as follows: + 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 +

    +

    + \"image\"

    -

    - These two models do not need to use a performance curve for the flow - characteristics. The reason is that + 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.

    -

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

    - 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: + 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

    - -

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

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

    -
    - Start-up and shut-down transients -
    +

    + Implementation +

    - All models have a parameter use_inputFilter. This - parameter affects the fan output as follows: + 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.

    -
      -
    1. If use_inputFilter=false, then the input signal - y (or Nrpm, m_flow_in, or - dp_in) is equal to the fan speed (or the mass flow rate - or pressure rise). Thus, a step change in the input signal causes a - step change in the fan speed (or mass flow rate or pressure rise). -
    2. -
    3. If use_inputFilter=true, which is the default, then - the fan speed (or the mass flow rate or the pressure rise) is equal - to the output of a filter. This filter is implemented as a 2nd order - differential equation and can be thought of as approximating the - inertia of the rotor and the fluid. Thus, a step change in the fan - input signal will cause a gradual change in the fan speed. The filter - has a parameter riseTime, which by default is set to - 30 seconds. The rise time is the time required to reach - 99.6% of the full speed, or, if the fan is switched off, to - reach a fan speed of 0.4%. -
    4. -
    +

    + References +

    - The figure below shows for a fan with - use_inputFilter=true and riseTime=30 - seconds the speed input signal and the actual speed. -

    -

    - \"image\" + 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.

    - Although many simulations do not require such a detailed model that - approximates the transients of fans or pumps, it turns out that using - this filter can reduce computing time and can lead to fewer - convergence problems in large system models. With a filter, any - sudden change in control signal, such as when a fan switches on, is - damped before it affects the air flow rate. This continuous change in - flow rate turns out to be easier, and in some cases faster, to - simulate compared to a step change. For most simulations, we - therefore recommend to use the default settings of - use_inputFilter=true and riseTime=30 - seconds. An exception are situations in which the fan or pump is - operated at a fixed speed during the whole simulation. In this case, - set use_inputFilter=false. + 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.

    - Note that if the fan is part of a closed loop control, then the - filter affects the transient response of the control. When changing - the value of use_inputFilter, the control gains may need - to be retuned. We now present values control parameters that seem to - work in most cases. Suppose there is a closed loop control with a - PI-controller AixLib.Controls.Continuous.LimPID - and a fan or pump, configured with use_inputFilter=true - and riseTime=30 seconds. Assume that the transient - response of the other dynamic elements in the control loop is fast - compared to the rise time of the filter. Then, a proportional gain of - k=0.5 and an integrator time constant of - Ti=15 seconds often yields satisfactory closed loop - control performance. These values may need to be changed for - different applications as they are also a function of the loop gain. - If the control loop shows oscillatory behavior, then reduce - k and/or increase Ti. If the control loop - reacts too slow, do the opposite. + Eskilson, P. 1987. Thermal analysis of heat extraction + boreholes. Ph.D. Thesis. Department of Mathematical Physics. + University of Lund. Sweden.

    -
    - Efficiency and electrical power consumption -

    - All models compute the motor power draw Pele, the - hydraulic power input Whyd, the flow work - Wflo and the heat dissipated into the medium - Q. Based on the first law, the flow work is -

    -

    - Wflo = | V̇ Δp |, + 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.

    + + +-------- 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\"/

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

    - where is the volume flow rate and Δp is the pressure - rise. The heat dissipated into the medium is as follows: If the motor - is cooled by the fluid, as indicated by - per.motorCooledByFluid=true, then the heat dissipated - into the medium is + 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.

    -

    - Q = Pele - Wflo. +

    + \"image\"

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

    attribute "align" not allowed for HTML5 + + +---- AixLib/Controls/Continuous/Examples/OffTimer.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 +

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

    - If per.motorCooledByFluid=false, then the motor is - outside the fluid stream, and only the shaft, or hydraulic, work - Whyd enters the thermodynamic control volume. - Hence, + 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.

    -

    - Q = Whyd - Wflo. -

    -

    - The efficiencies are computed as -

    -

    - η = Wflo ⁄ Pele = ηhyd   - ηmot
    - ηhyd = Wflo ⁄ Whyd
    - ηmot = Whyd ⁄ Pele
    +

    + \"Input
    + \"Input

    + + +-------- 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 wind pressure coefficient is computed based on the + side ratio of the walls, which is defined as +

    +

    + s = x ⁄ y +

    +

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

    +

    + 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 pressure p at the port ports is computed as +

    +

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

    +

    + where + pw is the atmospheric pressure from the weather bus, + v is the wind speed from the weather bus, and + ρ is the fluid density. +

    + +

    + 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

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

    - where ηhyd is the hydraulic efficiency, - ηmot is the motor efficiency and Q is the - heat released by the motor. + 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). +

    - If per.use_powerCharacteristic=true, then a set of data - points for the power Pele for different volume flow - rates at full speed needs to be provided by the user. Using the flow - work Wflo and the electrical power input - Pele, the total efficiency is computed as + The wind pressure coefficient is computed based on the side ratio of + the walls, which is defined as

    - η = Wflo ⁄ Pele,
    + s = x ⁄ y

    - and the two efficiencies ηhyd and - ηmot are computed as + 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.

    -

    - ηhyd = 1,
    - ηmot = η. +

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

    - However, if per.use_powerCharacteristic=false, then - performance data for ηhyd and - ηmot need to be provided by the user, and hence the - model computes + The pressure p at the port ports is computed as

    - η = ηhyd   ηmot
    - Pele = Wflo ⁄ η. -

    -

    - The efficiency data for the motor are a list of points and - ηmot. + p = pw + Cp 1 ⁄ 2 v2 ρ,

    -
    - Fluid volume of the component -

    - All models can be configured to have a fluid volume at the - low-pressure side. Adding such a volume sometimes helps the solver to - find a solution during initialization and time integration of large - models. + where pw is the atmospheric pressure from the + weather bus, v is the wind speed from the weather bus, and + ρ is the fluid density.

    -
    - Enthalpy change of the component -

    - If per.motorCooledByFluid=true, then the enthalpy change - between the inlet and outlet fluid port is equal to the electrical - power Pele that is consumed by the component. - Otherwise, it is equal to the hydraulic work Whyd. - The parameter addPowerToMedium, which is by default set - to true, can be used to simplify the equations. If - addPowerToMedium = false, then no enthalpy change occurs - between inlet and outlet. This can lead to simpler equations, but the - temperature rise across the component will be zero. In particular for - fans, this simplification may not be permissible. + 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.

    - Differences to models in Modelica.Fluid.Machines + References

    -

    - The models in this package differ from Modelica.Fluid.Machines primarily in - the following points: -

    + -

    - References -

    -

    - Michael Wetter. - Fan and pump model that has a unique solution for any pressure - boundary condition and control signal. Proc. of the 13th - Conference of the International Building Performance Simulation - Association, p. 3505-3512. Chambery, France. August 2013. -

    -------- Errors -------- -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 +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/WD600.mo ---- +---- AixLib/BoundaryConditions/Validation/BESTEST/WD200.mo ---- -------- HTML Code --------

    -

    WD600: Ground Reflactance

    -

    Weather data file : WD600.epw

    -

    Table 1: Site Data for Weather file WD600.epw

    -
    +

    WD200: Low Elevation, Hot and Humid Case.

    +

    Weather data file : WD200.epw

    +

    Table 1: Site Data for Weather file WD200.epw

    +
    - + - + - + - +

    Latitude

    39.833° north

    33.633° north

    Longitude

    104.65° west

    84.433° west

    Altitude

    1650 m

    308 m

    Time Zone

    -7

    -5

    @@ -5805,17 +4857,21 @@ line 484 column 1 - Warning:

    attribute "align" not allowed for HTML5 Rework after comments from pull request #1339. +

  • May 2, 2021, by Ettore Zanetti:
    + Updated weather file as explained in #1478. +
  • - WD600: Ground Reflactance + WD200: Low Elevation, Hot and Humid Case.

    - Weather data file : WD600.epw + Weather data file : WD200.epw

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

    - @@ -5837,7 +4893,7 @@ cellpadding=\"0\" border=\"1\"> @@ -5849,7 +4905,7 @@ cellpadding=\"0\" border=\"1\"> @@ -5861,7 +4917,7 @@ cellpadding=\"0\" border=\"1\"> @@ -5871,554 +4927,765 @@ cellpadding=\"0\" border=\"1\"> line 5 column 2 - Warning: The summary attribute on the
    @@ -5825,7 +4881,7 @@ cellpadding=\"0\" border=\"1\">

    - 39.833° north + 33.633° north

    - 104.65° west + 84.433° west

    - 1650 m + 308 m

    - -7 + -5

    element is obsolete in HTML5 ----- AixLib/Utilities/Math/Functions/biquadratic.mo ---- +---- AixLib/ThermalZones/ReducedOrder/RC/ThreeElements.mo ---- -------- HTML Code -------- - This function computes -

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

    - +

    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 function computes -

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

    +

    + 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 3 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_dp.mo ---- +---- AixLib/Fluid/Movers/Validation/PowerSimplified.mo ---- -------- HTML Code --------

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

    -

    - m = sign(Δp) k √ Δp   + This example compares the power consumed by pumps that + take three different control signals. + Each pump has identical mass flow rate and pressure rise.

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

    -

    - k = m ⁄ √ Δp   + 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 input m_flow_turbulent determines the location of the regularization. + The figure below shows the approximation error for the + power calculation where the speed Nrpm differs from + the nominal speed Nnominal. +

    +

    + \"image\"

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

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

    -

    - m = sign(Δp) k √ Δp -   + This example compares the power consumed by pumps that take three + different control signals. Each pump has identical mass flow rate and + pressure rise.

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

    -

    - k = m ⁄ √ Δp -   + 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 input m_flow_turbulent determines the location of - the regularization. + The figure below shows the approximation error for the power + calculation where the speed Nrpm differs from the + nominal speed Nnominal. +

    +

    + \"image\"

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

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

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

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/Validation/PowerExact.mo ---- +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT.mo ---- -------- HTML 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. + 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.

    -

    - \"image\" +

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

    - - --------- 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/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/LoadAggregation/Validation/ShiftAggregationCells.mo ---- --------- HTML Code -------- -

    - This validation case replicates the load-shifting procedure illustred in the figure below by Cimmino (2014). + 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.

    -

    - \"image\" +

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

    -

    References

    +

    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)

    - 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. + Where the thermal conductivity of the ground lambda_g = 2.4 W/(m K).

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

    - This validation case replicates the load-shifting procedure illustred - in the figure below by Cimmino (2014). + 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.

    -

    - \"image\" +

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

    - References + Test bench schematic

    - 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. + \"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).

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

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

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/CheckValve.mo ---- +---- AixLib/Fluid/HeatExchangers/Radiators/RadiatorEN442_2.mo ---- -------- HTML Code --------

    - Implementation of a hydraulic check valve. - Note that the small reverse flows can still occur with this model. + 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.

    -

    Main equations

    - The basic flow function -

    -

    - m = sign(Δp) k √ Δp  , + 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.

    - with regularization near the origin, is used to compute the pressure drop. - The flow coefficient + 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

    - k = m ⁄ √ Δp   + Qic = sign(Ti-Ta) + (1-fr) UA ⁄ N |Ti-Ta|n +

    + Qir = sign(Ti-Tr) + fr UA ⁄ N |Ti-Tr|n

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

    -

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

    -

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

    - Implementation of a hydraulic check valve. Note that the small - reverse flows can still occur with this model. -

    -

    - Main equations -

    -

    - The basic flow function -

    -

    - m = sign(Δp) k √ Δp -  , -

    -

    - with regularization near the origin, is used to compute the pressure - drop. The flow coefficient -

    -

    - k = m ⁄ √ Δp -   -

    -

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

    -

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

    -

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

    - - --------- 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/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 +

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

    - y = a1 + a2 x + a3 x2 + - ... + 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.

    -------- Errors -------- -line 4 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 ----- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/InteriorWall.mo ---- +---- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/ExteriorWall.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\"/

    +

    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\"/

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

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

    - - --------- Errors -------- -line 7 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/timeGeometric.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. + The chiller COP is computed as the product +

    +

    + COP = ηCarnot,0 COPCarnot ηPL,

    - If t_max > nTim*dt, then a geometrically expanding vector is built 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

    -

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

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

    - where r is the geometric expansion factor. + where the coefficients ai + are declared by the parameter a.

    - If t_max < nTim*dt, then a linearly expanding vector is built 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.

    -

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

    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.

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

    - 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], + 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)).

    - where r is the geometric expansion factor. + The chiller COP is computed as the product +

    +

    + COP = ηCarnot,0 COPCarnot ηPL,

    - If t_max < nTim*dt, then a linearly expanding vector - is built 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

    -

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

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

    +

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

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

    attribute "align" not allowed for HTML5 -line 18 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/Fluid/Geothermal/Borefields/UsersGuide.mo ---- +---- AixLib/Fluid/Storage/UsersGuide.mo ---- -------- HTML 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. +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 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 is a model of a stratified storage tank as shown in the figure below.

    -\"image\" +\"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. +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.

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

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

    -Further information on the tLoaAgg and nCel parameters can -be found in the documentation of - -AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse. +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].

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

    -
    Running simulations
    +
    + +AixLib.Fluid.Storage.StratifiedEnhanced +

    -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. +The model is identical to + +AixLib.Fluid.Storage.Stratified, +except for the following:

    -

    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). +It adds a correction that reduces the numerical dissipation.
    • -Inside the boreholes, the non-advective heat transfer is only in the radial direction. +It does not contain the fluid ports fluPorVol that +connect from the outside to the individual volumes.

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

    -

    -\"image\" +

    + +AixLib.Fluid.Storage.StratifiedEnhancedInternalHex + +

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

    -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. +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\" +\"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. +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 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. +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.

    -

    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. +The heat exchanger is implemented in + +AixLib.Fluid.Storage.BaseClasses.IndirectTankHeatExchanger.

    +
    -------- 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: + This user's guide describes the storage tank models. There are three + storage tank models in the this package.

    - -

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

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

    -

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

    -

    - 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/Geothermal/Borefields/BaseClasses/HeatTransfer/GroundTemperatureResponse.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 κ. -

    -

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

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

    -

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

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

    attribute "align" not allowed for HTML5 -line 17 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 16 column 4 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Storage/UsersGuide.mo ---- --------- HTML 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. -

    -
    - --------- 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 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/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\" -

    -

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

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

    - - --------- 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/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\" -

    -

    - The integral is solved numerically, with the integrand defined in - - AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource_Integrand. -

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

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

    - - --------- Errors -------- -line 5 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. -

    -

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

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

    -

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

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

    attribute "align" not allowed for HTML5 - - ----- AixLib/BoundaryConditions/Validation/BESTEST/WD100.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.

    - - - --------- 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 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/infiniteLineSource.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 -

    -

    - \"image\" -

    -

    - 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 infinite line source solution is given by the exponential integral -

    -

    - \"image\" -

    -

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

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

    -

    - \"image\" -

    -

    - 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 infinite line source solution is given by the exponential - integral -

    -

    - \"image\" -

    -

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

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

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

    attribute "align" not allowed for HTML5 - - ----- AixLib/Controls/SetPoints/Examples/OccupancySchedule.mo ---- --------- HTML 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 -

    - - - --------- 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 - - ----- AixLib/Fluid/HeatExchangers/SensibleCooler_T.mo ---- --------- HTML Code -------- - -

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

    -

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

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

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

    -

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

    - - --------- Errors -------- -line 29 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. -

    - - - --------- Corrected 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: -

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

    -

    - - -

    -

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

    - - --------- 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/BoundaryConditions/WeatherData/ReaderTMY3.mo ---- --------- HTML Code -------- - -

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

    - - - -

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

    - - - -

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

    - - - -

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

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

    +

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

    +

    + \"image\" +

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

    +

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

    +
    +

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

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

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

    - To add new weather data, proceed as follows: + 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.

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

    -

    - The following location data are automatically read from the weather file: +

    + \"Time

    + - -

    Wet bulb temperature

    + +-------- 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 + + +---- AixLib/Fluid/HeatPumps/ReciprocatingWaterToWater.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. + 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\"

    - -

    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: + The rate of heat transferred to the evaporator is given by: +

    +

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

    -

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

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

    References

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

    + + +-------- 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/WD100.mo ---- +-------- HTML Code -------- + +

    WD100: Base Case

    +

    Weather data file : WD100.epw

    +

    Table 1: Site Data for Weather file WD100.epw

    +
    Parameter HSou - Data used to compute weather data. -
    - File - - Use data from file. -
    + + - - - + + - - + + - - + +

    Latitude

    39.833° north

    - Input_HGloHor_HDifHor - - Use global horizontal and diffuse horizontal radiation from input connector. -

    Longitude

    104.65° west

    - Input_HDirNor_HDifHor - - Use direct normal and diffuse horizontal radiation from input connector. -

    Altitude

    1650 m

    - Input_HDirNor_HGloHor - - Use direct normal and global horizontal radiation from input connector. -

    Time Zone

    -7

    - -

    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

    -
      +

      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 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- 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. +

      + + +

      - Different units apply depending on whether data are obtained from a file, or - from a parameter or an input connector: + 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. +

      + - -
    1. +

      - 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.) + Fusion temperature of antifreeze-water mixture at specified mass fraction and + temperature, based on Melinder (2010).

      -
    2. +

      References

      +

      + Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary + Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: + IIR/IIF. +

      + + +

      - 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. + Evaluates a thermophysical property of a mixture, based on correlations proposed + by Melinder (2010).

      -
      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 polynomial has the form

      -

      - \"image\" +

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

      +

      + + +

      +

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

      +

      + + +

      +

      + 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) +

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

      + + + +-------- Corrected 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]. +

      + + +-------- 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/HeatExchangers/PrescribedOutlet.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. +

      +

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

      +

      + τ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. + If no flow resistance is requested, set dp_nominal=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 + +

      +

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

      +

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

      +

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

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

      +

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

      +

      + τ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. If no flow + resistance is requested, set dp_nominal=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 +

      +

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

      +

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

      +

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

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

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

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

      + + + +-------- Corrected Code -------- +This function 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/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 --------

      - 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. + 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);

      -

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

      -

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

      - Implementation + References

      - 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. + Fundamentals of Heat and Mass Transfer (Fourth Edition), Frank + Incropera and David DeWitt, John Wiley and Sons, 1996

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

      - 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. +The package AixLib.BoundaryConditions.Validation.BESTEST +contains the models that are used for the BESTEST validation ASHRAE 2020 for weather data acquisition and postprocessing.

      -

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

      + +

      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: +

      + +

      References

      +

      (Not available yet)

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

      - 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 package AixLib.BoundaryConditions.Validation.BESTEST + contains the models that are used for the BESTEST validation ASHRAE + 2020 for weather data acquisition and postprocessing.

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

      + 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 following variables serve as output and are accessible via - weaBus: + The weather radiation data has to be provided at different + orientations and inclinations.

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

      + Table 2: Azimuth and Slope for Surfaces +

      +
      - Name - - Unit - - Description -
      - HDifHor - - W/m2 - - Horizontal diffuse solar radiation. -
      - - + - - + - - + - - + - - + - - + - - + - - + - - + - - + - - + +
      - HDifNor - - W/m2 +

      + Azimuth +

      - Direct normal radiation. +

      + Slope +

      - HGloHor - - W/m2 +

      + Horizontal +

      - Horizontal global radiation. +

      + 0° from horizontal +

      - HHorIR - - W/m2 +

      + South +

      - Horizontal infrared irradiation. +

      + 90° from horizontal +

      - TBlaSky - - K +

      + East +

      - Output temperature. +

      + 90° from horizontal +

      - TDewPoi - - K +

      + North +

      - Dew point temperature. +

      + 90° from horizontal +

      - TDryBul - - K +

      + West +

      - Dry bulb temperature at ground level. +

      + 90° from horizontal +

      - TWetBul - - K +

      + 45° East of South +

      - Wet bulb temperature. +

      + 90° from horizontal +

      - celHei - - m +

      + 45° West of South +

      - Ceiling height. +

      + 90° from horizontal +

      - cloTim - - s +

      + East +

      - One-based day number in seconds. +

      + 30° from horizontal +

      - lat - - rad +

      + South +

      - Latitude of the location. +

      + 30° from horizontal +

      - lon - - rad +

      + West +

      - Longitude of the location. +

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

      + - - + - - + - - + - - + - - + - - + - - + +
      - nOpa - - 1 +

      + Case +

      - Opaque sky cover [0, 1]. +

      + Days +

      - nTot - - 1 +

      + WD100 +

      - Total sky Cover [0, 1]. +

      + May 4th, July 14th, September 6th +

      - pAtm - - Pa +

      + WD200 +

      - Atmospheric pressure. +

      + May 24th, August 26th +

      - relHum - - 1 +

      + WD300 +

      - Relative humidity. +

      + February 7th, August 13th +

      - solAlt - - rad +

      + WD400 +

      - Altitude angle. +

      + January 24th, July 1st +

      - solDec - - rad +

      + WD500 +

      - Declination angle. +

      + March 1st, September 14th +

      - solHouAng - - rad +

      + WD600 +

      - Solar hour angle. +

      + 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: +

      + +

      + 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/ActiveBeams/Data/BaseClasses/TemperatureDifference.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 +

      +

      + rΔTi= + ΔTi ⁄ ΔTnominal + = + (Twi-Tz) + ⁄ + (Tw,nominal-Tz), +

      +

      + where + Twi is the water inlet temperature, + Tz is the zone air temperature and + Tw,nominal is the nominal water inlet temperature. +

      +

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

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

      +

      + rΔTi= ΔTi ⁄ ΔTnominal = + (Twi-Tz) ⁄ + (Tw,nominal-Tz), +

      +

      + where Twi is the water inlet + temperature, Tz is the zone air temperature and + Tw,nominal is the nominal water inlet temperature. +

      +

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

      + + +-------- 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 following pipe configurations are available in this enumeration: +

      + - - - - + + + - - + - - + - -
      - solTim - - s - - Solar time. -
      + Enumeration + + Description +
      - solZen - - rad + SingleUTube - Zenith angle. + Single U-tube configuration
      - winDir - - rad + DoubleUTubeParallel - Wind direction. + Double U-tube configuration with pipes connected in parallel
      - winSpe - - m/s + DoubleUTubeSeries - Wind speed. + Double U-tube configuration with pipes connected in series
      -

      - Adding new weather data -

      + +

      - To add new weather data, proceed as follows: + This package contains type definitions. +

      + +-------- Errors -------- +line 8 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 + + +---- AixLib/Fluid/Chillers/BaseClasses/Carnot.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. +

      +

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

      -
        -
      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 + Implementation

      - The following location data are automatically read from the weather - file: + 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.

      +
    3. March 28, 2017, by Felix Buenning:
      + Added temperature difference between fluids in condenser and + evaporator. The difference is based on discussions with Emerson + Climate Technologies.
      + This is for #698. +
    4. +
    5. January 2, 2017, by Filip Jorissen:
      + Removed option for choosing what temperature should be used to + compute the Carnot efficiency. This is for issue 497. +
    6. +
    7. January 26, 2016, by Michael Wetter:
      + First implementation of this base class. +
    8. + + +-------- 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 +

      +

      + ṁ = 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. +

      - Wet bulb temperature + Assumptions

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

      + 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\" +

      - Using constant or user-defined input signals for weather data + Important parameters

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

      -

      - 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. + If the parameter linearized is set to true, + then the pressure drop is computed as a linear function of the mass + flow rate.

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

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

      - - - - - - - - - - - - - - - - - - - - - - -
      - 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 + Notes

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

      - 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. + For a model that uses the hydraulic parameter and flow velocity at + nominal conditions as a parameter, use AixLib.Fluid.FixedResistances.HydraulicDiameter.

      -

      - 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 + Implementation

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

        +

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

        +
          +
        • September 21, 2018, by Michael Wetter:
          + Decrease value of deltaM(min=...) attribute. See + #1026. +
        • +
        • February 3, 2018, by Filip Jorissen:
          + Revised implementation of pressure drop equation such that it + depends on from_dp when linearized=true. + See #884. +
        • +
        • December 1, 2016, by Michael Wetter:
          + Simplified model by removing the geometry dependent parameters into + the new model AixLib.Fluid.FixedResistances.HydraulicDiameter. +
        • +
        • 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.
        • -
        • -

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

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

          +
        • August 5, 2014, by Michael Wetter:
          + Corrected error in documentation of computation of k.
        • -
        • 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. +
        • May 29, 2014, by Michael Wetter:
          + Removed undesirable annotation Evaluate=true.
        • -
      -

      - Implementation -

      -
      - Start and end data for annual weather data files -
      +
    9. October 8, 2013, by Michael Wetter:
      + Removed parameter show_V_flow. +
    10. +
    11. December 14, 2012 by Michael Wetter:
      + Renamed protected parameters for consistency with the naming + conventions. +
    12. +
    13. 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. +
    14. +
    15. May 30, 2008 by Michael Wetter:
      + Added parameters use_dh and deltaM for + easier parameterization. +
    16. +
    17. July 20, 2007 by Michael Wetter:
      + First implementation. +
    18. + + +-------- 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 + + +---- AixLib/Fluid/BaseClasses/FlowModels/basicFlowFunction_dp.mo ---- +-------- HTML 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. +

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

      - 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. + Function that computes the pressure drop of flow elements as +

      +

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

      -
      - 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. + with regularization near the origin. Therefore, the flow coefficient + is

      -

      - \"image\" +

      + k = m ⁄ √ Δp +   +

      +

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

      -

      - References -

      - + +-------- 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/Humidifiers/Humidifier_u.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. +

      +

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

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

      +

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

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

      + This data record contains the coefficients for perfect gases. +

      + + + +

      + This package contains a thermally perfect model of moist air. +

      +

      + A medium is called thermally perfect if +

      + +

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

      +

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

      +

      References

      +

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

      + This data record contains the coefficients for perfect gases. +

      + +

      + This package contains a thermally perfect model of moist air. +

      +

      + A medium is called thermally perfect if +

      + +

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

      +

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

      +

      + References +

      +

      + Bower, William B. A primer in fluid mechanics: Dynamics of flows + in one space dimension. CRC Press. 1998. +

      + -------- 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 25 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Media/Antifreeze/PropyleneGlycolWater.mo ---- +---- AixLib/Fluid/Movers/BaseClasses/Characteristics/pressure.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. -

      +

      + This function computes the fan static + pressure raise as a function of volume flow rate and revolution in the form +

      +

      + Δp = rN2   s(V̇/rN, d), +

      +

      + 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

      +

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

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

      + This function computes the fan static pressure raise as a function of + volume flow rate and revolution in the form +

      +

      + Δp = rN2   s(V̇/rN, d), +

      +

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

      +

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

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

      attribute "align" not allowed for HTML5 + + +---- AixLib/BoundaryConditions/WeatherData/ReaderTMY3.mo ---- +-------- HTML Code -------- + +

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

      + + -

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

      -

      References

      +

      Implementation

      - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. + 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.

      - Fusion temperature of antifreeze-water mixture at specified mass fraction and - temperature, based on Melinder (2010). + 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.

      -

      References

      +

      Implementation

      - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. + 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.

      - Evaluates a thermophysical property of a mixture, based on correlations proposed - by Melinder (2010). + 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 polynomial has the form + 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.

      -

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

      Output to weaBus

      +

      + The following variables serve as output and are accessible via weaBus:

      -

      References

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

      - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. + To add new weather data, proceed as follows:

      - - - -

      - 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): -

      + 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

    - Medium = AixLib.Media.Antifreeze.PropyleneGlycolWater(property_T=293.15, X_a=0.40) + The following location data are automatically read from the weather file:

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

    - -

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

    -

    - - -

    -

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

    -

    - - -

    -

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

    - - --------- 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/Sensors/LatentEnthalpyFlowRate.mo ---- --------- HTML Code -------- - +

  • + the time zone relative to Greenwich Mean Time, timZone. +
  • + + +

    Wet bulb temperature

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

    -

    - Ḣtot = Ḣsen + Ḣlat, + +

    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:

    +

    - where - sen = ṁ (1-Xw) cp,air, - then this sensor outputs Ḣ = Ḣlat. + 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.

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

      + 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: +

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

    - For a sensor that measures - tot, use - - AixLib.Fluid.Sensors.EnthalpyFlowRate.
    - For a sensor that measures - sen, use - - AixLib.Fluid.Sensors.SensibleEnthalpyFlowRate. + 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 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\"

    +

    References

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

    -

    - Ḣtot = Ḣsen + Ḣlat, +

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

    +

    - where sen = ṁ (1-Xw) - cp,air, then this sensor outputs Ḣ = - Ḣlat. + 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 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. + 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.

    +

    - For a sensor that measures tot, use AixLib.Fluid.Sensors.EnthalpyFlowRate.
    - - For a sensor that measures sen, use AixLib.Fluid.Sensors.SensibleEnthalpyFlowRate. + 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 +

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

    - --------- Errors -------- -line 6 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\" -

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

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

    - The figure below shows the approximation error for the power - calculation where the speed Nrpm differs from the - nominal speed Nnominal. -

    -

    - \"image\" + To add new weather data, proceed as follows:

    - - --------- Errors -------- -line 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowAIT.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). -

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

    + +

    + Location data that are read automatically from the weather data file +

    - Note that these three models are identical, except for the pipe model - that is used: + The following location data are automatically read from the weather + file:

    -

    - 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 + Wet bulb temperature

    - \"Schematic -

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

    - Calibration + Using constant or user-defined input signals for weather data

    - 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). + 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:

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

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/Sensors/UsersGuide.mo ---- --------- HTML 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. + 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.

    -

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

    - - - -
    Correct use - \"image\" + + + + + + + + - - - - -
    + Parameter *Sou + + Data used to compute weather data. +
    + File
    Not recommended - \"image\" + + Use data from file.
    - -

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

    -
      -
    • -

      - -Sensors for quantities that depend on the direction of the mass flow rate but -not of its magnitude: - -Such quantities include density, mass fraction, PPM, relative humidity, specific enthalpy, specific entropy and trace substances. -Not that these are all quantities that are carried by the fluid that flows through the sensor. -For these sensors, if the parameter allowFlowReversal=true is set (which is the default setting), -then it is strongly recommended to configure them -as a dynamic sensor. This is the default setting.
      -Configuring a sensor as a dynamic sensor is done by setting the time constant to a non-zero -value. Typically, setting tau=10 seconds yields good results. -For tau=0, numerical problems may occur if the mass flow rate is close to zero -and allowFlowReversal=true.
      -If allowFlowReversal=false, then the measurement of these sensors only depends on properties -at port_a. -If the mass flow rate at port_a is a ≤ 0, -i.e., fluid flows from port_b to port_a, -the model still assumes a > 0. Hence there are no numerical problems; -but use of the sensor output may yield wrong results. -Therefore, only set allowFlowReversal=false if you can guarantee a ≥ 0. -

      -
    • -
    • -

      - -Sensors for quantities that are the product of mass flow rate times a measured fluid property: - -Such quantities include volumentric flow rate or enthalpy flow rate. -For these quantities, sensors are by default configured as steady-state sensor. -These sensors may be configured by the user -as a dynamic sensor by setting tau > 0, but there is typically no benefit as these sensors typically -do not cause numerical problems. -The reason is that these sensors multiply the quantity that is carried by the flow, -such as specific enthalpy h by the mass flow rate -to compute the measured signal Ḣ=ṁ h. -Hence, as the mass flow rate goes to zero, the sensor output -signal also goes to zero, which avoids numerical problems. -

      -
    • -
    • -

      -Static pressure measurements: - -For static pressure measurements, sensors always output the instantaneous measurement. -These sensors cannot be configured to be dynamic. -

      -
    • -
    -

    -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
    + Parameter + + Use value specified by the parameter. +
    + Input + + Use value from the input connector. +
    - -

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

    -

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

    -

    Implementation

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

    -The above equation is implemented in such a way that it is differentiable in the mass flow rate. + 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.

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

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

    - This package contains models of sensors. There are models with one - and with two fluid ports. -

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

    - Selection and parameterization of sensor models + 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 +

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

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

    - - - - - - - - - -
    - Correct use - - \"image\" -
    - Not recommended - - \"image\" -
    -

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

    + \"image\"

    +

    + References +

      -
    • -

      - Sensors for quantities that depend on the direction of the - mass flow rate but not of its magnitude: Such quantities - include density, mass fraction, PPM, relative humidity, specific - enthalpy, specific entropy and trace substances. Not that these - are all quantities that are carried by the fluid that flows - through the sensor. For these sensors, if the parameter - allowFlowReversal=true is set (which is the default - setting), then it is strongly recommended to configure them as a - dynamic sensor. This is the default setting.
      - Configuring a sensor as a dynamic sensor is done by setting the - time constant to a non-zero value. Typically, setting - tau=10 seconds yields good results. For - tau=0, numerical problems may occur if the mass flow - rate is close to zero and - allowFlowReversal=true.
      - If allowFlowReversal=false, then the measurement of - these sensors only depends on properties at port_a. - If the mass flow rate at port_a is a - ≤ 0, i.e., fluid flows from port_b to - port_a, the model still assumes a - > 0. Hence there are no numerical problems; but use of the - sensor output may yield wrong results. Therefore, only set - allowFlowReversal=false if you can guarantee - a ≥ 0. -

      +
    • Wilcox S. and W. Marion. Users Manual for TMY3 Data Sets. + Technical Report, NREL/TP-581-43156, revised May 2008.
    • -
    • -

      - Sensors for quantities that are the product of mass flow rate - times a measured fluid property: Such quantities include - volumentric flow rate or enthalpy flow rate. For these - quantities, sensors are by default configured as steady-state - sensor. These sensors may be configured by the user as a dynamic - sensor by setting tau > 0, but there is typically - no benefit as these sensors typically do not cause numerical - problems. The reason is that these sensors multiply the quantity - that is carried by the flow, such as specific enthalpy h - by the mass flow rate to compute the measured signal - Ḣ=ṁ h. Hence, as the mass flow rate goes to zero, the - sensor output signal also goes to zero, which avoids numerical - problems. -

      +
    +
      +
    • September 6, 2021, by Ettore Zanetti:
      + Changed alt and lat to real inputs.
      + This is for IBPSA, + #1477.
    • -
    • -

      - Static pressure measurements: For static pressure - measurements, sensors always output the instantaneous - measurement. These sensors cannot be configured to be dynamic. -

      +
    • May 2, 2021, by Ettore Zanetti:
      + Added altitude to parameters.
      + This is for IBPSA, + #1477. +
    • +
    • 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.
    -

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

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

    -

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

    -

    - Implementation -

    -

    - The above equation is implemented in such a way that it is - differentiable in the mass flow rate. -

    -

    - 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 +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/FMI/ExportContainers/HVACZone.mo ---- +---- AixLib/Fluid/FMI/ExportContainers/HVACZones.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. + to be exported as an FMU and that serves multiple zones.

    Typical use and important parameters

    - To use this model as a container for an FMU, extend + 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.HVACZone - shows how a simple HVAC system can be implemented and exported as + + 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. @@ -13908,7 +12723,7 @@ line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 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 + heat added by the HVAC system need to implement an equation such as

    Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon), @@ -13924,15 +12739,18 @@ line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 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) + 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. - All fluid streams at port ports are at the same + 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 @@ -13940,27 +12758,29 @@ line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 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 + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones 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. + 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. + model conserves mass for each thermal zone.

    - This model does not impose any pressure, other than setting the pressure - of all fluid connections to ports to be equal. + 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 @@ -13983,7 +12803,7 @@ line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 See #1050.

  • - April 15, 2016, by Michael Wetter:
    + May 25, 2016, by Michael Wetter:
    First implementation.
  • @@ -13991,21 +12811,21 @@ line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 -------- 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. + exported as an FMU and that serves multiple zones.

    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 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 @@ -14031,7 +12862,7 @@ line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 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 + compute the heat added by the HVAC system need to implement an equation such as

    @@ -14049,46 +12880,51 @@ line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 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 + 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. 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, + 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.

    See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone for a + \"modelica://AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones\"> + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones 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. + 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. + model conserves mass for each thermal zone.

    - 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 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 @@ -14096,5622 +12932,7041 @@ line 197 column 1 - Warning:

    attribute "align" not allowed for HTML5 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 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. +

    +
      +
    • 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 60 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowULg.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. +

    +

    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

    +

    + 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)

    + +
      +
    • + 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. +
    • +
    • + November 24, 2016 by Bram van der Heijde:
      Add pipe thickness for wall + capacity calculation and expand documentation section.
    • +
    • April 2, 2016 by Bram van der Heijde:
      Change thermal conductivity and + put boundary condition in K. +
    • +
    • Januar 26, 2016 by Carles Ribas:
      First implementation. +
    • +
    + +-------- 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. +

    +

    + Test bench schematic +

    +

    + \"Schematic +

    +

    + Calibration +

    +

    + 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) +

    +
      +
    • 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. +
    • +
    • November 24, 2016 by Bram van der Heijde:
      + Add pipe thickness for wall capacity calculation and expand + documentation section. +
    • +
    • April 2, 2016 by Bram van der Heijde:
      + Change thermal conductivity and put boundary condition in K. +
    • +
    • Januar 26, 2016 by Carles Ribas:
      + First implementation. +
    • +
    + +-------- Errors -------- +line 25 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 + + +---- AixLib/Controls/Continuous/NumberOfRequests.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. +

    + +
      +
    • + November 21, 2011, by Michael Wetter:
      + Improved documentation. +
    • +
    • + November 25, 2008, by Michael Wetter:
      + First implementation. +
    • +
    + +-------- 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.

      -
    • January 18, 2019, by Jianjun Hu:
      - Limited the media choice to moist air only. See #1050. +
    • November 21, 2011, by Michael Wetter:
      + Improved documentation.
    • -
    • April 15, 2016, by Michael Wetter:
      +
    • November 25, 2008, by Michael Wetter:
      First implementation.
    -------- Errors -------- -line 47 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 7 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Fluid/HeatExchangers/ActiveBeams/UsersGuide.mo ---- +---- AixLib/Fluid/FixedResistances/Junction.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 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\" +

    +

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

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

    + +
      +
    • + April 14, 2020, by Michael Wetter:
      + Changed homotopyInitialization to a constant.
      + This is for + IBPSA, #1341. +
    • +
    • + February 26, 2020, by Michael Wetter:
      + Changed icon to display its operating state.
      + This is for + #1294. +
    • +
    • + March 26, 2018 by Filip Jorissen:
      + Removed final allowFlowReversal=true from all resistances + since this overrides the default simplification when the flow + is not bidirectional. + This change can lead to smaller algebraic loops. + This is for + issue 898. +
    • +
    • + December 1, 2016, by Michael Wetter:
      + Renamed model from SplitterFixedResistanceDpM to + FlowJunction and removed the parameters + use_dh, dh and ReC.
      + This is for + issue 451. +
    • +
    • + October 14, 2016 by Michael Wetter:
      + Added to Annex 60 library.
      + Updated comment for parameter use_dh.
      + This is for + issue 451. +
    • +
    • + Removed parameter dynamicBalance that overwrote the setting + of energyDynamics and massDynamics. + This is for + + Annex 60, issue 411. +
    • +
    • + February 1, 2012 by Michael Wetter:
      + Expanded documentation. +
    • +
    • + August 4, 2011 by Michael Wetter:
      + Added final allowFlowReversal=true to all resistances since it is impractical + to avoid flow reversal in large flow networks where such a setting may be useful. +
    • +
    • + June 11, 2008 by Michael Wetter:
      + Based class on + + AixLib.Fluid.BaseClasses.PartialThreeWayFixedResistance. +
    • +
    • + July 20, 2007 by Michael Wetter:
      + First implementation. +
    • +
    + +-------- Corrected Code -------- +

    + Model of a flow junction with an optional fixed resistance in each + flow leg and an optional mixing volume at the junction.

    - -

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

    -For the heating water stream, the temperature difference ΔTh -used for the calculation of the modification factor fΔT(·) is + 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.

    -

    -ΔTh = Thw-Tz, +

    + \"image\"

    -where Thw is the hot water temperature entering the convector in heating mode -and Tz is the zone air temperature. + 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

    - -

    Dynamics

    +
    +   V = sum(abs(m_flow_nominal[:])/3)*tau/rho_nominal
    + 

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

    +
      +
    • April 14, 2020, by Michael Wetter:
      + Changed homotopyInitialization to a constant.
      + This is for IBPSA, + #1341. +
    • +
    • February 26, 2020, by Michael Wetter:
      + Changed icon to display its operating state.
      + This is for #1294. +
    • +
    • March 26, 2018 by Filip Jorissen:
      + Removed final allowFlowReversal=true from all + resistances since this overrides the default simplification when + the flow is not bidirectional. This change can lead to smaller + algebraic loops. This is for issue 898. +
    • +
    • December 1, 2016, by Michael Wetter:
      + Renamed model from SplitterFixedResistanceDpM to + FlowJunction and removed the parameters + use_dh, dh and ReC.
      + This is for issue 451. +
    • +
    • October 14, 2016 by Michael Wetter:
      + Added to Annex 60 library.
      + Updated comment for parameter use_dh.
      + This is for issue 451. +
    • +
    • Removed parameter dynamicBalance that overwrote the + setting of energyDynamics and massDynamics. + This is for Annex 60, issue + 411. +
    • +
    • February 1, 2012 by Michael Wetter:
      + Expanded documentation. +
    • +
    • August 4, 2011 by Michael Wetter:
      + Added final allowFlowReversal=true to all resistances + since it is impractical to avoid flow reversal in large flow + networks where such a setting may be useful. +
    • +
    • June 11, 2008 by Michael Wetter:
      + Based class on + AixLib.Fluid.BaseClasses.PartialThreeWayFixedResistance. +
    • +
    • July 20, 2007 by Michael Wetter:
      + First implementation. +
    • +
    -

    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 23 column 2 - Warning:

    attribute "align" not allowed for HTML5 --------- Corrected Code -------- + +---- 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

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

    - 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. +To access these weather data from the graphical model editor, +proceed as follows:

    +
      +
    1. - 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. +Create an instance of + +AixLib.BoundaryConditions.WeatherData.ReaderTMY3.

      -

      - Model equations for cooling -

      +
    2. +
    3. - 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. +Create an instance of + +AixLib.BoundaryConditions.WeatherData.Bus.

      +
    4. +
    5. - 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. +Draw a connection between these two instances.

      +
    6. +
    7. - 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. +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\"

    - The primary air contribution is -

    -

    - Qsa = ṁsa cp,sa - (Tsa-Tz) +For the surface azimuth and tilt, the enumerations + +AixLib.Types.Azimuth +and + +AixLib.Types.Tilt +can be used.

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

    - 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 ), + 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 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, + 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.

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

    - Model equations for heating + Conventions for surface azimuth and tilt

    - 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. + To compute the solar irradiation, parameters such as the surface + azimuth and the surface tilt are defined as shown in the following + three figures.

    -

    - For the heating water stream, the temperature difference - ΔTh used for the calculation of the - modification factor fΔT(·) is +

    + \"image\"

    -

    - ΔTh = Thw-Tz, +

    + \"image\" +

    +

    + \"image\"

    - where Thw is the hot water temperature entering the - convector in heating mode and Tz is the zone air - temperature. + For the surface azimuth and tilt, the enumerations AixLib.Types.Azimuth and + AixLib.Types.Tilt can be + used.

    -

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

    - Energy balance + References

    -

    - 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 +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/Movers/BaseClasses/Characteristics/efficiency.mo ---- +---- AixLib/Utilities/Math/Functions/polynomial.mo ---- -------- HTML Code -------- -

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

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

    - η = 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. + y = a1 + a2 x + a3 x2 + ...

    • - December 2, 2016, by Michael Wetter:
      - Removed min attribute as otherwise numerical noise can cause - the assertion on the limit to fail.
      + December 14, 2016, by Michael Wetter:
      + Removed derivative annotation.
      This is for - #606. -
    • -
    • - November 22, 2014, by Michael Wetter:
      - Corrected documentation as curve uses - as an independent variable. + issue 602.
    • - September 30, 2014, by Filip Jorissen:
      - Changed polynomial to be evaluated at V_flow - instead of r_V. + March 30, 2011, by Michael Wetter:
      + Added zeroDerivative keyword.
    • - 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. + March 2, by Michael Wetter:
      + Removed redundant smoothOrder annotation.
    • - September 28, 2011, by Michael Wetter:
      + February 29, 2009 by Michael Wetter:
      First implementation.
    -------- 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. +This function computes a polynomial of arbitrary order. The polynomial +has the form +

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

      -
    • December 2, 2016, by Michael Wetter:
      - Removed min attribute as otherwise numerical noise can - cause the assertion on the limit to fail.
      +
    • December 14, 2016, by Michael Wetter:
      + Removed derivative annotation.
      This is for #606. -
    • -
    • November 22, 2014, by Michael Wetter:
      - Corrected documentation as curve uses as an independent - variable. + \"https://github.com/ibpsa/modelica-ibpsa/issues/602\">issue 602.
    • -
    • September 30, 2014, by Filip Jorissen:
      - Changed polynomial to be evaluated at V_flow instead - of r_V. +
    • March 30, 2011, by Michael Wetter:
      + Added zeroDerivative keyword.
    • -
    • 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. +
    • March 2, by Michael Wetter:
      + Removed redundant smoothOrder annotation.
    • -
    • September 28, 2011, by Michael Wetter:
      +
    • February 29, 2009 by Michael Wetter:
      First implementation.
    -------- Errors -------- -line 6 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/ActiveBeams/BaseClasses/Convector.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/infiniteLineSource.mo ---- -------- HTML Code --------

    - In cooling mode, this model adds heat to the water stream. The heat added is equal to: + 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

    -

    - QBeam = Qrated fΔT fSA fW +

    + \"image\"

    - In heating mode, the heat is removed from the water stream. + 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 infinite line source solution is given by the exponential integral +

    +

    + \"image\" +

    +

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

    • - March 3, 2022, by Michael Wetter:
      - Removed massDynamics.
      - This is for - issue 1542. -
    • -
    • - April 14, 2020, by Michael Wetter:
      - Changed homotopyInitialization to a constant.
      - This is for - IBPSA, #1341. -
    • -
    • - November 2, 2016, by Michael Wetter:
      - Made assignment of senTem.y final. -
    • -
    • - June 13, 2016, by Michael Wetter:
      - Revised implementation. -
    • -
    • - May 20, 2016, by Alessandro Maccarini:
      + March 22, 2018 by Massimo Cimmino:
      First implementation.
    -------- Corrected Code --------

    - In cooling mode, this model adds heat to the water stream. The heat - added is equal to: + 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

    -

    - QBeam = Qrated fΔT - fSA fW +

    + \"image\"

    - In heating mode, the heat is removed from the water stream. + 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 infinite line source solution is given by the exponential + integral +

    +

    + \"image\" +

    +

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

      -
    • March 3, 2022, by Michael Wetter:
      - Removed massDynamics.
      - This is for issue - 1542. -
    • -
    • April 14, 2020, by Michael Wetter:
      - Changed homotopyInitialization to a constant.
      - This is for IBPSA, - #1341. -
    • -
    • November 2, 2016, by Michael Wetter:
      - Made assignment of senTem.y final. -
    • -
    • June 13, 2016, by Michael Wetter:
      - Revised implementation. -
    • -
    • May 20, 2016, by Alessandro Maccarini:
      +
    • March 22, 2018 by Massimo Cimmino:
      First implementation.
    -------- Errors -------- -line 5 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/Geothermal/Borefields/BaseClasses/Boreholes/BaseClasses/Functions/convectionResistanceCircularPipe.mo ---- +---- AixLib/Fluid/HeatPumps/Compressors/ReciprocatingCompressor.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). + 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) ).

    - 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 + The power consumed by the compressor is given by a linear efficiency relation:

    - Nu = 0.023   Re0.8   Prn, + P = PTheoretical / η + PLoss,constant.

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

    - 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. + H. Jin. + + Parameter estimation based models of water source heat pumps. + + PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002.

    • - July 10, 2018, by Alex Laferrière:
      - Added laminar flow and smooth laminar-turbulent transition. - Revised documentation. -
    • -
    • - February 14, 2014, by Michael Wetter:
      - Removed unused input rBor. - Revised documentation. + January 25, 2019, by Michael Wetter:
      + Added start value to avoid warning in JModelica.
    • - January 24, 2014, by Michael Wetter:
      - Revised implementation. - Changed cpFluid to cpMed to use consistent notation. - Added regularization for computation of convective heat transfer coefficient to - avoid an event and a non-differentiability. + May 30, 2017, by Filip Jorissen:
      + Removed pressure_error as + this is replaced by + + AixLib.Fluid.HeatPumps.Compressors.BaseClasses.TemperatureProtection. + See #769.
    • - January 23, 2014, by Damien Picard:
      + November 14, 2016, by Massimo Cimmino:
      First implementation.
    -------- 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). + 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) + ).

    - 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 + The power consumed by the compressor is given by a linear efficiency + relation:

    - Nu = 0.023   Re0.8   Prn, + P = PTheoretical / η + PLoss,constant.

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

    - 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. + H. Jin. Parameter estimation based models of water source heat + pumps. PhD Thesis. Oklahoma State University. Stillwater, + Oklahoma, USA. 2002.

      -
    • July 10, 2018, by Alex Laferrière:
      - Added laminar flow and smooth laminar-turbulent transition. Revised - documentation. -
    • -
    • February 14, 2014, by Michael Wetter:
      - Removed unused input rBor. Revised documentation. +
    • January 25, 2019, by Michael Wetter:
      + Added start value to avoid warning in JModelica.
    • -
    • January 24, 2014, by Michael Wetter:
      - Revised implementation. Changed cpFluid to - cpMed to use consistent notation. Added regularization - for computation of convective heat transfer coefficient to avoid an - event and a non-differentiability. +
    • May 30, 2017, by Filip Jorissen:
      + Removed pressure_error as this is replaced by + AixLib.Fluid.HeatPumps.Compressors.BaseClasses.TemperatureProtection. + See #769.
    • -
    • January 23, 2014, by Damien Picard:
      +
    • November 14, 2016, by Massimo Cimmino:
      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 ----- AixLib/Fluid/HeatExchangers/Heater_T.mo ---- +---- AixLib/Fluid/Actuators/Valves/TwoWayTable.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. + Two way valve with opening characteristic that is configured through + a table.

    - 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 + 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 - τ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 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})
    +  

    - Optionally, this model can have a flow resistance. - Set dp_nominal = 0 to disable the flow friction calculation. + Note, however, that + + AixLib.Fluid.Actuators.Valves.TwoWayLinear provides a more + efficient implementation for this simple case.

    - 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 - + The parameter flowCharacteristics must meet the following + requirements, otherwise the model stops with an error:

    -

    Limitations

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

    - If the flow is from port_b to port_a, - then the enthalpy of the medium is not affected by this model. + 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.

    -

    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. + For an example that specifies an opening characteristics, see + + AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable.

    • - September 10, 2018, by Michael Wetter:
      - Corrected missing propagation of initial conditions.
      + 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 - - AixLib, #1016. + #1498.
    • - May 3, 2017, by Michael Wetter:
      - First implementation.
      - This is for - - AixLib, #763. + 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 --------

    - 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. + Two way valve with opening characteristic that is configured through + a table.

    - 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 + 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 τ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 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})
    +  

    - Optionally, this model can have a flow resistance. Set - dp_nominal = 0 to disable the flow friction calculation. + Note, however, that AixLib.Fluid.Actuators.Valves.TwoWayLinear + provides a more efficient implementation for this simple case.

    - 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 + The parameter flowCharacteristics must meet the + following requirements, otherwise the model stops with an error:

    -

    - Limitations -

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

    - If the flow is from port_b to port_a, then - the enthalpy of the medium is not affected by this model. + 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.

    -

    - 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. + For an example that specifies an opening characteristics, see + + AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable.

      -
    • September 10, 2018, by Michael Wetter:
      - Corrected missing propagation of initial conditions.
      +
    • 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 AixLib, - #1016. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1498\">#1498.
    • -
    • May 3, 2017, by Michael Wetter:
      - First implementation.
      - This is for AixLib, - #763. +
    • 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 29 column 2 - Warning:

    attribute "align" not allowed for HTML5 +line 14 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/gFunction.mo ---- +---- AixLib/Fluid/HeatExchangers/ActiveBeams/UsersGuide.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 -

    -

    - \"image\" -

    -

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

    -

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

    -

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

    -

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

    -

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

    -

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

    -

    - Eskilson, P. 1987. Thermal analysis of heat extraction boreholes. Ph.D. - Thesis. Department of Mathematical Physics. University of Lund. Sweden. -

    -

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

    - -
      -
    • - March 22, 2018 by Massimo Cimmino:
      - 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 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\" +

    +\"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 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. +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 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. +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 ),

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

    -

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

    + ΔTc = Tcw-Tz,

    -

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

    -

    - References -

    + +

    Model equations for heating

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

    - 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. +For the heating water stream, the temperature difference ΔTh +used for the calculation of the modification factor fΔT(·) is

    -

    - Eskilson, P. 1987. Thermal analysis of heat extraction - boreholes. Ph.D. Thesis. Department of Mathematical Physics. - University of Lund. Sweden. +

    +ΔTh = Thw-Tz,

    - 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. +where Thw is the hot water temperature entering the convector in heating mode +and Tz is the zone air temperature.

    -
      -
    • 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 +

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

    ----- AixLib/BoundaryConditions/UsersGuide.mo ---- --------- HTML Code -------- +

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

    -

    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

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

    -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. + 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\"

    -To access these weather data from the graphical model editor, -proceed as follows: + 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.

    -
      -
    1. -Create an instance of - -AixLib.BoundaryConditions.WeatherData.ReaderTMY3. + 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.

      -
    2. -
    3. +

      + Model equations for cooling +

      -Create an instance of - -AixLib.BoundaryConditions.WeatherData.Bus. + 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.

      -
    4. -
    5. -Draw a connection between these two instances. + 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.

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

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

    -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. + The heat flow rate of the beam convector Qc,Beam is + determined using the rated capacity which is modified by three + separate functions as

    - -

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

    + Qc,Beam = Qc,nominal fΔT ( + ΔTc ⁄ ΔTc,nominal ) fsa( + ṁsa ⁄ ṁsa,nominal ) fw( + ṁc,w ),

    -

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

    - To access these weather data from the graphical model editor, proceed - as follows: + 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.

    -
      -
    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 + Model equations for heating

    - 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\" + 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.

    -

    - \"image\" +

    + For the heating water stream, the temperature difference + ΔTh used for the calculation of the + modification factor fΔT(·) is

    -

    - \"image\" +

    + ΔTh = Thw-Tz,

    - For the surface azimuth and tilt, the enumerations AixLib.Types.Azimuth and - AixLib.Types.Tilt can be - used. + where Thw is the hot water temperature entering the + convector in heating mode and Tz is the zone air + temperature.

    +

    + Dynamics +

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

    - References + 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 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 +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/FixedResistances/Junction.mo ---- +---- AixLib/Controls/Continuous/LimPID.mo ---- -------- HTML Code --------

    - Model of a flow junction with an optional fixed resistance in each flow leg - and an optional mixing volume at the junction. + PID controller in the standard form +

    +

    + y = k   ( e(t) + 1 ⁄ Ti   ∫ e(s) ds + Td de(t)⁄dt ),

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

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

    -

    - \"image\" +

    + 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:

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

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

    -
    -   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. + R. Montgomery and R. McDowall (2008). + \"Fundamentals of HVAC Control Systems.\" + American Society of Heating Refrigerating and Air-Conditioning Engineers Inc. Atlanta, GA.

    +
    • - April 14, 2020, by Michael Wetter:
      - Changed homotopyInitialization to a constant.
      - This is for - IBPSA, #1341. -
    • -
    • - February 26, 2020, by Michael Wetter:
      - Changed icon to display its operating state.
      - This is for - #1294. -
    • -
    • - March 26, 2018 by Filip Jorissen:
      - Removed final allowFlowReversal=true from all resistances - since this overrides the default simplification when the flow - is not bidirectional. - This change can lead to smaller algebraic loops. - This is for - issue 898. + 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.
    • - December 1, 2016, by Michael Wetter:
      - Renamed model from SplitterFixedResistanceDpM to - FlowJunction and removed the parameters - use_dh, dh and ReC.
      - This is for - issue 451. + March 9, 2020, by Michael Wetter:
      + Corrected wrong unit declaration for parameter k.
      + This is for issue 1316.
    • - October 14, 2016 by Michael Wetter:
      - Added to Annex 60 library.
      - Updated comment for parameter use_dh.
      - This is for - issue 451. + 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.
    • - Removed parameter dynamicBalance that overwrote the setting - of energyDynamics and massDynamics. - This is for - - Annex 60, issue 411. + September 29, 2016, by Michael Wetter:
      + Refactored model.
    • - February 1, 2012 by Michael Wetter:
      - Expanded documentation. + 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.
    • -
    • - August 4, 2011 by Michael Wetter:
      - Added final allowFlowReversal=true to all resistances since it is impractical - to avoid flow reversal in large flow networks where such a setting may be useful. +
    • July 18, 2016, by Philipp Mehrfeld:
      + Added integrator reset. + This is for issue 494.
    • - June 11, 2008 by Michael Wetter:
      - Based class on - - AixLib.Fluid.BaseClasses.PartialThreeWayFixedResistance. + 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.
    • - July 20, 2007 by Michael Wetter:
      + February 24, 2010, by Michael Wetter:
      First implementation.
    -------- Corrected Code --------

    - Model of a flow junction with an optional fixed resistance in each - flow leg and an optional mixing volume at the junction. + PID controller in the standard form +

    +

    + y = k   ( e(t) + 1 ⁄ Ti   ∫ e(s) ds + + Td de(t)⁄dt ),

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

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

    -

    - \"image\" +

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

    - 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 + Through the parameter controllerType, the controller can + be configured as P, PI, PD or PID controller. The default + configuration is PI.

    -
    -   V = sum(abs(m_flow_nominal[:])/3)*tau/rho_nominal
    - 
    +
    + Direct or reverse acting +

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

      -
    • April 14, 2020, by Michael Wetter:
      - Changed homotopyInitialization to a constant.
      - This is for IBPSA, - #1341. +
    • for a heating coil with a two-way valve, leave + reverseActing = true, but
    • -
    • February 26, 2020, by Michael Wetter:
      - Changed icon to display its operating state.
      +
    • 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 #1294. -
    • -
    • March 26, 2018 by Filip Jorissen:
      - Removed final allowFlowReversal=true from all - resistances since this overrides the default simplification when - the flow is not bidirectional. This change can lead to smaller - algebraic loops. This is for issue 898. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1365\">issue + 1365.
    • -
    • December 1, 2016, by Michael Wetter:
      - Renamed model from SplitterFixedResistanceDpM to - FlowJunction and removed the parameters - use_dh, dh and ReC.
      +
    • March 9, 2020, by Michael Wetter:
      + Corrected wrong unit declaration for parameter k.
      This is for issue 451. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1316\">issue + 1316.
    • -
    • October 14, 2016 by Michael Wetter:
      - Added to Annex 60 library.
      - Updated comment for parameter use_dh.
      - This is for issue 451. +
    • 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.
    • -
    • Removed parameter dynamicBalance that overwrote the - setting of energyDynamics and massDynamics. - This is for Annex 60, issue - 411. +
    • September 29, 2016, by Michael Wetter:
      + Refactored model.
    • -
    • February 1, 2012 by Michael Wetter:
      - Expanded documentation. +
    • 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.
    • -
    • August 4, 2011 by Michael Wetter:
      - Added final allowFlowReversal=true to all resistances - since it is impractical to avoid flow reversal in large flow - networks where such a setting may be useful. +
    • July 18, 2016, by Philipp Mehrfeld:
      + Added integrator reset. This is for issue 494.
    • -
    • June 11, 2008 by Michael Wetter:
      - Based class on - AixLib.Fluid.BaseClasses.PartialThreeWayFixedResistance. +
    • 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.
    • -
    • July 20, 2007 by Michael Wetter:
      +
    • February 24, 2010, by Michael Wetter:
      First implementation.
    -------- Errors -------- -line 23 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT.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. +

    + + +

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

    + +
      +
    • + March 16, 2018 by Massimo Cimmino:
      + First implementation. + This function is used models in + + AixLib.Media.Antifreeze. +
    • +
    + +

    + 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

    - Note that these three models are identical, except for the pipe model that is used: + 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

    -

    - 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 enthalpy is computed using the convention that h=0 + if T=0 °C.

    -

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

    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.

    -

    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)

    +

    Typical use and important parameters

    - Where the thermal conductivity of the ground lambda_g = 2.4 W/(m K). + 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)

    • - 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. + August 05, 2020, by Wen HU:
      + First implementation.
    • -
    • 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 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. + 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. +

    +
      +
    • March 16, 2018 by Massimo Cimmino:
      + First implementation. This function is used models in AixLib.Media.Antifreeze. +
    • +
    +

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

    +

    + + +

    +

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

    +

    + +

    - Note that these three models are identical, except for the pipe model - that is used: + 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.

    - -

    - 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. + The enthalpy is computed using the convention that h=0 if + T=0 °C.

    - Test bench schematic + Limitations

    - \"Schematic + 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.

    - Calibration + Typical use and important parameters

    - 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) + 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 the thermal conductivity of the ground lambda_g = - 2.4 W/(m K). + Medium = + AixLib.Media.Antifreeze.EthyleneGlycolWater(property_T=293.15, + X_a=0.40)

      -
    • 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:
      +
    • August 05, 2020, by Wen HU:
      First implementation.
    -------- Errors -------- -line 56 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Chillers/Carnot_y.mo ---- +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/FMI/ExportContainers/ThermalZones.mo ---- -------- HTML 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, +

    + 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

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

    - where the coefficients ai - are declared by the parameter a. + The example + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones + shows how multiple simple thermal zones can be implemented and exported as + an FMU. +

    +

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

    -

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

    -

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

    + Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon),

    - The maximum cooling capacity is set by the parameter QEva_flow_min, - which is by default set to negative infinity. + 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 coefficient of performance depends on the - evaporator and condenser leaving temperature - since otherwise the second law of thermodynamics may be violated. + 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.

    -

    Notes

    - For a similar model that can be used as a heat pump, see - AixLib.Fluid.HeatPumps.Carnot_y. + 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. +

    +

    +

    • - January 2, 2017, by Filip Jorissen:
      - 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.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 - - 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. + January 18, 2019, by Jianjun Hu:
      + Limited the media choice to moist air. + See #1050.
    • - May 10, 2013 by Michael Wetter:
      - Added electric power P as an output signal. + September 20, 2016, by Thierry S. Nouidui:
      + Revised documentation to explain the rationale + of needing mass flow rate sensors.
    • - October 11, 2010 by Michael Wetter:
      - Fixed bug in energy balance. + June 29, 2016, by Michael Wetter:
      + Revised implementation and documentation.
    • - March 3, 2009 by Michael Wetter:
      + April 27, 2016, by Thierry S. Nouidui:
      First implementation.
    -------- 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)). + 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 +

    - The chiller COP is computed as the product -

    -

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

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

    - 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 example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones + shows how multiple simple thermal zones can be implemented and + exported as an FMU.

    - where the coefficients ai are declared by the - parameter a. + 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.

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

    -

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

    + Qsen = max(0, ṁsup)   cp   + (Tsup - Tair,zon),

    - 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 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 maximum cooling capacity is set by the parameter - QEva_flow_min, which is by default set to negative - infinity. + 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 coefficient of performance depends on the evaporator and - condenser leaving temperature since otherwise the second law of - thermodynamics may be violated. + 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.

    -

    - Notes -

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

      -
    • January 2, 2017, by Filip Jorissen:
      - 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.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 - 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. +
    • January 18, 2019, by Jianjun Hu:
      + Limited the media choice to moist air. See #1050.
    • -
    • May 10, 2013 by Michael Wetter:
      - Added electric power P as an output signal. +
    • September 20, 2016, by Thierry S. Nouidui:
      + Revised documentation to explain the rationale of needing mass flow + rate sensors.
    • -
    • October 11, 2010 by Michael Wetter:
      - Fixed bug in energy balance. +
    • June 29, 2016, by Michael Wetter:
      + Revised implementation and documentation.
    • -
    • March 3, 2009 by Michael Wetter:
      +
    • April 27, 2016, by Thierry S. Nouidui:
      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 +line 78 column 2 - Warning:

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/PrescribedOutlet.mo ---- +---- AixLib/Fluid/HeatExchangers/EvaporatorCondenser.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. -

    -

    - 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 outlet conditions at port_a are not affected by this model. + Model for a constant temperature evaporator or condenser based on a ε-NTU + heat exchanger 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 + The heat exchanger effectiveness is calculated from the number of transfer units + (NTU):

    - τ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. + ε = 1 - exp(UA ⁄ (ṁ cp))

    Optionally, this model can have a flow resistance. If no flow resistance is requested, set dp_nominal=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 -

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

    -

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

    -

    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 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 3, 2022, by Michael Wetter:
      + March 7, 2022, by Michael Wetter:
      Removed massDynamics.
      This is for - issue 1542. -
    • -
    • - May 3, 2017, by Michael Wetter:
      - Updated protected model for - #763. + #1542.
    • - December 1, 2016, by Michael Wetter:
      - Updated model as use_dh is no longer a parameter in the pressure drop model.
      + May 27, 2017, by Filip Jorissen:
      + Regularised heat transfer around zero flow.
      This is for - #480. + #769.
    • - November 11, 2014, by Michael Wetter:
      - Revised implementation. + April 12, 2017, by Michael Wetter:
      + Corrected invalid syntax for computing the specific heat capacity.
      + This is for + #707.
    • - March 19, 2014, by Christoph Nytsch-Geusen:
      + October 11, 2016, by Massimo Cimmino:
      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 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 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 outlet conditions at port_a are not affected by this - model. + Model for a constant temperature evaporator or condenser based on a + ε-NTU heat exchanger 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 + The heat exchanger effectiveness is calculated from the number of + transfer units (NTU):

    - τ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. + ε = 1 - exp(UA ⁄ (ṁ cp))

    Optionally, this model can have a flow resistance. If no flow resistance is requested, set dp_nominal=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 -

    -

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

    -

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

    -

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

    + 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 3, 2022, by Michael Wetter:
      +
    • March 7, 2022, by Michael Wetter:
      Removed massDynamics.
      This is for issue - 1542. -
    • -
    • May 3, 2017, by Michael Wetter:
      - Updated protected model for #763. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1542\">#1542.
    • -
    • December 1, 2016, by Michael Wetter:
      - Updated model as use_dh is no longer a parameter in - the pressure drop model.
      +
    • May 27, 2017, by Filip Jorissen:
      + Regularised heat transfer around zero flow.
      This is for #480. + \"https://github.com/lbl-srg/modelica-buildings/issues/769\">#769.
    • -
    • November 11, 2014, by Michael Wetter:
      - Revised implementation. +
    • April 12, 2017, by Michael Wetter:
      + Corrected invalid syntax for computing the specific heat + capacity.
      + This is for #707.
    • -
    • March 19, 2014, by Christoph Nytsch-Geusen:
      +
    • October 11, 2016, by Massimo Cimmino:
      First implementation.
    -------- Errors -------- -line 34 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 ----- AixLib/Media/Antifreeze/EthyleneGlycolWater.mo ---- +---- AixLib/Utilities/Math/Functions/Examples/CubicHermite.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. + 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\"

    -

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

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

    • - May 2, 2018 by Massimo Cimmino:
      + 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. - This function is used by - - AixLib.Media.Antifreeze.EthyleneGlycolWater. +
    • +
    • + 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

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

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

    -

    References

    -

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. +

    + \"Input
    + \"Output

    • - March 16, 2018 by Massimo Cimmino:
      - First implementation. - This function is used models in - - AixLib.Media.Antifreeze. + 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.
    • -
    - -

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

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

    - Thermal conductivity of antifreeze-water mixture at specified mass fraction and - temperature, based on Melinder (2010). + 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.

    -

    References

    - Melinder, Åke. 2010. Properties of Secondary Working Fluids (Secondary - Refrigerants or Coolants, Heat Transfer Fluids) for Indirect Systems. Paris: - IIR/IIF. + The image below shows the RC-network of this model.

    - +

    + \"image\"/ +

    +
    • - March 16, 2018 by Massimo Cimmino:
      - First implementation. - This function is used by - - AixLib.Media.Antifreeze.EthyleneGlycolWater. + 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. +
    +-------- 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 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. + 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:

    - \"Relative + \"image\"

    - The enthalpy is computed using the convention that h=0 - if T=0 °C. + 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.

    -

    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 finite line source solution is given by:

    -

    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): +

    + \"image\"

    - Medium = AixLib.Media.Antifreeze.EthyleneGlycolWater(property_T=293.15, X_a=0.40) + 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.

    • - August 05, 2020, by Wen HU:
      + 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.
    -------- 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. -

    - -

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

    -
      -
    • March 16, 2018 by Massimo Cimmino:
      - First implementation. This function is used models in AixLib.Media.Antifreeze. -
    • -
    -

    - 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. + 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\"

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

    -

    - - + 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 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 finite line source solution is given by:

    - - -

    -

    - 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): + \"image\"

    -

    - Medium = - AixLib.Media.Antifreeze.EthyleneGlycolWater(property_T=293.15, - X_a=0.40) +

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

      -
    • August 05, 2020, by Wen HU:
      +
    • 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 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 12 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatPumps/ScrollWaterToWater.mo ---- +---- AixLib/Fluid/Interfaces/PrescribedOutlet.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) ). + 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.

    - The power consumed by the compressor is given by a linear efficiency relation: + 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

    - 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 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 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. + τeff = τ |ṁ| ⁄ ṁnom

    -

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

    -

    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 model has no pressure drop. + See + AixLib.Fluid.HeatExchangers.PrescribedOutlet + for a model that instantiates this model and that has a pressure drop.

    -

    References

    - H. Jin. - - Parameter estimation based models of water source heat pumps. - - PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002. + In case of reverse flow, + the fluid that leaves port_a has the same + properties as the fluid that enters port_b.

    • - May 30, 2017, by Filip Jorissen:
      - Revised documentation for temperature protection. - See #769. + March 3, 2022, by Michael Wetter:
      + Removed massDynamics.
      + This is for + issue 1542.
    • - November 11, 2016, by Massimo Cimmino:
      + 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.
    -------- 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\" -

    -

    - The rate of heat transferred to the evaporator is given by: -

    -

    - Q̇Eva = ṁref ( - hVap(TEva) - hLiq(TCon) - ). + 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.

    - The power consumed by the compressor is given by a linear efficiency - relation: + 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

    - 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 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 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. + τeff = τ |ṁ| ⁄ ṁnom

    -

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

    -

    - 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 model has no pressure drop. See AixLib.Fluid.HeatExchangers.PrescribedOutlet + for a model that instantiates this model and that has a pressure + drop.

    -

    - References -

    - H. Jin. Parameter estimation based models of water source heat - pumps. PhD Thesis. Oklahoma State University. Stillwater, - Oklahoma, USA. 2002. + In case of reverse flow, the fluid that leaves port_a + has the same properties as the fluid that enters port_b.

      -
    • May 30, 2017, by Filip Jorissen:
      - Revised documentation for temperature protection. See #769. +
    • 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 11, 2016, by Massimo Cimmino:
      +
    • November 10, 2014, by Michael Wetter:
      First implementation.
    -------- 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/Media/Air.mo ---- +---- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlow.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. + October 20, 2017, by Michael Wetter:
      + Deleted various parameters and variables that were not used. +
      + Revised documentation to follow the guidelines.
    • -
    - - 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. + May 19, 2016 by Marcus Fuchs:
      + Remove condition on show_V_flow for calculation of + V_flow to conform with pedantic checking.
    • -
    - - 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, -

    -

    - where - v is the specific volume, - T is the temperature and - p is the pressure. -

    - -
    • - December 18, 2013, by Michael Wetter:
      + October 10, 2015 by Marcus Fuchs:
      + Copy Icon from KUL implementation and rename model. +
    • +
    • + June 23, 2015 by Marcus Fuchs:
      First implementation.

    - This function returns the isothermal compressibility coefficient. - The isothermal compressibility is + 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,

    - κT = -1 ⁄ v   (∂ v ⁄ ∂ p)T - = -1 ⁄ p, + ∂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

    - where - v is the specific volume, - T is the temperature and - p is the pressure. + This model is based on the following assumptions:

    -
    • - December 18, 2013, by Michael Wetter:
      - First implementation. + Axial diffusion in water is assumed to be negligibe. +
    • +
    • + The water temperature is assumed uniform in a cross section.
    +-------- 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 -------- +

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

    -

    - 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)), + Three way valve with table-specified opening characteristics. + A separate characteristic for each flow path is used.

    - where R is the gas constant, - X is the mass fraction, - M is the molar mass, and - Y is the mole fraction. + 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

    - To obtain the state for a given pressure, entropy and mass fraction, use - - AixLib.Media.Air.setState_psX. + 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

    -

    Limitations

    +
    +  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 is only valid for a relative humidity below 100%. + Note, however, that + + AixLib.Fluid.Actuators.Valves.ThreeWayLinear provides a more + efficient implementation for this simple case.

    - -
      -
    • - November 27, 2013, by Michael Wetter:
      - First implementation. -
    • -
    -

    - This function returns the partial derivative of density - with respect to pressure at constant temperature. + 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.
    • -
    - -

    - This function computes the derivative of density with respect to temperature - at constant pressure. -

    - -
    • - December 18, 2013, by Michael Wetter:
      - First implementation. + 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.
    • -
    - -

    - 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 last values must satisfy + y[end]=1 and + phi[end]=1.
    - -

    - 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. + 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 state is computed by symbolically solving - - AixLib.Media.Air.specificEntropy - for temperature. + For an example that specifies an opening characteristics, see + + AixLib.Fluid.Actuators.Valves.Examples.TwoWayValveTable.

    +
    • - November 27, 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.
    - 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. - +-------- Corrected 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. +
    • +
    • 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 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. +
    • +
    • 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/HeatExchangers/BaseClasses/WetCoilDryWetRegime.mo ---- +-------- HTML Code -------- +
    • - April 30, 2015, by Filip Jorissen and Michael Wetter:
      - Added Inline=true for - - issue 227. + Jan 21, 2021, by Donghun Kim:
      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. + This model implements the switching algorithm for the dry and wet regime.

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

    - This function returns the molar mass. + 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 -------- +
      +
    • Jan 21, 2021, by Donghun Kim:
      + First implementation. +
    • +
    +

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

    • - December 18, 2013, by Michael Wetter:
      + 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.
    • -
    - - 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. + 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 data record contains the coefficients for perfect gases. -

    +

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

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

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

    • - September 12, 2014, by Michael Wetter:
      - Corrected the wrong location of the preferredView - and the revisions annotation. + September 21, 2021, by Michael Wetter:
      + Renamed class to correct typo in class name.
      + This is for + IBPSA, #1524.
    • - November 21, 2013, by Michael Wetter:
      + 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 3 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/FMI/ExportContainers/HVACZone.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. + 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

    - This medium uses the gas law -

    -

    - ρ/ρstp = p/pstp, + 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. +

    - where - pstd and ρstp are constant reference - temperature and density, rathern than the ideal gas law + 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

    - ρ = p ⁄(R T), + Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon),

    - where R is the gas constant and T is the temperature. + 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.

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

    +

    - Note that models in this package implement the equation for the internal energy as -

    -

    - u = h - pstp ⁄ ρstp, + See + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZone + for a model that uses this model.

    - 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, + For models that multiple thermal zones connected to the HVAC system, + use the model + + AixLib.Fluid.FMI.ExportContainers.HVACZones.

    -

    - h = u + p v, +

    Assumption and limitations

    +

    + The mass flow rates at ports sum to zero, hence this + model conserves mass.

    - from which follows that + 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.

    -

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

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

    + +
      +
    • + January 18, 2019, by Jianjun Hu:
      + Limited the media choice to moist air only. + See #1050. +
    • +
    • + April 15, 2016, by Michael Wetter:
      + First implementation. +
    • +
    + +-------- 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. +

    +

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

    +
      +
    • January 18, 2019, by Jianjun Hu:
      + Limited the media choice to moist air only. See #1050. +
    • +
    • April 15, 2016, by Michael Wetter:
      + First implementation. +
    • +
    + +-------- Errors -------- +line 47 column 2 - Warning:

    attribute "align" not allowed for HTML5 + + +---- AixLib/Utilities/IO/SignalExchange/SignalTypes/SignalsForKPIs.mo ---- +-------- HTML Code -------- +

    - because p ⁄ ρ = pstp ⁄ ρstp in this medium model. + This enumeration defines the signal types that are used by BOPTEST + to compute the key performance indices (KPI).

    - The enthalpy is computed using the convention that h=0 - if T=0 °C and no water vapor is present. + 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
    • - 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. + July 17, 2019, by Michael Wetter:
      + Added documentation.
    • - August 28, 2008, by Michael Wetter:
      + April 10, 2019, by Javier Arroyo:
      First implementation.
    -------- Corrected Code --------

    - Model with basic thermodynamic properties. + This enumeration defines the signal types that are used by BOPTEST to + compute the key performance indices (KPI).

    - This model provides equation for the following thermodynamic - properties: + The following signal types are supported.

    - +
    + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
    + Value + + Description +
    - Variable + None - Unit + Not used for KPI +
    + AirZoneTemperature - Description + Air zone temperature
    - T + RadiativeZoneTemperature - K + Radiative zone temperature
    - temperature + OperativeZoneTemperature + + Operative zone temperature
    - p + RelativeHumidity - Pa + Relative humidity
    - absolute pressure + 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
    +
      +
    • July 17, 2019, by Michael Wetter:
      + Added documentation. +
    • +
    • April 10, 2019, by Javier Arroyo:
      + First implementation. +
    • +
    + +-------- Errors -------- +line 9 column 2 - Warning: The summary attribute on the element is obsolete in 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 +

    +
      +
    • M. W. Liddament, 1996, A guide to energy efficient ventilation. AIVC Annex V.
    • +
    + +
      +
    • + February 2, 2022, by Michael Wetter:
      + Revised implementation.
      + This is for + IBPSA, #1436. +
    • +
    • + Apr 6, 2021, by Klaas De Jonge:
      + 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 + 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. +
    - d - - kg/m3 - - density + + Wind from North:
    + 0
    + 0°
    - h - - J/kg + + Wind from West:
    + 3π/2
    + 270°
    - specific enthalpy + + Wind from East:
    + π/2
    + 90°
    - u - - J/kg - - specific internal energy + + 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. +
    - Xi[nXi] - - kg/kg - - independent mass fractions m_i/m + + Wall facing north:
    + π
    + 180°
    - R - - J/kg.K + + Wall facing West:
    + π/2
    + 90°
    - gas constant + + Wall facing east:
    + 3π/2
    + 270°
    - M - - kg/mol - - molar mass + + 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 +

      -
    • September 22, 2020, by Michael Wetter:
      - First implementation based on Modelica Standard Library, but with - noEvent added to check of bounds. +
    • M. W. Liddament, 1996, A guide to energy efficient + ventilation. AIVC Annex V.
    -Density is computed from pressure, temperature and composition in the -thermodynamic state record applying the ideal gas law. +
      +
    • February 2, 2022, by Michael Wetter:
      + Revised implementation.
      + This is for IBPSA, + #1436. +
    • +
    • Apr 6, 2021, by Klaas De Jonge:
      + First implementation. +
    • +
    + +-------- 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/HeatExchangers/Heater_T.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 + +

    +

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

    + +
      +
    • + September 10, 2018, by Michael Wetter:
      + Corrected missing propagation of initial conditions.
      + This is for + + AixLib, #1016. +
    • +
    • + May 3, 2017, by Michael Wetter:
      + First implementation.
      + This is for + + AixLib, #763. +
    • +
    + +-------- Corrected Code --------

    - This function returns the dynamic viscosity. + 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.

    -

    - 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 outlet conditions at port_a are not affected by this + model, other than for a possible pressure difference due to flow + friction.

    -
      -
    • 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 + 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 = - 1 ⁄ v   (∂ v ⁄ ∂ T)p = 0, + τeff = τ |ṁ| ⁄ ṁnom

    - where v is the specific volume, T is the temperature - and p is the pressure. + 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.

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

    - This function returns the isothermal compressibility coefficient. The - isothermal compressibility is + Optionally, this model can have a flow resistance. Set + dp_nominal = 0 to disable the flow friction calculation.

    -

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

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

    - where v is the specific volume, T is the temperature - and p is the pressure. + The model has been validated against the analytical solution in the + examples AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet + and + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic.

      -
    • December 18, 2013, by Michael Wetter:
      - First implementation. +
    • September 10, 2018, by Michael Wetter:
      + Corrected missing propagation of initial conditions.
      + This is for AixLib, + #1016. +
    • +
    • 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/Fluid/HeatExchangers/SensibleCooler_T.mo ---- +-------- HTML Code -------- + +

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

    +

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

    + +
      +
    • + September 10, 2018, by Michael Wetter:
      + Corrected missing propagation of initial conditions.
      + This is for + + AixLib, #1016. +
    • +
    • + May 3, 2017, by Michael Wetter:
      + First implementation.
      + This is for + + AixLib, #763. +
    • +
    + +-------- Corrected Code --------

    - This function computes the specific entropy. + Model for an ideal sensible-only cooler that controls its outlet + temperature to a prescribed outlet temperature.

    - The specific entropy of the mixture is obtained from + 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.

    -

    - s = ss + sm, +

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

    - 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 outlet conditions at port_a are not affected by this + model, other than for a possible pressure difference due to flow + friction.

    - The entropy change due to change in state is obtained from + 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

    - ss = cv ln(T/T0) + R - ln(v/v0)
    - = cv ln(T/T0) + R ln(ρ0/ρ) + τeff = τ |ṁ| ⁄ ṁnom

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

    - Next, the entropy of mixing is obtained from a reversible isothermal - expansion process. Hence, + Optionally, this model can have a flow resistance. Set + dp_nominal = 0 to disable the flow friction calculation.

    -

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

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

    - where R is the gas constant, X is the mass fraction, - M is the molar mass, and Y is the mole fraction. + If the flow is from port_b to port_a, then + the enthalpy of the medium is not affected by this model.

    - To obtain the state for a given pressure, entropy and mass fraction, - use AixLib.Media.Air.setState_psX. + 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.

    - Limitations + Validation

    - This function is only valid for a relative humidity below 100%. + The model has been validated against the analytical solution in the + examples AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet + and + AixLib.Fluid.HeatExchangers.Validation.PrescribedOutlet_dynamic.

      -
    • November 27, 2013, by Michael Wetter:
      - First implementation. +
    • September 10, 2018, by Michael Wetter:
      + Corrected missing propagation of initial conditions.
      + This is for AixLib, + #1016. +
    • +
    • 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/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. +

    + +
      +
    • + July 10, 2018, by Alex Laferrière:
      + Added laminar flow and smooth laminar-turbulent transition. + Revised documentation. +
    • +
    • + February 14, 2014, by Michael Wetter:
      + Removed unused input rBor. + Revised documentation. +
    • +
    • + January 24, 2014, by Michael Wetter:
      + Revised implementation. + Changed cpFluid to cpMed to use consistent notation. + Added regularization for computation of convective heat transfer coefficient to + avoid an event and a non-differentiability. +
    • +
    • + January 23, 2014, by Damien Picard:
      + First implementation. +
    • +
    + +-------- Corrected Code --------

    - This function returns the partial derivative of density with respect - to pressure at constant temperature. + This model computes the convection resistance in the pipes of a + borehole segment with heigth hSeg using + correlations suggested by Bergman et al. (2011).

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

    - This function computes the derivative of density with respect to - temperature at constant pressure. + 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,

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

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

      -
    • December 18, 2013, by Michael Wetter:
      +
    • July 10, 2018, by Alex Laferrière:
      + Added laminar flow and smooth laminar-turbulent transition. Revised + documentation. +
    • +
    • February 14, 2014, by Michael Wetter:
      + Removed unused input rBor. Revised documentation. +
    • +
    • January 24, 2014, by Michael Wetter:
      + Revised implementation. Changed cpFluid to + cpMed to use consistent notation. Added regularization + for computation of convective heat transfer coefficient to avoid an + event and a non-differentiability. +
    • +
    • January 23, 2014, by Damien Picard:
      First implementation.
    + +-------- 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\" +

    +

    + The integral is solved numerically, with the integrand defined in + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource_Integrand. +

    + +
      +
    • + March 22, 2018 by Massimo Cimmino:
      + First implementation. +
    • +
    + +-------- Corrected Code --------

    - The - thermodynamic state record is computed from density - d, temperature T and composition - X. + 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

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

    + \"image\"

    - The state is computed by symbolically solving AixLib.Media.Air.specificEntropy - for temperature. + 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.

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

    - This function computes the specific enthalpy for an isentropic state - change from the temperature that corresponds to the state - refState to reference_T. + The cylindrical heat source solution is given by: +

    +

    + \"image\"

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

    - This function returns the molar mass. + The integral is solved numerically, with the integrand defined in + + AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.ThermalResponseFactors.cylindricalHeatSource_Integrand.

      -
    • December 18, 2013, by Michael Wetter:
      +
    • March 22, 2018 by Massimo Cimmino:
      First implementation.
    -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. -
    • -
    -

    - This data record contains the coefficients for perfect gases. -

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

      +
    • + January 12, 2017, by Thierry S. Nouidui:
      + Modified example to prevent simultaneous events + This is for + #646. +
    • +
    • + November 21, 2011, by Michael Wetter:
      + Added documentation. +
    • +
    + +

    + 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 --------
      -
    • September 12, 2014, by Michael Wetter:
      - Corrected the wrong location of the preferredView and - the revisions annotation. +
    • January 12, 2017, by Thierry S. Nouidui:
      + Modified example to prevent simultaneous events This is for + #646.
    • -
    • November 21, 2013, by Michael Wetter:
      - First implementation. +
    • November 21, 2011, by Michael Wetter:
      + Added documentation.

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

    -

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

    + \"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. +

    +

    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. +
    • +
    + +-------- Corrected Code --------

    - Note that models in this package implement the equation for the - internal energy as + 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.

    -

    - u = h - pstp ⁄ ρstp, +

    + Main equation +

    +

    + ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0,

    - 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, + 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 +

    - from which follows that -

    -

    - u = h - p v = h - p ⁄ ρ = h - pstp ⁄ ρstd, + 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.

    - because p ⁄ ρ = pstp ⁄ ρstp in this - medium model. + 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 +

    - The enthalpy is computed using the convention that h=0 if - T=0 °C and no water vapor is present. + No axial mixing takes place in the pipe.

      -
    • 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.
      +
    • December 2, 2020, by Philipp Mehrfeld:
      + Corrected calculation of tau and tauRev + to be be only positive.
      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=...). + \"https://github.com/ibpsa/modelica-ibpsa/issues/1427\">#1427.
    • -
    • April 4, 2012, by Michael Wetter:
      - Added redeclaration of ThermodynamicState to avoid a - warning during model check and translation. +
    • December 14, 2018, by Michael Wetter:
      + Corrected argument of spatialDistribution operator to + be a parameter expression.
      + This is for #1055.
    • -
    • 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. +
    • September 9, 2016 by Bram van der Heijde:
      + Rename from PDETime_massFlowMod to PlugFlowTransportDelayMod
    • -
    • 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. +
    • December 2015 by Carles Ribas Tugores:
      + Modification in delay calculation to fix issues.
    • -
    • January 22, 2010, by Michael Wetter:
      - Added implementation of function - enthalpyOfNonCondensingGas and its derivative. +
    • 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.
    • -
    • January 13, 2010, by Michael Wetter:
      - Fixed implementation of derivative functions. +
    • October 13, 2015 by Marcus Fuchs:
      + Use abs() of normalized velocity input in order to + avoid negative delay times.
    • -
    • August 28, 2008, by Michael Wetter:
      +
    • July 2015 by Arnout Aertgeerts:
      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 54 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FixedResistances/PressureDrop.mo ---- +---- AixLib/Media/Specialized/Water/TemperatureDependentDensity.mo ---- -------- HTML Code -------- +

    + Base properties of the medium. +

    +

    - Model of a flow resistance with a fixed flow coefficient. - The mass flow rate is + 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. +

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

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

    + This function computes the specific enthalpy of liquid water. +

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

    + This function computes the specific internal energy. +

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

    + This function computes the specific entropy. +

    +

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

    + This function computes the specific Gibbs energy. +

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

    + 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,

    - ṁ = k - √ΔP, + βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)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. + v is the specific volume, + T is the temperature and + p is the pressure.

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

    - 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\" + This function returns the isothermal compressibility coefficient, + which is zero as this medium is incompressible. + The isothermal compressibility is defined as

    -

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

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

    - If the parameter linearized is set to true, - then the pressure drop is computed as a linear function of the - mass flow rate. + where + v is the specific volume, + T is the temperature and + p is the pressure.

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

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

    - 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. + This function computes the derivative of density with respect to temperature + at constant pressure.

    -

    Notes

    + +
      +
    • + August 17, 2015, by Michael Wetter:
      + Removed dublicate entry of smooth and smoothOrder. + This is for + issue 303. +
    • +
    • + December 18, 2013, by Michael Wetter:
      + First implementation, based on the IDA implementation in therpro.nmf, + but converted from Celsius to Kelvin. +
    • +
    +

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

    - For a model that uses the hydraulic parameter and flow velocity at nominal conditions - as a parameter, use - - AixLib.Fluid.FixedResistances.HydraulicDiameter. + This function returns the specific heat capacity at constant pressure.

    -

    Implementation

    + +
      +
    • + December 11, 2013, by Michael Wetter:
      + First 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   + This function computes the specific heat capacity at constant volume.

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

    - and its inverse function. + This function returns the thermal conductivity. + The expression is obtained from Ramires et al. (1995).

    +

    References

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

    • - September 21, 2018, by Michael Wetter:
      - Decrease value of deltaM(min=...) attribute. - See #1026. -
    • -
    • - February 3, 2018, by Filip Jorissen:
      - Revised implementation of pressure drop equation - such that it depends on from_dp - when linearized=true. - See #884. -
    • -
    • - December 1, 2016, by Michael Wetter:
      - Simplified model by removing the geometry dependent parameters into the new - model - - AixLib.Fluid.FixedResistances.HydraulicDiameter. + December 18, 2013, by Michael Wetter:
      + First implementation.
    • +
    + +

    + This function returns the pressure. +

    + +
    • - November 23, 2016, by Filip Jorissen:
      - Removed dp_nominal and - m_flow_nominal labels from icon. + December 18, 2013, by Michael Wetter:
      + First implementation.
    • +
    + +

    + This function returns the temperature. +

    + +
    • - October 14, 2016, by Michael Wetter:
      - Updated comment for parameter use_dh. + December 18, 2013, by Michael Wetter:
      + First implementation.
    • +
    + +

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

    + +
    • - 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. + December 11, 2013, by Michael Wetter:
      + First implementation.
    • +
    + +

    + This function returns the thermodynamic state for a given pressure, + temperature and composition. +

    + +
    • - August 5, 2014, by Michael Wetter:
      - Corrected error in documentation of computation of k. + December 11, 2013, by Michael Wetter:
      + First implementation.
    • +
    + +

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

    +

    + The state is computed by symbolically solving + + AixLib.Media.Specialized.Water.TemperatureDependentDensity.specificEntropy + for temperature. +

    + +
    • - May 29, 2014, by Michael Wetter:
      - Removed undesirable annotation Evaluate=true. + April 11, 2016 by Michael Wetter:
      + Corrected wrong hyperlink in documentation for + issue 450.
    • - October 8, 2013, by Michael Wetter:
      - Removed parameter show_V_flow. + 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 14, 2012 by Michael Wetter:
      - Renamed protected parameters for consistency with the naming conventions. + December 11, 2013, by Michael Wetter:
      + First implementation.
    • +
    + +

    + This function computes the temperature derivative of the enthalpy of liquid water + per unit mass. +

    + +
    • - 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. + December 11, 2013, by Michael Wetter:
      + First implementation.
    • +
    + +

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

    + +
    • - May 30, 2008 by Michael Wetter:
      - Added parameters use_dh and deltaM for easier parameterization. + April 11, 2016 by Michael Wetter:
      + Corrected wrong hyperlink in documentation for + issue 450.
    • - July 20, 2007 by Michael Wetter:
      - First implementation. + December 18, 2013, by Michael Wetter:
      + First implementation, based on the IDA implementation in therpro.nmf, + but converted from Celsius to Kelvin.
    --------- Corrected 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. -

    -
      -
    • September 21, 2018, by Michael Wetter:
      - Decrease value of deltaM(min=...) attribute. See - #1026. -
    • -
    • February 3, 2018, by Filip Jorissen:
      - Revised implementation of pressure drop equation such that it - depends on from_dp when linearized=true. - See #884. -
    • -
    • December 1, 2016, by Michael Wetter:
      - Simplified model by removing the geometry dependent parameters into - the new model AixLib.Fluid.FixedResistances.HydraulicDiameter. -
    • -
    • 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 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/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. + 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.

    - \"image\" + \"Mass

    - The rate of heat transferred to the evaporator is given by: + 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.

    -

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

    + \"Relative

    + +

    - The power consumed by the compressor is given by a linear efficiency relation: + Thermal conductivity is calculated as a function of temperature as shown in the figure below. + The correlation used to calculate the thermal conductivity is

    +

    - P = PTheoretical / η + PLoss,constant. + λ(T) = λ(298.15 K) ⋅ (-1.48445+4.12292⋅(T/298.15)-1.63866⋅(T/298.15)2),

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

    -

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

    + \"Thermal

    -

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

    -

    Assumptions and limitations

    +

    + \"Kinematic +

    +

    - 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 enthalpy is computed using the convention that h=0 + if T=0 °C.

    -

    References

    +

    Limitations

    - H. Jin. - - Parameter estimation based models of water source heat pumps. - - PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002. + Phase changes are not modeled.

    • - May 30, 2017, by Filip Jorissen:
      - Revised documentation for temperature protection. - See #769. + April 5, 2022, by Michael Wetter:
      + Corrected assignment of R_s in BaseProperties to avoid a unit error.
      + This is for + #1603.
    • - November 14, 2016, by Massimo Cimmino:
      + 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 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\". +
    • +
    • + February 3, 2015, by Michael Wetter:
      + Removed stateSelect.prefer for temperature. + This is for + #160. +
    • +
    • + October 15, 2014, by Michael Wetter:
      + Renamed from AixLib.Media.Water to + AixLib.Media.Water.Detailed to allow addition of + AixLib.Media.Water.Simple. +
    • +
    • + 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.
    -------- 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. + 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. +

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

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

    + This function computes the specific enthalpy of liquid water. +

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

    + This function computes the specific internal energy. +

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

    + This function computes the specific entropy. +

    +

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

    + This function computes the specific Gibbs energy. +

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

    + 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,

    -

    - \"image\" +

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

    - The rate of heat transferred to the evaporator is given by: + 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

    - Q̇Eva = ṁref ( - hVap(TEva) - hLiq(TCon) - ). + κT = - 1 ⁄ v   (∂ v ⁄ ∂ p)T,

    - The power consumed by the compressor is given by a linear efficiency - relation: + where v is the specific volume, T is the temperature + and p is the pressure.

    -

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

      +
    • 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, 2013, by Michael Wetter:
      + First implementation. +
    • +

    - 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 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. +
    • +
    • December 18, 2013, by Michael Wetter:
      + First implementation, based on the IDA implementation in + therpro.nmf, but converted from Celsius to Kelvin. +
    • +

    - 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. + This function returns the partial derivative of density with respect + to mass fraction, which is zero as the medium is a single substance.

    -

    - Options -

    +
      +
    • December 18, 2013, 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. + This function returns the specific heat capacity at constant + pressure.

    -

    - Assumptions and limitations -

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

    - 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 function computes the specific heat capacity at constant volume. +

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

    + This function returns the thermal conductivity. The expression is + obtained from Ramires et al. (1995).

    References

    - H. Jin. Parameter estimation based models of water source heat - pumps. PhD Thesis. Oklahoma State University. Stillwater, - Oklahoma, USA. 2002. + 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.

      -
    • May 30, 2017, by Filip Jorissen:
      - Revised documentation for temperature protection. See #769. -
    • -
    • November 14, 2016, by Massimo Cimmino:
      +
    • December 18, 2013, by Michael Wetter:
      First implementation.
    - --------- 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/Fluid/HeatExchangers/ActiveBeams/Data/BaseClasses/TemperatureDifference.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 -

    -

    - rΔTi= - ΔTi ⁄ ΔTnominal - = - (Twi-Tz) - ⁄ - (Tw,nominal-Tz), -

    -

    - where - Twi is the water inlet temperature, - Tz is the zone air temperature and - Tw,nominal is the nominal water inlet temperature. -

    -

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

    - -
      -
    • - June 13, 2016, by Michael Wetter:
      - Revised implementation. -
    • -
    • - May 20, 2016, by Alessandro Maccarini:
      - First implementation. -
    • -
    - --------- 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 + This function returns the pressure.

    -

    - rΔTi= ΔTi ⁄ ΔTnominal = - (Twi-Tz) ⁄ - (Tw,nominal-Tz), +

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

    + This function returns the temperature.

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

    - where Twi is the water inlet - temperature, Tz is the zone air temperature and - Tw,nominal is the nominal water inlet temperature. + This function returns the molar mass, which is assumed to be + constant.

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

    - 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. + This function returns the thermodynamic state for a given pressure, + specific enthalpy and composition.

      -
    • June 13, 2016, by Michael Wetter:
      - Revised implementation. +
    • December 11, 2013, by Michael Wetter:
      + First implementation.
    • -
    • May 20, 2016, by Alessandro Maccarini:
      +
    +

    + This function returns the thermodynamic state for a given pressure, + temperature and composition. +

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

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

    +

    + 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.
    - --------- Errors -------- -line 8 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\" -

    - -
      -
    • - March 22, 2018 by Massimo Cimmino:
      - First implementation. -
    • -
    - --------- Corrected Code --------

    - This function evaluates the integral of the error function, given by: + This function computes the derivative of the specific heat capacity + at constant pressure with respect to the state.

    -

    - \"image\" +

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

    + This function computes the temperature derivative of the enthalpy of + liquid water per unit mass.

      -
    • March 22, 2018 by Massimo Cimmino:
      +
    • December 11, 2013, by Michael Wetter:
      First implementation.
    - --------- Errors -------- -line 5 column 2 - Warning:

    attribute "align" not allowed for HTML5 - - ----- AixLib/Fluid/FMI/ExportContainers/HVACZones.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. -

    -

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

    -

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

    -

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

    -

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

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

    - Model that is used as a container for an HVAC system that is to be - exported as an FMU and that serves multiple zones. + This function computes the kinematic viscosity as a function of + temperature.

    - Typical use and important parameters + Implementation

    - 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 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);
    +       

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

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

    +

    + +

    - 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 + Thermal conductivity is calculated as a function of temperature as + shown in the figure below. The correlation used to calculate the + thermal conductivity is

    - Qsen = max(0, ṁsup)   cp   - (Tsup - Tair,zon), + λ(T) = λ(298.15 K) ⋅ + (-1.48445+4.12292⋅(T/298.15)-1.63866⋅(T/298.15)2),

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

    -

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

    + \"Thermal

    - See - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.HVACZones for a - model that uses this model. + 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

    - For models that only have one thermal zone connected to the HVAC - system, use the simpler model AixLib.Fluid.FMI.ExportContainers.HVACZone. + The enthalpy is computed using the convention that h=0 if + T=0 °C.

    - Assumption and limitations + 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. + Phase changes are not modeled.

      -
    • January 18, 2019, by Jianjun Hu:
      - Limited the media choice to moist air only. See #1050. +
    • April 5, 2022, by Michael Wetter:
      + Corrected assignment of R_s in + BaseProperties to avoid a unit error.
      + This is for #1603.
    • -
    • May 25, 2016, by Michael Wetter:
      +
    • 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 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\". +
    • +
    • February 3, 2015, by Michael Wetter:
      + Removed stateSelect.prefer for temperature. This is + for #160. +
    • +
    • October 15, 2014, by Michael Wetter:
      + Renamed from AixLib.Media.Water to + AixLib.Media.Water.Detailed to allow addition of + AixLib.Media.Water.Simple. +
    • +
    • 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 60 column 2 - Warning:

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

    attribute "align" not allowed for HTML5 ----- AixLib/Utilities/Math/Functions/Examples/CubicHermite.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/Sensors/UsersGuide.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 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. +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. +

    + +

    +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\" +
    + +

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

    +
      +
    • +

      + +Sensors for quantities that depend on the direction of the mass flow rate but +not of its magnitude: + +Such quantities include density, mass fraction, PPM, relative humidity, specific enthalpy, specific entropy and trace substances. +Not that these are all quantities that are carried by the fluid that flows through the sensor. +For these sensors, if the parameter allowFlowReversal=true is set (which is the default setting), +then it is strongly recommended to configure them +as a dynamic sensor. This is the default setting.
      +Configuring a sensor as a dynamic sensor is done by setting the time constant to a non-zero +value. Typically, setting tau=10 seconds yields good results. +For tau=0, numerical problems may occur if the mass flow rate is close to zero +and allowFlowReversal=true.
      +If allowFlowReversal=false, then the measurement of these sensors only depends on properties +at port_a. +If the mass flow rate at port_a is a ≤ 0, +i.e., fluid flows from port_b to port_a, +the model still assumes a > 0. Hence there are no numerical problems; +but use of the sensor output may yield wrong results. +Therefore, only set allowFlowReversal=false if you can guarantee a ≥ 0. +

      +
    • +
    • +

      + +Sensors for quantities that are the product of mass flow rate times a measured fluid property: + +Such quantities include volumentric flow rate or enthalpy flow rate. +For these quantities, sensors are by default configured as steady-state sensor. +These sensors may be configured by the user +as a dynamic sensor by setting tau > 0, but there is typically no benefit as these sensors typically +do not cause numerical problems. +The reason is that these sensors multiply the quantity that is carried by the flow, +such as specific enthalpy h by the mass flow rate +to compute the measured signal Ḣ=ṁ h. +Hence, as the mass flow rate goes to zero, the sensor output +signal also goes to zero, which avoids numerical problems.

      -

      - \"image\" +

    • +
    • +

      +Static pressure measurements: + +For static pressure measurements, sensors always output the instantaneous measurement. +These sensors cannot be configured to be dynamic.

      -
        -
      • March 8, 2013, by Michael Wetter:
        - First implementation. -
      • +
      - --------- Errors -------- -line 11 column 2 - Warning:

      attribute "align" not allowed for 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. +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

      - This model transfers heat in the amount of +If a sensor is configured as a dynamic sensor by setting tau > 0, +then the measured quantity, say the temperature T, is +computed as

      - Q = Qmax ε, + τ   dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T),

      - where ε is a constant effectiveness and Qmax - is the maximum heat that can be transferred. +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 a heat and moisture exchanger, use AixLib.Fluid.MassExchangers.ConstantEffectiveness - instead of this model. +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

      -
        -
      • 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. -
      • -
      - --------- Errors -------- -line 8 column 2 - Warning:

      attribute "align" not allowed for HTML5 - - ----- AixLib/Utilities/IO/SignalExchange/SignalTypes/SignalsForKPIs.mo ---- --------- HTML Code -------- - -

      - This enumeration defines the signal types that are used by BOPTEST - to compute the key performance indices (KPI). -

      -

      - 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
      - -
        -
      • - July 17, 2019, by Michael Wetter:
        - Added documentation. -
      • -
      • - April 10, 2019, by Javier Arroyo:
        - First implementation. -
      • -
      - +

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

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

      +

      Implementation

      +

      +The above equation is implemented in such a way that it is differentiable in the mass flow rate. +

      +

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

      - This enumeration defines the signal types that are used by BOPTEST to - compute the key performance indices (KPI). + This package contains models of sensors. There are models with one + and with two fluid ports.

      +

      + Selection and parameterization of sensor models +

      - The following signal types are supported. + 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.

      - +

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

      +
      - - - - - - - - - - - - - - - - + +
      - Value - - Description + + Correct use
      - None - - Not used for KPI -
      - AirZoneTemperature - - Air zone temperature -
      - RadiativeZoneTemperature - - Radiative zone temperature + + \"image\"
      - OperativeZoneTemperature - - Operative zone temperature + + Not recommended + + \"image\"
      +

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

      +
        +
      • +

        + Sensors for quantities that depend on the direction of the + mass flow rate but not of its magnitude: Such quantities + include density, mass fraction, PPM, relative humidity, specific + enthalpy, specific entropy and trace substances. Not that these + are all quantities that are carried by the fluid that flows + through the sensor. For these sensors, if the parameter + allowFlowReversal=true is set (which is the default + setting), then it is strongly recommended to configure them as a + dynamic sensor. This is the default setting.
        + Configuring a sensor as a dynamic sensor is done by setting the + time constant to a non-zero value. Typically, setting + tau=10 seconds yields good results. For + tau=0, numerical problems may occur if the mass flow + rate is close to zero and + allowFlowReversal=true.
        + If allowFlowReversal=false, then the measurement of + these sensors only depends on properties at port_a. + If the mass flow rate at port_a is a + ≤ 0, i.e., fluid flows from port_b to + port_a, the model still assumes a + > 0. Hence there are no numerical problems; but use of the + sensor output may yield wrong results. Therefore, only set + allowFlowReversal=false if you can guarantee + a ≥ 0. +

        +
      • +
      • +

        + Sensors for quantities that are the product of mass flow rate + times a measured fluid property: Such quantities include + volumentric flow rate or enthalpy flow rate. For these + quantities, sensors are by default configured as steady-state + sensor. These sensors may be configured by the user as a dynamic + sensor by setting tau > 0, but there is typically + no benefit as these sensors typically do not cause numerical + problems. The reason is that these sensors multiply the quantity + that is carried by the flow, such as specific enthalpy h + by the mass flow rate to compute the measured signal + Ḣ=ṁ h. Hence, as the mass flow rate goes to zero, the + sensor output signal also goes to zero, which avoids numerical + problems. +

        +
      • +
      • +

        + Static pressure measurements: For static pressure + measurements, sensors always output the instantaneous + measurement. These sensors cannot be configured to be dynamic. +

        +
      • +
      +

      + The table below summarizes the recommendations for the use of + sensors. +

      + - - + + + - - - - - - - - - - - - - - - - - - - -
      - RelativeHumidity - - Relative humidity - + Measured quantity + + One port sensor + + Two port sensor +
      - CO2Concentration + + steady-state (tau=0) - CO2 concentration + + dynamic (tau > 0)
      - ElectricPower + + temperature
      + relative humidity
      + mass fraction
      + trace substances
      + specific enthalpy
      + specific entropy
      - Electric power from grid + + use only if connected to a volume
      - DistrictHeatingPower + + avoid - Thermal power from district heating + + recommended
      - GasPower + + volume flow rate
      + enthalpy flow rate
      + entropy flow rate
      - Thermal power from natural gas + + -
      - BiomassPower + + recommended - Thermal power from biomass + + recommended
      - SolarThermalPower + + pressure - Thermal power from solar thermal + + recommended
      - FreshWaterFlowRate + + recommended - FreshWaterFlowRate + + recommended
      -
        -
      • July 17, 2019, by Michael Wetter:
        - Added documentation. -
      • -
      • April 10, 2019, by Javier Arroyo:
        - First implementation. -
      • -
      - --------- Errors -------- -line 9 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/ThermalZones/ReducedOrder/RC/FourElements.mo ---- --------- HTML Code -------- - -
        -
      • - March 7, 2022, by Michael Wetter:
        - Removed massDynamics.
        - This is for - #1542. -
      • -
      • - 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 -
      • -
      • - 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 -------- -
        -
      • March 7, 2022, by Michael Wetter:
        - Removed massDynamics.
        - This is for #1542. -
      • -
      • 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 -
      • -
      • 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. -
      • -
      +

      + Sensor Dynamics +

      +
      + Dynamic response to fluid flowing through the sensor +

      - 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. + 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),

      - The image below shows the RC-network of this model. + 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.

      -

      - \"image\" +

      + 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),

      - --------- Errors -------- -line 15 column 4 - 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 + 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.

      -

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

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

      -
        -
      • 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 3 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

      - -
        -
      • - November 29, 2013 by Marcus Fuchs:
        - Implementation based on Functions.quadraticLinear. -
      • -
      - --------- Corrected Code -------- +
      + Combined dynamic response +

      - Block for function quadraticLinear, which computes + For the sensor AixLib.Fluid.Sensors.TemperatureTwoPort, + if both dynamic effects are enabled, then the output T is + computed as

      -

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

      + dT ⁄ dt = |ṁ| ⁄ ṁ0   (θ-T) ⁄ τ + + (TAmb-T) ⁄ τHeaTra. +

      +

      + Implementation +

      +

      + The above equation is implemented in such a way that it is + differentiable in the mass flow rate. +

      +

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

      -
        -
      • November 29, 2013 by Marcus Fuchs:
        - Implementation based on Functions.quadraticLinear. -
      • -
      -------- Errors -------- -line 3 column 2 - Warning:

      attribute "align" not allowed for HTML5 +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/Functions/quadraticLinear.mo ---- +---- AixLib/Utilities/Math/Bicubic.mo ---- -------- HTML Code -------- - This function computes +

      + This block computes +

      - y = a1 + a2 x1 - + a3 x12 - + (a4 + a5 x1 - + a6 x12) x2 + 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

      • - February 29, 2009 by Michael Wetter:
        + Sep 17, 2010 by Michael Wetter:
        First implementation.
      -------- Corrected Code -------- -This function computes +

      + This block computes +

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

        -
      • February 29, 2009 by Michael Wetter:
        - First implementation. -
      • -
      - --------- Errors -------- -line 3 column 2 - Warning:

      attribute "align" not allowed for HTML5 - - ----- AixLib/BoundaryConditions/Validation/BESTEST/WD200.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. -
      • -
      - -

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

      -
      -------- Errors -------- -line 5 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/Movers/BaseClasses/Characteristics/pressure.mo ---- +---- AixLib/Controls/Discrete/BooleanDelay.mo ---- -------- HTML Code --------

      - This function computes the fan static - pressure raise as a function of volume flow rate and revolution in the form + 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

      - Δp = rN2   s(V̇/rN, d), -

      -

      - 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

      -

      - 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. + y(ti+1) = u(ti).

      • - September 8, 2016, by Michael Wetter and Filip Jorissen:
        - Changed implementation to allow r_N = 0.
        - This is - for #458. + 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.
      • - 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. + November 21, 2011, by Michael Wetter:
        + Improved documentation. +
      • +
      • + November 26, 2008, by Michael Wetter:
        + First implementation.
      -------- Corrected Code --------

      - This function computes the fan static pressure raise as a function of - volume flow rate and revolution in the form -

      -

      - Δp = rN2   s(V̇/rN, d), -

      -

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

      -

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

      -

      - The function allows rN to be zero. +

      + y(ti+1) = u(ti).

        -
      • September 8, 2016, by Michael Wetter and Filip Jorissen:
        - Changed implementation to allow r_N = 0.
        - This is for #458. +
      • 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.
      • -
      • 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. +
      • November 21, 2011, by Michael Wetter:
        + Improved documentation. +
      • +
      • November 26, 2008, by Michael Wetter:
        + First implementation.
      -------- Errors -------- -line 6 column 2 - Warning:

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

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FMI/ExportContainers/ThermalZones.mo ---- +---- AixLib/Fluid/FMI/Adaptors/HVAC.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. + 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.

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

      - The example - - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones - shows how multiple simple thermal zones can be implemented and exported as - an FMU. - + 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 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. + 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 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 + 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 respective room, even if the flow is zero or negative. + 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

      @@ -19726,140 +19981,107 @@ line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 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 + Note that without the max(·, ·) function, 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. + 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

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

      • January 18, 2019, by Jianjun Hu:
        - Limited the media choice to moist air. + Limited the media choice to moist air only. See #1050.
      • - September 20, 2016, by Thierry S. Nouidui:
        - Revised documentation to explain the rationale - of needing mass flow rate sensors. + 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 and documentation. + Revised implementation.
      • - April 27, 2016, by Thierry S. Nouidui:
        + April 14, 2016, 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. + 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.

      -

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

      - The example - AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZones - shows how multiple simple thermal zones can be implemented and - exported as an FMU. + 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 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. + 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 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 + 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 respective room, even if the flow is - zero or negative. If a medium has no moisture, e.g., if + 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 + 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   @@ -19872,1683 +20094,1427 @@ line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 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. + temperature. Note that without the max(·, ·) function, the + energy balance would be wrong.

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

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

      • 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. +
      • 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 and documentation. + Revised implementation.
      • -
      • April 27, 2016, by Thierry S. Nouidui:
        +
      • April 14, 2016, by Michael Wetter:
        First implementation.
      -------- Errors -------- -line 78 column 2 - Warning:

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

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/BaseClasses/PlugFlow.mo ---- +---- AixLib/Controls/SetPoints/Examples/SupplyReturnTemperatureReset.mo ---- -------- HTML 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. + 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.

      -

      Assumptions

      -

      - This model is based on the following assumptions: +

      + \"Supply

      +
      • - Axial diffusion in water is assumed to be negligibe. -
      • -
      • - The water temperature is assumed uniform in a cross section. + November 21, 2011, by Michael Wetter:
        + Added 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. + 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.

      -

      - Assumptions -

      -

      - This model is based on the following assumptions: +

      + \"Supply

        -
      • Axial diffusion in water is assumed to be negligibe. -
      • -
      • The water temperature is assumed uniform in a cross section. +
      • November 21, 2011, by Michael Wetter:
        + Added documentation.
      -------- Errors -------- -line 10 column 2 - Warning:

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

      attribute "align" not allowed for HTML5 ----- AixLib/Controls/Continuous/Examples/OffTimer.mo ---- +---- AixLib/Utilities/Math/Functions/biquadratic.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 function computes +

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

      • - 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 + 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

        -
      • November 21, 2011, by Michael Wetter:
        - Added documentation. +
      • Sep 8, 2010 by Michael Wetter:
        + First implementation.
      -------- Errors -------- -line 10 column 2 - Warning:

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

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/BaseClasses/Characteristics/power.mo ---- +---- AixLib/Fluid/HeatPumps/Compressors/ScrollCompressor.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 a scroll processor, as detailed in Jin (2002). The rate of heat transferred to the evaporator is given by:

      - P = rN3   s(V̇/rN, d), + Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ).

      - 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. + The power consumed by the compressor is given by a linear efficiency relation: +

      +

      + P = PTheoretical / η + PLoss,constant.

      -

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

      • - 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. + January 25, 2019, by Michael Wetter:
        + Added start value to avoid warning in JModelica.
      • - September 28, 2011, by Michael Wetter:
        + May 30, 2017, by Filip Jorissen:
        + Removed pressure_error as + this is replaced by + + AixLib.Fluid.HeatPumps.Compressors.BaseClasses.TemperatureProtection. + See #769. +
      • +
      • + November 11, 2016, by Massimo Cimmino:
        First implementation.
      -------- Corrected Code --------

      - This function computes the fan power consumption for given volume - flow rate, speed and performance data. The power consumption is + Model for a scroll processor, as detailed in Jin (2002). The rate of + heat transferred to the evaporator is given by:

      - P = rN3   s(V̇/rN, d), + Q̇Eva = ṁref ( + hVap(TEva) - hLiq(TCon) + ).

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

      - Implementation + Assumptions and 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. + 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.

        -
      • 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. +
      • January 25, 2019, by Michael Wetter:
        + Added start value to avoid warning in JModelica.
      • -
      • September 28, 2011, by Michael Wetter:
        +
      • May 30, 2017, by Filip Jorissen:
        + Removed pressure_error as this is replaced by + AixLib.Fluid.HeatPumps.Compressors.BaseClasses.TemperatureProtection. + See #769. +
      • +
      • November 11, 2016, by Massimo Cimmino:
        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 +line 11 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/FixedResistances/HydraulicDiameter.mo ---- +---- AixLib/Fluid/Humidifiers/SprayAirWasher_X.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. + Model for a spray air washer with a prescribed outlet water vapor mass fraction + in kg/kg total air.

      - The factor fac takes into account additional resistances such as - for bends. The default value of 2 can be changed by the user. + 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 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 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.

      - If the parameter linearized is set to true, - then the pressure drop is computed as a linear function of the - mass flow rate. + The outlet conditions at port_a are not affected by this model, + other than for a possible pressure difference due to flow friction.

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

      -

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

      + τeff = τ |ṁ| ⁄ ṁnom

      -

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

      - For a model that uses dp_nominal as a parameter rather than - geoemetric data, use - - AixLib.Fluid.FixedResistances.PressureDrop. + Optionally, this model can have a flow resistance. + Set dp_nominal = 0 to disable the flow friction calculation.

      -

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

      - and its inverse function. + 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 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 model does not affect the enthalpy of the air. Therefore, + if water is added, the temperature will decrease, e.g., the humidification + is adiabatic.

      • - September 21, 2021, by Michael Wetter:
        - Corrected typo in comments.
        + 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 - #1525. + #1057.
      • - December 1, 2016, by Michael Wetter:
        - First implementation for - #480. + May 3, 2017, by Michael Wetter:
        + First implementation.
      -------- Corrected Code --------

      - This is a model of a flow resistance with a fixed flow coefficient. - The mass flow rate is computed as + 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

      - ṁ = k √ΔP, + τeff = τ |ṁ| ⁄ ṁnom

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

      -

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

      - Important parameters + Limitations

      - By default, the pressure drop at nominal flow rate is computed as + 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.

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

      +
        +
      • 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. +
      • +
      • May 3, 2017, by Michael Wetter:
        + First implementation. +
      • +
      + +-------- Errors -------- +line 33 column 2 - Warning:

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

      - The factor fac takes into account additional resistances - such as for bends. The default value of 2 can be changed - by the user. +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 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 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. +
      • +
      +

      - If the parameter linearized is set to true, - then the pressure drop is computed as a linear function of the mass - flow rate. +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

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

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

      -

      - Notes -

      +
      Ground heat transfer parameters

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

      - For a model that uses dp_nominal as a parameter rather - than geoemetric data, use AixLib.Fluid.FixedResistances.PressureDrop. +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.

      -

      - 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 -   +Further information on the tLoaAgg and nCel parameters can +be found in the documentation of + +AixLib.Fluid.Geothermal.Borefields.BaseClasses.HeatTransfer.GroundTemperatureResponse.

      +
      Other parameters

      - and its inverse function. +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:

        -
      • September 21, 2021, by Michael Wetter:
        - Corrected typo in comments.
        - This is for #1525. -
      • -
      • December 1, 2016, by Michael Wetter:
        - First implementation for #480. -
      • +
      • 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. +
      - --------- Errors -------- -line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 104 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. -

      -

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

      -

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

      -

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

      -

      - where kd is the loss coefficient (total pressure drop divided - by dynamic pressure) and y is the fractional opening. -

      -

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

      -

      - The damper characteristics is then used to compute the flow coefficient k(y) as: -

      -

      - k(y) = (2 ρ ⁄ kd(y))1/2 A -

      -

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

      -

      - ASHRAE 825-RP lists the following parameter values as typical (note that the - default values in the model correspond to opposed blades). -
      -

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

      -

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

      - -
        -
      • - 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.
        - This is for - #1188. -
      • -
      • - 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. -
      • -
      • - 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. -
      • -
      • - 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. -
      • -
      • - 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. -
      • -
      • - 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. -
      • -
      • - June 22, 2008 by Michael Wetter:
        - Extended range of control signal from 0 to 1 by implementing the function - - exponentialDamper. -
      • -
      • - June 10, 2008 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. +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 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. +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.

      - For yL < y < yU, the damper characteristics is: +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.

      -

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

      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.

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

      - where kd is the loss coefficient (total pressure drop divided - by dynamic pressure) and y is the fractional opening. + 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.

      - 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. + 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 damper characteristics is then used to compute the flow - coefficient k(y) as: + 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).

      -

      - k(y) = (2 ρ ⁄ kd(y))1/2 A +

      + \"image\"

      +

      + How to use the borefield models +

      +
      + Borefield data record +

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

      - ASHRAE 825-RP lists the following parameter values as typical (note - that the default values in the model correspond to opposed - blades).
      + 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.

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

      - (The loss coefficient in fully closed position k0 is - computed based on the leakage coefficient and the coefficient in - fully open position.) + 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.

      - References + Model description

      - 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. + The borefield models rely on the following key assumptions:

        -
      • 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.
        - This is for #1188. -
      • -
      • 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. -
      • -
      • 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. -
      • -
      • 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. -
      • -
      • December 14, 2012 by Michael Wetter:
        - Renamed protected parameters for consistency with the naming - conventions. +
      • The thermal properties of the soil (conductivity and diffusivity) + are constant, homogenous and isotropic.
      • -
      • 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. +
      • The conductivity, capacitance and density of the grout and pipe + material are constant, homogenous and isotropic.
      • -
      • 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. +
      • There is no heat extraction or injection prior to the simulation + start.
      • -
      • June 22, 2008 by Michael Wetter:
        - Extended range of control signal from 0 to 1 by implementing the - function exponentialDamper. +
      • All of the boreholes in the borefield have uniform dimensions + (including the pipe dimensions).
      • -
      • June 10, 2008 by Michael Wetter:
        - First implementation. +
      • Inside the boreholes, the non-advective heat transfer is only in + the radial direction.
      - --------- Errors -------- -line 50 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 - - ----- AixLib/Controls/Continuous/Examples/SignalRanker.mo ---- --------- HTML 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. -
      • -
      - --------- 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]. + 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.

      - \"Input
      - \"Output + \"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.

      -
        -
      • 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 - +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/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
      - +---- AixLib/Fluid/HeatExchangers/ActiveBeams/BaseClasses/Convector.mo ---- +-------- HTML Code -------- +

      - The details of the coefficients are explained in the - - Users Guide. + In cooling mode, this model adds heat to the water stream. The heat added is equal to:

      - - -

      - Enumeration that defines the heat exchanger construction. +

      + QBeam = Qrated fΔT fSA fW

      - The following heat exchanger configurations are available in this enumeration: + In heating mode, the heat is removed from the water stream.

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

      • - March 27, 2017, by Michael Wetter:
        - Added ConstantTemperaturePhaseChange.
        + March 3, 2022, by Michael Wetter:
        + Removed massDynamics.
        This is for - - AixLib #694. -
      • -
      • - February 18, 2009, by Michael Wetter:
        - First implementation. + issue 1542.
      • -
      - -

      - 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
      - -
      • - March 27, 2017, by Michael Wetter:
        - Added ConstantTemperaturePhaseChange.
        + April 14, 2020, by Michael Wetter:
        + Changed homotopyInitialization to a constant.
        This is for - - AixLib #694. -
      • -
      • - 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, + IBPSA, #1341.
      2. - a series of possible set points that can be switched using an integer input, or + November 2, 2016, by Michael Wetter:
        + Made assignment of senTem.y final.
      3. - a continuously variable set point. + June 13, 2016, by Michael Wetter:
        + Revised implementation.
      4. -
      - -
      • - April 2, 2015, by Filip Jorissen:
        + May 20, 2016, by Alessandro Maccarini:
        First implementation.
      -

      - 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 - - Kv (metric) flow coefficient -
      - Cv - - Cv (US) flow coefficient -
      - Av - - Av (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: -

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

      -
        -
      • March 27, 2017, by Michael Wetter:
        - Added ConstantTemperaturePhaseChange.
        - This is for AixLib - #694. -
      • -
      • February 18, 2009, by Michael Wetter:
        - First implementation. -
      • -
      -

      - Enumeration to define the heat exchanger flow regime. + In cooling mode, this model adds heat to the water stream. The heat + added is equal to:

      -

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

      + QBeam = Qrated fΔT + fSA fW

      - The following heat exchanger flow regimes are available in this - enumeration: + In heating mode, the heat is removed from the water stream.

      - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
      - 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.
        +
      • March 3, 2022, by Michael Wetter:
        + Removed massDynamics.
        This is for AixLib - #694. -
      • -
      • February 18, 2009, by Michael Wetter:
        - First implementation. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1542\">issue + 1542.
      • -
      -

      - 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. April 14, 2020, by Michael Wetter:
        + Changed homotopyInitialization to a constant.
        + This is for IBPSA, + #1341.
      3. -
      4. a series of possible set points that can be switched using an - integer input, or +
      5. November 2, 2016, by Michael Wetter:
        + Made assignment of senTem.y final.
      6. -
      7. a continuously variable set point. +
      8. June 13, 2016, by Michael Wetter:
        + Revised implementation.
      9. -
      -
        -
      • April 2, 2015, by Filip Jorissen:
        +
      • May 20, 2016, by Alessandro Maccarini:
        First implementation.
      -

      - 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 - - -line 13 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/FMI/Adaptors/HVAC.mo ---- +---- AixLib/Fluid/FixedResistances/CheckValve.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. -

      - -

      - 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. + Implementation of a hydraulic check valve. + Note that the small reverse flows can still occur with this model.

      +

      Main equations

      - 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 basic flow function

      - 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. + m = sign(Δp) k √ Δp  ,

      - 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. + with regularization near the origin, is used to compute the pressure drop. + The flow coefficient

      -

      Assumption and limitations

      -

      - The mass flow rates at ports sum to zero, hence this - model conserves mass. +

      + k = m ⁄ √ Δp  

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

      +

      Typical use and important parameters

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

      -

      Typical use and important parameters

      +

      Implementation

      - See - - AixLib.Fluid.FMI.ExportContainers.HVACZone - for a model that uses this model. + 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.

      • - 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. -
      • -
      • - April 14, 2016, by Michael Wetter:
        - First implementation. + September 16, 2019, by Kristoff Six and Filip Jorissen:
        + Implementation of a hydraulic check valve. This is for + issue 1198.
      -------- 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. + Implementation of a hydraulic check valve. Note that the small + reverse flows can still occur with this model.

      +

      + Main equations +

      - 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 basic flow function

      - Qsen = max(0, ṁsup)   cp   - (Tsup - Tair,zon), + m = sign(Δp) k √ Δp +  ,

      - 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. + with regularization near the origin, is used to compute the pressure + drop. The flow coefficient +

      +

      + k = m ⁄ √ Δp +  

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

      - Assumption and limitations + Typical use and important parameters

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

      - Typical use and important parameters + Implementation

      - See AixLib.Fluid.FMI.ExportContainers.HVACZone - for a model that uses this model. + 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.

        -
      • 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. -
      • -
      • April 14, 2016, by Michael Wetter:
        - First implementation. +
      • September 16, 2019, by Kristoff Six and Filip Jorissen:
        + Implementation of a hydraulic check valve. This is for issue + 1198.
      -------- Errors -------- -line 26 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/Media/Specialized/Water/TemperatureDependentDensity.mo ---- +---- AixLib/Media/Air.mo ---- -------- HTML Code -------- -

      - Base properties of the medium. -

      +

      + 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, +

      +

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

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

      - This function computes the density as a function of temperature. + 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 +

      +

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

      -

      Implementation

      - The function is based on the IDA implementation in therpro.nmf, which - implements + Next, the entropy of mixing is obtained from a reversible isothermal + expansion process. Hence, +

      +

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

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

      • - 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. + November 27, 2013, by Michael Wetter:
        + First implementation.

      - This function computes the dynamic viscosity. + This function returns the partial derivative of density + with respect to pressure at constant temperature.

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

      - This function computes the specific enthalpy. + This function computes the derivative of density with respect to temperature + at constant pressure.

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

      - This function computes the specific enthalpy of liquid water. + 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 2, 2013, by Michael Wetter:
        + December 18, 2013, by Michael Wetter:
        First implementation.

      - This function computes the specific internal energy. + 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.

      • - December 11, 2013, by Michael Wetter:
        + 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. +
      • +
      +

      - 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 enthalpy for + an isentropic state change from the temperature + that corresponds to the state refState + to reference_T.

        @@ -21558,920 +21524,1298 @@ line 26 column 2 - Warning:

        attribute "align" not allowed for HTML5

      + Temperature is returned from the thermodynamic state record input as a simple assignment. +

      - This function computes the specific Gibbs energy. + This function returns the molar mass.

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

      - This function computes the specific Helmholtz energy. -

      + 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.
      • - December 2, 2013, by Michael Wetter:
        - First implementation. + April 30, 2015, by Filip Jorissen and Michael Wetter:
        + Added Inline=true for + + issue 227.

      - This function computes the specific enthalpy for - an isentropic state change from the temperature - that corresponds to the state refState - to reference_T. + This data record contains the coefficients for perfect gases.

      • - December 18, 2013, by Michael Wetter:
        + September 12, 2014, by Michael Wetter:
        + Corrected the wrong location of the preferredView + and the revisions annotation. +
      • +
      • + November 21, 2013, by Michael Wetter:
        First implementation.

      - This function returns the isobaric expansion coefficient, + 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

      - βp = - 1 ⁄ v   (∂ v ⁄ ∂ T)p, + ρ/ρstp = p/pstp,

      where - v is the specific volume, - T is the temperature and - p is the pressure. + 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, +

      +

      + 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, +

      +

      + from which follows that +

      +

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

      +

      + because p ⁄ ρ = pstp ⁄ ρstp in this medium model. +

      +

      + The enthalpy is computed using the convention that h=0 + if T=0 °C and no water vapor is present.

      • - December 18, 2013, by Michael Wetter:
        - First implementation. + 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.
      • -
      - -

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

      - -
      • - December 18, 2013, by Michael Wetter:
        - First implementation. + May 1, 2015, by Michael Wetter:
        + Added Inline=true for + + issue 227.
      • -
      - -

      - 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 20, 2015, by Michael Wetter:
        + Added missing term state.p/reference_p in function + specificEntropy. + #193.
      • -
      - -

      - 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. + February 3, 2015, by Michael Wetter:
        + Removed stateSelect.prefer for temperature. This is for - issue 303. + #160.
      • - December 18, 2013, by Michael Wetter:
        - First implementation, based on the IDA implementation in therpro.nmf, - but converted from Celsius to Kelvin. + July 24, 2014, by Michael Wetter:
        + Changed implementation to use + + AixLib.Utilities.Psychrometrics.Constants. + This was done to use consistent values throughout the library.
      • -
      - -

      - 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. + November 16, 2013, by Michael Wetter:
        + Revised and simplified the implementation.
      • -
      - -

      - This function returns the specific heat capacity at constant pressure. -

      - -
      • - December 11, 2013, by Michael Wetter:
        - First implementation. + November 14, 2013, by Michael Wetter:
        + Removed function + HeatCapacityOfWater + which is neither needed nor implemented in the + Modelica Standard Library.
      • -
      - -

      - This function computes the specific heat capacity at constant volume. -

      - -
      • - December 11, 2013, by Michael Wetter:
        - First implementation. + November 13, 2013, by Michael Wetter:
        + Removed non-used computations in specificEnthalpy_pTX and + in temperature_phX.
      • -
      - -

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

      - This function returns the pressure. -

      - -
      • - December 18, 2013, by Michael Wetter:
        - First implementation. + April 12, 2012, by Michael Wetter:
        + Added keyword each to Xi(stateSelect=...).
      • -
      - -

      - This function returns the temperature. -

      - -
      • - December 18, 2013, by Michael Wetter:
        - First implementation. + April 4, 2012, by Michael Wetter:
        + Added redeclaration of ThermodynamicState to avoid a warning + during model check and translation.
      • -
      - -

      - This function returns the molar mass, - which is assumed to be constant. -

      - -
      • - December 18, 2013, by Michael Wetter:
        - First implementation. + 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.
      • -
      - -

      - This function returns the thermodynamic state for a given pressure, - specific enthalpy and composition. -

      - -
      • - December 11, 2013, by Michael Wetter:
        - First implementation. + 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.
      • -
      - -

      - This function returns the thermodynamic state for a given pressure, - temperature and composition. -

      - -
      • - December 11, 2013, by Michael Wetter:
        - First implementation. + January 22, 2010, by Michael Wetter:
        + Added implementation of function + + enthalpyOfNonCondensingGas and its derivative.
      • -
      - -

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

      -

      - 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. + January 13, 2010, by Michael Wetter:
        + Fixed implementation of derivative functions.
      • - December 11, 2013, by Michael Wetter:
        + August 28, 2008, by Michael Wetter:
        First implementation.
      +-------- Corrected Code -------- +

      + Model with basic thermodynamic properties. +

      +

      + 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 +
      +
        +
      • 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, +

      +

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

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

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

      +

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

      +
        +
      • November 27, 2013, by Michael Wetter:
        + First implementation. +
      • +
      +

      + This function returns the partial derivative of density with respect + to pressure at constant temperature. +

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

      + This function computes the derivative of density with respect to + temperature at constant pressure. +

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

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

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

      + This function returns the molar mass. +

      +
        +
      • December 18, 2013, by Michael Wetter:
        + First implementation. +
      • +
      +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. +
      • +
      +

      + 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. +
      • +
      • November 21, 2013, by Michael Wetter:
        + 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 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, +

      +

      + 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, +

      +

      + from which follows that +

      +

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

      +

      + because p ⁄ ρ = pstp ⁄ ρstp in this + medium model. +

      +

      + The enthalpy is computed using the convention that h=0 if + T=0 °C and no water vapor is present. +

      +
        +
      • 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 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 -------- +

      - This function computes the derivative of the specific heat capacity - at constant pressure with respect to the state. + This is a model of a flow resistance with a fixed flow coefficient. + The mass flow rate is computed as +

      +

      + ṁ = k + √ΔP,

      - -
        -
      • - December 11, 2013, by Michael Wetter:
        - First implementation. -
      • -
      -

      - This function computes the temperature derivative of the enthalpy of liquid water - per unit mass. + 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.

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

      Assumptions

      - This function computes the kinematic viscosity as a function of temperature. + 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.

      -

      Implementation

      +

      Important parameters

      - The function is based on the IDA implementation in therpro.nmf. - The original equation is + By default, the pressure drop at nominal flow rate is computed as

      - 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);
      -       
      + dp_nominal = fac * dpStraightPipe_nominal, +

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

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

      - This medium package models liquid water. + The factor fac takes into account additional resistances such as + for bends. The default value of 2 can be changed by the user.

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

      - 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 + If the parameter linearized is set to true, + then the pressure drop is computed as a linear function of the + mass flow rate.

      - -

      - Thermal conductivity is calculated as a function of temperature as shown in the figure below. - The correlation used to calculate the thermal conductivity is + 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.

      - -

      - λ(T) = λ(298.15 K) ⋅ (-1.48445+4.12292⋅(T/298.15)-1.63866⋅(T/298.15)2), +

      + 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

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

      -

      - \"Thermal +

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

      - +

      Implementation

      - 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 pressure drop is computed by calling a function in the package + + AixLib.Fluid.BaseClasses.FlowModels, + This package contains regularized implementations of the equation

      -

      - \"Kinematic +

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

      -

      - The enthalpy is computed using the convention that h=0 - if T=0 °C. + and its inverse function.

      -

      Limitations

      - Phase changes are not modeled. + 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.

      • - April 5, 2022, by Michael Wetter:
        - Corrected assignment of R_s in BaseProperties to avoid a unit error.
        - This is for - #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 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\". -
      • -
      • - February 3, 2015, by Michael Wetter:
        - Removed stateSelect.prefer for temperature. - This is for - #160. -
      • -
      • - October 15, 2014, by Michael Wetter:
        - Renamed from AixLib.Media.Water to - AixLib.Media.Water.Detailed to allow addition of - AixLib.Media.Water.Simple. -
      • -
      • - 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. + September 21, 2021, by Michael Wetter:
        + Corrected typo in comments.
        + This is for + #1525.
      • - December 18, 2013, by Michael Wetter:
        - First implementation. + December 1, 2016, by Michael Wetter:
        + First implementation for + #480.
      -------- Corrected 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. -

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

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

      - This function computes the specific enthalpy of liquid water. -

      -
        -
      • December 2, 2013, by Michael Wetter:
        - First implementation. -
      • -
      -

      - This function computes the specific internal energy. -

      -
        -
      • December 11, 2013, by Michael Wetter:
        - First implementation. -
      • -
      -

      - This function computes the specific entropy. -

      -

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

      - This function computes the specific Gibbs energy. -

      -
        -
      • December 2, 2013, by Michael Wetter:
        - First implementation. -
      • -
      -

      - 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 + This is a model of a flow resistance with a fixed flow coefficient. + The mass flow rate is computed as

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

      -

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

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

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

      - This function returns the specific heat capacity at constant - pressure. -

      -
        -
      • December 11, 2013, by Michael Wetter:
        - First implementation. -
      • -
      -

      - This function computes the specific heat capacity at constant volume. + ṁ = k √ΔP,

      -
        -
      • December 11, 2013, by Michael Wetter:
        - First implementation. -
      • -

      - This function returns the thermal conductivity. The expression is - obtained from Ramires et al. (1995). + 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.

      - References + Assumptions

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

      - This function returns the pressure. + 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.

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

      + Important parameters +

      - This function returns the temperature. + By default, the pressure drop at nominal flow rate is computed as

      -
        -
      • December 18, 2013, by Michael Wetter:
        - First implementation. -
      • -
      +
      + dp_nominal = fac * dpStraightPipe_nominal,
      + 

      - This function returns the molar mass, which is assumed to be - constant. -

      -
        -
      • December 18, 2013, by Michael Wetter:
        - First implementation. -
      • -
      + 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. +

      - This function returns the thermodynamic state for a given pressure, - specific enthalpy and composition. + The factor fac takes into account additional resistances + such as for bends. The default value of 2 can be changed + by the user.

      -
        -
      • December 11, 2013, by Michael Wetter:
        - First implementation. -
      • -

      - This function returns the thermodynamic state for a given pressure, - temperature and composition. + 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.

      -
        -
      • December 11, 2013, by Michael Wetter:
        - First implementation. -
      • -

      - This function returns the thermodynamic state based on pressure, - specific entropy and mass fraction. + If the parameter linearized is set to true, + then the pressure drop is computed as a linear function of the mass + flow rate.

      - The state is computed by symbolically solving - AixLib.Media.Specialized.Water.TemperatureDependentDensity.specificEntropy - for temperature. + 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.

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

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

      + Notes +

      - This function computes the temperature derivative of the enthalpy of - liquid water per unit mass. + 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.

      -
        -
      • December 11, 2013, by Michael Wetter:
        - First implementation. -
      • -

      - This function computes the kinematic viscosity as a function of - temperature. + For a model that uses dp_nominal as a parameter rather + than geoemetric data, use AixLib.Fluid.FixedResistances.PressureDrop.

      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 + The pressure drop is computed by calling a function in the package - AixLib.Media.Specialized.Water.TemperatureDependentDensity.dynamicViscosity. + \"modelica://AixLib.Fluid.BaseClasses.FlowModels\">AixLib.Fluid.BaseClasses.FlowModels, + This package contains regularized implementations of the equation

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

      - This medium package models liquid water. +

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

      - 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 + and its inverse function.

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

      -

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

      +
        +
      • September 21, 2021, by Michael Wetter:
        + Corrected typo in comments.
        + This is for #1525. +
      • +
      • December 1, 2016, by Michael Wetter:
        + First implementation for #480. +
      • +
      + +-------- Errors -------- +line 6 column 2 - Warning:

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

      attribute "align" not allowed for 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 --------

      - Thermal conductivity is calculated as a function of temperature as - shown in the figure below. The correlation used to calculate the - thermal conductivity is + 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

      - λ(T) = λ(298.15 K) ⋅ - (-1.48445+4.12292⋅(T/298.15)-1.63866⋅(T/298.15)2), + Ḣtot = Ḣsen + Ḣlat,

      - 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 sen = ṁ (1-Xw) + cp,air, then this sensor outputs Ḣ = + Ḣlat.

      - 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 + 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 enthalpy is computed using the convention that h=0 if - T=0 °C. + For a sensor that measures tot, use AixLib.Fluid.Sensors.EnthalpyFlowRate.
      + + For a sensor that measures sen, use AixLib.Fluid.Sensors.SensibleEnthalpyFlowRate.

      -

      - Limitations -

      - Phase changes are not modeled. + 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).

        -
      • April 5, 2022, by Michael Wetter:
        - Corrected assignment of R_s in - BaseProperties to avoid a unit error.
        +
      • October 19, 2020, by Antoine Gautier:
        + Changed default value for tau from 1 to + 0.
        This is for #1603. + \"https://github.com/ibpsa/modelica-ibpsa/issues/1406\">#1406.
      • -
      • July 7, 2016, by Carles Ribas Tugores:
        - Correct Documentation. This is for #487. +
      • February 25, 2020, by Michael Wetter:
        + Changed icon to display its operating state.
        + This is for #1294.
      • -
      • 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 +
      • January 18, 2016 by Filip Jorissen:
        + Using parameter tauInv since this now exists in #266. + \"modelica://AixLib.Fluid.Sensors.BaseClasses.PartialDynamicFlowSensor\"> + AixLib.Fluid.Sensors.BaseClasses.PartialDynamicFlowSensor. This + is for #372.
      • -
      • May 1, 2015, by Michael Wetter:
        - Added Inline=true for issue 227. +
      • September 10, 2013, by Michael Wetter:
        + Changed medium declaration in the extends statement to + replaceable to avoid a translation error in + OpenModelica.
      • -
      • 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 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.
      • -
      • February 3, 2015, by Michael Wetter:
        - Removed stateSelect.prefer for temperature. This is - for #160. +
      • 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.
      • -
      • October 15, 2014, by Michael Wetter:
        - Renamed from AixLib.Media.Water to - AixLib.Media.Water.Detailed to allow addition of - AixLib.Media.Water.Simple. +
      • 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.
      • -
      • 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. +
      • 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.
      • -
      • December 18, 2013, by Michael Wetter:
        - First implementation. +
      • 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.
      -------- 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 6 column 2 - Warning:

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

      - This is the base class for the Carnot chiller and the Carnot heat pump - whose coefficient of performance COP changes + 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 @@ -22485,90 +22829,108 @@ line 62 column 2 - Warning:

      attribute "align" not allowed for HTML5

      ηCarnot,0 = COP0 - ⁄ (Tuse,0 ⁄ (Tcon,0-Teva,0)), + ⁄ (Teva,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. + On the Advanced tab, a user can specify the temperatures that + will be used as the evaporator and condenser temperature.

      - The COP is computed as the product + 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 the part load efficiency, expressed using - a polynomial. + η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 y + a3 y2 + ... + ηPL = a1 + a2 yPL + a3 yPL2 + ...

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

      +

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

        -
      • - April 14, 2020, by Michael Wetter:
        - Changed homotopyInitialization to a constant.
        - This is for - IBPSA, #1341. -
      • -
      • - September 12, 2019, by Michael Wetter:
        - Corrected value of evaluate_etaPL and how it is used. - This correction only affects protected variables and does not affect the results.
        - This is for - #1200. -
      • -
      • - June 16, 2017, by Michael Wetter:
        - Added temperature difference between fluids in condenser and evaporator - for computation of nominal COP and effectiveness.
        - This is for - #698. -
      • -
      • - March 28, 2017, by Felix Buenning:
        - Added temperature difference between fluids in condenser and evaporator. - The difference is based on discussions with Emerson Climate Technologies.
        - This is for - #698. +
      • + May 8, 2017, by Michael Wetter:
        + Replaced model that interfaces with fluid stream.
        + This is for + + AixLib, #763.
      • January 2, 2017, by Filip Jorissen:
        - Removed option for choosing what temperature - should be used to compute the Carnot efficiency. + Removed parameters + effInpEva and effInpCon + and updated documentation. This is for issue 497.
      • - January 26, 2016, by Michael Wetter:
        - First implementation of this base class. + 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 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 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 @@ -22579,2435 +22941,2073 @@ line 62 column 2 - Warning:

      attribute "align" not allowed for HTML5 effectivness as

      - ηCarnot,0 = COP0 ⁄ (Tuse,0 ⁄ - (Tcon,0-Teva,0)), + ηCarnot,0 = COP0 ⁄ (Teva,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. + On the Advanced tab, a user can specify the temperatures + that will be used as the evaporator and condenser temperature.

      - The COP is computed as the product + 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 the part load efficiency, expressed using a - polynomial. This polynomial has the form + η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 y + a3 - y2 + ... + ηPL = a1 + a2 yPL + + a3 yPL2 + ...

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

      - Implementation + Typical use and important parameters

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

      +

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

        -
      • April 14, 2020, by Michael Wetter:
        - Changed homotopyInitialization to a constant.
        - This is for IBPSA, - #1341. -
      • -
      • September 12, 2019, by Michael Wetter:
        - Corrected value of evaluate_etaPL and how it is used. - This correction only affects protected variables and does not - affect the results.
        +
      • May 8, 2017, by Michael Wetter:
        + Replaced model that interfaces with fluid stream.
        This is for #1200. + \"https://github.com/ibpsa/modelica-ibpsa/issues/763\">AixLib, + #763.
      • -
      • June 16, 2017, by Michael Wetter:
        - Added temperature difference between fluids in condenser and - evaporator for computation of nominal COP and effectiveness.
        - This is for #698. +
      • January 2, 2017, by Filip Jorissen:
        + Removed parameters effInpEva and + effInpCon and updated documentation. This is for + issue + 497.
      • -
      • March 28, 2017, by Felix Buenning:
        - Added temperature difference between fluids in condenser and - evaporator. The difference is based on discussions with Emerson - Climate Technologies.
        +
      • 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 #698. -
      • -
      • January 2, 2017, by Filip Jorissen:
        - Removed option for choosing what temperature should be used to - compute the Carnot efficiency. This is for issue 497. + \"https://github.com/ibpsa/modelica-ibpsa/issues/497\">Annex 60, + issue 497.
      • -
      • January 26, 2016, by Michael Wetter:
        - First implementation of this base class. +
      • November 25, 2015 by Michael Wetter:
        + First implementation.
      -------- Errors -------- -line 16 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 30 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/Humidifiers/SteamHumidifier_X.mo ---- +---- AixLib/Fluid/HeatExchangers/DryCoilEffectivenessNTU.mo ---- -------- HTML 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 + Model of a coil without humidity condensation. + This model transfers heat in the amount of

      - τeff = τ |ṁ| ⁄ ṁnom + Q̇ = Q̇max ε
      + ε = f(NTU, Z, flowRegime),

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

      - 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 - + The flow regimes depend on the heat exchanger configuration. All configurations + defined in + + AixLib.Fluid.Types.HeatExchangerConfiguration + are supported.

      -

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

      - -
        -
      • - March 8, 2022, by Michael Wetter:
        - Renamed parameter massDynamics to energyDynamics for consistency with other models. -
      • -
      • - May 10, 2017, by Michael Wetter:
        - First implementation. -
      • -
      - --------- 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. -

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

      + +
        +
      • + September 25, 2018, by Michael Wetter:
        + Refactored model to use a common base class. +
      • +
      + +-------- Corrected Code --------

      - 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 + Model of a coil without humidity condensation. This model transfers + heat in the amount of

      - τeff = τ |ṁ| ⁄ ṁnom + Q̇ = Q̇max ε
      + ε = f(NTU, Z, flowRegime),

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

      - Optionally, this model can have a flow resistance. Set - dp_nominal = 0 to disable the flow friction calculation. + The flow regimes depend on the heat exchanger configuration. All + configurations defined in AixLib.Fluid.Types.HeatExchangerConfiguration + are supported.

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

      -

      - 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. + For a heat and moisture exchanger, use AixLib.Fluid.MassExchangers.ConstantEffectiveness.

        -
      • March 8, 2022, by Michael Wetter:
        - Renamed parameter massDynamics to - energyDynamics for consistency with other models. -
      • -
      • May 10, 2017, by Michael Wetter:
        - First implementation. +
      • September 25, 2018, by Michael Wetter:
        + Refactored model to use a common base class.
      -------- 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/HeatPumps/Carnot_y.mo ---- +---- AixLib/Fluid/HeatPumps/ScrollWaterToWater.mo ---- -------- HTML 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 + 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.

      -

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

      + \"image\"

      - The heat pump COP is computed as the product + The rate of heat transferred to the evaporator is given by:

      - COP = ηCarnot,0 COPCarnot ηPL, + Q̇Eva = ṁref ( hVap(TEva) - hLiq(TCon) ).

      - 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 + The power consumed by the compressor is given by a linear efficiency relation:

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

      -

      - where the coefficients ai are declared by the parameter a. + P = PTheoretical / η + PLoss,constant.

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

      -

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

      - The maximum heating capacity is set by the parameter QCon_flow_max, - which is by default set to infinity. + 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 coefficient of performance depends on the - evaporator and condenser leaving temperature - since otherwise the second law of thermodynamics may be violated. + 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.

      -

      Notes

      +

      References

      - For a similar model that can be used as a chiller, see - AixLib.Fluid.Chillers.Carnot_y. + H. Jin. + + Parameter estimation based models of water source heat pumps. + + PhD Thesis. Oklahoma State University. Stillwater, Oklahoma, USA. 2002.

      • - 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. + May 30, 2017, by Filip Jorissen:
        + Revised documentation for temperature protection. + See #769.
      • - March 3, 2009 by Michael Wetter:
        + November 11, 2016, by Massimo Cimmino:
        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. + 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 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 rate of heat transferred to the evaporator is given by:

      - ηCarnot,0 = COP0 ⁄ (Tcon,0 ⁄ - (Tcon,0-Teva,0)). + Q̇Eva = ṁref ( + hVap(TEva) - hLiq(TCon) + ).

      - The heat pump COP is computed as the product + The power consumed by the compressor is given by a linear efficiency + relation:

      - COP = ηCarnot,0 COPCarnot ηPL, + P = PTheoretical / η + PLoss,constant.

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

      - where the coefficients ai are declared by the - parameter a. + 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.

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

      - Typical use and important parameters + Options

      - 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. + 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 coefficient of performance depends on the evaporator and - condenser leaving temperature since otherwise the second law of - thermodynamics may be violated. + 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.

      - Notes + References

      - For a similar model that can be used as a chiller, see AixLib.Fluid.Chillers.Carnot_y. + H. Jin. Parameter estimation based models of water source heat + pumps. PhD Thesis. Oklahoma State University. Stillwater, + Oklahoma, USA. 2002.

        -
      • 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. +
      • May 30, 2017, by Filip Jorissen:
        + Revised documentation for temperature protection. See #769.
      • -
      • March 3, 2009 by Michael Wetter:
        +
      • November 11, 2016, by Massimo Cimmino:
        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 +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/Utilities/Math/Bicubic.mo ---- +---- AixLib/Fluid/HeatPumps/Carnot_y.mo ---- -------- HTML Code --------

      - This block 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 x2 + a5 x22 - + a6 x1 x2 - + a7 x1^3 - + a8 x2^3 - + a9 x12 x2 - + a10 x1 x22 + η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.

      • - Sep 17, 2010 by Michael Wetter:
        - First implementation. -
      • -
      - --------- 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/BoundaryConditions/Validation/BESTEST/WD400.mo ---- --------- HTML Code -------- - -

        -
      • - September 6, 2021, by Ettore Zanetti:
        - Removed parameter lat as it is now obtained from the weather data bus.
        + January 3, 2017, by Michael Wetter:
        + Removed parameters + effInpEva and effInpCon + and updated documentation. This is for - IBPSA, #1477. + + issue 497.
      • - March 11, 2020, by Ettore Zanetti:
        - First implementation. + 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.
      • - April 14, 2020, by Ettore Zanetti:
        - Rework after comments from pull request - #1339. + 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.
      • - May 2, 2021, by Ettore Zanetti:
        - Updated weather file as explained in #1478. + 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.
      • -
      - -

      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 -------- -
        -
      • 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/BoundaryConditions/Validation/BESTEST/WD500.mo ---- --------- HTML Code -------- - -
      • - September 6, 2021, by Ettore Zanetti:
        - Removed parameter lat as it is now obtained from the weather data bus.
        + 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, #1477. + + issue 476.
      • - March 11, 2020, by Ettore Zanetti:
        - 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 is for + + issue 468.
      • - April 14, 2020, by Ettore Zanetti:
        - Rework after comments from pull request - #1339. + September 3, 2015 by Michael Wetter:
        + Expanded documentation.
      • - May 2, 2021, by Ettore Zanetti:
        - Updated weather file as explained in #1478. + May 6, 2015 by Michael Wetter:
        + Added prescribedHeatFlowRate=true for vol2.
      • -
      - -

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

      - WD500: Time Zone Case -

      +
    • + 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 --------

      - Weather data file : WD500.epw + 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.

      - Table 1: Site Data for Weather file WD500epw + 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)).

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

      - Latitude -

      -
      -

      - 28.567° north -

      -
      -

      - Longitude -

      -
      -

      - 77.103° east -

      -
      -

      - Altitude -

      -
      -

      - 236.9 m -

      -
      -

      - Time Zone -

      -
      -

      - 5.5 -

      -
      - --------- Errors -------- -line 5 column 2 - Warning: The summary attribute on the element is obsolete in 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 heat pump COP is computed as the product +

      +

      + COP = ηCarnot,0 COPCarnot ηPL,

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

      -The weather radiation data has to be provided at different orientations and inclinations. + where the coefficients ai are declared by the + parameter a.

      -

      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

      -
        -
      • Ground reflectance ρ is set to 0 for cases from WD100 to WD500 and 0.2 for WD600
      • -
      • -Sky black body temperature -calculated using Horizontal radiation or dew point temperature and sky cover. -
      • -
      • Diffused radiation calculated using Perez and -Isotropic sky models
      • -
      -

      Outputs required

      -

      Annual Outputs

      -

       The following outputs are provided for an annual simulation:

      -
        -
      • Average dry bulb temperature (°C)
      • -
      • Average relative humidity (%)
      • -
      • Average dewpoint temperature (°C)
      • -
      • 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)
      • -
      -

      Hourly Outputs

      -

      The following outputs are provided for each hour of the days specified for each test case in Table 3:

      -
        -
      • Dry bulb temperature (°C)
      • -
      • Relative humidity (%)
      • -
      • Dewpoint temperature (°C)
      • -
      • Humidity ratio (kg moisture/kg dry air)
      • -
      • Wet bulb temperature (°C)
      • -
      • Windspeed (m/s)
      • -
      • Wind direction (degrees from north)
      • -
      • Station pressure (mbar)
      • -
      • Total cloud cover (tenths of sky)
      • -
      • Opaque cloud cover (tenths of sky)
      • -
      • Sky temperature (°C)
      • -
      • Sum of total, beam, and diffuse solar radiation incident on each surface (Wh/m2) 
      • -
      -

      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:

      -
        -
      • Dry bulb temperature (C)
      • -
      • Relative humidity (%)
      • -
      • 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)
      • -
      • Total incident horizontal diffuse solar radiation (Wh/m2)
      • -
      -

      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: +

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

        -
      • Clone the last master branch of the AixLib repository into a temporary directory
      • -
      • Execute all the simulations and create the folders with the .mat and .json files inside the BESTEST/Simulations folder
      • -
      -

      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.
      -
        -
      • -March 11, 2020, by Ettore Zanetti:
        -first implementation of BESTEST weather validation -
      • + 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. +

      +

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

      +

      + For yL < y < yU, the damper characteristics is: +

      +

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

      +

      + where kd is the loss coefficient (total pressure drop divided + by dynamic pressure) and y is the fractional opening. +

      +

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

      +

      + The damper characteristics is then used to compute the flow coefficient k(y) as: +

      +

      + k(y) = (2 ρ ⁄ kd(y))1/2 A +

      +

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

      +

      + ASHRAE 825-RP lists the following parameter values as typical (note that the + default values in the model correspond to opposed blades). +
      +

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

      +

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

      + +
        +
      • + 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.
        + This is for + #1188. +
      • +
      • + 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. +
      • +
      • + 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. +
      • +
      • + 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. +
      • +
      • + 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. +
      • +
      • + 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. +
      • +
      • + June 22, 2008 by Michael Wetter:
        + Extended range of control signal from 0 to 1 by implementing the function + + exponentialDamper. +
      • +
      • + June 10, 2008 by Michael Wetter:
        + First implementation. +
      • +
      + -------- 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. + 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.

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

      - The weather radiation data has to be provided at different - orientations and inclinations. + For yL < y < yU, the damper characteristics is:

      -

      - Table 2: Azimuth and Slope for Surfaces +

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

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

      - 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 + where kd is the loss coefficient (total pressure drop divided + by dynamic pressure) and y is the fractional opening.

      -
        -
      • Ground reflectance ρ is set to 0 for cases from WD100 to WD500 - and 0.2 for WD600 -
      • -
      • - Sky - black body temperature calculated using Horizontal radiation or - dew point temperature and sky cover. -
      • -
      • Diffused radiation calculated using - Perez and - Isotropic sky models -
      • -
      -

      - Outputs required -

      - Annual Outputs + 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.

      -  The following outputs are provided for an annual - simulation: + The damper characteristics is then used to compute the flow + coefficient k(y) as:

      -
        -
      • Average dry bulb temperature (°C) -
      • -
      • Average relative humidity (%) -
      • -
      • Average dewpoint temperature (°C) -
      • -
      • 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) -
      • -

      -

      - Hourly Outputs +

      + k(y) = (2 ρ ⁄ kd(y))1/2 A

      - The following outputs are provided for each hour of the days - specified for each test case in Table 3: -

      -
        -
      • Dry bulb temperature (°C) -
      • -
      • Relative humidity (%) -
      • -
      • Dewpoint temperature (°C) -
      • -
      • Humidity ratio (kg moisture/kg dry air) -
      • -
      • Wet bulb temperature (°C) -
      • -
      • Windspeed (m/s) -
      • -
      • Wind direction (degrees from north) -
      • -
      • Station pressure (mbar) -
      • -
      • Total cloud cover (tenths of sky) -
      • -
      • Opaque cloud cover (tenths of sky) -
      • -
      • Sky temperature (°C) -
      • -
      • Sum of total, beam, and diffuse solar radiation incident on each - surface (Wh/m2)  -
      • -

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

      - Table 3: Specific Days for Output + ASHRAE 825-RP lists the following parameter values as typical (note + that the default values in the model correspond to opposed + blades).

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

      - Case -

      -
      -

      - Days -

      -
      + opposed blades + + single blades +
      -

      - WD100 -

      -
      -

      - May 4th, July 14th, September 6th -

      + yL
      -

      - WD200 -

      + 15/90
      -

      - May 24th, August 26th -

      + 15/90
      -

      - WD300 -

      + yU
      -

      - February 7th, August 13th -

      + 55/90 +
      + 65/90
      -

      - WD400 -

      + k1
      -

      - January 24th, July 1st -

      + 0.2 to 0.5 +
      + 0.2 to 0.5
      -

      - WD500 -

      + a
      -

      - March 1st, September 14th -

      + -1.51 +
      + -1.51
      -

      - WD600 -

      + b
      -

      - May 4th, July 14th, September 6th -

      + 0.105*90 +
      + 0.0842*90

      +
    • - Sub-hourly Outputs + (The loss coefficient in fully closed position k0 is + computed based on the leakage coefficient and the coefficient in + fully open position.)

      +

      + References +

      - The following outputs are provided at each timestep of the days - specified for each test case in Table 3: + 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.

        -
      • Dry bulb temperature (C) +
      • September 21, 2021, by Michael Wetter:
        + Corrected typo in comments.
        + This is for #1525.
      • -
      • Relative humidity (%) +
      • 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.
      • -
      • Sum of total, beam, and diffuse solar radiation incident on each - surface (Wh/m2) +
      • 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.
      • -
      -

      - 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) +
      • 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.
      • -
      • Total incident horizontal beam solar radiation (Wh/m2) +
      • 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.
      • -
      • Total incident horizontal diffuse solar radiation (Wh/m2) +
      • December 14, 2012 by Michael Wetter:
        + Renamed protected parameters for consistency with the naming + conventions.
      • -
      -

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

      -
        -
      • Clone the last master branch of the AixLib repository into a - temporary directory +
      • 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.
      • -
      • Execute all the simulations and create the folders with the .mat - and .json files inside the BESTEST/Simulations folder +
      • 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.
      • -
      -

      - References -

      -

      - (Not available yet) -

      -
        -
      • March 11, 2020, by Ettore Zanetti:
        - first implementation of BESTEST weather validation +
      • June 22, 2008 by Michael Wetter:
        + Extended range of control signal from 0 to 1 by implementing the + function exponentialDamper. +
      • +
      • June 10, 2008 by Michael Wetter:
        + First implementation.
      -------- 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 50 column 2 - Warning: The summary attribute on the
      element is obsolete in HTML5 ----- AixLib/Utilities/Math/Biquadratic.mo ---- +---- AixLib/Fluid/HeatExchangers/ConstantEffectiveness.mo ---- -------- HTML Code --------

      - This block computes + Model for a heat exchanger with constant effectiveness. +

      +

      + This model transfers heat in the amount of

      - y = a1 + a2 x1 - + a3 x12 - + a4 x2 + a5 x22 - + a6 x1 x2 + 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.

      • - Sep. 8, 2010, by Michael Wetter:
        + 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 --------

      - This block computes + Model for a heat exchanger with constant effectiveness. +

      +

      + This model transfers heat in the amount of

      - y = a1 + a2 x1 + a3 - x12 + a4 x2 + - a5 x22 + a6 x1 - x2 + 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.

        -
      • Sep. 8, 2010, by Michael Wetter:
        +
      • 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.
      -------- Errors -------- -line 5 column 2 - Warning:

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

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/Cylindrical.mo ---- +---- AixLib/Fluid/FixedResistances/Validation/PlugFlowPipes/MSLAIT2Nodes.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 ), +

      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.

      - 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. + Note that these three models are identical, except for the pipe model that is used:

      +

      - If the heat capacity of the material is set to zero, then steady-state heat flow is computed using + 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.

      -

      - Q = 2 π k (Ta-Tb)⁄ ln(ra ⁄ rb), +

      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

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

      -

      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]. + Where the thermal conductivity of the ground lambda_g = 2.4 W/(m K).

      • - 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 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.
      • - March 9, 2012, by Michael Wetter:
        - Removed protected variable der_T as it is not required. + May 15, 2019, by Jianjun Hu:
        + Replaced fluid source. This is for + #1072. +
      • +
      • November 28, 2016 by Bram van der Heijde:
        Remove pipVol.
      • - April 14 2011, by Pierre Vigouroux:
        - First implementation. + 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 --------

      - Model for radial heat transfer in a hollow cylinder. + 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.

      - 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 ), + Note that these three models are identical, except for the pipe model + that is used:

      +

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

      - 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), + The pipes' temperatures are not initialized, thus results of outflow + temperature before approximately the first 10000 seconds should not + be considered.

      +

      + Test bench schematic +

      - 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. + \"Schematic

      - Implementation + Calibration

      - 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]. + 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).

        -
      • 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 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.
      • -
      • March 9, 2012, by Michael Wetter:
        - Removed protected variable der_T as it is not - required. +
      • 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.
      • -
      • April 14 2011, by Pierre Vigouroux:
        +
      • 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.
      -------- Errors -------- -line 9 column 2 - Warning:

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

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

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sources/Outside_CpData.mo ---- +---- AixLib/Fluid/FMI/ExportContainers/ThermalZone.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. + 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

      - The pressure p at the fluid ports is computed as: -

      -

      - p = pw + Cp,act Cs v2 ρ ⁄ 2, + 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. +
      • +
      +

      - 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 example + + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone + shows how a simple thermal zone can be implemented and exported as + an FMU. +

      +

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

      - The wind speed modifier Cs can be used to incorporate the effect of the surroundings on the local wind speed. + 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

      -

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

      + Qsen = max(0, ṁsup)   cp   (Tsup - Tair,zon),

      -

      \"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. + 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.

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

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

      - References +

      -
        -
      • M. W. Liddament, 1996, A guide to energy efficient ventilation. AIVC Annex V.
      • -
      • - February 2, 2022, by Michael Wetter:
        - Revised implementation.
        - This is for - IBPSA, #1436. + January 18, 2019, by Jianjun Hu:
        + Limited the media choice to moist air. + See #1050.
      • - Apr 6, 2021, by Klaas De Jonge:
        + 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 --------

      - 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, + 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 +

      - where pw is the atmospheric pressure from the - weather bus, v is the wind speed from the weather bus, and - ρ is the fluid density. -

      + 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 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 example + AixLib.Fluid.FMI.ExportContainers.Examples.FMUs.ThermalZone shows + how a simple thermal zone can be implemented and exported as an FMU. +

      - The wind speed modifier Cs can be used to - incorporate the effect of the surroundings on the local wind speed. + 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.

      -

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

      -

      - \"image\" +

      + Qsen = max(0, ṁsup)   cp   + (Tsup - Tair,zon),

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

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

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

      - References +

        -
      • M. W. Liddament, 1996, A guide to energy efficient - ventilation. AIVC Annex V. -
      • -
      -
        -
      • February 2, 2022, by Michael Wetter:
        - Revised implementation.
        - This is for IBPSA, - #1436. -
      • -
      • Apr 6, 2021, by Klaas De Jonge:
        - First implementation. -
      • -
      - --------- 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/ThermalZones/ReducedOrder/RC/TwoElements.mo ---- --------- HTML Code -------- - -

        -
      • - March 7, 2022, by Michael Wetter:
        - Removed massDynamics.
        - This is for - #1542. -
      • -
      • - July 11, 2019, by Katharina Brinkmann:
        - Renamed alphaInt to hConInt, - alphaIntWall to hConIntWall -
      • -
      • - January 25, 2019, by Michael Wetter:
        - Added start value to avoid warning in JModelica. -
      • -
      • - April 18, 2015, by Moritz Lauster:
        - First implementation. -
      • -
      - -

      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 -------- -
        -
      • March 7, 2022, by Michael Wetter:
        - Removed massDynamics.
        - This is for #1542. +
      • January 18, 2019, by Jianjun Hu:
        + Limited the media choice to moist air. See #1050.
      • -
      • July 11, 2019, by Katharina Brinkmann:
        - Renamed alphaInt to hConInt, - alphaIntWall to hConIntWall +
      • September 20, 2016, by Thierry S. Nouidui:
        + Revised documentation to explain the rationale of needing mass flow + rate sensors.
      • -
      • January 25, 2019, by Michael Wetter:
        - Added start value to avoid warning in JModelica. +
      • June 29, 2016, by Michael Wetter:
        + Revised implementation and documentation.
      • -
      • April 18, 2015, by Moritz Lauster:
        +
      • April 27, 2016, by Thierry S. Nouidui:
        First implementation.
      -

      - 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 14 column 4 - Warning:

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

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/HeatExchangers/Radiators/RadiatorEN442_2.mo ---- +---- AixLib/Fluid/Actuators/Valves/Examples/TwoWayValveTable.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. + 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

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

      - 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. + Plotting the variables kv.y versus y.y shows that the valve + reproduces the Kv values shown in the above table.

      -

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

      + \"image\"

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

      • - March 7, 2022, by Michael Wetter:
        - Set final massDynamics=energyDynamics.
        - This is for - #1542. -
      • -
      • - April 14, 2020, by Michael Wetter:
        - Changed homotopyInitialization to a constant.
        - This is for - IBPSA, #1341. -
      • -
      • - February 21, 2020, by Michael Wetter:
        - Changed icon to display its operating state.
        - This is for - #1294. -
      • -
      • - November 17, 2016, by Filip Jorissen:
        - Added pressure drop equations and parameters.
        - This is for - #586. -
      • -
      • - November 3, 2016, by Michael Wetter:
        - Set preHea(final alpha=0) as this allows to simplify the - system of equations.
        - This is for - #570. -
      • -
      • - March 17, 2016, by Michael Wetter:
        - Reformulated model to reduce the dimension of the nonlinear system of equations. - This is for - #435. -
      • -
      • - November 19, 2015, by Michael Wetter:
        - Removed assignment of parameter - showDesignFlowDirection in extends statement. - This is for - #349. -
      • -
      • - April 11, 2015, by Filip Jorissen:
        - Propagated vol.massDynamics to - top level parameter massDynamics instead of energyDynamics. -
      • -
      • - November 25, 2014, by Carles Ribas Tugores:
        - Interchange position of fraRad parameter and the complementary (1-fraRad) - in the equation used to calculate the nominal heating power of each element, QEle_flow_nominal[i]. -
      • -
      • - October 29, 2014, by Michael Wetter:
        - Made assignment of mFactor final, and changed computation of - density to use default medium states as are also used to compute the - specific heat capacity. -
      • -
      • - October 21, 2014, by Filip Jorissen:
        - Added parameter mFactor and removed thermal capacity - which can lead to an index reduction. -
      • -
      • - May 29, 2014, by Michael Wetter:
        - Removed undesirable annotation Evaluate=true. -
      • -
      • - October 8, 2013 by Michael Wetter:
        - Removed conditional statement in the declaration of the parameter - mDry, as this is incorrect syntax. -
      • -
      • - September 26, 2013 by Michael Wetter:
        - Reformulated implementation to avoid mixing textual and graphical - declarations in the equation section. -
      • -
      • - April 4, 2011 by Michael Wetter:
        - Changed the implementation to use - - AixLib.Utilities.Math.Functions.regNonZeroPower. - This allows formulating the model without any non-differentiable function - inside the equation section. -
      • -
      • - April 2, 2011 by Michael Wetter:
        - Added homotopy operator. -
      • -
      • - February 11, 2011 by Michael Wetter:
        - Revised the initialization to ensure that at the nominal conditions, the - amount of transferred heat is excatly the same as the specified nominal power. - In the previous implementation, the UA-value was computed using a simplified - expression for the temperature difference, leading to a slightly different amount - of heat transfer. -
      • -
      • - February 4, 2011 by Michael Wetter:
        - Simplified implementation. + 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.
      • - January 30, 2009 by Michael Wetter:
        + April 2, 2014 by Michael Wetter:
        First implementation.
      -------- 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. + 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 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 + 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.

      - 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. + Plotting the variables kv.y versus y.y + shows that the valve reproduces the Kv values shown + in the above table.

      -

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

      + \"image\"

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

        -
      • March 7, 2022, by Michael Wetter:
        - Set final massDynamics=energyDynamics.
        - This is for #1542. -
      • -
      • April 14, 2020, by Michael Wetter:
        - Changed homotopyInitialization to a constant.
        - This is for IBPSA, - #1341. -
      • -
      • February 21, 2020, by Michael Wetter:
        - Changed icon to display its operating state.
        - This is for #1294. -
      • -
      • November 17, 2016, by Filip Jorissen:
        - Added pressure drop equations and parameters.
        - This is for #586. -
      • -
      • November 3, 2016, by Michael Wetter:
        - Set preHea(final alpha=0) as this allows to simplify - the system of equations.
        - This is for #570. -
      • -
      • March 17, 2016, by Michael Wetter:
        - Reformulated model to reduce the dimension of the nonlinear system - of equations. This is for #435. -
      • -
      • November 19, 2015, by Michael Wetter:
        - Removed assignment of parameter - showDesignFlowDirection in extends - statement. This is for #349. -
      • -
      • April 11, 2015, by Filip Jorissen:
        - Propagated vol.massDynamics to top level parameter - massDynamics instead of energyDynamics. -
      • -
      • November 25, 2014, by Carles Ribas Tugores:
        - Interchange position of fraRad parameter and the - complementary (1-fraRad) in the equation used to - calculate the nominal heating power of each element, - QEle_flow_nominal[i]. -
      • -
      • October 29, 2014, by Michael Wetter:
        - Made assignment of mFactor final, and changed - computation of density to use default medium states as are also - used to compute the specific heat capacity. -
      • -
      • October 21, 2014, by Filip Jorissen:
        - Added parameter mFactor and removed thermal capacity - which can lead to an index reduction. -
      • -
      • May 29, 2014, by Michael Wetter:
        - Removed undesirable annotation Evaluate=true. -
      • -
      • October 8, 2013 by Michael Wetter:
        - Removed conditional statement in the declaration of the parameter - mDry, as this is incorrect syntax. -
      • -
      • September 26, 2013 by Michael Wetter:
        - Reformulated implementation to avoid mixing textual and graphical - declarations in the equation section. -
      • -
      • April 4, 2011 by Michael Wetter:
        - Changed the implementation to use AixLib.Utilities.Math.Functions.regNonZeroPower. - This allows formulating the model without any non-differentiable - function inside the equation section. -
      • -
      • April 2, 2011 by Michael Wetter:
        - Added homotopy operator. -
      • -
      • February 11, 2011 by Michael Wetter:
        - Revised the initialization to ensure that at the nominal - conditions, the amount of transferred heat is excatly the same as - the specified nominal power. In the previous implementation, the - UA-value was computed using a simplified expression for the - temperature difference, leading to a slightly different amount of - heat transfer. -
      • -
      • February 4, 2011 by Michael Wetter:
        - Simplified implementation. +
      • 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.
      • -
      • January 30, 2009 by Michael Wetter:
        +
      • April 2, 2014 by Michael Wetter:
        First implementation.
      -------- Errors -------- -line 26 column 2 - Warning:

      attribute "align" not allowed for HTML5 +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/FixedResistances/BaseClasses/PlugFlowTransportDelay.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/LoadAggregation/Validation/ShiftAggregationCells.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 validation case replicates the load-shifting procedure illustred in the figure below by Cimmino (2014).

      -

      Main equation

      - ∂z(x,t)/∂t + v(t) ∂z(x,t)/∂x = 0, + \"image\"

      +

      References

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

      -

      Implementation

      + +
        +
      • + July 18, 2018, by Alex Laferrière:
        + 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. +

      +
        +
      • July 18, 2018, by Alex Laferrière:
        + First implementation. +
      • +
      + +-------- Errors -------- +line 5 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/Fluid/HeatExchangers/BaseClasses/PartialEffectivenessNTU.mo ---- +-------- HTML Code -------- +

      - 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. + Partial model of a heat exchanger without humidity condensation. + This model transfers heat in the amount of +

      +

      + Q = Qmax ε
      + ε = f(NTU, Z, flowRegime),

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

      -

      Assumption

      - No axial mixing takes place in the pipe. + The flow regimes depend on the heat exchanger configuration. All configurations + defined in + + AixLib.Fluid.Types.HeatExchangerConfiguration + are supported. +

      +

      + Models that extend from this partial model need to provide an assignment + for UA.

      • - December 2, 2020, by Philipp Mehrfeld:
        - Corrected calculation of tau and tauRev to be be - only positive.
        - This is for - #1427. + February 25, 2021 by Baptiste Ravache:
        + Added a warning for when Q_flow_nominal is specified with the wrong sign.
      • - December 14, 2018, by Michael Wetter:
        - Corrected argument of spatialDistribution operator to be a parameter - expression.
        + January 10, 2018 by Michael Wetter:
        + Removed variable Z that is not used. This is for - #1055. + issue 1328.
      • - September 9, 2016 by Bram van der Heijde:
        - Rename from PDETime_massFlowMod to PlugFlowTransportDelayMod + January 10, 2018 by Filip Jorissen:
        + Corrected an error where the value of NTU was assigned to Z. + This is for + issue 1328.
      • - December 2015 by Carles Ribas Tugores:
        - Modification in delay calculation to fix issues. + 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). + This is for + issue 490.
      • - 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. + April 29, 2014 by Michael Wetter:
        + Changed assert statement to avoid comparing + enumeration with an integer, which triggers a warning + in Dymola 2015.
      • - October 13, 2015 by Marcus Fuchs:
        - Use abs() of normalized velocity input in order to avoid negative - delay times. + July 30, 2013 by Michael Wetter:
        + Updated model to use new variable mWat_flow + in the base class.
      • - July 2015 by Arnout Aertgeerts:
        + February 12, 2010, by Michael Wetter:
        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, + Partial model of a heat exchanger without humidity condensation. This + model transfers heat in the amount of

      -

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

      + Q = Qmax ε
      + ε = f(NTU, Z, flowRegime),

      -

      - 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. + 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 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. + The flow regimes depend on the heat exchanger configuration. All + configurations defined in AixLib.Fluid.Types.HeatExchangerConfiguration + are supported.

      -

      - Assumption -

      - No axial mixing takes place in the pipe. + Models that extend from this partial model need to provide an + assignment for UA.

        -
      • December 2, 2020, by Philipp Mehrfeld:
        - Corrected calculation of tau and tauRev - to be be only positive.
        - This is for #1427. +
      • February 25, 2021 by Baptiste Ravache:
        + Added a warning for when Q_flow_nominal is specified with the wrong + sign.
      • -
      • December 14, 2018, by Michael Wetter:
        - Corrected argument of spatialDistribution operator to - be a parameter expression.
        +
      • January 10, 2018 by Michael Wetter:
        + Removed variable Z that is not used. This is for + issue + 1328. +
      • +
      • January 10, 2018 by Filip Jorissen:
        + Corrected an error where the value of NTU was assigned to Z. This + is for issue + 1328. +
      • +
      • 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). This is for #1055. + \"https://github.com/lbl-srg/modelica-buildings/issues/490\">issue + 490.
      • -
      • September 9, 2016 by Bram van der Heijde:
        - Rename from PDETime_massFlowMod to PlugFlowTransportDelayMod +
      • April 29, 2014 by Michael Wetter:
        + Changed assert statement to avoid comparing + enumeration with an integer, which triggers a warning in Dymola + 2015.
      • -
      • December 2015 by Carles Ribas Tugores:
        - Modification in delay calculation to fix issues. +
      • July 30, 2013 by Michael Wetter:
        + Updated model to use new variable mWat_flow in the + base class.
      • -
      • 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. +
      • February 12, 2010, by Michael Wetter:
        + First implementation.
      • -
      • October 13, 2015 by Marcus Fuchs:
        - Use abs() of normalized velocity input in order to - avoid negative delay times. +
      + +-------- Errors -------- +line 6 column 2 - Warning:

      attribute "align" not allowed for HTML5 + + +---- AixLib/BoundaryConditions/Validation/BESTEST/WD600.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. +
      • +
      + +

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

        +
      • September 6, 2021, by Ettore Zanetti:
        + Removed parameter lat as it is now obtained from the + weather data bus.
        + This is for IBPSA, + #1477.
      • -
      • July 2015 by Arnout Aertgeerts:
        +
      • March 11, 2020, by Ettore Zanetti:
        First implementation.
      • +
      • April 14, 2020, by Ettore Zanetti:
        + Rework after comments from pull request #1339. +
      +

      + 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 7 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 5 column 2 - Warning: The summary attribute on the element is obsolete in HTML5 diff --git a/docs/ci_updates/syntax/HTML_error_log.txt b/docs/ci_updates/syntax/HTML_error_log.txt index cd40472199..2a08ac2684 100644 --- a/docs/ci_updates/syntax/HTML_error_log.txt +++ b/docs/ci_updates/syntax/HTML_error_log.txt @@ -1,133 +1,95 @@ ----- AixLib/ThermalZones/ReducedOrder/RC/BaseClasses/ExteriorWall.mo ---- -line 14 column 4 - 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/Geothermal/Borefields/Types.mo ---- -line 8 column 2 - Warning: The summary attribute on the

      element is obsolete in HTML5 - - ----- AixLib/Fluid/Sources/Outside_CpLowRise.mo ---- -line 28 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 61 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/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/HeatPumps/Compressors/ScrollCompressor.mo ---- +---- AixLib/Fluid/Geothermal/Borefields/BaseClasses/HeatTransfer/ThermalResponseFactors/finiteLineSource_Erfint.mo ---- line 5 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 11 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/Controls/Continuous/Examples/NumberOfRequests.mo ---- -line 10 column 2 - Warning:

      attribute "align" not allowed for HTML5 +---- AixLib/BoundaryConditions/Validation/BESTEST/WD500.mo ---- +line 5 column 2 - Warning: The summary attribute on the

      element is obsolete in 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/Types.mo ---- +line 8 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 +line 8 column 2 - Warning: The summary attribute on the
      element is obsolete in HTML5 ----- AixLib/Fluid/Interfaces/PrescribedOutlet.mo ---- -line 18 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/Movers/Data/Pumps/Wilo/Stratos25slash1to6.mo ---- line 27 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/ThermalZones/ReducedOrder/RC/FourElements.mo ---- +line 15 column 4 - 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/Movers/Validation/PowerExact.mo ---- +line 12 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/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/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/Media/Water.mo ---- +line 17 column 2 - Warning: The summary attribute on the

      element is obsolete in 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 +line 18 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/Humidifiers/SteamHumidifier_X.mo ---- +line 33 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Chillers/Carnot_TEva.mo ---- +---- AixLib/Fluid/HeatPumps/Carnot_TCon.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/BaseClasses/PartialEffectivenessNTU.mo ---- -line 6 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/SetPoints/Examples/SupplyReturnTemperatureReset.mo ---- -line 16 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 +line 25 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 35 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/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/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/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/Media/Specialized/Air/PerfectGas.mo ---- -line 25 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/HeatExchangers/DryCoilEffectivenessNTU.mo ---- -line 6 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/EvaporatorCondenser.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/Fluid/FMI/ExportContainers/ThermalZone.mo ---- -line 72 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/Movers/UsersGuide.mo ---- @@ -147,91 +109,79 @@ line 473 column 1 - Warning:

      attribute "align" not allowed for HTML5 line 484 column 1 - 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/Utilities/Math/Functions/biquadratic.mo ---- -line 3 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/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/Movers/BaseClasses/Characteristics/power.mo ---- +line 6 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/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/Geothermal/Borefields/BaseClasses/HeatTransfer/LoadAggregation/Validation/ShiftAggregationCells.mo ---- -line 5 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/Fluid/FixedResistances/CheckValve.mo ---- +---- AixLib/Controls/Continuous/Examples/OffTimer.mo ---- 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/Functions/polynomial.mo ---- -line 4 column 2 - Warning:

      attribute "align" not allowed for HTML5 +---- AixLib/Fluid/Sources/Outside_CpLowRise.mo ---- +line 28 column 2 - Warning:

      attribute "align" not allowed for HTML5 +line 61 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/BoundaryConditions/Validation/BESTEST/WD200.mo ---- +line 5 column 2 - Warning: The summary attribute on the

      element is obsolete in HTML5 ----- AixLib/Fluid/Actuators/BaseClasses/exponentialDamper.mo ---- -line 11 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/Humidifiers/Humidifier_u.mo ---- -line 9 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/FixedResistances/Validation/PlugFlowPipes/MSLAIT2Nodes.mo ---- -line 51 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/Controls/Continuous/NumberOfRequests.mo ---- -line 7 column 2 - Warning: The summary attribute on the

      element is obsolete in HTML5 +---- AixLib/Fluid/HeatExchangers/Radiators/RadiatorEN442_2.mo ---- +line 26 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/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/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/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/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/Utilities/Math/Functions/bicubic.mo ---- +line 3 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/Movers/BaseClasses/Characteristics/efficiency.mo ---- +line 6 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/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/Storage/UsersGuide.mo ---- @@ -240,123 +190,119 @@ line 17 column 1 - Warning:

      attribute "align" not allowed for HTML5 line 129 column 1 - 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/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/ThermalZones/ReducedOrder/RC/TwoElements.mo ---- +line 14 column 4 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Controls/Continuous/LimPID.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/Fluid/HeatPumps/Carnot_TCon.mo ---- -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/SetPoints/Examples/OccupancySchedule.mo ---- +line 8 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Sensors/SensibleEnthalpyFlowRate.mo ---- +---- 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/WD100.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/Media/Antifreeze/PropyleneGlycolWater.mo ---- +line 9 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 +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/HeatExchangers/SensibleCooler_T.mo ---- +---- 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/Media/Water.mo ---- -line 17 column 2 - 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 -line 18 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/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/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/Media/Antifreeze/PropyleneGlycolWater.mo ---- -line 9 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 -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/HeatExchangers/ActiveBeams/Data/BaseClasses/TemperatureDifference.mo ---- +line 8 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/Fluid/Geothermal/Borefields/Types.mo ---- +line 8 column 2 - Warning: The summary attribute on the

      element is obsolete in HTML5 ----- AixLib/Fluid/Movers/Validation/PowerSimplified.mo ---- -line 29 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/Fluid/FixedResistances/Validation/PlugFlowPipes/PlugFlowAIT.mo ---- -line 48 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 ----- 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/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/FMI/ExportContainers/HVACZone.mo ---- -line 47 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/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/Media/Specialized/Air/PerfectGas.mo ---- +line 25 column 2 - Warning:

      attribute "align" not allowed for HTML5 ----- AixLib/Fluid/Movers/BaseClasses/Characteristics/efficiency.mo ---- +---- AixLib/Fluid/Movers/BaseClasses/Characteristics/pressure.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/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/Geothermal/Borefields/BaseClasses/Boreholes/BaseClasses/Functions/convectionResistanceCircularPipe.mo ---- -line 11 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/Fluid/HeatExchangers/Heater_T.mo ---- -line 29 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/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/Controls/Continuous/NumberOfRequests.mo ---- +line 7 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/BoundaryConditions/UsersGuide.mo ---- @@ -365,22 +311,34 @@ 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/Junction.mo ---- -line 23 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/FixedResistances/Validation/PlugFlowPipes/MSLAIT.mo ---- -line 56 column 2 - 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/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/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/HeatExchangers/PrescribedOutlet.mo ---- -line 34 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/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/Controls/Continuous/LimPID.mo ---- +line 5 column 2 - Warning:

      attribute "align" not allowed for HTML5 ---- AixLib/Media/Antifreeze/EthyleneGlycolWater.mo ---- @@ -392,160 +350,214 @@ line 24 column 2 - Warning:

      attribute "align" not allowed for HTML5 line 35 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 +---- AixLib/Fluid/FMI/ExportContainers/ThermalZones.mo ---- +line 78 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 +---- AixLib/Fluid/HeatExchangers/EvaporatorCondenser.mo ---- +line 10 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 6 column 2 - 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/Controls/Continuous/Examples/SignalRanker.mo ---- 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 54 column 2 - Warning:

      attribute "align" not allowed for HTML5 -line 60 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/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/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/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 +---- AixLib/Fluid/Interfaces/PrescribedOutlet.mo ---- line 18 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/PlugFlow.mo ---- +line 10 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/Actuators/Valves/ThreeWayTable.mo ---- +line 21 column 2 - Warning: The summary attribute on the

      element is obsolete in HTML5 ----- AixLib/Fluid/FMI/ExportContainers/HVACZones.mo ---- -line 60 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/Utilities/Math/Functions/Examples/CubicHermite.mo ---- -line 11 column 2 - Warning:

      attribute "align" not allowed for HTML5 +---- AixLib/BoundaryConditions/Validation/BESTEST/WD300.mo ---- +line 5 column 2 - Warning: The summary attribute on the

      element is obsolete in HTML5 ----- AixLib/Fluid/HeatExchangers/ConstantEffectiveness.mo ---- -line 8 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/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/ThermalZones/ReducedOrder/RC/FourElements.mo ---- -line 15 column 4 - 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/Utilities/Math/Polynomial.mo ---- -line 3 column 2 - 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/Utilities/Math/QuadraticLinear.mo ---- -line 3 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/Utilities/Math/Functions/quadraticLinear.mo ---- -line 3 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/BoundaryConditions/Validation/BESTEST/WD200.mo ---- -line 5 column 2 - Warning: The summary attribute on the

      element is obsolete in 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/Movers/BaseClasses/Characteristics/pressure.mo ---- -line 6 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/FMI/ExportContainers/ThermalZones.mo ---- -line 78 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/FixedResistances/BaseClasses/PlugFlow.mo ---- -line 10 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/Controls/Continuous/Examples/OffTimer.mo ---- -line 10 column 2 - Warning:

      attribute "align" not allowed for 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 +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/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/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/Actuators/BaseClasses/PartialDamperExponential.mo ---- -line 50 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 ----- AixLib/Controls/Continuous/Examples/SignalRanker.mo ---- -line 8 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/Fluid/Types.mo ---- -line 8 column 2 - Warning: The summary attribute on the

      element is obsolete in HTML5 +---- AixLib/Fluid/FMI/Adaptors/HVAC.mo ---- +line 26 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/Controls/SetPoints/Examples/SupplyReturnTemperatureReset.mo ---- +line 16 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/Utilities/Math/Functions/biquadratic.mo ---- +line 3 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/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/Media/Specialized/Water/TemperatureDependentDensity.mo ---- +---- AixLib/Fluid/Humidifiers/SprayAirWasher_X.mo ---- +line 33 column 2 - 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/Fluid/HeatExchangers/ActiveBeams/BaseClasses/Convector.mo ---- line 5 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/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 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 6 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 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 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/Sensors/LatentEnthalpyFlowRate.mo ---- +line 6 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/Fluid/Humidifiers/SteamHumidifier_X.mo ---- -line 33 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/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 ---- AixLib/Fluid/HeatPumps/Carnot_y.mo ---- @@ -554,47 +566,35 @@ line 24 column 2 - Warning:

      attribute "align" not allowed for HTML5 line 34 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/BoundaryConditions/Validation/BESTEST/WD400.mo ---- -line 5 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 +---- AixLib/Fluid/Actuators/BaseClasses/PartialDamperExponential.mo ---- +line 50 column 2 - Warning: The summary attribute on the
      element is obsolete in 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/ConstantEffectiveness.mo ---- +line 8 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/MSLAIT2Nodes.mo ---- +line 51 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/Fluid/FMI/ExportContainers/ThermalZone.mo ---- +line 72 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/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/TwoElements.mo ---- -line 14 column 4 - 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/HeatExchangers/Radiators/RadiatorEN442_2.mo ---- -line 26 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/PlugFlowTransportDelay.mo ---- -line 7 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