Extends from Modelica.Icons.VariantsPackage (Icon for package containing variants).
Name | Description |
---|---|
RadiatorEN442_2 | Dynamic radiator for space heating |
Examples | Collection of models that illustrate model use and test models |
However, to allow for varying mass flow rates, the transferred heat is computed using a discretization along the water flow path, and heat is exchanged between each compartment and a uniform room air and radiation temperature. This discretization is different from the computation in EN 442-2, which may yield water outlet temperatures that are below the room temperature at low mass flow rates. Furthermore, rather than using only one room temperature, this model uses a room air and room radiation temperature.
The transferred heat is modeled as follows: Let N denote the number of elements used to discretize the radiator model. For each element i ∈ {1, … , N}, the convective and radiative heat transfer Qic and Qir from the radiator to the room is
Qic = sign(Ti-Ta)
(1-fr) UA ⁄ N |Ti-Ta|n
Qir = sign(Ti-Tr)
fr UA ⁄ N |Ti-Tr|n
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.
Extends from Fluid.Interfaces.PartialTwoPortInterface (Partial model transporting fluid between two ports without storing mass or energy), Buildings.Fluid.Interfaces.LumpedVolumeDeclarations (Declarations for lumped volumes).
Type | Name | Default | Description |
---|---|---|---|
replaceable package Medium | PartialMedium | Medium in the component | |
Integer | nEle | 5 | Number of elements used in the discretization |
Real | fraRad | 0.35 | Fraction radiant heat transfer |
Real | n | 1.24 | Exponent for heat transfer |
Nominal condition | |||
MassFlowRate | m_flow_nominal | abs(Q_flow_nominal/cp_nomina... | Nominal mass flow rate [kg/s] |
Power | Q_flow_nominal | Nominal heating power (positive for heating) [W] | |
Temperature | T_a_nominal | Water inlet temperature at nominal condition [K] | |
Temperature | T_b_nominal | Water outlet temperature at nominal condition [K] | |
Temperature | TAir_nominal | 293.15 | Air temperature at nominal condition [K] |
Temperature | TRad_nominal | TAir_nominal | Radiative temperature at nominal condition [K] |
Initialization | |||
MassFlowRate | m_flow.start | 0 | Mass flow rate from port_a to port_b (m_flow > 0 is design flow direction) [kg/s] |
Pressure | dp.start | 0 | Pressure difference between port_a and port_b [Pa] |
Assumptions | |||
Boolean | allowFlowReversal | system.allowFlowReversal | = true to allow flow reversal, false restricts to design direction (port_a -> port_b) |
Advanced | |||
MassFlowRate | m_flow_small | 1E-4*abs(m_flow_nominal) | Small mass flow rate for regularization of zero flow [kg/s] |
Boolean | homotopyInitialization | true | = true, use homotopy method |
Diagnostics | |||
Boolean | show_V_flow | false | = true, if volume flow rate at inflowing port is computed |
Boolean | show_T | true | = true, if actual temperature at port is computed (may lead to events) |
Dynamics | |||
Equations | |||
Dynamics | energyDynamics | Modelica.Fluid.Types.Dynamic... | Formulation of energy balance |
Dynamics | massDynamics | energyDynamics | Formulation of mass balance |
Volume | VWat | 5.8E-6*abs(Q_flow_nominal) | Water volume of radiator [m3] |
Mass | mDry | 0.0263*abs(Q_flow_nominal) | Dry mass of radiator that will be lumped to water heat capacity [kg] |
Initialization | |||
AbsolutePressure | p_start | Medium.p_default | Start value of pressure [Pa] |
Temperature | T_start | Medium.T_default | Start value of temperature [K] |
MassFraction | X_start[Medium.nX] | Medium.X_default | Start value of mass fractions m_i/m [kg/kg] |
ExtraProperty | C_start[Medium.nC] | fill(0, Medium.nC) | Start value of trace substances |
ExtraProperty | C_nominal[Medium.nC] | fill(1E-2, Medium.nC) | Nominal value of trace substances. (Set to typical order of magnitude.) |
Type | Name | Description |
---|---|---|
FluidPort_a | port_a | Fluid connector a (positive design flow direction is from port_a to port_b) |
FluidPort_b | port_b | Fluid connector b (positive design flow direction is from port_a to port_b) |
HeatPort_a | heatPortCon | Heat port for convective heat transfer with room air temperature |
HeatPort_a | heatPortRad | Heat port for radiative heat transfer with room radiation temperature |
model RadiatorEN442_2 "Dynamic radiator for space heating" extends Fluid.Interfaces.PartialTwoPortInterface( showDesignFlowDirection = false, show_T=true, m_flow_nominal=abs(Q_flow_nominal/cp_nominal/(T_a_nominal-T_b_nominal))); extends Buildings.Fluid.Interfaces.LumpedVolumeDeclarations( final X_start = Medium.X_default, final C_start = fill(0, Medium.nC), final C_nominal = fill(1E-2, Medium.nC)); parameter Integer nEle(min=1) = 5 "Number of elements used in the discretization"; parameter Real fraRad(min=0, max=1) = 0.35 "Fraction radiant heat transfer"; // Assumptions parameter Modelica.SIunits.Power Q_flow_nominal "Nominal heating power (positive for heating)"; parameter Modelica.SIunits.Temperature T_a_nominal "Water inlet temperature at nominal condition"; parameter Modelica.SIunits.Temperature T_b_nominal "Water outlet temperature at nominal condition"; parameter Modelica.SIunits.Temperature TAir_nominal = 293.15 "Air temperature at nominal condition"; parameter Modelica.SIunits.Temperature TRad_nominal = TAir_nominal "Radiative temperature at nominal condition"; parameter Real n = 1.24 "Exponent for heat transfer"; parameter Modelica.SIunits.Volume VWat = 5.8E-6*abs(Q_flow_nominal) "Water volume of radiator"; parameter Modelica.SIunits.Mass mDry = 0.0263*abs(Q_flow_nominal) if not (energyDynamics == Modelica.Fluid.Types.Dynamics.SteadyState) "Dry mass of radiator that will be lumped to water heat capacity"; parameter Boolean homotopyInitialization = true "= true, use homotopy method"; Modelica.SIunits.HeatFlowRate QCon_flow "Heat input into the water due to convective heat transfer with room air"; Modelica.SIunits.HeatFlowRate QRad_flow "Heat input into the water due to radiative heat transfer with room"; Modelica.SIunits.HeatFlowRate Q_flow "Heat input into the water";public Modelica.Thermal.HeatTransfer.Interfaces.HeatPort_a heatPortCon "Heat port for convective heat transfer with room air temperature"; Modelica.Thermal.HeatTransfer.Interfaces.HeatPort_a heatPortRad "Heat port for radiative heat transfer with room radiation temperature"; Modelica.Thermal.HeatTransfer.Components.HeatCapacitor[nEle] heaCap( each C=500*mDry/nEle, each T(start=T_start)) if not (energyDynamics == Modelica.Fluid.Types.Dynamics.SteadyState) "heat capacity of radiator metal"; Buildings.HeatTransfer.Sources.PrescribedHeatFlow[nEle] preHeaFloCon "Heat input into radiator from convective heat transfer"; Buildings.HeatTransfer.Sources.PrescribedHeatFlow[nEle] preHeaFloRad "Heat input into radiator from radiative heat transfer"; Fluid.MixingVolumes.MixingVolume[nEle] vol( redeclare each package Medium = Medium, each nPorts = 2, each V=VWat/nEle, each final m_flow_nominal = m_flow_nominal, each final energyDynamics=energyDynamics, each final massDynamics=energyDynamics, each final p_start=p_start, each final T_start=T_start, each final X_start=X_start, each final C_start=C_start) "Volume for fluid stream"; protected parameter Modelica.SIunits.SpecificHeatCapacity cp_nominal= Medium.specificHeatCapacityCp( Medium.setState_pTX(Medium.p_default, T_a_nominal, Medium.X_default)) "Specific heat capacity at nominal conditions"; parameter Modelica.SIunits.HeatFlowRate QEle_flow_nominal[nEle]( each fixed=false, each start=Q_flow_nominal/nEle) "Nominal heating power of each element"; parameter Modelica.SIunits.Temperature TWat_nominal[nEle]( each fixed=false, start={T_a_nominal - i/nEle * (T_a_nominal-T_b_nominal) for i in 1:nEle}) "Water temperature in each element at nominal conditions"; parameter Modelica.SIunits.TemperatureDifference[nEle] dTRad_nominal( each fixed=false, start={T_a_nominal - i/nEle * (T_a_nominal-T_b_nominal) - TRad_nominal for i in 1:nEle}) "Temperature difference for radiative heat transfer at nominal conditions"; parameter Modelica.SIunits.TemperatureDifference[nEle] dTCon_nominal( each fixed=false, start={T_a_nominal - i/nEle * (T_a_nominal-T_b_nominal) - TAir_nominal for i in 1:nEle}) "Temperature difference for convective heat transfer at nominal conditions"; parameter Modelica.SIunits.ThermalConductance UAEle(fixed=false, min=0, start=Q_flow_nominal/((T_a_nominal+T_b_nominal)/2-((1-fraRad)*TAir_nominal+fraRad*TRad_nominal))/nEle) "UA value at nominal condition for each element"; final parameter Real k = if T_b_nominal > TAir_nominal then 1 else -1 "Parameter that is used to compute QEle_flow_nominal for heating or cooling mode"; Modelica.SIunits.TemperatureDifference dTCon[nEle] "Temperature difference for convective heat transfer"; Modelica.SIunits.TemperatureDifference dTRad[nEle] "Temperature difference for radiative heat transfer"; initial equation if T_b_nominal > TAir_nominal then assert(T_a_nominal > T_b_nominal, "In RadiatorEN442_2, T_a_nominal must be higher than T_b_nominal"); assert(Q_flow_nominal > 0, "In RadiatorEN442_2, nominal power must be bigger than zero if T_b_nominal > TAir_nominal"); else assert(T_a_nominal < T_b_nominal, "In RadiatorEN442_2, T_a_nominal must be lower than T_b_nominal"); assert(Q_flow_nominal < 0, "In RadiatorEN442_2, nominal power must be smaller than zero if T_b_nominal < TAir_nominal"); end if; TWat_nominal[1] = T_a_nominal - QEle_flow_nominal[1]/m_flow_nominal/ Medium.specificHeatCapacityCp( Medium.setState_pTX(Medium.p_default, T_a_nominal, Medium.X_default)); for i in 2:nEle loop TWat_nominal[i] = TWat_nominal[i-1] - QEle_flow_nominal[i]/m_flow_nominal/ Medium.specificHeatCapacityCp( Medium.setState_pTX(Medium.p_default, TWat_nominal[i-1], Medium.X_default)); end for; dTRad_nominal = TWat_nominal .- TRad_nominal; dTCon_nominal = TWat_nominal .- TAir_nominal; Q_flow_nominal = sum(QEle_flow_nominal); for i in 1:nEle loop QEle_flow_nominal[i] = k * UAEle * ((1-fraRad) * Buildings.Utilities.Math.Functions.powerLinearized(x=k*dTRad_nominal[i], n=n, x0=0.1*k*(T_b_nominal-TRad_nominal)) + fraRad * Buildings.Utilities.Math.Functions.powerLinearized(x=k*dTCon_nominal[i], n=n, x0=0.1*k*(T_b_nominal-TAir_nominal))); end for; equation dTCon = heatPortCon.T .- vol.T; dTRad = heatPortRad.T .- vol.T; if homotopyInitialization then preHeaFloCon.Q_flow = homotopy(actual=(1-fraRad) .* UAEle .* dTCon .* Buildings.Utilities.Math.Functions.regNonZeroPower(x=dTCon, n=n-1, delta=0.05), simplified= (1-fraRad) .* UAEle .* abs(dTCon_nominal).^(n-1) .* dTCon); preHeaFloRad.Q_flow = homotopy(actual=fraRad .* UAEle .* dTRad .* Buildings.Utilities.Math.Functions.regNonZeroPower(x=dTRad, n=n-1, delta=0.05), simplified=fraRad .* UAEle .* abs(dTRad_nominal).^(n-1) .* dTRad); else preHeaFloCon.Q_flow = (1-fraRad) .* UAEle .* dTCon .* Buildings.Utilities.Math.Functions.regNonZeroPower(x=dTCon, n=n-1, delta=0.05); preHeaFloRad.Q_flow = fraRad .* UAEle .* dTRad .* Buildings.Utilities.Math.Functions.regNonZeroPower(x=dTRad, n=n-1, delta=0.05); end if; QCon_flow = sum(preHeaFloCon.Q_flow); QRad_flow = sum(preHeaFloRad.Q_flow); Q_flow = QCon_flow + QRad_flow; heatPortCon.Q_flow = QCon_flow; heatPortRad.Q_flow = QRad_flow;connect(preHeaFloCon.port, vol.heatPort); connect(preHeaFloRad.port, vol.heatPort); connect(heaCap.port, vol.heatPort); connect(port_a, vol[1].ports[1]); connect(vol[nEle].ports[2], port_b); for i in 1:nEle-1 loopconnect(vol[i].ports[2], vol[i+1].ports[1]); end for;end RadiatorEN442_2;