diff --git a/.decent_ci-Linux.yaml b/.decent_ci-Linux.yaml
index f31d71f635d..209f3482261 100644
--- a/.decent_ci-Linux.yaml
+++ b/.decent_ci-Linux.yaml
@@ -1,12 +1,12 @@
compilers:
- name: "gcc"
- version: "11.3"
+ version: "11.4"
cmake_extra_flags: -DLINK_WITH_PYTHON:BOOL=ON -DBUILD_FORTRAN:BOOL=ON -DBUILD_TESTING:BOOL=ON -DENABLE_REGRESSION_TESTING:BOOL=ON -DREGRESSION_BASELINE_PATH:PATH=$REGRESSION_BASELINE -DREGRESSION_SCRIPT_PATH:PATH=$REGRESSION_DIR -DREGRESSION_BASELINE_SHA:STRING=$REGRESSION_BASELINE_SHA -DCOMMIT_SHA:STRING=$COMMIT_SHA -DENABLE_GTEST_DEBUG_MODE:BOOL=OFF -DBUILD_PERFORMANCE_TESTS:BOOL=ON -DVALGRIND_ANALYZE_PERFORMANCE_TESTS:BOOL=ON -DENABLE_PCH:BOOL=OFF
collect_performance_results: true
s3_upload_bucket: energyplus
- name: "gcc"
- version: "11.3"
+ version: "11.4"
build_type: Debug
cmake_extra_flags: -DLINK_WITH_PYTHON:BOOL=ON -DBUILD_FORTRAN:BOOL=ON -DBUILD_TESTING:BOOL=ON -DENABLE_REGRESSION_TESTING:BOOL=OFF -DCOMMIT_SHA:STRING=$COMMIT_SHA -DENABLE_COVERAGE:BOOL=ON -DENABLE_GTEST_DEBUG_MODE:BOOL=OFF -DENABLE_PCH:BOOL=OFF
coverage_enabled: true
@@ -20,7 +20,7 @@ compilers:
skip_packaging: true
- name: "gcc"
- version: "11.3"
+ version: "11.4"
build_type: Debug
cmake_extra_flags: -DLINK_WITH_PYTHON:BOOL=ON -DBUILD_FORTRAN:BOOL=ON -DBUILD_TESTING:BOOL=ON -DENABLE_REGRESSION_TESTING:BOOL=OFF -DCOMMIT_SHA:STRING=$COMMIT_SHA -DENABLE_COVERAGE:BOOL=ON -DENABLE_GTEST_DEBUG_MODE:BOOL=OFF -DENABLE_PCH:BOOL=OFF
coverage_enabled: true
diff --git a/.gitignore b/.gitignore
index d4ebd59d419..bc3e1ed4d39 100644
--- a/.gitignore
+++ b/.gitignore
@@ -89,3 +89,4 @@ dist
# if you generate sphinx docs, it builds a dummy version of the schema in the idd folder, just ignore it
/idd/Energy+.schema.epJSON
/idd/Energy+.schema.epJSON.in
+design/FY2023/earth_tube_solution_space_diagram.pdf
diff --git a/README.md b/README.md
index 09098cc4182..5cb72a85de4 100644
--- a/README.md
+++ b/README.md
@@ -23,7 +23,7 @@ Every commit and every release of EnergyPlus undergoes rigorous testing.
The testing consists of building EnergyPlus, of course, then there are unit tests, integration tests, API tests, and regression tests.
Since 2014, most of the testing has been performed by our bots ([Tik-Tok](https://github.com/nrel-bot), [Gort](https://github.com/nrel-bot-2), and [Marvin](https://github.com/nrel-bot-3)), using a fork of the [Decent CI](https://github.com/lefticus/decent_ci) continuous integration system.
We are now adapting our efforts to use the Github Actions system to handle more of our testing processes.
-In the meantime, while Decent CI is still handling the regression and bulkier testing, results from Decent CI are still available on the testing [dashboard](http://nrel.github.io/EnergyPlusBuildResults/).
+In the meantime, while Decent CI is still handling the regression and bulkier testing, results from Decent CI are still available on the testing [dashboard](https://myoldmopar.github.io/EnergyPlusBuildResults/).
## Releases
diff --git a/datasets/ResidentialACsAndHPsPerfCurves.idf b/datasets/ResidentialACsAndHPsPerfCurves.idf
index 8685977b81e..003ea636b99 100644
--- a/datasets/ResidentialACsAndHPsPerfCurves.idf
+++ b/datasets/ResidentialACsAndHPsPerfCurves.idf
@@ -154,10 +154,10 @@
! , !- Speed 1 Rated COP {W/W}
! , !- Speed 1 Rated Air Flow Rate {m3/s}
! , !- Rated Evaporator Fan Power Per Volume Flow Rate {W/(m3/s)}
-! ACHighStageCoolingCAPFTemp, !- Speed 1 Total Cooling Capacity Function of Temperature Curve Name
-! ACHighStageCoolingCAPFFF, !- Speed 1 Total Cooling Capacity Function of Flow Fraction Curve Name
-! ACHighStageCoolingEIRFTemp, !- Speed 1 Energy Input Ratio Function of Temperature Curve Name
-! ACHighStageCoolingEIRFFF, !- Speed 1 Energy Input Ratio Function of Flow Fraction Curve Name
+! ACLowStageCoolingCAPFTemp, !- Speed 1 Total Cooling Capacity Function of Temperature Curve Name
+! ACLowStageCoolingCAPFFF, !- Speed 1 Total Cooling Capacity Function of Flow Fraction Curve Name
+! ACLowStageCoolingEIRFTemp, !- Speed 1 Energy Input Ratio Function of Temperature Curve Name
+! ACLowStageCoolingEIRFFF, !- Speed 1 Energy Input Ratio Function of Flow Fraction Curve Name
! AC2StageCoolingPLFFPLR, !- Speed 1 Part Load Fraction Correlation Curve Name
! , !- Speed 1 Nominal Time for Condensate Removal to Begin {s}
! , !- Speed 1 Ratio of Initial Moisture Evaporation Rate and Steady State Latent Capacity {dimensionless}
@@ -173,10 +173,10 @@
! , !- Speed 2 Rated COP {W/W}
! , !- Speed 2 Rated Air Flow Rate {m3/s}
! , !- Rated Evaporator Fan Power Per Volume Flow Rate {W/(m3/s)}
-! ACLowStageCoolingCAPFTemp, !- Speed 2 Total Cooling Capacity Function of Temperature Curve Name
-! ACLowStageCoolingCAPFFF, !- Speed 2 Total Cooling Capacity Function of Flow Fraction Curve Name
-! ACLowStageCoolingEIRFTemp, !- Speed 2 Energy Input Ratio Function of Temperature Curve Name
-! ACLowStageCoolingEIRFFF, !- Speed 2 Energy Input Ratio Function of Flow Fraction Curve Name
+! ACHighStageCoolingCAPFTemp, !- Speed 2 Total Cooling Capacity Function of Temperature Curve Name
+! ACHighStageCoolingCAPFFF, !- Speed 2 Total Cooling Capacity Function of Flow Fraction Curve Name
+! ACHighStageCoolingEIRFTemp, !- Speed 2 Energy Input Ratio Function of Temperature Curve Name
+! ACHighStageCoolingEIRFFF, !- Speed 2 Energy Input Ratio Function of Flow Fraction Curve Name
! AC2StageCoolingPLFFPLR, !- Speed 2 Part Load Fraction Correlation Curve Name
! , !- Speed 2 Nominal Time for Condensate Removal to Begin {s}
! , !- Speed 2 Ratio of Initial Moisture Evaporation Rate and steady state Latent Capacity {dimensionless}
@@ -570,10 +570,10 @@
! , !- Speed 1 Rated COP {W/W}
! , !- Speed 1 Rated Air Flow Rate {m3/s}
! , !- Rated Evaporator Fan Power Per Volume Flow Rate {W/(m3/s)}
-! HPHighStageCoolingCAPFTemp, !- Speed 1 Total Cooling Capacity Function of Temperature Curve Name
-! HPHighStageCoolingCAPFFF, !- Speed 1 Total Cooling Capacity Function of Flow Fraction Curve Name
-! HPHighStageCoolingEIRFTemp, !- Speed 1 Energy Input Ratio Function of Temperature Curve Name
-! HPHighStageCoolingEIRFFF, !- Speed 1 Energy Input Ratio Function of Flow Fraction Curve Name
+! HPLowStageCoolingCAPFTemp, !- Speed 1 Total Cooling Capacity Function of Temperature Curve Name
+! HPLowStageCoolingCAPFFF, !- Speed 1 Total Cooling Capacity Function of Flow Fraction Curve Name
+! HPLowStageCoolingEIRFTemp, !- Speed 1 Energy Input Ratio Function of Temperature Curve Name
+! HPLowStageCoolingEIRFFF, !- Speed 1 Energy Input Ratio Function of Flow Fraction Curve Name
! HP2StageCoolingPLFFPLR, !- Speed 1 Part Load Fraction Correlation Curve Name
! , !- Speed 1 Nominal Time for Condensate Removal to Begin {s}
! , !- Speed 1 Ratio of Initial Moisture Evaporation Rate and Steady State Latent Capacity {dimensionless}
@@ -589,10 +589,10 @@
! , !- Speed 2 Rated COP {W/W}
! , !- Speed 2 Rated Air Flow Rate {m3/s}
! , !- Rated Evaporator Fan Power Per Volume Flow Rate {W/(m3/s)}
-! HPLowStageCoolingCAPFTemp, !- Speed 2 Total Cooling Capacity Function of Temperature Curve Name
-! HPLowStageCoolingCAPFFF, !- Speed 2 Total Cooling Capacity Function of Flow Fraction Curve Name
-! HPLowStageCoolingEIRFTemp, !- Speed 2 Energy Input Ratio Function of Temperature Curve Name
-! HPLowStageCoolingEIRFFF, !- Speed 2 Energy Input Ratio Function of Flow Fraction Curve Name
+! HPHighStageCoolingCAPFTemp, !- Speed 2 Total Cooling Capacity Function of Temperature Curve Name
+! HPHighStageCoolingCAPFFF, !- Speed 2 Total Cooling Capacity Function of Flow Fraction Curve Name
+! HPHighStageCoolingEIRFTemp, !- Speed 2 Energy Input Ratio Function of Temperature Curve Name
+! HPHighStageCoolingEIRFFF, !- Speed 2 Energy Input Ratio Function of Flow Fraction Curve Name
! HP2StageCoolingPLFFPLR, !- Speed 2 Part Load Fraction Correlation Curve Name
! , !- Speed 2 Nominal Time for Condensate Removal to Begin {s}
! , !- Speed 2 Ratio of Initial Moisture Evaporation Rate and steady state Latent Capacity {dimensionless}
@@ -762,10 +762,10 @@
! , !- Speed 1 Rated COP {W/W}
! , !- Speed 1 Rated Air Flow Rate {m3/s}
! , !- Speed 1 Rated Supply Air Fan Power Per Volume Flow Rate {W/(m3/s)}
-! HPHighStageHeatingCAPFTemp, !- Speed 1 Total Heating Capacity Function of Temperature Curve Name
-! HPHighStageHeatingCAPFFF, !- Speed 1 Total Heating Capacity Function of Flow Fraction Curve Name
-! HPHighStageHeatingEIRFTemp, !- Speed 1 Energy Input Ratio Function of Temperature Curve Name
-! HPHighStageHeatingEIRFFF, !- Speed 1 Energy Input Ratio Function of Flow Fraction Curve Name
+! HPLowStageHeatingCAPFTemp, !- Speed 1 Total Heating Capacity Function of Temperature Curve Name
+! HPLowStageHeatingCAPFFF, !- Speed 1 Total Heating Capacity Function of Flow Fraction Curve Name
+! HPLowStageHeatingEIRFTemp, !- Speed 1 Energy Input Ratio Function of Temperature Curve Name
+! HPLowStageHeatingEIRFFF, !- Speed 1 Energy Input Ratio Function of Flow Fraction Curve Name
! HP2StageHeatingPLFFPLR, !- Speed 1 Part Load Fraction Correlation Curve Name
! , !- Speed 1 Rated Waste Heat Fraction of Power Input {dimensionless}
! , !- Speed 1 Waste Heat Function of Temperature Curve Name
@@ -773,10 +773,10 @@
! , !- Speed 2 Rated COP {W/W}
! , !- Speed 2 Rated Air Flow Rate {m3/s}
! , !- Speed 2 Rated Supply Air Fan Power Per Volume Flow Rate {W/(m3/s)}
-! HPLowStageHeatingCAPFTemp, !- Speed 2 Total Heating Capacity Function of Temperature Curve Name
-! HPLowStageHeatingCAPFFF, !- Speed 2 Total Heating Capacity Function of Flow Fraction Curve Name
-! HPLowStageHeatingEIRFTemp, !- Speed 2 Energy Input Ratio Function of Temperature Curve Name
-! HPLowStageHeatingEIRFFF, !- Speed 2 Energy Input Ratio Function of Flow Fraction Curve Name
+! HPHighStageHeatingCAPFTemp, !- Speed 2 Total Heating Capacity Function of Temperature Curve Name
+! HPHighStageHeatingCAPFFF, !- Speed 2 Total Heating Capacity Function of Flow Fraction Curve Name
+! HPHighStageHeatingEIRFTemp, !- Speed 2 Energy Input Ratio Function of Temperature Curve Name
+! HPHighStageHeatingEIRFFF, !- Speed 2 Energy Input Ratio Function of Flow Fraction Curve Name
! HP2StageHeatingPLFFPLR, !- Speed 2 Part Load Fraction Correlation Curve Name
! , !- Speed 2 Rated Waste Heat Fraction of Power Input {dimensionless}
! ; !- Speed 2 Waste Heat Function of Temperature Curve Name
diff --git a/design/FY2023/Design-Document-EarthTube-1DEnhancement.md b/design/FY2023/Design-Document-EarthTube-1DEnhancement.md
new file mode 100644
index 00000000000..509484e3ccb
--- /dev/null
+++ b/design/FY2023/Design-Document-EarthTube-1DEnhancement.md
@@ -0,0 +1,410 @@
+Earth Tube 1-D Conduction Enhancement (Design Document)
+================
+
+**Rick Strand, University of Illinois at Urbana-Champaign**
+
+ - April 2023
+ - Revision Date (Version 2): May 11, 2023
+ - Revision Date (Version 3): May 12, 2023
+ - Revision Date (Version 4): June 7, 2023 (converted to a design document, minor grammatical edits, addition of the Code Development setion)
+ - Revision Date (Version 5): June 27, 2023 (switch to LU decomposition)
+
+
+## Justification for New Feature ##
+
+It has long been known that the earth tube model in EnergyPlus, though an important addition to the program, has one critical assumption that potentially affects the accuracy of the earth tube results. The assumption is that the presence of the earth tube and any heat transfer from the air passing through it to the ground is negligible. While this is a common assumption for many first principle models in the literature (these models generally all use the model used in EnergyPlus to determine the temperature at a particular depth), it does not take into account any changes that the heat rejection from the outside air to the ground itself. It is not currently known how much of an impact this will have, but it would seem at least plausible that the ground around the earth tube would be impacted and that this would affect the potential outlet temperatures that can be achieved and thus the amount of cooling that is possible. The goal is to provide a more accurate assessment of these systems using EnergyPlus.
+The improvement of the earth tube model will be done in stages. The first step is to handle the impact of the earth on the ground surrounding the earth in a single dimension (with the soil depth being that dimension). Future work would potentially handle heat transfer axially along the length of the tube, the impact of more than one earth tube and the impact that adjacent tubes have on each other, and any time lag due to the air passing through the earth tube.
+
+## E-mail, Slack, and Conference Call Conclusions ##
+
+Technicalities Meeting (5/3/23): team review the document briefly and stated the desire for this to get additional feedback in the next technicalities meeting. Two initial requests from the team included modifying the proposal to factor in the impact of the soil at the depth of the earth tube since this would be more realistic of the situation (as in, the earth tube in not infinite in width) and to contact John Nelson who has expertise in earth tube modeling and has requested improved earth tube simulation capabilities in EnergyPlus in the past. This update includes a modification of the finite difference scheme to address the concern regarding what is happening at the depth of the earth tube itself. In addition, GitHub was used to contact John Nelson and that conversation is contained in the comments for the GitHub issue regarding earth tubes (https://github.com/NREL/EnergyPlus/issues/6627). John suggested that the model at some point include the ability to model temperature variation axially along the earth tube (something already logged as a potential future enhancement) and also to provide some improved controls where air might bypass the earth tube and use heat recovery in certain situations to save the earth tube’s ability to cool. This is an interesting idea but may also be fairly complicated because it may deal with specific control algorithms and bridging between the zone and air loop simulations. Such a concept is different from what is currently in EnergyPlus and there doesn’t appear to be another model in E+ that bridges with air flow at the zone and air loop level. Such a concept is definitely beyond the scope of this initial enhancement.
+
+Slack Discussion (5/11/23): Neal Kruis brought up two issues in this NFP. First, there is the issue of the infinitely wide domain which is unrealistic. Second, there is the question of what air temperature is being used for heat transfer between the earth tube and the air passing through it. The second issue will be resolved by adding the discussion of the effectiveness-NTU heat exchanger model that is being used. This will be similar in the assumptions as the heat exchanger algorithm used in the low temperature radiant system model (solid side with a “constant” temperature and a fluid side which has a temperature which varies throughout). The first issue will be addressed by modifying the solution domain to have a user-defined width with adiabatic boundary conditions on either side. In reality, at some distance from the earth tube there will be negligible heat transfer toward/away from the earth tube. Making this a user-defined input parameter will allow the width to be studied.
+
+Technicalities Meeting (6/14/23): Jason DeGraw expressed specific concern about using matrix inversion as part of the solution technique due to concerns about slow execution speeds. He recommended that an LU decomposition technique be used as a much faster approach and noted that there were several already in EnergyPlus. As a result, this document was modified to remove inversion as a solution approach and replace it with LU decomposition, using the existing routines in the Window Manager.
+
+## Overview ##
+
+The earth tube model in EnergyPlus uses an established equation for determining the temperature of soil below grade. This equation is published in the literature and is documented in the EnergyPlus Engineering Reference. In EnergyPlus, this equation for temperature as a function of distance is integrated over the diameter of the earth tube to come up with an average temperature that is then used as the soil temperature with which the earth tube interacts. While this is useful and is a common assumption in much of the existing literature, it does not take into account any impact that the earth tube has on the surrounding soil in any direction. The model simply assumes that the earth tube does not impact the local soil temperature.
+
+Clearly, over an entire season of cooling, there would be some impact on the local soil temperature due to the presence of the earth tube. While the base equation does account for seasonal variation of the undisturbed earth temperature, it does not include any terms that would account for the heat gains in the soil due to the cooling effect on the air passing through the earth tube. This would vary the soil temperature in all directions around the coil—vertically, horizontally, and axially along the length of the tube. So, to better model an earth tube and its performance within EnergyPlus, improvements must be made to account for the transient impact of the earth tube on the local soil temperatures in all directions. In addition, there should be some sort of accounting for the potential presence of more than a single earth tube, since it is common for such systems to have more than a single pipe/tube.
+
+In addition, the current model also assumes that the air passing through the tube does so without any time delay. In other words, the air instantaneously passes through the earth tube and this has an immediate impact on the space. In reality, there is a time lag since air entering the tube must pass through the entire length of the tube. While the impact of this assumption has not been explored, it could potentially be another element of the existing model that could be improved.
+
+Given all of these areas of potential improvement to the model and the limited availability of resources, this initial phase of enhancing the existing earth tube model in EnergyPlus will be to focus on the impact of the heat transfer within the earth tube on the local soil conditions in the vertical direction only. There is actually a good reason to focus on that direction first. It is the direction in which there is an existing equation for temperature as a function of soil depth.
+
+Furthermore, research in this area seems to at least give the impression that the biggest impact is in the vertical direction. Research by Liu, Xu, Guo, and Zhu (2019) shows that the direction that is the most important as far as variations in temperature are the vertical direction. While temperature variation does occur horizontally and axially as well, the largest temperature changes in comparison to the undisturbed temperature happen vertically. So, it makes the most sense to make the first enhancement pass to the model to look at the vertical temperature variation caused by the heat transfer due to the earth tube.
+
+## Approach ##
+
+Overall, the approach will be to add a new 1-D heat transfer model that will run as a separate option from the existing model. The reason for this is two-fold: execution speed and comparative accuracy. First, the new model will be slower than the existing model. It may be that users do not wish to have their run times increase and at this time it is uncertain how much the run time will be impacted given the solution technique that will be used, particularly as additional dimensions of heat transfer get added later. Second, it would be helpful to know how much the solution was impacted by the new enhancement of 1-D heat conduction. This will allow test cases to be run and comparisons made to deduce when the use of the new enhancement will be necessary and how much the soil temperature is impacted. This might also give the team useful information on how important additional solution dimensions will be.
+
+The 1-D heat conduction model itself will be implemented using a 1-D implicit finite difference scheme. The solution dimension will be bounded by a temperature just below grade at the top of the solution space and another temperature boundary condition at a depth below the earth tube. The temperatures at these upper and lower boundaries will be set using the existing equation from the literature for undisturbed soil temperature. At the sides of the solution space, adiabatic conditions will be assumed. The user will be given the option to specify the overall thickness of the solution region, but there will only be heat transfer vertically (none horizontally since it will be adiabatic on the “sides”).
+
+The finite difference grid will include an upper portion from the upper temperature boundary to the node just above the earth tube and also a lower portion from the node just below the earth tube to the lower boundary condition. The node at the earth tube itself will also be modeled as an “all soil” node but also include a connection to the earth tube itself. In a one dimensional model like the one proposed for this enhancement, it is more realistic to model the level at the earth tube to be soil because in all directions there will be soil and not an entire layer of air/earth tube. Thus, this earth tube node will capture the conditions of the soil at that level, and a heat exchanger model that connects to the temperature of the earth tube node will be used, and checks will be made to insure that the heat loss of the air is equal to the total heat gain of the soil.
+
+The solution for this finite difference model will use an implicit scheme. Implicit schemes are known for being inherently stable. Since it is possible that the number of nodes may be small and thus the nodes large, it will be important to avoid potential stability issues in the solution. The user will be given some flexibility in the input to specify the number of nodes above and below the earth tube. While some reasonable limits will be applied to those inputs to avoid too few or too many nodes, the control of the number of nodes will also help during the testing and verification process to make sure that the model is producing results that make sense and are believable. An example of the node layout is shown in the figure below.
+
+![earth_tube_solution_space_diagram](earth_tube_solution_space_diagram.png)
+
Figure 1. Earth Tube 1-D Model Solution Space Node Diagram.
+
+The heat transfer between the soil and the air flowing through the earth tube will be calculated using an effectiveness-NTU heat exchanger formulation. Because the soil temperature does not vary axially along the earth tube in this model, the effectiveness for a heat exchanger equation in this situation where one side is at constant temperature and the other side (air side) varies in temperature is:
+
+\begin{equation}
+\varepsilon = 1 - {e^{ - NTU}}
+\end{equation}
+
+This is similar to the reasoning used in the low temperature radiant system models where similar assumptions are made for the embedding material and the fluid being circulated through the tubing. The effectiveness will then used to calculate the outlet air temperature based on an inlet air temperature, soil temperature, and other conditions of the situation (flow, thermal properties, etc.). The overall heat exchange between the soil and the air is calculated using this effectiveness, and there is no need to determine the "average" temperature of the air as it passes through the earth tube. The heat exchanger model defines the heat exchange using the effectiveness and the theoretical maximum heat transfer between the air and soil.
+
+Another important point regarding this model is that unlike the existing model which only calculates the performance of the earth tube when the earth tube is actually operating, the enhancement 1-D model will need to calculate the response of the soil even when the earth tube is not running, whether that is due to no cooling being needed, the earth tube is turned off, or it being not the appropriate season for the earth tube to operate. So, while the existing model simply skips the earth tube code when it is “off”, the enhanced model will have to calculate node conditions all the time. This again could add to the execution run time as the earth tube calculations will have to be made all of the time. This will naturally be impacted by the number of nodes selected by the users. At this time, it is uncertain how much time this model will add to execution time. Testing will be done with the new model to help identify some benchmarks and provide some helpful guidance to users via the Engineering Reference documentation.
+
+This work will also include modernization of the earth tube code based on recent standard practices implemented by the EnergyPlus development team.
+
+## Testing/Validation/Data Sources ##
+
+Explicit data sets for earth tube performance that monitors temperature in the vertical direction have not been published in the literature. More qualitative graphs have been published but it is difficult to get exact data from these diagrams. They can, however, be used to establish trends that can be checked against the results from the new EnergyPlus enhancement. The more important testing and validation that will occur will compare the results of the new model with the existing one at various depths, different number of nodes (upper and lower), and for different soil conditions. Comparisons can then be made both to the existing model as well as different depths, node arrangements, and soil conditions to establish the improvement in the temperature predictions of both the soil conditions as well as the outlet air temperatures. It is anticipated that this work will result in a publication following the completion of this work in EnergyPlus.
+
+## Input Output Reference Documentation ##
+
+The existing input output reference documentation that already exists for earth tubes will be reviewed and corrected as needed for the model that is already in the code. The most significant changes to the documentation will be the addition of two new fields in the input syntax for earth tubes and the addition of a new input object for the details of the finite difference solution. This is shown starting in the next paragraph.
+
+\subsection{ZoneEarthtube}\label{zoneearthtube-earth-tube}
+
+An earth tube is a long, underground metal or plastic pipe through which air is drawn. During cooling season, as air travels through the pipe, it gives up some of its heat to the surrounding soil and enters the room as cooler air. Similarly, during heating season, as air travels through the pipe, it receives some of its heat from the soil and enters the zone as warmer air. Simple earth tubes in EnergyPlus can be controlled by a schedule and through the specification of minimum, maximum, and delta temperatures as described below. As with infiltration and ventilation, the actual flow rate of air through the earth tube can be modified by the temperature difference between the inside and outside environment and the wind speed. The basic equation used to calculate air flow rate of earth tube in EnergyPlus is:
+
+\begin{equation}
+EarthTubeFlowRate = \left( {{E_{design}}} \right)\left( {{F_{schedule}}} \right)\left[ {A + B\left| {{T_{zone}} - {T_{odb}}} \right| + C\left( {WindSpeed} \right) + D\left( {WindSpee{d^2}} \right)} \right]
+\end{equation}
+
+For the simulation of the earth tube, a weather data file is required and, therefore, the earth tube cannot run without weather data file. The required input fields to simulate the earth tube include the average soil surface temperature, the amplitude of soil surface temperature, and the phase constant of soil surface temperature. These fields should be calculated in advance by using a separate stand-alone program (CalcSoilSurfTemp) and should be input into earth tube.
+
+\subsubsection{CalcSoilSurfTemp -- Auxiliary Programs Document}\label{calcsoilsurftemp-auxiliary-programs-document}
+
+The CalcSoilSurfTemp program is simple and requires only two input fields: soil condition and soil surface condition in addition to a valid weather file. For soil condition, the user should select the number corresponding to the actual condition of the soil surrounding the earth tube from the four following options: 1. HEAVY AND SATURATED, 2. HEAVY AND DAMP, 3. HEAVY AND DRY and 4. LIGHT AND DRY. This determines the thermal diffusivity and thermal conductivity of the surrounding soil. For soil surface conditions, the user should select the number corresponding to the actual condition of the ground surface above the earth tube from the eight following options: 1. BARE AND WET, 2. BARE AND MOIST, 3. BARE AND ARID, 4. BARE AND DRY, 5. COVERED AND WET, 6. COVERED AND MOIST, 7. COVERED AND ARID and 8. COVERED AND DRY. This determines the absorption coefficient and the fraction of evaporation rate of the ground surface.
+
+
+## Input Description ##
+
+\subsubsection{Inputs}
+From this information and an analysis of the weather for the location selected, the CalcSoilSurfTemp program (ref. Auxiliary Programs document) calculates the three parameters listed above. The user must then add these parameters as input into EnergyPlus. The full input description of an earth tube (EARTHTUBE object) in EnergyPlus is given below.
+
+\paragraph{Field: Zone Name}\label{field-zone-name-5}
+
+This field is the name of the zone (ref: Zone) and attaches a particular earth tube statement to a thermal zone in the building.
+
+\paragraph{Field: Schedule Name}\label{field-schedule-name-6}
+
+This field is the name of the schedule (ref: Schedule) that modifies the maximum design volume flow rate parameter (see next field). This fraction between 0.0 and 1.0 is noted as F\(_{schedule}\) in the above equation.
+
+\paragraph{Field: Design Flow Rate}\label{field-design-flow-rate-4}
+
+This number (noted as E\(_{design}\) in the above equation) is the maximum amount of air mass flow rate of the earth tube expected at design conditions. The flow rate is expressed in units of m\(^{3}\)/s. The design value is modified by the schedule fraction (see previous field) and user specified coefficients (see last four fields).
+
+\paragraph{Field: Minimum Zone Temperature when Cooling}\label{field-minimum-zone-temperature-when-cooling}
+
+This is the indoor temperature (in Celsius) below which the earth tube is shut off. This lower temperature limit is intended to avoid overcooling a space and thus result in a heating load. For example, if the user specifies a minimum temperature of 20$^\circ$C, earth tube is assumed to be available if the zone air temperature is above 20$^\circ$C. If the zone air temperature drops below 20$^\circ$C, then earth tube is automatically turned off.
+
+\paragraph{Field: Maximum Zone Temperature when Heating}\label{field-maximum-zone-temperature-when-heating}
+
+This is the indoor temperature (in Celsius) above which the earth tube is shut off. This higher temperature limit is intended to avoid overheating a space and thus result in a cooling load. For example, if the user specifies a maximum temperature of 20$^\circ$C, earth tube is assumed to be available if the zone air temperature is below 20$^\circ$C. If the zone air temperature rises above 20$^\circ$C, then earth tube is automatically turned off.
+
+\paragraph{Field: Delta Temperature}\label{field-delta-temperature-4}
+
+This is the temperature difference (in Celsius) between the indoor and outdoor air dry-bulb temperatures below which the earth tube is shut off. This is to allow the earth tube to be stopped either if the temperature outside is too warm and could potentially heat the space or if the temperature outside is too cold and could potentially cool the space. For example, if the user specifies a delta temperature of 2$^\circ$C, earth tube is assumed to be available if the temperature difference between indoor and outdoor temperature is at least 2$^\circ$C. If the outside air dry-bulb temperature is less than 2$^\circ$C cooler or warmer than the indoor dry-bulb temperature, then the earth tube is automatically turned off.
+
+\paragraph{Field: Earthtube Type}\label{field-earthtube-type}
+
+This alpha character string defines the type of earth tube as one of the following options: \emph{Natural}, \emph{Exhaust}, or \emph{Intake}. A \emph{Natural} earth tube is assumed to be air movement/exchange that will not consume any fan energy or is the result of natural air flow through the tube and into the building. Values for fan pressure and efficiency for a natural flow earth tube are ignored. For either \emph{Exhaust} or \emph{Intake} earth tubes, values for fan pressure and efficiency define the fan electric consumption. For \emph{Natural} and \emph{Exhaust} earth tubes, the conditions of the air entering the space are assumed to be equivalent to the air which is cooled or heated by passing along the pipe. For \emph{Intake} earth tubes, an appropriate amount of fan heat is added to the air stream.
+
+\paragraph{Field: Fan Pressure Rise}\label{field-fan-pressure-rise-1}
+
+This is the pressure rise experienced across the fan in Pascals (N/m\(^{2}\)). This is a function of the fan and plays a role in determining the amount of energy consumed by the fan.
+
+\paragraph{Field: Fan Total Efficiency}\label{field-fan-total-efficiency-1}
+
+This is the total fan efficiency (a decimal number between 0.0 and 1.0). This is a function of the fan and plays a role in determining the amount of energy consumed by the fan.
+
+\paragraph{Field: Pipe Radius}\label{field-pipe-radius}
+
+This is the radius of the earth tube/pipe (in meters). This plays a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe. If the pipe has non-circular cross section, user can use the concept of hydraulic diameter as follows.
+
+\begin{equation}
+D = 4 \times Area/Perimeter
+\end{equation}
+
+However, since this field requires the pipe radius, hydraulic diameter should be divided by two.
+
+\paragraph{Field: Pipe Thickness}\label{field-pipe-thickness}
+
+This is the thickness of the pipe wall (in meters). This plays a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe.
+
+\paragraph{Field: Pipe Length}\label{field-pipe-length}
+
+This is the total length of the pipe (in meters). This plays a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe. As the length of the pipe becomes longer, the amount of the heat transfer becomes larger.
+
+\paragraph{Field: Pipe Thermal Conductivity}\label{field-pipe-thermal-conductivity}
+
+This is the thermal conductivity of the pipe (in W/m-C). This plays a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe.
+
+\paragraph{Field: Pipe Depth Under Ground Surface}\label{field-pipe-depth-under-ground-surface}
+
+This is the depth of the pipe under the ground surface (in meters). This plays a role in determining the temperature of the soil surrounding the pipe.
+
+\paragraph{Field: Soil Condition}\label{field-soil-condition}
+
+This alpha character string defines the actual condition of the soil surrounding the earth tube and can be one of any of the following options: HeavyAndSaturated, HeavyAndDamp, HeavyAndDry or LightAndDry. This determines the thermal diffusivity and thermal conductivity of the surrounding soil, which play a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe.
+
+\paragraph{Field: Average Soil Surface Temperature}\label{field-average-soil-surface-temperature}
+
+This is the annual average soil surface temperature straight above the earth tube, which plays a role in determining the temperature of the soil surrounding the pipe. This field should be calculated in advance using the separate CalcSoilSurfTemp program.
+
+\paragraph{Field: Amplitude of Soil Surface Temperature}\label{field-amplitude-of-soil-surface-temperature}
+
+This is the amplitude of soil surface temperature above the earth tube, which plays a role in determining the temperature of the soil surrounding the pipe. This is the difference between the maximum and minimum soil surface temperature for the whole year divided by two. This field should be calculated in advance using the separate CalcSoilSurfTemp program.
+
+\paragraph{Field: Phase Constant of Soil Surface Temperature}\label{field-phase-constant-of-soil-surface-temperature}
+
+This is the phase constant of the soil surface temperature straight above the earth tube, which play a role in determining the temperature of the soil surrounding the pipe at particular time. This is the time elapsed from the beginning of the year until the soil surface temperature reaches the minimum value of the year. This field should be calculated in advance using the separate CalcSoilSurfTemp program.
+
+\paragraph{Field: Constant Term Flow Coefficient}\label{field-constant-term-flow-coefficient}
+
+This number is the ``A'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter, however, is a constant under all conditions and is not modified by any environmental effect. As a result, it is dimensionless.
+
+\paragraph{Field: Temperature Term Flow Coefficient}\label{field-temperature-term-flow-coefficient}
+
+This number is the ``B'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter is modified by the temperature difference between the outdoor and indoor air dry-bulb temperatures. The units for this parameter are inverse Celsius.
+
+\paragraph{Field: Velocity Term Flow Coefficient}\label{field-velocity-term-flow-coefficient}
+
+This number is the ``C'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter is modified by the speed of wind being experienced outside the building. The units for this parameter are s/m.
+
+\paragraph{Field: Velocity Squared Term Flow Coefficient}\label{field-velocity-squared-term-flow-coefficient}
+
+This number is the ``D'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter is modified by square of the speed of wind being experienced outside the building. The units for this parameter are s\(^{2}\)/m\(^{2}\).
+
+\paragraph{Field: Earth Tube Model Type}\label{field-earth-tube-model-type}
+
+This field determines which modeling technique will be used to assess the performance of the earth tube. The options are: Simple and Vertical. In the Simple modeling approach, the temperature of the soil at the earth tube is approximated by the undisturbed ground conditions. In the Vertical modeling approach, the temperature of the soil around the earth tube is modeled using a finite difference scheme to account for the impact of the earth tube on the surrounding soil conditions in a single direction (1-D). For more information on the model type, reference the Earth Tube section of the EnergyPlus Engineering Reference. This input is optional, and the default value is Simple.
+
+\paragraph{Field: Earth Tube Model Parameters}\label{field-earth-tube-model-parameters}
+
+This field refers to separate input syntax (see below) that is used for controlling parameters for the 1-D (Vertical) solution technique. This input field is ignored for the Simple model.
+
+\paragraph{EarthTube:Parameters}\label{field-earth-tube-parameters}
+For the 1-D (Vertical) model, some additional optional parameters are available for the user to potentially control the solution space (number of nodes, distances) for the finite difference solution. These are described below.
+
+\paragraph{Field: Earth Tube Parameters Name}\label{field-earth-tube-parameters-name}
+This name is used as a reference in the main EarthTube input syntax. It is used to identify the parameters that the user desires to use to control what is being modeled and how detailed the model is.
+
+\paragraph{Field: Earth Tube Nodes Above}\label{field-earth-tube-nodes-above}
+This parameter sets the number of nodes above the earth tube, between the earth tube and the ground surface. It has a minimum of three nodes and a maximum of ten nodes. These limits were chosen to avoid the extremes of excessive execution times and overly simplified results. The default value for this parameter is 5 (nodes).
+
+\paragraph{Field: Earth Tube Nodes Below}\label{field-earth-tube-nodes-below}
+This parameter sets the number of nodes below the earth tube, between the earth tube and the deep ground boundary. It has a minimum of three nodes and a maximum of ten nodes. These limits were chosen to avoid the extremes of excessive execution times and overly simplified results. The default value for this parameter is 3 (nodes) or the minimum.
+
+\paragraph{Field: Earth Tube Dimensionless Boundary Above}\label{field-earth-tube-dimensionless-boundary-above}
+This parameter sets the dimensionless distance above the earth tube for the solution space. The maximum value is 1.0, and the minimum value is 0.25. When this parameter is set to 1.0, the upper boundary is set to be half of the diameter below the ground surface and the solution space thickness above the earth tube is the depth of the earth tube minus the earth tube diameter. This maximum distance (earth tube depth minus diameter) is multiplied by this parameter to constrain the solution space to less than the maximum (when the parameter is less than 1.0). The default value for this parameter is 1.0 (the maximum value).
+
+\paragraph{Field: Earth Tube Dimensionless Boundary Below}\label{field-earth-tube-dimensionless-boundary-below}
+This parameter sets the dimensionless distance below the earth tube for the solution space. The maximum value is 1.0, and the minimum value is 0.25. This parameter is interpretted in a similar fashion as the previous parameter where the depth of the solution space below the earth tube is determined by the maximum distance above the earth tube (earth tube depth minus diameter). This allows the user to have different thickness for the modeled portion of the ground above and below the earth tube. The default value for this parameter is 0.25 (the minimum value).
+
+\paragraph{Field: Earth Tube Dimensionless Solution Space Width}\label{field-earth-tube-dimensionless-solution-space-width}
+This parameter sets the dimensionless width of the solution space horizontally as a function of the earth tube radius as defined in the main earth tube input syntax. The maximum value is 20.0, and the minimum value is 3.0. The default value for this parameter is 4.0 which means that the width of the solution space is four times the radius. In other words, this would include soil one radius length beyond the edges of the tube on either side of the earth tube.
+
+An IDF example:
+
+\begin{lstlisting}
+
+EARTHTUBE,
+ Zone 2, !- Zone Name
+ 1D Modeled Tube, !- Schedule Name
+ 3.425198, !- Design Volume Flow Rate
+ 10.0, !- Minimum Zone Temperature when Cooling
+ 30.0, !- Maximum Zone Temperature when Heating
+ 1.0, !- Delta Temperature
+ NATURAL, !- EarthTube Type
+ 350.0, !- Fan Pressure Rise
+ 0.9, !- Fan Total Efficiency
+ 0.25, !- Pipe Radius
+ 0.2, !- Pipe Thickness
+ 15.0, !- Pipe Length
+ 200.0, !- Pipe Thermal Conductivity
+ 3.5, !- Pipe Depth Under Ground Surface
+ HeavyAndDamp, !- Soil Condition
+ 15.0, !- Average Soil Surface Temperature
+ 5.6, !- Amplitude of Soil Surface Temperature
+ 0.0, !- Phase Constant of Soil Surface Temperature
+ 0.6060000 , !- Constant Term Flow Coef
+ 2.0199999E-02, !- Temp Term Flow Coef
+ 5.9800001E-04, !- Velocity Term Flow Coef
+ 0.0000000E+00, !- Velocity**2 Term Flow Coef
+ Vertical, !- Earth Tube Model Type
+ EarthTubeParams; !- Earth Tube Model Parameters
+
+EarthTube:Parameters,
+ EarthTubeParams, !- Earth Tube Model Parameters (Name)
+ 5, !- Earth Tube Nodes Above
+ 3, !- Earth Tube Nodes Below
+ 1.0, !- Earth Tube Dimensionless Boundary Above
+ 0.5, !- Earth Tube Dimensionless Boundary Below
+ 4.0; !- Earth Tube Dimensionless Solution Space Width
+
+\end{lstlisting}
+
+## Outputs Description ##
+
+\subsubsection{Outputs}\label{zoneearthtube-outputs}
+
+Current Earth Tube output variables:
+
+\begin{itemize}
+\item
+ HVAC,Sum,Earth Tube Zone Sensible Cooling Energy {[}J{]}
+\item
+ HVAC,Average,Earth Tube Zone Sensible Cooling Rate {[}W{]}
+\item
+ HVAC,Sum,Earth Tube Zone Sensible Heating Energy {[}J{]}
+\item
+ HVAC,Average,Earth Tube Zone Sensible Heating Rate {[}W{]}
+\item
+ HVAC,Sum,Earth Tube Air Flow Volume {[}m3{]}
+\item
+ HVAC,Average,Earth Tube Current Density Volume Flow Rate {[}m3/s{]}
+\item
+ HVAC,Average,Earth Tube Standard Density Volume Flow Rate {[}m3/s{]}
+\item
+ HVAC,Sum,Earth Tube Air Flow Mass {[}kg{]}
+\item
+ HVAC,Average,Earth Tube Air Mass Flow Rate {[}kg/s{]}
+\item
+ HVAC,Average,Earth Tube Water Mass Flow Rate {[}kg/s{]}
+\item
+ HVAC,Sum,Earth Tube Fan Electricity Energy {[}J{]}
+\item
+ HVAC,Average,Earth Tube Fan Electricity Rate {[}W{]}
+\item
+ HVAC,Average,Earth Tube Zone Inlet Air Temperature {[}C{]}
+\item
+ HVAC,Average,Earth Tube Ground Interface Temperature {[}C{]}
+\item
+ HVAC,Average,Earth Tube Outdoor Air Heat Transfer Rate {[}W{]}
+\item
+ HVAC,Average,Earth Tube Inlet Wet Bulb Temperature {[}C{]}
+\item
+ HVAC,Average,Earth Tube Inlet Humidity Ratio {[}kgWater/kgDryAir{]}
+\item
+ HVAC,Average,Earth Tube Node Temperatures {[}C{]}
+\item
+ HVAC,Average,Earth Tube Undisturbed Ground Temperatures {[}C{]}
+\end{itemize}
+
+\paragraph{Earth Tube Zone Sensible Cooling Energy {[}J{]}}\label{earth-tube-zone-sensible-cooling-energy-j}
+
+\paragraph{Earth Tube Zone Sensible Cooling Rate {[}W{]}}\label{earth-tube-zone-sensible-cooling-rate-w}
+
+These are the energy and rate associated with the zone cooling provided by the air from the earth tube.~ This occurs when the earth tube outlet air temperature is less than zone air temperature.
+
+\paragraph{Earth Tube Zone Sensible Heating Energy {[}J{]}}\label{earth-tube-zone-sensible-heating-energy-j}
+
+\paragraph{Earth Tube Zone Sensible Heating Rate {[}W{]}}\label{earth-tube-zone-sensible-heating-rate-w}
+
+These are the energy and rate associated with the zone heating provided by the air from the earth tube.~ This occurs when the earth tube outlet air temperature is greater than the zone air temperature.
+
+\paragraph{Earth Tube Air Flow Volume {[}m3{]}}\label{earth-tube-air-flow-volume-m3}
+
+The volume flow of air through the earth tube.
+
+\paragraph{Earth Tube Current Density Volume Flow Rate {[}m3/s{]}}\label{earth-tube-air-current-density-volumetric-flow-rate-m3s}
+
+The volume flow rate of air through the earth tube evaluating density at current zone conditions.
+
+\paragraph{Earth Tube Standard Density Volume Flow Rate {[}m3/s{]}}\label{earth-tube-air-standard-density-volumetric-flow-rate-m3s}
+
+The volume flow rate of air through the earth tube evaluating density at standard conditions.
+
+\paragraph{Earth Tube Air Flow Mass {[}kg{]}}\label{earth-tube-air-flow-mass-kg}
+
+The mass flow of air through the earth tube.
+
+\paragraph{Earth Tube Air Mass Flow Rate {[}kg/s{]}}\label{earth-tube-air-mass-flow-rate-kgs}
+
+The mass flow rate of air through the earth tube.
+
+\paragraph{Earth Tube Water Mass Flow Rate {[}kg/s{]}}\label{earth-tube-water-mass-flow-rate-kgs}
+
+The mass flow rate of water vapor at the exit of the earth tube.
+
+\paragraph{Earth Tube Fan Electricity Energy {[}J{]}}\label{earth-tube-fan-electric-energy-j}
+
+\paragraph{Earth Tube Fan Electricity Rate {[}W{]}}\label{earth-tube-fan-electric-power-w}
+
+These are the fan electricity consumption and power for intake or exhaust earth tube types.
+
+\paragraph{Earth Tube Zone Inlet Air Temperature {[}C{]}}\label{earth-tube-zone-inlet-air-temperature-c}
+
+This is the temperature of the air entering the zone after passing through the earth tube {[}C{]}.~ This temperature includes the cooling or heating of outdoor air as it passes along the pipe. ~When intake fan assist is used, then the additional heat due to the fan is included in the inlet air temperature.
+
+\paragraph{Earth Tube Ground Interface Temperature {[}C{]}}\label{earth-tube-ground-interface-temperature-c}
+
+This is the average temperature of the ground along the outer surface of the earth tube {[}C{]}.
+
+\paragraph{Earth Tube Outdoor Air Heat Transfer Rate {[}W{]}}\label{earth-tube-outdoor-air-heat-transfer-rate-w}
+
+This is the rate of heat transfer from the earth tube to the outdoor air {[}W{]}.~ Positive values indicate the rate at which outdoor air is preheated; negative values indicate the rate of precooling.
+
+\paragraph{Earth Tube Zone Inlet Wet Bulb Temperature {[}C{]}}\label{earth-tube-zone-inlet-wet-bulb-temperature-c}
+
+This is the wet bulb temperature of the air entering the zone after passing through the earth tube {[}C{]}.
+
+\paragraph{Earth Tube Zone Inlet Humidity Ratio {[}kgWater/krDryAir{]}}\label{earth-tube-zone-inlet-humidity-ratio-kgWater/kgDryAir}
+
+This is the humidity ratio of the air entering the zone after passing through the earth tube {[}kgWater/kgDryAir{]}.
+
+\paragraph{Earth Tube Node Temperatures {[}C{]}}\label{earth-tube-node-temperatures}
+
+This will generate the internal node temperatures {[}C{]} for the earth tube as a result of the 1-D finite difference model. This is only valid for the 1-D (Vertical) model.
+
+\paragraph{Earth Tube Undisturbed Ground Temperatures {[}C{]}}\label{earth-tube-node-temperatures}
+
+This will report the theoretical undisturbed ground temperature at the location of the internal node temperatures {[}C{]} as well as the average for the location of the earth tube for the 1-D finite difference model. This is only valid for the 1-D (Vertical) model and provides a comparison of conditions for the simple model and the 1-D (Vertical) model.
+
+## Engineering Reference ##
+
+Note: The existing engineering reference section on earth tubes will be kept with some editing to account for the fact that there will be two potential models that can be used for the earth tube. Much of the existing text and description can stay since it will apply to both models. A new sections will be added to specifically describe the 1-D (Vertical) earth tube modeling technique. This section will outline the assumptions and boundary conditions of the 1-D model and refer back to the existing description and equations to show what the two models have in common. As this documentation will be specific to how the new model solves for earth tube temperature, this new section of documentation will be written once the approach outlined above has gained the approval of the development team.
+
+## Example File and Transition Changes ##
+
+There is already an existing EarthTubeSimpleTest.idf file that is used to test the earth tube as presented in the current version of EnergyPlus. This file will be duplicated, renamed to EarthTubeVerticalTest.idf, and modified to test the 1-D (Vertical) earth tube model being added for this enhancement.
+
+Due to the fact that the two new fields in the EarthTube input are at the end of the current description and are both optional, no transition changes will be needed. Existing files will continue to run without problem and will default to the simple solution method. In addition, the new input syntax EarthTube:Parameters is also optional and only needed for the 1-D (Vertical) model. Thus, current user files will not need this new input to continue to run their earth tube models.
+
+
+## Code Development ##
+
+The current code has one main subroutine that is tasked with the calculation of the earth tube performance. First, after some preliminary initializations, the air flow related terms are calculated for the air side of the earth tube. Then, the average earth temperature between the depth of the top of the earth tube and the bottom of the earth tube. Next, given the air flow and thermal properties of the soil, the heat transfer coefficient including the various thermal resistances are calculated. Finally, given the various conditions already calculated, an outlet air temperature is calculated for the earth tube.
+
+All of this methodology must be preserved since the goal of this implementation is to allow the modeing of both the existing model and the new enhancement so that the results can be compared side-by-side. Most of the auxiliary functions that will be shared between the existing and the new model (air flow terms, heat transfer coefficients, etc.) will be converted to subroutines, reducing the clutter in the main calculation routine. The existing model will also be converted into a function that will calculate the average temperature for various depths. The main calculation routine will then chose one of two options: the existing model or the "vertical" model. The existing model will continue to calculate the ground tempeature as is currently done, using the undisturbed temperature correlation using the new subroutine for average temperature between two depths. The new "vertical" model will call out to a new subroutine that will implement the implicit finite difference scheme presented above.
+
+The new subroutine that will actually contain new code and not simply code moved from the main routine will deal with the calculation of the new vertical model being installed for this work. The main purpose of this new subroutine will be the calculation of the node temperatures using the implicit finite difference scheme. There will likely also need to be a one-time initialization routine for the various terms in the node equations since they will be based on thermo-physical properties of the unique situation (based on user input) and thus constant (assumption).
+
+Another initialization that only needs to be done once per day is the calculation of the soil temperatures. In the current implementation, the soil temperature at the depth of the earth tube is calculated every zone time step. This is unnecessary because the equation for the soil temperature at a given depth is set based on the day of the year, not on the hour of the day. So, this initialization could be calculated once each day, increasing the efficiency of the routine.
+
+The new routine for the vertical model will have the following sequence/components:
+
+1. Initialize the node equation terms (once per simulation). Also calculate the depth of the various nodes for the vertical solution. Also make initial guesses for the various node temperatures based on the undisturbed ground temperature model.
+2. Calculate the air flow related terms for the air side of the earth tube (impacting the air heat balance of the zone).
+3. Calculate the soil temperature at the various node depths used for the model (once per day). This includes the temperature at the depth of the tube as well as at the depth of the top and the bottom of the solution space.
+4. Calculate the heat transfer coefficients and thermal resistances that will be used for the heat exchanger model. This will have an impact on the earth tube node equation since there will be heat exchange between the earth tube node, surrounding nodes, and the air passing through the earth tube.
+5. Calculate the node temperatures and outlet air temperature using an implicit finite difference scheme. The node equations will be set up in a matrix format that follows the general layout of Ax = b. This will be solved via the LU Decomposition strategy using existing EnergyPlus routines (see subroutine LUdecomposition and LUsolution in WindowManager.cc--will need to update so that it is no longer limited to an index of 10). This will avoid the need for iteration to obtain a solution, but it will require the decomposition and solution to be calculated each time step because one of the terms in the A matrix will include the effectiveness (based on NTU as shown above) of the heat transfer between the air passing through the earth tube and the ground. The remaining terms in the A matrix will include thermo-physical properties of the ground and the earth tube material itself which will all be assumed to be constant. Experience with the existing earth tube model and the low temperature hydronic radiant system model has shown that in many situations, the effectiveness is very close or equal to 1. So, during initializations, the decomposed matris for A when the effectiveness is 1 will be calculated and stored to hopefully reduce the time required to obtain a solution. In addition, the decomposition of the A matrix for when the earth tube is not operating (zero flow conditions). This is because the earth tube could spend considerable time being turned off (not needed during cooling season or not being run during heating season, for example). However, due to the transient nature of the model, it will need to model the ground temperature nodes even when the earth tube is not running. Storing A for zero flow and an effectiveness of one will increase data requirements but this will provide a faster solution since during those times, the A matrix will already have been LU decomposed and thus only the solution routine will need to be run.
+6. Record and report output from the vertical model. Output for the vertical model will include all of the existing output for the current model. In addition, output variables will be established for the node temperatures both above the earth tube, below the earth tube, and at the location of the earth tube.
+
+One potential improvememt that could be considered in the future for the model is the ability to specify starting ground temperatures rather than calculate them based on the undisturbed ground temperature as the initial starting point. The point of this would be to allow the user to run multiple simulations sequentially. The last node temperatures of one annual simulation could then be plugged into the next annual simulation as a way to get a better starting point or to see what happens when the earth tube is present for multiple years. Eventually the starting conditions would be no longer be a factor, but at this point it is uncertain whether such a feature is necessary. It is possible that a single annual simulation might be long enough to establish a realistic trend, but this is not known at this time and would be studied at a later date in a future FY.
+
+## References ##
+
+Existing EnergyPlus Earth Tube Model, EnergyPlus Engineering Reference, EnergyPlus Input-Output Reference.
+
+Liu, X., M. Xu, J. Guo, and R. Zhu. 2019. “Conceptual Development of the Earth Tube Cooling System For a Tall Building,” Journal of Green Building (2019) 14 (2): 1–28.
+
+
+
diff --git a/design/FY2023/NFP-EarthTube-1DEnhancement.md b/design/FY2023/NFP-EarthTube-1DEnhancement.md
new file mode 100644
index 00000000000..e0a422ff1ff
--- /dev/null
+++ b/design/FY2023/NFP-EarthTube-1DEnhancement.md
@@ -0,0 +1,384 @@
+Earth Tube 1-D Conduction Enhancement
+================
+
+**Rick Strand, University of Illinois at Urbana-Champaign**
+
+ - April 2023
+ - Revision Date (Version 2): May 11, 2023
+ - Revision Date (Version 3): May 12, 2023
+
+
+## Justification for New Feature ##
+
+It has long been known that the earth tube model in EnergyPlus, though an important addition to the program, has one critical assumption that potentially affects the accuracy of the earth tube results. The assumption is that the presence of the earth tube and any heat transfer from the air passing through it to the ground is negligible. While this is a common assumption for many first principle models in the literature (these models generally all use the model used in EnergyPlus to determine the temperature at a particular depth), it does not take into account any changes that the heat rejection from the outside air to the ground itself. It is not currently known how much of an impact this will have, but it would seem at least plausible that the ground around the earth tube would be impacted and that this would affect the potential outlet temperatures that can be achieved and thus the amount of cooling that is possible. The goal is to provide a more accurate assessment of these systems using EnergyPlus.
+The improvement of the earth tube model will be done in stages. The first step is to handle the impact of the earth on the ground surrounding the earth in a single dimension (with the soil depth being that dimension). Future work would potentially handle heat transfer axially along the length of the tube, the impact of more than one earth tube and the impact that adjacent tubes have on each other, and any time lag due to the air passing through the earth tube.
+
+## E-mail, Slack, and Conference Call Conclusions ##
+
+Technicalities Meeting (5/3/23): team review the document briefly and stated the desire for this to get additional feedback in the next technicalities meeting. Two initial requests from the team included modifying the proposal to factor in the impact of the soil at the depth of the earth tube since this would be more realistic of the situation (as in, the earth tube in not infinite in width) and to contact John Nelson who has expertise in earth tube modeling and has requested improved earth tube simulation capabilities in EnergyPlus in the past. This update includes a modification of the finite difference scheme to address the concern regarding what is happening at the depth of the earth tube itself. In addition, GitHub was used to contact John Nelson and that conversation is contained in the comments for the GitHub issue regarding earth tubes (https://github.com/NREL/EnergyPlus/issues/6627). John suggested that the model at some point include the ability to model temperature variation axially along the earth tube (something already logged as a potential future enhancement) and also to provide some improved controls where air might bypass the earth tube and use heat recovery in certain situations to save the earth tube’s ability to cool. This is an interesting idea but may also be fairly complicated because it may deal with specific control algorithms and bridging between the zone and air loop simulations. Such a concept is different from what is currently in EnergyPlus and there doesn’t appear to be another model in E+ that bridges with air flow at the zone and air loop level. Such a concept is definitely beyond the scope of this initial enhancement.
+
+Slack Discussion (5/11/23): Neal Kris brought up two issues in this NFP. First, there is the issue of the infinitely wide domain which is unrealistic. Second, there is the question of what air temperature is being used for heat transfer between the earth tube and the air passing through it. The second issue will be resolved by adding the discussion of the effectiveness-NTU heat exchanger model that is being used. This will be similar in the assumptions as the heat exchanger algorithm used in the low temperature radiant system model (solid side with a “constant” temperature and a fluid side which has a temperature which varies throughout). The first issue will be addressed by modifying the solution domain to have a user-defined width with adiabatic boundary conditions on either side. In reality, at some distance from the earth tube there will be negligible heat transfer toward/away from the earth tube. Making this a user-defined input parameter will allow the width to be studied.
+
+## Overview ##
+
+The earth tube model in EnergyPlus uses an established equation for determining the temperature of soil below grade. This equation is published in the literature and is documented in the EnergyPlus Engineering Reference. In EnergyPlus, this equation for temperature as a function of distance is integrated over the diameter of the earth tube to come up with an average temperature that is then used as the soil temperature with which the earth tube interacts. While this is useful and is a common assumption in much of the existing literature, it does not take into account any impact that the earth tube has on the surrounding soil in any direction. The model simply assumes that the earth tube does not impact the local soil temperature.
+
+Clearly, over an entire season of cooling, there would be some impact on the local soil temperature due to the presence of the earth tube. While the base equation does account for seasonal variation of the undisturbed earth temperature, it does not include any terms that would account for the heat gains in the soil due to the cooling effect on the air passing through the earth tube. This would vary the soil temperature in all directions around the coil—vertically, horizontally, and axially along the length of the tube. So, to better model an earth tube and its performance within EnergyPlus, improvements must be made to account for the transient impact of the earth tube on the local soil temperatures in all directions. In addition, there should be some sort of accounting for the potential presence of more than a single earth tube, since it is common for such systems to have more than a single pipe/tube.
+
+In addition, the current model also assumes that the air passing through the tube does so without any time delay. In other words, the air instantaneously passes through the earth tube and this has an immediate impact on the space. In reality, there is a time lag since air entering the tube must pass through the entire length of the tube. While the impact of this assumption has not been explored, it could potentially be another element of the existing model that could be improved.
+
+Given all of these areas of potential improvement to the model and the limited availability of resources, this initial phase of enhancing the existing earth tube model in EnergyPlus will be to focus on the impact of the heat transfer within the earth tube on the local soil conditions in the vertical direction only. There is actually a good reason to focus on that direction first. It is the direction in which there is an existing equation for temperature as a function of soil depth.
+
+Furthermore, research in this area seems to at least give the impression that the biggest impact is in the vertical direction. Research by Liu, Xu, Guo, and Zhu (2019) shows that the direction that is the most important as far as variations in temperature are the vertical direction. While temperature variation does occur horizontally and axially as well, the largest temperature changes in comparison to the undisturbed temperature happen vertically. So, it makes the most sense to make the first enhancement pass to the model to look at the vertical temperature variation caused by the heat transfer due to the earth tube.
+
+## Approach ##
+
+Overall, the approach will be to add a new 1-D heat transfer model that will run as a separate option from the existing model. The reason for this is two-fold: execution speed and comparative accuracy. First, the new model will be slower than the existing model. It may be that users do not wish to have their run times increase and at this time it is uncertain how much the run time will be impacted given the solution technique that will be used, particularly as additional dimensions of heat transfer get added later. Second, it would be helpful to know how much the solution was impacted by the new enhancement of 1-D heat conduction. This will allow test cases to be run and comparisons made to deduce when the use of the new enhancement will be necessary and how much the soil temperature is impacted. This might also give the team useful information on how important additional solution dimensions will be.
+
+The 1-D heat conduction model itself will be implemented using a 1-D implicit finite difference scheme. The solution dimension will be bounded by a temperature just below grade at the top of the solution space and another temperature boundary condition at a depth below the earth tube. The temperatures at these upper and lower boundaries will be set using the existing equation from the literature for undisturbed soil temperature. At the sides of the solution space, adiabatic conditions will be assumed. The user will be given the option to specify the overall thickness of the solution region, but there will only be heat transfer vertically (none horizontally since it will be adiabatic on the “sides”).
+
+The finite difference grid will include an upper portion from the upper temperature boundary to the node just above the earth tube and also a lower portion from the node just below the earth tube to the lower boundary condition. The node at the earth tube itself will also be modeled as an “all soil” node but also include a connection to the earth tube itself. In a one dimension model like the one proposed for this enhancement, it is more realistic to model the level at the earth tube to be soil because in all directions there will be soil and not an entire layer of air/earth tube. Thus, this earth tube node will capture the conditions of the soil at that level, and a heat exchanger model that connects to the temperature of the earth tube node will be used, and checks will be made to insure that the heat loss of the air is equal to the total heat gain of the soil.
+
+The solution for this finite difference model will use an implicit scheme. Implicit schemes are known for being inherently stable. Since it is possible that the number of nodes may be small and thus the nodes large, it will be important to avoid potential stability issues in the solution. The user will be given some flexibility in the input to specify the number of nodes above and below the earth tube. While some reasonable limits will be applied to those inputs to avoid too few or too many nodes, the control of the number of nodes will also help during the testing and verification process to make sure that the model is producing results that make sense and are believable. An example of the node layout is shown in the figure below.
+
+![earth_tube_solution_space_diagram](earth_tube_solution_space_diagram.png)
+ Figure 1. Earth Tube 1-D Model Solution Space Node Diagram.
+
+The heat transfer between the soil and the air flowing through the earth tube will be calculated using an effectiveness-NTU heat exchanger formulation. Because the soil temperature does not vary axially along the earth tube in this model, the effectiveness for a heat exchanger equation in this situation where one side is at constant temperature and the other side (air side) varies in temperature is:
+
+\begin{equation}
+\varepsilon = 1 - {e^{ - NTU}}
+\end{equation}
+
+This is similar to the reasoning used in the low temperature radiant system models where similar assumptions are made for the embedding material and the fluid being circulated through the tubing. The effectiveness will then used to calculate the outlet air temperature based on an inlet air temperature, soil temperature, and other conditions of the situation (flow, thermal properties, etc.). The overall heat exchange between the soil and the air is calculated using this effectiveness, and there is no need to determine the "average" temperature of the air as it passes through the earth tube. The heat exchanger model defines the heat exchange using the effectiveness and the theoretical maximum heat transfer between the air and soil.
+
+Another important point regarding this model is that unlike the existing model which only calculates the performance of the earth tube when the earth tube is actually operating, the enhancement 1-D model will need to calculate the response of the soil even when the earth tube is not running, whether that is due to no cooling being needed, the earth tube is turned off, or it being not the appropriate season for the earth tube to operate. So, while the existing model simply skips the earth tube code when it is “off”, the enhanced model will have to calculate node conditions all the time. This again could add to the execution run time as the earth tube calculations will have to be made all of the time. This will naturally be impacted by the number of nodes selected by the users. At this time, it is uncertain how much time this model will add to execution time. Testing will be done with the new model to help identify some benchmarks and provide some helpful guidance to users via the Engineering Reference documentation.
+
+This work will also include modernization of the earth tube code based on recent standard practices implemented by the EnergyPlus development team.
+
+## Testing/Validation/Data Sources ##
+
+Explicit data sets for earth tube performance that monitors temperature in the vertical direction have not been published in the literature. More qualitative graphs have been published but it is difficult to get exact data from these diagrams. They can, however, be used to establish trends that can be checked against the results from the new EnergyPlus enhancement. The more important testing and validation that will occur will compare the results of the new model with the existing one at various depths, different number of nodes (upper and lower), and for different soil conditions. Comparisons can then be made both to the existing model as well as different depths, node arrangements, and soil conditions to establish the improvement in the temperature predictions of both the soil conditions as well as the outlet air temperatures. It is anticipated that this work will result in a publication following the completion of this work in EnergyPlus.
+
+## Input Output Reference Documentation ##
+
+The existing input output reference documentation that already exists for earth tubes will be reviewed and corrected as needed for the model that is already in the code. The most significant changes to the documentation will be the addition of two new fields in the input syntax for earth tubes and the addition of a new input object for the details of the finite difference solution. This is shown starting in the next paragraph.
+
+\subsection{ZoneEarthtube}\label{zoneearthtube-earth-tube}
+
+An earth tube is a long, underground metal or plastic pipe through which air is drawn. During cooling season, as air travels through the pipe, it gives up some of its heat to the surrounding soil and enters the room as cooler air. Similarly, during heating season, as air travels through the pipe, it receives some of its heat from the soil and enters the zone as warmer air. Simple earth tubes in EnergyPlus can be controlled by a schedule and through the specification of minimum, maximum, and delta temperatures as described below. As with infiltration and ventilation, the actual flow rate of air through the earth tube can be modified by the temperature difference between the inside and outside environment and the wind speed. The basic equation used to calculate air flow rate of earth tube in EnergyPlus is:
+
+\begin{equation}
+EarthTubeFlowRate = \left( {{E_{design}}} \right)\left( {{F_{schedule}}} \right)\left[ {A + B\left| {{T_{zone}} - {T_{odb}}} \right| + C\left( {WindSpeed} \right) + D\left( {WindSpee{d^2}} \right)} \right]
+\end{equation}
+
+For the simulation of the earth tube, a weather data file is required and, therefore, the earth tube cannot run without weather data file. The required input fields to simulate the earth tube include the average soil surface temperature, the amplitude of soil surface temperature, and the phase constant of soil surface temperature. These fields should be calculated in advance by using a separate stand-alone program (CalcSoilSurfTemp) and should be input into earth tube.
+
+\subsubsection{CalcSoilSurfTemp -- Auxiliary Programs Document}\label{calcsoilsurftemp-auxiliary-programs-document}
+
+The CalcSoilSurfTemp program is simple and requires only two input fields: soil condition and soil surface condition in addition to a valid weather file. For soil condition, the user should select the number corresponding to the actual condition of the soil surrounding the earth tube from the four following options: 1. HEAVY AND SATURATED, 2. HEAVY AND DAMP, 3. HEAVY AND DRY and 4. LIGHT AND DRY. This determines the thermal diffusivity and thermal conductivity of the surrounding soil. For soil surface conditions, the user should select the number corresponding to the actual condition of the ground surface above the earth tube from the eight following options: 1. BARE AND WET, 2. BARE AND MOIST, 3. BARE AND ARID, 4. BARE AND DRY, 5. COVERED AND WET, 6. COVERED AND MOIST, 7. COVERED AND ARID and 8. COVERED AND DRY. This determines the absorption coefficient and the fraction of evaporation rate of the ground surface.
+
+
+## Input Description ##
+
+\subsubsection{Inputs}
+From this information and an analysis of the weather for the location selected, the CalcSoilSurfTemp program (ref. Auxiliary Programs document) calculates the three parameters listed above. The user must then add these parameters as input into EnergyPlus. The full input description of an earth tube (EARTHTUBE object) in EnergyPlus is given below.
+
+\paragraph{Field: Zone Name}\label{field-zone-name-5}
+
+This field is the name of the zone (ref: Zone) and attaches a particular earth tube statement to a thermal zone in the building.
+
+\paragraph{Field: Schedule Name}\label{field-schedule-name-6}
+
+This field is the name of the schedule (ref: Schedule) that modifies the maximum design volume flow rate parameter (see next field). This fraction between 0.0 and 1.0 is noted as F\(_{schedule}\) in the above equation.
+
+\paragraph{Field: Design Flow Rate}\label{field-design-flow-rate-4}
+
+This number (noted as E\(_{design}\) in the above equation) is the maximum amount of air mass flow rate of the earth tube expected at design conditions. The flow rate is expressed in units of m\(^{3}\)/s. The design value is modified by the schedule fraction (see previous field) and user specified coefficients (see last four fields).
+
+\paragraph{Field: Minimum Zone Temperature when Cooling}\label{field-minimum-zone-temperature-when-cooling}
+
+This is the indoor temperature (in Celsius) below which the earth tube is shut off. This lower temperature limit is intended to avoid overcooling a space and thus result in a heating load. For example, if the user specifies a minimum temperature of 20$^\circ$C, earth tube is assumed to be available if the zone air temperature is above 20$^\circ$C. If the zone air temperature drops below 20$^\circ$C, then earth tube is automatically turned off.
+
+\paragraph{Field: Maximum Zone Temperature when Heating}\label{field-maximum-zone-temperature-when-heating}
+
+This is the indoor temperature (in Celsius) above which the earth tube is shut off. This higher temperature limit is intended to avoid overheating a space and thus result in a cooling load. For example, if the user specifies a maximum temperature of 20$^\circ$C, earth tube is assumed to be available if the zone air temperature is below 20$^\circ$C. If the zone air temperature rises above 20$^\circ$C, then earth tube is automatically turned off.
+
+\paragraph{Field: Delta Temperature}\label{field-delta-temperature-4}
+
+This is the temperature difference (in Celsius) between the indoor and outdoor air dry-bulb temperatures below which the earth tube is shut off. This is to allow the earth tube to be stopped either if the temperature outside is too warm and could potentially heat the space or if the temperature outside is too cold and could potentially cool the space. For example, if the user specifies a delta temperature of 2$^\circ$C, earth tube is assumed to be available if the temperature difference between indoor and outdoor temperature is at least 2$^\circ$C. If the outside air dry-bulb temperature is less than 2$^\circ$C cooler or warmer than the indoor dry-bulb temperature, then the earth tube is automatically turned off.
+
+\paragraph{Field: Earthtube Type}\label{field-earthtube-type}
+
+This alpha character string defines the type of earth tube as one of the following options: \emph{Natural}, \emph{Exhaust}, or \emph{Intake}. A \emph{Natural} earth tube is assumed to be air movement/exchange that will not consume any fan energy or is the result of natural air flow through the tube and into the building. Values for fan pressure and efficiency for a natural flow earth tube are ignored. For either \emph{Exhaust} or \emph{Intake} earth tubes, values for fan pressure and efficiency define the fan electric consumption. For \emph{Natural} and \emph{Exhaust} earth tubes, the conditions of the air entering the space are assumed to be equivalent to the air which is cooled or heated by passing along the pipe. For \emph{Intake} earth tubes, an appropriate amount of fan heat is added to the air stream.
+
+\paragraph{Field: Fan Pressure Rise}\label{field-fan-pressure-rise-1}
+
+This is the pressure rise experienced across the fan in Pascals (N/m\(^{2}\)). This is a function of the fan and plays a role in determining the amount of energy consumed by the fan.
+
+\paragraph{Field: Fan Total Efficiency}\label{field-fan-total-efficiency-1}
+
+This is the total fan efficiency (a decimal number between 0.0 and 1.0). This is a function of the fan and plays a role in determining the amount of energy consumed by the fan.
+
+\paragraph{Field: Pipe Radius}\label{field-pipe-radius}
+
+This is the radius of the earth tube/pipe (in meters). This plays a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe. If the pipe has non-circular cross section, user can use the concept of hydraulic diameter as follows.
+
+\begin{equation}
+D = 4 \times Area/Perimeter
+\end{equation}
+
+However, since this field requires the pipe radius, hydraulic diameter should be divided by two.
+
+\paragraph{Field: Pipe Thickness}\label{field-pipe-thickness}
+
+This is the thickness of the pipe wall (in meters). This plays a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe.
+
+\paragraph{Field: Pipe Length}\label{field-pipe-length}
+
+This is the total length of the pipe (in meters). This plays a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe. As the length of the pipe becomes longer, the amount of the heat transfer becomes larger.
+
+\paragraph{Field: Pipe Thermal Conductivity}\label{field-pipe-thermal-conductivity}
+
+This is the thermal conductivity of the pipe (in W/m-C). This plays a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe.
+
+\paragraph{Field: Pipe Depth Under Ground Surface}\label{field-pipe-depth-under-ground-surface}
+
+This is the depth of the pipe under the ground surface (in meters). This plays a role in determining the temperature of the soil surrounding the pipe.
+
+\paragraph{Field: Soil Condition}\label{field-soil-condition}
+
+This alpha character string defines the actual condition of the soil surrounding the earth tube and can be one of any of the following options: HeavyAndSaturated, HeavyAndDamp, HeavyAndDry or LightAndDry. This determines the thermal diffusivity and thermal conductivity of the surrounding soil, which play a role in determining the amount of heat transferred from the surrounding soil to the air passing along the pipe.
+
+\paragraph{Field: Average Soil Surface Temperature}\label{field-average-soil-surface-temperature}
+
+This is the annual average soil surface temperature straight above the earth tube, which plays a role in determining the temperature of the soil surrounding the pipe. This field should be calculated in advance using the separate CalcSoilSurfTemp program.
+
+\paragraph{Field: Amplitude of Soil Surface Temperature}\label{field-amplitude-of-soil-surface-temperature}
+
+This is the amplitude of soil surface temperature above the earth tube, which plays a role in determining the temperature of the soil surrounding the pipe. This is the difference between the maximum and minimum soil surface temperature for the whole year divided by two. This field should be calculated in advance using the separate CalcSoilSurfTemp program.
+
+\paragraph{Field: Phase Constant of Soil Surface Temperature}\label{field-phase-constant-of-soil-surface-temperature}
+
+This is the phase constant of the soil surface temperature straight above the earth tube, which play a role in determining the temperature of the soil surrounding the pipe at particular time. This is the time elapsed from the beginning of the year until the soil surface temperature reaches the minimum value of the year. This field should be calculated in advance using the separate CalcSoilSurfTemp program.
+
+\paragraph{Field: Constant Term Flow Coefficient}\label{field-constant-term-flow-coefficient}
+
+This number is the ``A'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter, however, is a constant under all conditions and is not modified by any environmental effect. As a result, it is dimensionless.
+
+\paragraph{Field: Temperature Term Flow Coefficient}\label{field-temperature-term-flow-coefficient}
+
+This number is the ``B'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter is modified by the temperature difference between the outdoor and indoor air dry-bulb temperatures. The units for this parameter are inverse Celsius.
+
+\paragraph{Field: Velocity Term Flow Coefficient}\label{field-velocity-term-flow-coefficient}
+
+This number is the ``C'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter is modified by the speed of wind being experienced outside the building. The units for this parameter are s/m.
+
+\paragraph{Field: Velocity Squared Term Flow Coefficient}\label{field-velocity-squared-term-flow-coefficient}
+
+This number is the ``D'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter is modified by square of the speed of wind being experienced outside the building. The units for this parameter are s\(^{2}\)/m\(^{2}\).
+
+\paragraph{Field: Earth Tube Model Type}\label{field-earth-tube-model-type}
+
+This field determines which modeling technique will be used to assess the performance of the earth tube. The options are: Simple and Vertical. In the Simple modeling approach, the temperature of the soil at the earth tube is approximated by the undisturbed ground conditions. In the Vertical modeling approach, the temperature of the soil around the earth tube is modeled using a finite difference scheme to account for the impact of the earth tube on the surrounding soil conditions in a single direction (1-D). For more information on the model type, reference the Earth Tube section of the EnergyPlus Engineering Reference. This input is optional, and the default value is Simple.
+
+\paragraph{Field: Earth Tube Model Parameters}\label{field-earth-tube-model-parameters}
+
+This field refers to separate input syntax (see below) that is used for controlling parameters for the 1-D (Vertical) solution technique. This input field is ignored for the Simple model.
+
+\paragraph{EarthTube:Parameters}\label{field-earth-tube-parameters}
+For the 1-D (Vertical) model, some additional optional parameters are available for the user to potentially control the solution space (number of nodes, distances) for the finite difference solution. These are described below.
+
+\paragraph{Field: Earth Tube Parameters Name}\label{field-earth-tube-parameters-name}
+This name is used as a reference in the main EarthTube input syntax. It is used to identify the parameters that the user desires to use to control what is being modeled and how detailed the model is.
+
+\paragraph{Field: Earth Tube Nodes Above}\label{field-earth-tube-nodes-above}
+This parameter sets the number of nodes above the earth tube, between the earth tube and the ground surface. It has a minimum of three nodes and a maximum of ten nodes. These limits were chosen to avoid the extremes of excessive execution times and overly simplified results. The default value for this parameter is 5 (nodes).
+
+\paragraph{Field: Earth Tube Nodes Below}\label{field-earth-tube-nodes-below}
+This parameter sets the number of nodes below the earth tube, between the earth tube and the deep ground boundary. It has a minimum of three nodes and a maximum of ten nodes. These limits were chosen to avoid the extremes of excessive execution times and overly simplified results. The default value for this parameter is 3 (nodes) or the minimum.
+
+\paragraph{Field: Earth Tube Dimensionless Boundary Above}\label{field-earth-tube-dimensionless-boundary-above}
+This parameter sets the dimensionless distance above the earth tube for the solution space. The maximum value is 1.0, and the minimum value is 0.25. When this parameter is set to 1.0, the upper boundary is set to be half of the diameter below the ground surface and the solution space thickness above the earth tube is the depth of the earth tube minus the earth tube diameter. This maximum distance (earth tube depth minus diameter) is multiplied by this parameter to constrain the solution space to less than the maximum (when the parameter is less than 1.0). The default value for this parameter is 1.0 (the maximum value).
+
+\paragraph{Field: Earth Tube Dimensionless Boundary Below}\label{field-earth-tube-dimensionless-boundary-below}
+This parameter sets the dimensionless distance below the earth tube for the solution space. The maximum value is 1.0, and the minimum value is 0.25. This parameter is interpretted in a similar fashion as the previous parameter where the depth of the solution space below the earth tube is determined by the maximum distance above the earth tube (earth tube depth minus diameter). This allows the user to have different thickness for the modeled portion of the ground above and below the earth tube. The default value for this parameter is 0.25 (the minimum value).
+
+\paragraph{Field: Earth Tube Dimensionless Solution Space Width}\label{field-earth-tube-dimensionless-solution-space-width}
+This parameter sets the dimensionless width of the solution space horizontally as a function of the earth tube radius as defined in the main earth tube input syntax. The maximum value is 20.0, and the minimum value is 3.0. The default value for this parameter is 4.0 which means that the width of the solution space is four times the radius. In other words, this would include soil one radius length beyond the edges of the tube on either side of the earth tube.
+
+An IDF example:
+
+\begin{lstlisting}
+
+EARTHTUBE,
+ Zone 2, !- Zone Name
+ 1D Modeled Tube, !- Schedule Name
+ 3.425198, !- Design Volume Flow Rate
+ 10.0, !- Minimum Zone Temperature when Cooling
+ 30.0, !- Maximum Zone Temperature when Heating
+ 1.0, !- Delta Temperature
+ NATURAL, !- EarthTube Type
+ 350.0, !- Fan Pressure Rise
+ 0.9, !- Fan Total Efficiency
+ 0.25, !- Pipe Radius
+ 0.2, !- Pipe Thickness
+ 15.0, !- Pipe Length
+ 200.0, !- Pipe Thermal Conductivity
+ 3.5, !- Pipe Depth Under Ground Surface
+ HeavyAndDamp, !- Soil Condition
+ 15.0, !- Average Soil Surface Temperature
+ 5.6, !- Amplitude of Soil Surface Temperature
+ 0.0, !- Phase Constant of Soil Surface Temperature
+ 0.6060000 , !- Constant Term Flow Coef
+ 2.0199999E-02, !- Temp Term Flow Coef
+ 5.9800001E-04, !- Velocity Term Flow Coef
+ 0.0000000E+00, !- Velocity**2 Term Flow Coef
+ Vertical, !- Earth Tube Model Type
+ EarthTubeParams; !- Earth Tube Model Parameters
+
+EarthTube:Parameters,
+ EarthTubeParams, !- Earth Tube Model Parameters (Name)
+ 5, !- Earth Tube Nodes Above
+ 3, !- Earth Tube Nodes Below
+ 1.0, !- Earth Tube Dimensionless Boundary Above
+ 0.5, !- Earth Tube Dimensionless Boundary Below
+ 4.0; !- Earth Tube Dimensionless Solution Space Width
+
+\end{lstlisting}
+
+## Outputs Description ##
+
+\subsubsection{Outputs}\label{zoneearthtube-outputs}
+
+Current Earth Tube output variables:
+
+\begin{itemize}
+\item
+ HVAC,Sum,Earth Tube Zone Sensible Cooling Energy {[}J{]}
+\item
+ HVAC,Average,Earth Tube Zone Sensible Cooling Rate {[}W{]}
+\item
+ HVAC,Sum,Earth Tube Zone Sensible Heating Energy {[}J{]}
+\item
+ HVAC,Average,Earth Tube Zone Sensible Heating Rate {[}W{]}
+\item
+ HVAC,Sum,Earth Tube Air Flow Volume {[}m3{]}
+\item
+ HVAC,Average,Earth Tube Current Density Volume Flow Rate {[}m3/s{]}
+\item
+ HVAC,Average,Earth Tube Standard Density Volume Flow Rate {[}m3/s{]}
+\item
+ HVAC,Sum,Earth Tube Air Flow Mass {[}kg{]}
+\item
+ HVAC,Average,Earth Tube Air Mass Flow Rate {[}kg/s{]}
+\item
+ HVAC,Average,Earth Tube Water Mass Flow Rate {[}kg/s{]}
+\item
+ HVAC,Sum,Earth Tube Fan Electricity Energy {[}J{]}
+\item
+ HVAC,Average,Earth Tube Fan Electricity Rate {[}W{]}
+\item
+ HVAC,Average,Earth Tube Zone Inlet Air Temperature {[}C{]}
+\item
+ HVAC,Average,Earth Tube Ground Interface Temperature {[}C{]}
+\item
+ HVAC,Average,Earth Tube Outdoor Air Heat Transfer Rate {[}W{]}
+\item
+ HVAC,Average,Earth Tube Inlet Wet Bulb Temperature {[}C{]}
+\item
+ HVAC,Average,Earth Tube Inlet Humidity Ratio {[}kgWater/kgDryAir{]}
+\item
+ HVAC,Average,Earth Tube Node Temperatures {[}C{]}
+\item
+ HVAC,Average,Earth Tube Undisturbed Ground Temperatures {[}C{]}
+\end{itemize}
+
+\paragraph{Earth Tube Zone Sensible Cooling Energy {[}J{]}}\label{earth-tube-zone-sensible-cooling-energy-j}
+
+\paragraph{Earth Tube Zone Sensible Cooling Rate {[}W{]}}\label{earth-tube-zone-sensible-cooling-rate-w}
+
+These are the energy and rate associated with the zone cooling provided by the air from the earth tube.~ This occurs when the earth tube outlet air temperature is less than zone air temperature.
+
+\paragraph{Earth Tube Zone Sensible Heating Energy {[}J{]}}\label{earth-tube-zone-sensible-heating-energy-j}
+
+\paragraph{Earth Tube Zone Sensible Heating Rate {[}W{]}}\label{earth-tube-zone-sensible-heating-rate-w}
+
+These are the energy and rate associated with the zone heating provided by the air from the earth tube.~ This occurs when the earth tube outlet air temperature is greater than the zone air temperature.
+
+\paragraph{Earth Tube Air Flow Volume {[}m3{]}}\label{earth-tube-air-flow-volume-m3}
+
+The volume flow of air through the earth tube.
+
+\paragraph{Earth Tube Current Density Volume Flow Rate {[}m3/s{]}}\label{earth-tube-air-current-density-volumetric-flow-rate-m3s}
+
+The volume flow rate of air through the earth tube evaluating density at current zone conditions.
+
+\paragraph{Earth Tube Standard Density Volume Flow Rate {[}m3/s{]}}\label{earth-tube-air-standard-density-volumetric-flow-rate-m3s}
+
+The volume flow rate of air through the earth tube evaluating density at standard conditions.
+
+\paragraph{Earth Tube Air Flow Mass {[}kg{]}}\label{earth-tube-air-flow-mass-kg}
+
+The mass flow of air through the earth tube.
+
+\paragraph{Earth Tube Air Mass Flow Rate {[}kg/s{]}}\label{earth-tube-air-mass-flow-rate-kgs}
+
+The mass flow rate of air through the earth tube.
+
+\paragraph{Earth Tube Water Mass Flow Rate {[}kg/s{]}}\label{earth-tube-water-mass-flow-rate-kgs}
+
+The mass flow rate of water vapor at the exit of the earth tube.
+
+\paragraph{Earth Tube Fan Electricity Energy {[}J{]}}\label{earth-tube-fan-electric-energy-j}
+
+\paragraph{Earth Tube Fan Electricity Rate {[}W{]}}\label{earth-tube-fan-electric-power-w}
+
+These are the fan electricity consumption and power for intake or exhaust earth tube types.
+
+\paragraph{Earth Tube Zone Inlet Air Temperature {[}C{]}}\label{earth-tube-zone-inlet-air-temperature-c}
+
+This is the temperature of the air entering the zone after passing through the earth tube {[}C{]}.~ This temperature includes the cooling or heating of outdoor air as it passes along the pipe. ~When intake fan assist is used, then the additional heat due to the fan is included in the inlet air temperature.
+
+\paragraph{Earth Tube Ground Interface Temperature {[}C{]}}\label{earth-tube-ground-interface-temperature-c}
+
+This is the average temperature of the ground along the outer surface of the earth tube {[}C{]}.
+
+\paragraph{Earth Tube Outdoor Air Heat Transfer Rate {[}W{]}}\label{earth-tube-outdoor-air-heat-transfer-rate-w}
+
+This is the rate of heat transfer from the earth tube to the outdoor air {[}W{]}.~ Positive values indicate the rate at which outdoor air is preheated; negative values indicate the rate of precooling.
+
+\paragraph{Earth Tube Zone Inlet Wet Bulb Temperature {[}C{]}}\label{earth-tube-zone-inlet-wet-bulb-temperature-c}
+
+This is the wet bulb temperature of the air entering the zone after passing through the earth tube {[}C{]}.
+
+\paragraph{Earth Tube Zone Inlet Humidity Ratio {[}kgWater/krDryAir{]}}\label{earth-tube-zone-inlet-humidity-ratio-kgWater/kgDryAir}
+
+This is the humidity ratio of the air entering the zone after passing through the earth tube {[}kgWater/kgDryAir{]}.
+
+\paragraph{Earth Tube Node Temperatures {[}C{]}}\label{earth-tube-node-temperatures}
+
+This will generate the internal node temperatures {[}C{]} for the earth tube as a result of the 1-D finite difference model. This is only valid for the 1-D (Vertical) model.
+
+\paragraph{Earth Tube Undisturbed Ground Temperatures {[}C{]}}\label{earth-tube-node-temperatures}
+
+This will report the theoretical undisturbed ground temperature at the location of the internal node temperatures {[}C{]} as well as the average for the location of the earth tube for the 1-D finite difference model. This is only valid for the 1-D (Vertical) model and provides a comparison of conditions for the simple model and the 1-D (Vertical) model.
+
+## Engineering Reference ##
+
+Note: The existing engineering reference section on earth tubes will be kept with some editing to account for the fact that there will be two potential models that can be used for the earth tube. Much of the existing text and description can stay since it will apply to both models. A new sections will be added to specifically describe the 1-D (Vertical) earth tube modeling technique. This section will outline the assumptions and boundary conditions of the 1-D model and refer back to the existing description and equations to show what the two models have in common. As this documentation will be specific to how the new model solves for earth tube temperature, this new section of documentation will be written once the approach outlined above has gained the approval of the development team.
+
+## Example File and Transition Changes ##
+
+There is already an existing EarthTubeSimpleTest.idf file that is used to test the earth tube as presented in the current version of EnergyPlus. This file will be duplicated, renamed to EarthTubeVerticalTest.idf, and modified to test the 1-D (Vertical) earth tube model being added for this enhancement.
+
+Due to the fact that the two new fields in the EarthTube input are at the end of the current description and are both optional, no transition changes will be needed. Existing files will continue to run without problem and will default to the simple solution method. In addition, the new input syntax EarthTube:Parameters is also optional and only needed for the 1-D (Vertical) model. Thus, current user files will not need this new input to continue to run their earth tube models.
+
+## References ##
+
+Existing EnergyPlus Earth Tube Model, EnergyPlus Engineering Reference, EnergyPlus Input-Output Reference.
+
+Liu, X., M. Xu, J. Guo, and R. Zhu. 2019. “Conceptual Development of the Earth Tube Cooling System For a Tall Building,” Journal of Green Building (2019) 14 (2): 1–28.
+
+
+
diff --git a/design/FY2023/earth_tube_solution_space_diagram.png b/design/FY2023/earth_tube_solution_space_diagram.png
new file mode 100644
index 00000000000..bc8e26b5093
Binary files /dev/null and b/design/FY2023/earth_tube_solution_space_diagram.png differ
diff --git a/doc/engineering-reference/media/earth_tube_solution_space_diagram.png b/doc/engineering-reference/media/earth_tube_solution_space_diagram.png
new file mode 100644
index 00000000000..bc8e26b5093
Binary files /dev/null and b/doc/engineering-reference/media/earth_tube_solution_space_diagram.png differ
diff --git a/doc/engineering-reference/src/alternative-modeling-processes/airflownetwork-model.tex b/doc/engineering-reference/src/alternative-modeling-processes/airflownetwork-model.tex
index d394b617662..e3a50d0bee3 100644
--- a/doc/engineering-reference/src/alternative-modeling-processes/airflownetwork-model.tex
+++ b/doc/engineering-reference/src/alternative-modeling-processes/airflownetwork-model.tex
@@ -1462,7 +1462,7 @@ \subsection{Duct Sizing}\label{duct-sizingl}
There are two methods used to size duct diameter and cross section area by assuming round ducts. Each method is presented below.
-1. Maxiumum velocity
+1. Maximum velocity
The cross section area (A) is calculated below
@@ -1520,7 +1520,7 @@ \subsection{Duct Sizing}\label{duct-sizingl}
When entry and exit velocities and elevations are the same, the total pressure difference is equal to the static pressure difference. The assumption will be used for duct sizing.
-The total pressure loss in either a truck or a branch can be calculated using Darcy-Weisbach Equation (Eq. 34 in Chpater 21, 2017 ASHRAE HOF)
+The total pressure loss in either a truck or a branch can be calculated using Darcy-Weisbach Equation (Eq. 34 in Chapter 21, 2017 ASHRAE HOF)
\begin{equation}
\Delta P = \big( \frac{ f L}{D} + \Sigma C ) * \frac{ \rho V^{2} }{2}
@@ -1569,7 +1569,7 @@ \subsection{Duct Sizing}\label{duct-sizingl}
A = \frac{D^2 * \pi}{4}
\end{equation}
-When ΔP given, and the relationship between D and V is also given, there is only a single unknow D. The value can be obtained through iteration.
+When ΔP given, and the relationship between D and V is also given, there is only a single unknown D. The value can be obtained through iteration.
\subsection{References}\label{afn-references}
diff --git a/doc/engineering-reference/src/alternative-modeling-processes/hybrid-model.tex b/doc/engineering-reference/src/alternative-modeling-processes/hybrid-model.tex
index 296d0ac00c8..f7b78e70650 100644
--- a/doc/engineering-reference/src/alternative-modeling-processes/hybrid-model.tex
+++ b/doc/engineering-reference/src/alternative-modeling-processes/hybrid-model.tex
@@ -2,11 +2,11 @@ \section{Hybrid Model}\label{hybrid-model}
\subsection{Overview}
-The hybrid modeling integrates physics-based and data-driven modeling methods which combines forward and inverse physics-based modeling taking advantage of easily measurable zone air temperature, humidity ratio, or CO$_2$ concentration data to solve hard-to-measure zone parameters including internal thermal mass, air infiltration rate, or zone people count. It aims to enhance the current energy retrofit practices not only offering more user-friendly energy modeling environments but also providing more accurate estimates of energy savings at the same time. Parameters such as interior thermal mass, air infiltration rates, and people count are required in physics-based models, and they have significant impacts as they are driving factors for the dynamic performance of buildings. An accurate estimate of interior thermal mass has been a difficult problem because the building usually has various amounts of furniture and changeable partitions. The air infiltration rate changes in time and dynamically interacts with indoor and outdoor climatic conditions. However the accurate estimation of the data is almost impossible to collect without a fan pressurized test, which can not be easily done by typical energy modelers (Gowri et al. 2009). The high uncertainty of occupants’ presence and behavior have significant impacts on building energy modeling (Clevenger \& Haymaker, 2001). However, people count is usually hard to measure in reality, which result in simplification of occupancy schedule assumptions in energy modeling. The hybrid model introduces an approach estimate the zone level interior thermal masss, air infiltration rate, and people count with measured zone air parameters in EnergyPlus.
+The hybrid modeling integrates physics-based and data-driven modeling methods which combines forward and inverse physics-based modeling taking advantage of easily measurable zone air temperature, humidity ratio, or CO$_2$ concentration data to solve hard-to-measure zone parameters including internal thermal mass, air infiltration rate, or zone people count. It aims to enhance the current energy retrofit practices not only offering more user-friendly energy modeling environments but also providing more accurate estimates of energy savings at the same time. Parameters such as interior thermal mass, air infiltration rates, and people count are required in physics-based models, and they have significant impacts as they are driving factors for the dynamic performance of buildings. An accurate estimate of interior thermal mass has been a difficult problem because the building usually has various amounts of furniture and changeable partitions. The air infiltration rate changes in time and dynamically interacts with indoor and outdoor climatic conditions. However the accurate estimation of the data is almost impossible to collect without a fan pressurized test, which can not be easily done by typical energy modelers (Gowri et al. 2009). The high uncertainty of occupants’ presence and behavior have significant impacts on building energy modeling (Clevenger \& Haymaker, 2001). However, people count is usually hard to measure in reality, which result in simplification of occupancy schedule assumptions in energy modeling. The hybrid model introduces an approach estimate the zone level interior thermal mass, air infiltration rate, and people count with measured zone air parameters in EnergyPlus.
Solving building energy and environmental problems inversely using measured data gets more attention as more data are easily and freely available. (Yinping Zhang et al. 2015). Measurements are to supplement to reduce discrepancies or to identify model parameters, nevertheless the majority of efforts go into the derivation of the dynamic inverse modeling. Inverse modeling is a discipline that applies mathematical techniques to combine measurements and models. Inverse modeling can provide solutions when direct measurements of model parameters are not widely available, rendering the use of numerical techniques. Temperature, humidity, and CO$_2$ concentration data are easily available nowadays and are used for controls of indoor environments due to a wider use of low-cost thermostats with data loggers, which bring opportunities to inversely solve other hard-to-measure parameters.
-The new hybrid modeling approach uses the inverse modeling method to improve the accuracy of the building energy simulation for existing buildings, which adds measured data to solve uncertain model parameters. The hybrid modeling approach builds upon the virtue of the physics-based model taking advantage of measured data. The approach uses measured zone air temperature, humidity ratio, or CO$_2$ concentration to solve highly uncertain parameters such as internal thermal mass, infiltration airflow rate, and people count with the reformulated zone heat, moisture, or CO$_2$ balance equations. Figure~\ref{fig:hybrid-model-solution-diagram} shows the relationship among the measurements and unkonwn parameters.
+The new hybrid modeling approach uses the inverse modeling method to improve the accuracy of the building energy simulation for existing buildings, which adds measured data to solve uncertain model parameters. The hybrid modeling approach builds upon the virtue of the physics-based model taking advantage of measured data. The approach uses measured zone air temperature, humidity ratio, or CO$_2$ concentration to solve highly uncertain parameters such as internal thermal mass, infiltration airflow rate, and people count with the reformulated zone heat, moisture, or CO$_2$ balance equations. Figure~\ref{fig:hybrid-model-solution-diagram} shows the relationship among the measurements and unknown parameters.
\begin{figure}[h]
\begin{center}
diff --git a/doc/engineering-reference/src/alternative-modeling-processes/room-air-models.tex b/doc/engineering-reference/src/alternative-modeling-processes/room-air-models.tex
index 7dd8bde537f..1e7fb0d87d2 100644
--- a/doc/engineering-reference/src/alternative-modeling-processes/room-air-models.tex
+++ b/doc/engineering-reference/src/alternative-modeling-processes/room-air-models.tex
@@ -72,7 +72,7 @@ \section{RoomAir Models}\label{roomair-models}
\subsection{User Defined RoomAir Temperatures}\label{user-defined-roomair-temperatures}
-The input object RoomAir:TemperaturePattern:UserDefined provides a capabity for users to define the sort of air temperature pattern he or she expects in the zone. With these models, the pattern is generally set beforehand and does not respond to conditions that evolve during the simulation.~ (Exception: the pattern available through the RoomAir:TemperaturePattern:TwoGradient object will switch between two different pre-defined vertical gradients depending on the current value of certain temperatures or thermal loads. )
+The input object RoomAir:TemperaturePattern:UserDefined provides a capability for users to define the sort of air temperature pattern he or she expects in the zone. With these models, the pattern is generally set beforehand and does not respond to conditions that evolve during the simulation.~ (Exception: the pattern available through the RoomAir:TemperaturePattern:TwoGradient object will switch between two different pre-defined vertical gradients depending on the current value of certain temperatures or thermal loads. )
The user-defined patterns obtain the mean air temperature, \({T_{MAT}}\), from the heat balance domain and then produce modified values for:
diff --git a/doc/engineering-reference/src/building-system-simulation-system-manager/plant-condenser-loops.tex b/doc/engineering-reference/src/building-system-simulation-system-manager/plant-condenser-loops.tex
index 0fbc5a7731f..9ff91c8280b 100644
--- a/doc/engineering-reference/src/building-system-simulation-system-manager/plant-condenser-loops.tex
+++ b/doc/engineering-reference/src/building-system-simulation-system-manager/plant-condenser-loops.tex
@@ -6,7 +6,7 @@ \subsection{Integration of System and Plant}\label{integration-of-system-and-pla
\subsection{Current Primary System Modeling Methodology}\label{current-primary-system-modeling-methodology}
-There are two main types of loops within the HVAC simulation in EnergyPlus: an air loop and a plant loop. The air loop is assumed to use air as the transport medium as part of an air handling system while the plant loops use a liquid fluid of the user's choosing (typically water).~ Condenser loops are a special case of plant loop that are for heat rejection and are distinguished by slightily different control options and applicable equipment types.~ A user may have any number of each type of loop in a particular input file. There are no explicit limits on the number of loops within the program---the user is only limited by computer hardware. Execution speed will naturally vary with the complexity of the input file.
+There are two main types of loops within the HVAC simulation in EnergyPlus: an air loop and a plant loop. The air loop is assumed to use air as the transport medium as part of an air handling system while the plant loops use a liquid fluid of the user's choosing (typically water).~ Condenser loops are a special case of plant loop that are for heat rejection and are distinguished by slightly different control options and applicable equipment types.~ A user may have any number of each type of loop in a particular input file. There are no explicit limits on the number of loops within the program---the user is only limited by computer hardware. Execution speed will naturally vary with the complexity of the input file.
Plant loops are further divided into ``half-loops'' or ``semi-loops'' for organizational clarity and simulation logistics (see Figure ``Connections between the Main HVAC Simulation Loops and Half-Loops''). These sub-loops, or half-loop sides, are matched pairs that consist of half of a main plant loop. Plant loops are broken into supply and demand sides. The plant demand side half-loop contains equipment that places a load on the primary equipment. This might include coils, baseboards, radiant systems, etc. The load is met by primary equipment such as chillers or boilers on the supply side half-loop. Each supply side half-loop must be connected to a demand side half-loop and vice versa. A similar breakdown is present on condenser loops where the demand side includes the water side of chiller's condensers while the supply side includes condenser equipment such as cooling towers.
@@ -16,7 +16,7 @@ \subsection{Current Primary System Modeling Methodology}\label{current-primary-s
\caption{Connections between the Main HVAC Simulation Loops and Half-Loops. \protect \label{fig:connections-between-the-main-hvac-simulation}}
\end{figure}
-The breakdown into two half-loops allows for better handling and control of information and simulation flow throughout the program. Direct connections between the half-loops of the air, plant, and condenser loops are enhanced by components with connections between the various main loop types. For example, coils (heating or cooling) are in reality heat exchangers with an air and a water or refrigerant side. The air side of the coil is handled within the air loop where the control of the device is also maintained. The fluid side of the coil is handled within the plant demand side, which passes the energy requirements of the coil on to the plant supply side. All loops are simulated together by successively modeling each half-loop in a particulary calling order. Overall iterations ensure that the results for the current time step are balanced and updated information has been passed to both sides of the sub-loops as well as across to the other side of air loop connections such as coils.
+The breakdown into two half-loops allows for better handling and control of information and simulation flow throughout the program. Direct connections between the half-loops of the air, plant, and condenser loops are enhanced by components with connections between the various main loop types. For example, coils (heating or cooling) are in reality heat exchangers with an air and a water or refrigerant side. The air side of the coil is handled within the air loop where the control of the device is also maintained. The fluid side of the coil is handled within the plant demand side, which passes the energy requirements of the coil on to the plant supply side. All loops are simulated together by successively modeling each half-loop in a particular calling order. Overall iterations ensure that the results for the current time step are balanced and updated information has been passed to both sides of the sub-loops as well as across to the other side of air loop connections such as coils.
The plant equipment on a half-loop is described by a set of branches for that half-loop.~ Components can be arranged on a branch in series, and branches can be placed in parallel, with some restrictions. Figure ``Branch Layout for Individual Plant Half-Loops'' provides an overview of the intended branch layout for each plant half-loop. Branches are individual legs within the loop structure. Thus, the segment between point A and point B is defined as a branch, as is the section between points E and F. There may be multiple sections (C1 to D1 through Cn to Dn) in between the splitter and mixer.
@@ -38,7 +38,7 @@ \subsection{Plant Manager}\label{plant-manager}
\subsubsection{Plant Half-Loop Calling Order}\label{plant-half-loop-calling-order}
-Because there can be multiple plant loops in a model that depend on each other, one job of the plant manager is to determine an appropriate calling order for the half-loops.~ The intial starting calling order (and the order always used prior to EnergyPlus Version 7) is as follows:
+Because there can be multiple plant loops in a model that depend on each other, one job of the plant manager is to determine an appropriate calling order for the half-loops.~ The initial starting calling order (and the order always used prior to EnergyPlus Version 7) is as follows:
1.~~~~Call all the demand side half-loops of the plant loops (in input object order)
@@ -554,11 +554,11 @@ \subsection{Plant Operation Schemes}\label{plant-operation-schemes}
\subsubsection{Uncontrolled Loop Operation}\label{uncontrolled-loop-operation}
-The PlantEquipmentOperation:Uncontrolled scheme takes the full capacity of the supply equipment and cools or heats the loop accordingly. An example would be a cooling tower where the cooling tower would cool the condenser loop with all of its available capacity and not be limioted by a capacity range or setpoint. Uncontrolled loop operation simply specifies a group of equipment that runs `uncontrolled'. If the loop runs, this equipment will run also, unless turned off by the loop flow resolver to maintain continuity in the fluid loop.
+The PlantEquipmentOperation:Uncontrolled scheme takes the full capacity of the supply equipment and cools or heats the loop accordingly. An example would be a cooling tower where the cooling tower would cool the condenser loop with all of its available capacity and not be limited by a capacity range or setpoint. Uncontrolled loop operation simply specifies a group of equipment that runs `uncontrolled'. If the loop runs, this equipment will run also, unless turned off by the loop flow resolver to maintain continuity in the fluid loop.
\subsubsection{Cooling Load Range Based Operation or Heating Load Range Based Operation}\label{cooling-load-range-based-operation-or-heating-load-range-based-operation}
-PlantEquipmentOperation:CoolingLoad (or PlantEquipmentOperation:HeatingLoad) defines the different ranges and which equipment list is valid for each range. In each trio, there is a lower limit for the load range, an upper limit for the load range, and a name that links to an equipment availability list (PlantEquipmentList). Load range operation is used when the loop load is calculated and then the equipment is selected in the proper range. This allows for the most efficient operation of the plant equipment or for the user to determine the most efficient plant configuration. When the equipment list has been deteremined then the load is allocated to the equipment in a manner selected by the user with ``Optimal or Sequential'' load distribution scheme. The load range based operation scheme has two statements associated with it: a main statement that defines the ranges that individual priority settings are valid and the lists of equipment that may be used for each range.
+PlantEquipmentOperation:CoolingLoad (or PlantEquipmentOperation:HeatingLoad) defines the different ranges and which equipment list is valid for each range. In each trio, there is a lower limit for the load range, an upper limit for the load range, and a name that links to an equipment availability list (PlantEquipmentList). Load range operation is used when the loop load is calculated and then the equipment is selected in the proper range. This allows for the most efficient operation of the plant equipment or for the user to determine the most efficient plant configuration. When the equipment list has been determined then the load is allocated to the equipment in a manner selected by the user with ``Optimal or Sequential'' load distribution scheme. The load range based operation scheme has two statements associated with it: a main statement that defines the ranges that individual priority settings are valid and the lists of equipment that may be used for each range.
\subsubsection{Outdoor Drybulb Range Based Operation, Outdoor Wetbulb Range Based Operation, Outdoor RHPercent Range Based Operation}\label{outdoor-drybulb-range-based-operation-outdoor-wetbulb-range-based-operation-outdoor-rhpercent-range-based-operation}
@@ -566,15 +566,15 @@ \subsubsection{Outdoor Drybulb Range Based Operation, Outdoor Wetbulb Range Base
\subsection{Condenser Operation Schemes}\label{condenser-operation-schemes}
-This is very similar to the plant operation schemes, but there are several more options avaible with the CondenserLoop. The condenser operation schemes apply to the equipment on the `supply side' of the condenser loop---pumps, cooling towers, ground coupled heat exchangers, etc. The keywords select the algorithm that will be used to determine which equipment is available for each time step. The `\emph{Range Based Operation'} schemes select a user specified set of equipment for each user specified range of a particular simulation variable. `\emph{Load} \emph{Range} \emph{Based'} ~schemes compare the demand on the condenser supply side with specified load ranges and associated equipment lists. `\emph{Outdoor\ldots{}Range Based'} schemes compare the current value of an environmental parameter with user specified ranges of that parameter. See the Input Output Reference for input field details.
+This is very similar to the plant operation schemes, but there are several more options available with the CondenserLoop. The condenser operation schemes apply to the equipment on the `supply side' of the condenser loop---pumps, cooling towers, ground coupled heat exchangers, etc. The keywords select the algorithm that will be used to determine which equipment is available for each time step. The `\emph{Range Based Operation'} schemes select a user specified set of equipment for each user specified range of a particular simulation variable. `\emph{Load} \emph{Range} \emph{Based'} ~schemes compare the demand on the condenser supply side with specified load ranges and associated equipment lists. `\emph{Outdoor\ldots{}Range Based'} schemes compare the current value of an environmental parameter with user specified ranges of that parameter. See the Input Output Reference for input field details.
\subsubsection{Uncontrolled Loop Operation}\label{uncontrolled-loop-operation-1}
-The PlantEquipmentOperation:Uncontrolled scheme takes the full capacity of the supply equipment and cools or heats the loop accordingly. An example would be a cooling tower where the cooling tower would cool the condenser loop with all of its available capacity and not be limioted by a capacity range or setpoint. Uncontrolled loop operation simply specifies a group of equipment that runs `uncontrolled'. If the loop runs, this equipment will run also, unless turned off by the loop flow resolver to maintain continuity in the fluid loop.
+The PlantEquipmentOperation:Uncontrolled scheme takes the full capacity of the supply equipment and cools or heats the loop accordingly. An example would be a cooling tower where the cooling tower would cool the condenser loop with all of its available capacity and not be limited by a capacity range or setpoint. Uncontrolled loop operation simply specifies a group of equipment that runs `uncontrolled'. If the loop runs, this equipment will run also, unless turned off by the loop flow resolver to maintain continuity in the fluid loop.
\subsubsection{Cooling Load Range Based Operation or Heating Load Range Based Operation}\label{cooling-load-range-based-operation-or-heating-load-range-based-operation-1}
-PlantEquipmentOperation:CoolingLoad (or PlantEquipmentOperation:HeatingLoad) statement defines the different ranges and which equipment list is valid for each range. In each trio, there is a lower limit for the load range, an upper limit for the load range, and a name that links to an equipment availability list (CondenserEquipmentList). Load range operation is used when the loop load is calculated and then the equipment is selected in the proper range. This allows for the most efficient operation of the plant equipment or for the user to determine the most efficient plant configuration. When the equipment list has been deteremined then the load is allocated to the equipment in a manner selected by the user with ``Optimal or Sequential'' load distribution scheme. The load range based operation scheme has two statements associated with it: a main statement that defines the ranges that individual priority settings are valid and the lists of equipment that may be used for each range.
+PlantEquipmentOperation:CoolingLoad (or PlantEquipmentOperation:HeatingLoad) statement defines the different ranges and which equipment list is valid for each range. In each trio, there is a lower limit for the load range, an upper limit for the load range, and a name that links to an equipment availability list (CondenserEquipmentList). Load range operation is used when the loop load is calculated and then the equipment is selected in the proper range. This allows for the most efficient operation of the plant equipment or for the user to determine the most efficient plant configuration. When the equipment list has been determined then the load is allocated to the equipment in a manner selected by the user with ``Optimal or Sequential'' load distribution scheme. The load range based operation scheme has two statements associated with it: a main statement that defines the ranges that individual priority settings are valid and the lists of equipment that may be used for each range.
\subsubsection{Outdoor Drybulb Range Based Operation, Outdoor Wetbulb Range Based Operation, Outdoor RHPercent Range Based Operation}\label{outdoor-drybulb-range-based-operation-outdoor-wetbulb-range-based-operation-outdoor-rhpercent-range-based-operation-1}
diff --git a/doc/engineering-reference/src/building-system-simulation-system-manager/steam-systems-and-component-models.tex b/doc/engineering-reference/src/building-system-simulation-system-manager/steam-systems-and-component-models.tex
index a06559f989a..4f67afa0cf5 100644
--- a/doc/engineering-reference/src/building-system-simulation-system-manager/steam-systems-and-component-models.tex
+++ b/doc/engineering-reference/src/building-system-simulation-system-manager/steam-systems-and-component-models.tex
@@ -468,7 +468,7 @@ \subsection{Steam Pipe}\label{steam-pipe}
\subsubsection{Description of Model}\label{description-of-model-1}
-The steam pipe essentially serves as ``energy carrier'' and transfers the node conditions from one point of the pipe to another.~ It's simply a node inlet to node outlet connection, transferring values from inlet to outlet.~ The pipe forms an important part of the framework connecting various equipments from the supply to demand side and inlet and outlets of the equipments.
+The steam pipe essentially serves as ``energy carrier'' and transfers the node conditions from one point of the pipe to another.~ It's simply a node inlet to node outlet connection, transferring values from inlet to outlet.~ The pipe forms an important part of the framework connecting various equipment from the supply to demand side and inlet and outlets of the equipment.
The steam pipe supports two additional properties, which are pressure and quality, unlike its water counterpart.~ Pipe simulation model in EnergyPlus is hardwired to water as a fluid type; this necessitated the development of similar model supporting pressure and quality for the steam system.
diff --git a/doc/engineering-reference/src/building-system-simulation-system-manager/zone-equipment-simulation.tex b/doc/engineering-reference/src/building-system-simulation-system-manager/zone-equipment-simulation.tex
index 818ced83093..8982157d14b 100644
--- a/doc/engineering-reference/src/building-system-simulation-system-manager/zone-equipment-simulation.tex
+++ b/doc/engineering-reference/src/building-system-simulation-system-manager/zone-equipment-simulation.tex
@@ -163,7 +163,7 @@ \subsection{Simulation}\label{simulation-003}
\subsection{Zone Equipment Load Distribution}\label{zone-equipment-load-distribution}
-The function \emph{DistributeSystemOutputRequired} allocates the curent zone load among the available pieces of zone equipment for the current load type (cooling, heating, or no-load). Because some air loop components such as AirLoopHVAC:UnitarySystem may be controlled based on a control zone load, the sequenced loads must be known prior to the final iteration of the HVAC simulation so that the air loop equipment will adjust its output accordingly. When the zone equipment list is initially read, the maximum number of equipment across all zones is used to set the number of air loop iterations required after the initial iteration, \emph{MinAirLoopIterationsAfterFirst}. The control sequence is shown below.
+The function \emph{DistributeSystemOutputRequired} allocates the current zone load among the available pieces of zone equipment for the current load type (cooling, heating, or no-load). Because some air loop components such as AirLoopHVAC:UnitarySystem may be controlled based on a control zone load, the sequenced loads must be known prior to the final iteration of the HVAC simulation so that the air loop equipment will adjust its output accordingly. When the zone equipment list is initially read, the maximum number of equipment across all zones is used to set the number of air loop iterations required after the initial iteration, \emph{MinAirLoopIterationsAfterFirst}. The control sequence is shown below.
\begin{enumerate}
\item
Initial iteration (\emph{FirstHVACIteration} is true)
@@ -188,7 +188,7 @@ \subsection{Zone Equipment Load Distribution}\label{zone-equipment-load-distribu
\item
UniformLoad - The sequenced loads for all active equipment are set to the full load divided by the number of active pieces of equipment. All inactive sequenced loads are set to zero.
\item
- UniformPLR - Using the current equipment capacities (stored during the initial iteration), distribute the load among the availalbe pieces of equipment, such that each one is operating at the same part load ratio (PLR).
+ UniformPLR - Using the current equipment capacities (stored during the initial iteration), distribute the load among the available pieces of equipment, such that each one is operating at the same part load ratio (PLR).
\item
SequentialUniformPLR - Using the current equipment capacities (stored during the initial iteration), determine how many of the available pieces of equipment are required to meet the current full load. Then distribute the load among those pieces of equipment, such that each one is operating at the same part load ratio (PLR).
\end{itemize}
diff --git a/doc/engineering-reference/src/climate-sky-and-solar-shading-calculations/shading-module.tex b/doc/engineering-reference/src/climate-sky-and-solar-shading-calculations/shading-module.tex
index 7aeb04899d8..03252562a49 100644
--- a/doc/engineering-reference/src/climate-sky-and-solar-shading-calculations/shading-module.tex
+++ b/doc/engineering-reference/src/climate-sky-and-solar-shading-calculations/shading-module.tex
@@ -337,7 +337,7 @@ \subsubsection{Polygon Clipping Algorithms}\label{polygon-clipping-algorithms}
y'_2 = y_0 + t_2 \Delta y
\end{equation}
-The Slater-Barsky algorithm uses space subdivision to reduce the number of pre-emptive calculations. We break the plane into 9 parts, where region (4) is the clipping region.
+The Slater-Barsky algorithm uses space subdivision to reduce the number of preemptive calculations. We break the plane into 9 parts, where region (4) is the clipping region.
| 6 | 7 | 8 | \\
@@ -592,7 +592,7 @@ \subsubsection{FulInteriorAndlExteriorWithReflections}\label{fulinteriorandlexte
\subsection{Details of the Interior Solar Distribution Calculation}\label{details-of-the-interior-solar-distribution-calculation}
-EnergyPlus calculates the distribution of short-wave radiation in the interior of each thermal zone. This radiation consists of beam solar radiation, diffuse solar radiation, and short-wave radiation from electric lights. The program determines the amount of this radiation that is (1) absorbed on the inside face of opaque surfaces, (2) absorbed in the glass and shading device layers of the zone's exterior and interior windows, (3) transmitted through the zone's interior windows to adjacent zones, and (4) transmitted back out of the exterior windows. The effects of movable shading devices on the exterior windows are taken into account; \emph{the program does not allow shading devices on interior windows}. Most of this calculation is done in subroutine CalcInteriorSolarDistribution in the SolarShading module. EnergyPlus will use either Polygon Clipping or Pixel Counting--depending on the method of shading algorithm selected by the user--to determine interior solar distibution if full interior solar distribution is requested.
+EnergyPlus calculates the distribution of short-wave radiation in the interior of each thermal zone. This radiation consists of beam solar radiation, diffuse solar radiation, and short-wave radiation from electric lights. The program determines the amount of this radiation that is (1) absorbed on the inside face of opaque surfaces, (2) absorbed in the glass and shading device layers of the zone's exterior and interior windows, (3) transmitted through the zone's interior windows to adjacent zones, and (4) transmitted back out of the exterior windows. The effects of movable shading devices on the exterior windows are taken into account; \emph{the program does not allow shading devices on interior windows}. Most of this calculation is done in subroutine CalcInteriorSolarDistribution in the SolarShading module. EnergyPlus will use either Polygon Clipping or Pixel Counting--depending on the method of shading algorithm selected by the user--to determine interior solar distribution if full interior solar distribution is requested.
\subsubsection{Initial Distribution of Diffuse Solar Transmitted through Exterior and Interior Windows}\label{initial-distribution-of-diffuse-solar-transmitted-through-exterior-and-interior-windows}
diff --git a/doc/engineering-reference/src/daylighting-and-window-calculations/complex-fenestration-daylighting-calculations.tex b/doc/engineering-reference/src/daylighting-and-window-calculations/complex-fenestration-daylighting-calculations.tex
index 6669ae4c8f9..8b1fc00fd3b 100644
--- a/doc/engineering-reference/src/daylighting-and-window-calculations/complex-fenestration-daylighting-calculations.tex
+++ b/doc/engineering-reference/src/daylighting-and-window-calculations/complex-fenestration-daylighting-calculations.tex
@@ -10,7 +10,7 @@ \section{Complex Fenestration Daylighting Calculations}\label{complex-fenestrati
\subsection{Internal Average Reflected Illuminance From Window}\label{internal-average-reflected-illuminance-from-window}
-To calculate internal average reflected illumiance from the window it is necessary to calculate transmitted flux at the window.~ Observing an infinitesimal window element, illuminance can originate from the sky or sun, and in both cases the ray can reach the window directly or after reflecting from the ground.~ Based on this, the calculation of luminance at the window is divided into three parts:
+To calculate internal average reflected illuminance from the window it is necessary to calculate transmitted flux at the window.~ Observing an infinitesimal window element, illuminance can originate from the sky or sun, and in both cases the ray can reach the window directly or after reflecting from the ground.~ Based on this, the calculation of luminance at the window is divided into three parts:
\begin{itemize}
\item
@@ -23,7 +23,7 @@ \subsection{Internal Average Reflected Illuminance From Window}\label{internal-a
where total illuminance will be calculated as a superposition of these three parts.
-For any case, illuminace at a window element can be calculated by using the following general approach:
+For any case, illuminance at a window element can be calculated by using the following general approach:
\begin{equation}
dE{W_{at\_window}} = Lu{m_{el}}({\theta_{el}},{\phi_{el}}) \cdot cos({\beta_{el}}) \cdot \cos ({\phi_{el}}) \cdot d{\theta_{el}} \cdot d{\phi_{el}}
@@ -48,7 +48,7 @@ \subsection{Internal Average Reflected Illuminance From Window}\label{internal-a
Integrating luminous flux given by Equation~\ref{eq:IlluminanceAtWindowElement} over entire window area will give luminous flux on the interior side of the window.
-To calculate the interan average reflected illumiance from the window, a simillar approch will be used as described in the chapter ``Internally-Reflected Component of Interior Daylight Illuminance'', which gives the flux balance equation:
+To calculate the internal average reflected illuminance from the window, a similar approach will be used as described in the chapter ``Internally-Reflected Component of Interior Daylight Illuminance'', which gives the flux balance equation:
\begin{equation}
A \cdot {E_r} \cdot (1 - \rho ) = {F_1}
diff --git a/doc/engineering-reference/src/daylighting-and-window-calculations/daylight-factor-calculation.tex b/doc/engineering-reference/src/daylighting-and-window-calculations/daylight-factor-calculation.tex
index f8b97372051..66d9ca216a6 100644
--- a/doc/engineering-reference/src/daylighting-and-window-calculations/daylight-factor-calculation.tex
+++ b/doc/engineering-reference/src/daylighting-and-window-calculations/daylight-factor-calculation.tex
@@ -249,7 +249,7 @@ \subsubsection{Overcast Sky}\label{overcast-sky}
\subsection{Direct Normal Solar Illuminance}\label{direct-normal-solar-illuminance}
-For purposes of calculating daylight factors associated with beam solar illuminance, the direct normal solar illuminance is taken to be 1.0 W/m\(^{2}\). The actual direct normal solar illuminance, determined from direct normal solar irradiance from the weather file and empirically-determined luminious efficacy, is used in the time-step calculation.
+For purposes of calculating daylight factors associated with beam solar illuminance, the direct normal solar illuminance is taken to be 1.0 W/m\(^{2}\). The actual direct normal solar illuminance, determined from direct normal solar irradiance from the weather file and empirically-determined luminous efficacy, is used in the time-step calculation.
\subsection{Exterior Horizontal Illuminance}\label{exterior-horizontal-illuminance}
diff --git a/doc/engineering-reference/src/daylighting-and-window-calculations/daylighting-devices.tex b/doc/engineering-reference/src/daylighting-and-window-calculations/daylighting-devices.tex
index aad9067f266..db70e97ff72 100644
--- a/doc/engineering-reference/src/daylighting-and-window-calculations/daylighting-devices.tex
+++ b/doc/engineering-reference/src/daylighting-and-window-calculations/daylighting-devices.tex
@@ -169,7 +169,7 @@ \subsubsection{Solar Gains}\label{solar-gains}
\(\tau_{diff,horiz}\) = diffuse transmittance of the horizon, derived below
-It is important to note that transmittances above are for the total TDD.~ The transmittance of the dome and diffuser must be included to account for their angular dependences as well.
+It is important to note that transmittances above are for the total TDD.~ The transmittance of the dome and diffuser must be included to account for their angular dependencies as well.
The beam transmittance is used as an approximation for all circumsolar radiation.
@@ -300,7 +300,7 @@ \subsubsection{References}\label{references-016}
\subsection{Daylighting Shelves}\label{daylighting-shelves}
-The input object DaylightingDevice:Shelf provides a special model for light shelves used to augment daylighting.~ Light shelves are constructed from up to three components: a window, an inside shelf, and an outside shelf.~ The inside shelf acts to reflect all transmitted light from the upper window onto the ceiling of the zone as diffuse light.~ The outside shelf changes the amount of light incident on the window.~ All light reflected from the outside shelf also goes onto the zone ceiling.~ The inside shelf and outside shelf are both optional.~ However, if neither shelf is specifed, the daylighting shelf object has no effect on the simulation.
+The input object DaylightingDevice:Shelf provides a special model for light shelves used to augment daylighting.~ Light shelves are constructed from up to three components: a window, an inside shelf, and an outside shelf.~ The inside shelf acts to reflect all transmitted light from the upper window onto the ceiling of the zone as diffuse light.~ The outside shelf changes the amount of light incident on the window.~ All light reflected from the outside shelf also goes onto the zone ceiling.~ The inside shelf and outside shelf are both optional.~ However, if neither shelf is specified, the daylighting shelf object has no effect on the simulation.
The window is divided into two window surfaces: an upper window and a lower window.~ The upper window interacts with the daylighting shelf but the lower window does not, except to receive shading from the outside shelf.
diff --git a/doc/engineering-reference/src/daylighting-and-window-calculations/delight-daylighting-calculations.tex b/doc/engineering-reference/src/daylighting-and-window-calculations/delight-daylighting-calculations.tex
index add34d3bb75..e09ce4ceb71 100644
--- a/doc/engineering-reference/src/daylighting-and-window-calculations/delight-daylighting-calculations.tex
+++ b/doc/engineering-reference/src/daylighting-and-window-calculations/delight-daylighting-calculations.tex
@@ -6,7 +6,7 @@ \section{DElight Daylighting Calculations}\label{delight-daylighting-calculation
The DElight daylighting calculation has three main steps:
-1.~~~~\emph{Daylight Factor Calculation:}~ Daylight factors, which are ratios of interior illuminance to exterior horizontal illuminance, are pre-calculated and stored for later use. The user spcifies the coordinates of one or more reference points in each daylit zone. DElight first calculates the contribution of light transmitted through all simple and complex fenestration systems in the zone to the illuminance at each reference point, and to the luminance at subdivided nodal patches of interior surfaces, for a given exterior luminous environment (including sky, sun, and exterior reflecting surfaces).~ The effect of inter-reflection of this initial light between interior reflecting surfaces is then calculated, resulting in a final total illuminance at each reference point.~ This total illuminace is then divided by the exterior horizontal illuminance for the given exterior environment to give a daylight factor.~ Daylight factors are calculated for each reference point, for a set of sun positions and sky conditions that are representative of the building location.
+1.~~~~\emph{Daylight Factor Calculation:}~ Daylight factors, which are ratios of interior illuminance to exterior horizontal illuminance, are pre-calculated and stored for later use. The user specifies the coordinates of one or more reference points in each daylit zone. DElight first calculates the contribution of light transmitted through all simple and complex fenestration systems in the zone to the illuminance at each reference point, and to the luminance at subdivided nodal patches of interior surfaces, for a given exterior luminous environment (including sky, sun, and exterior reflecting surfaces).~ The effect of inter-reflection of this initial light between interior reflecting surfaces is then calculated, resulting in a final total illuminance at each reference point.~ This total illuminance is then divided by the exterior horizontal illuminance for the given exterior environment to give a daylight factor.~ Daylight factors are calculated for each reference point, for a set of sun positions and sky conditions that are representative of the building location.
2.~~~~\emph{Time-Step Interior Daylighting Calculation}:~ A daylighting calculation is performed for each heat-balance time step when the sun is up. In this calculation the illuminance at the reference points in each zone is found by interpolating the stored daylight factors using the current time step sun position and sky condition, then multiplying by the exterior horizontal illuminance.
@@ -16,7 +16,7 @@ \subsection{DElight Daylight Factor Calculation Differences from SplitFlux Metho
\begin{itemize}
\item
- \emph{Initial Interior Illuminance/Luminance Calculation:}~ DElight calculates the total initial contribution of light transmitted through all simple fenestration systems (i.e., windows and skylights) in the zone to the illuminance at each reference point, and to the luminance at each gridded nodal patch of interior surfaces.~ This differs from the models behind the ``Daylighting:Controls'' object using the SplitFlux Daylighting Method (henceforth referred to as ``SplitFlux'') in two ways. The first is that SplitFlux calculates initial illuminace values at reference points for each pair of reference point and aperture (window/skylight) in the zone, whereas DElight calculates the total contribution from all apertures to each reference point.~ The second difference from SplitFlux is that the initial luminance of interior surface nodal patches is calculated to support the inter-reflection calculation described below.~ This calculation uses the same formula as SplitFlux modified for arbitrarily oriented surfaces (i.e., non-horizontal), and to calculate luminance rather than illuminance.~ Note however, DElight does not account for interior surface obstructions (e.g., partitions) in this initial interior illuminance/luminance distribution.~ The SplitFlux method does account for interior surface obstruction of initial illuminance distribution on reference points.
+ \emph{Initial Interior Illuminance/Luminance Calculation:}~ DElight calculates the total initial contribution of light transmitted through all simple fenestration systems (i.e., windows and skylights) in the zone to the illuminance at each reference point, and to the luminance at each gridded nodal patch of interior surfaces.~ This differs from the models behind the ``Daylighting:Controls'' object using the SplitFlux Daylighting Method (henceforth referred to as ``SplitFlux'') in two ways. The first is that SplitFlux calculates initial illuminance values at reference points for each pair of reference point and aperture (window/skylight) in the zone, whereas DElight calculates the total contribution from all apertures to each reference point.~ The second difference from SplitFlux is that the initial luminance of interior surface nodal patches is calculated to support the inter-reflection calculation described below.~ This calculation uses the same formula as SplitFlux modified for arbitrarily oriented surfaces (i.e., non-horizontal), and to calculate luminance rather than illuminance.~ Note however, DElight does not account for interior surface obstructions (e.g., partitions) in this initial interior illuminance/luminance distribution.~ The SplitFlux method does account for interior surface obstruction of initial illuminance distribution on reference points.
\item
\emph{Reference Points:}~ DElight allows up to 100 reference points to be arbitrarily positioned with a daylighting zone.~ At this time all reference points are assumed to be oriented on a horizontal virtual surface ``facing'' toward the zenith and ``seeing'' the hemisphere above the horizontal plane.
\item
diff --git a/doc/engineering-reference/src/daylighting-and-window-calculations/window-calculation-module.tex b/doc/engineering-reference/src/daylighting-and-window-calculations/window-calculation-module.tex
index 842ad526950..e3bcd560b57 100644
--- a/doc/engineering-reference/src/daylighting-and-window-calculations/window-calculation-module.tex
+++ b/doc/engineering-reference/src/daylighting-and-window-calculations/window-calculation-module.tex
@@ -6,7 +6,7 @@ \section{Window Calculation Module}\label{window-calculation-module}
\begin{itemize}
\item
- \textbf{\emph{Glazing}}, which consists of one or more plane/parallel glass layers. If there are two or more glass layers, the layers are separated by gaps filled with air or another gas. The glazing optical and thermal calculations are based on algorithms from the WINDOW 4 and WINDOW 5 programs {[}Arasteh et al., 1989{]}, {[}Finlayson et al., 1993{]}.~ Glazing layers are described using te input object WindowMaterial:Glazing.
+ \textbf{\emph{Glazing}}, which consists of one or more plane/parallel glass layers. If there are two or more glass layers, the layers are separated by gaps filled with air or another gas. The glazing optical and thermal calculations are based on algorithms from the WINDOW 4 and WINDOW 5 programs {[}Arasteh et al., 1989{]}, {[}Finlayson et al., 1993{]}.~ Glazing layers are described using the input object WindowMaterial:Glazing.
\item
\textbf{\emph{Gap}}, layers filled with air or another gas that separate glazing layers.~ Gaps are described using the input object WindowMaterial:Gas.
\item
@@ -19,7 +19,7 @@ \section{Window Calculation Module}\label{window-calculation-module}
In the following, the description of the layer-by-layer glazing algorithms is based on material from Finlayson et al., 1993. The frame and divider thermal model, and the shading device optical and thermal models, are new to EnergyPlus.
-A second approch has been developed where windows are modeled in a simplified approach that requires minimal user input that is processed to develop and equivalent layer that then reuses much of the layer-by-model.~ This ``Simple Window Construction: model is described below.
+A second approach has been developed where windows are modeled in a simplified approach that requires minimal user input that is processed to develop and equivalent layer that then reuses much of the layer-by-model.~ This ``Simple Window Construction: model is described below.
\subsection{Optical Properties of Glazing}\label{optical-properties-of-glazing}
@@ -175,7 +175,7 @@ \subsubsection{Step 1.~ Determine glass-to-glass Resistance.}\label{step-1.-dete
\({R_{o,w}}\)~is the resistance of the exterior film coefficient under standard winter conditions in units of m\(^{2}\)·K/W, and
-\({R_{l,w}}\)~is the resisance of the bare window under winter conditions (without the film coefficients) in units of m\(^{2}\)·K/W.
+\({R_{l,w}}\)~is the resistance of the bare window under winter conditions (without the film coefficients) in units of m\(^{2}\)·K/W.
The values for \({R_{i,w}}\)~and \({R_{o,w}}\)~depend on U and are calculated using the following correlations.
@@ -197,7 +197,7 @@ \subsubsection{Step 1.~ Determine glass-to-glass Resistance.}\label{step-1.-dete
{R_{l,w}} = \frac{1}{U} - {R_{i,w}} - {R_{o,w}}
\end{equation}
-Because the window model in EnergyPlus is for flat geometries, the models are not necessarily applicable to low-performance projecting products, such as skylights with unisulated curbs.~ The model cannot support glazing systems with a U higher than 7.0 because the thermal resistance of the film coefficients alone can provide this level of performance and none of the various resistances can be negative.
+Because the window model in EnergyPlus is for flat geometries, the models are not necessarily applicable to low-performance projecting products, such as skylights with uninsulated curbs.~ The model cannot support glazing systems with a U higher than 7.0 because the thermal resistance of the film coefficients alone can provide this level of performance and none of the various resistances can be negative.
\subsubsection{Step 2.~ Determine Layer Thickness.}\label{step-2.-determine-layer-thickness.}
@@ -559,7 +559,7 @@ \subsection{Calculation of Angular Properties}\label{calculation-of-angular-prop
\subsubsection{Angular Properties for Uncoated Glass}\label{angular-properties-for-uncoated-glass}
-The following discussion assumes that optical quantities such as transmissivity, reflectvity, absorptivity, and index of refraction are a function of wavelength, λ. If there are no spectral data the angular dependence is calculated based on the single values for transmittance and reflectance in the visible and solar range. In the visible range an average wavelength of 0.575 microns is used in the calculations. In the solar range an average wavelength of 0.898 microns is used.
+The following discussion assumes that optical quantities such as transmissivity, reflectivity, absorptivity, and index of refraction are a function of wavelength, λ. If there are no spectral data the angular dependence is calculated based on the single values for transmittance and reflectance in the visible and solar range. In the visible range an average wavelength of 0.575 microns is used in the calculations. In the solar range an average wavelength of 0.898 microns is used.
The spectral data include the transmittance, \emph{T}, and the reflectance, \emph{R}. For uncoated glass the reflectance is the same for the front and back surfaces. For angle of incidence, \(\phi\) , the transmittance and reflectance are related to the transmissivity, \(\tau\), and reflectivity, \(\rho\), by the following relationships:
@@ -707,7 +707,7 @@ \subsection{Optical Properties of Window Shading Devices}\label{optical-properti
With ``Switchable glazing,'' shading is achieved making the glazing more absorbing or more reflecting, usually by an electrical or chemical mechanism. An example is electrochromic glazing where the application of an electrical voltage or current causes the glazing to switch from light to dark.
-Shades and blinds can be either fixed or moveable. If moveable, they can be deployed according to a schedule or according to a trigger variable, such as solar radiation incident on the window. Screens can be either fixed or moveable according to a schedule.
+Shades and blinds can be either fixed or movable. If movable, they can be deployed according to a schedule or according to a trigger variable, such as solar radiation incident on the window. Screens can be either fixed or movable according to a schedule.
\subsubsection{Shades}\label{shades}
@@ -1134,7 +1134,7 @@ \subsubsection{Diffuse-to-Diffuse Transmittance and Reflectance of Blind}\label{
\subsubsection{Blind properties for sky and ground diffuse radiation}\label{blind-properties-for-sky-and-ground-diffuse-radiation}
-For horizontal slats on a vertical window (the most common configuration) the blind diffuse-to-diffuse properties will be sensitve to whether the radiation is incident upward from the ground or downward from the sky (Figure~\ref{fig:side-view-of-horizontal-slats-in-a-vertical}). For this reason we also calculate the following solar properties for a blind consisting of horizontal slats in a vertical plane:
+For horizontal slats on a vertical window (the most common configuration) the blind diffuse-to-diffuse properties will be sensitive to whether the radiation is incident upward from the ground or downward from the sky (Figure~\ref{fig:side-view-of-horizontal-slats-in-a-vertical}). For this reason we also calculate the following solar properties for a blind consisting of horizontal slats in a vertical plane:
\(\tau_{bl,f}^{gnd - dif,dif} = {\rm{ }}\) front transmittance for ground diffuse solar
@@ -1960,13 +1960,13 @@ \subsubsection{Solar Radiation Transmitted and Absorbed by a Window/Screen Syste
\subsection{Complex Fenestration Calculation Module}\label{complex-fenestration-calculation-module}
-This section describes detailed method for modeling complex fenestration systems, including shading devices and general fenestration attachments. This detailed method primarily refers to the optical side of modeling complex fenestration systems. Thermal modeling is done according to ISO 15099 standard, which is described in the Window Heat Balance Calculation section with the addition of deflection and vacuum glazing systems modeling and some modifications to shading layer algorithms, which is described in Shading Device Thermal Model section. Optical caclulations in this method are done using Bidirectional Scattering Distribution Function (BSDF) approach.~ The concept behind BSDF is based on the definition of descrete set of incident and outgoing angles, which fully describes optical performance of any system, simple or complex, limited only by the resolution of angular discretization.~ In this method each layer, as well as the whole system is described by a matrix of incident and outgoing angles.
+This section describes detailed method for modeling complex fenestration systems, including shading devices and general fenestration attachments. This detailed method primarily refers to the optical side of modeling complex fenestration systems. Thermal modeling is done according to ISO 15099 standard, which is described in the Window Heat Balance Calculation section with the addition of deflection and vacuum glazing systems modeling and some modifications to shading layer algorithms, which is described in Shading Device Thermal Model section. Optical calculations in this method are done using Bidirectional Scattering Distribution Function (BSDF) approach.~ The concept behind BSDF is based on the definition of discrete set of incident and outgoing angles, which fully describes optical performance of any system, simple or complex, limited only by the resolution of angular discretization.~ In this method each layer, as well as the whole system is described by a matrix of incident and outgoing angles.
\subsubsection{Complex Fenestration Solar-Optical Calculations}\label{complex-fenestration-solar-optical-calculations}
\paragraph{\textbf{Solar radiation calculation outline}}\label{solar-radiation-calculation-outline}
-For solar radiation calculations, each of the layers as well as entire glazing system can be represented with the set of Bi-directional Scattering Distribution Functions or BSDF, consisting of Bi-directional Reflectance Distribution Function or BRDF and Bi-directional Transmittance Distribution Function or BTDF.~ Each function is a matrix 145 x 145 that describes reflectance or transmittance distribution in the outgoing hemisphere for each incident angle in the incidence hemisphere.~ For each function there is forward and back matrix, for a total of 4 145 x 145 matrices.~ Depending on the purpose of calculations, description of entire glazing system is divided into solar and visible spectrum, which means that there can be 8 matrices describing visible and complete solar spectrums.~ Reflectance and transmittance being non-dimnsional ratios of reflected or transmitted energy over incident energy, in order to get total reflected and transmitted energy it is necessary to supply vector of incident solar energy, which usually consists of direct and diffuse radition.Specifics of calculations of direct and diffuse solar radiationis be described in some detail in oncoming chapters.
+For solar radiation calculations, each of the layers as well as entire glazing system can be represented with the set of Bi-directional Scattering Distribution Functions or BSDF, consisting of Bi-directional Reflectance Distribution Function or BRDF and Bi-directional Transmittance Distribution Function or BTDF.~ Each function is a matrix 145 x 145 that describes reflectance or transmittance distribution in the outgoing hemisphere for each incident angle in the incidence hemisphere.~ For each function there is forward and back matrix, for a total of 4 145 x 145 matrices.~ Depending on the purpose of calculations, description of entire glazing system is divided into solar and visible spectrum, which means that there can be 8 matrices describing visible and complete solar spectrums.~ Reflectance and transmittance being non-dimensional ratios of reflected or transmitted energy over incident energy, in order to get total reflected and transmitted energy it is necessary to supply vector of incident solar energy, which usually consists of direct and diffuse radiation.Specifics of calculations of direct and diffuse solar radiation is be described in some detail in oncoming chapters.
\subparagraph{\textbf{Scattering (Non-Specular) Glazing and Shading Devices}}\label{scattering-non-specular-glazing-and-shading-devices}
@@ -2679,7 +2679,7 @@ \subsubsection{Complex Fenestration Solar-Optical Calculations}\label{complex-fe
Z\(^{(sp,Sf,n),k}_{r(t)}\) & Exterior surface specular irradiation factor; N\(^{(Sf,n)}_{Sun}\) X N\(_{Sf}\) X N\(_{IntSurf}\) \tabularnewline
Z\(^{(Sun,Sf,n),k}_{s(t)}\) & Exterior surface direct-diffuse irradiation factor; N\(^{(Sf,n)}_{Sun}\) X N\(_{Sf}\) X N\(_{IntSurf}\) \tabularnewline
Z\(^{(Sky,Sf,n),k}\) & Exterior surface sky irradiation factor; N\(_{Sf}\) X N\(_{IntSurf}\) \tabularnewline
-Z\(^{(D,Gnd),k}_{s(t)}\) & Ground-reflected direct solar irradiaton factor (given sun direction s(\emph{t})); N\(^{(Gnd)}_{Sun}\) X N\(_{IntSurf}\) \tabularnewline
+Z\(^{(D,Gnd),k}_{s(t)}\) & Ground-reflected direct solar irradiation factor (given sun direction s(\emph{t})); N\(^{(Gnd)}_{Sun}\) X N\(_{IntSurf}\) \tabularnewline
Z\(^{(Sky,Gnd),k}\) & Ground-reflected diffuse solar irradiation factor; N\(_{IntSurf}\) \tabularnewline
Z\(^{(Sun),k}_{s(t)}\) & Direct solar irradiation factor; N\(_{Sun}\) X N\(_{IntSurf}\) \tabularnewline
K\(^{(Sky),l}\) & Sky absorption factor; N\(_{Layers}\) \tabularnewline
@@ -2770,11 +2770,11 @@ \subsubsection{Complex Fenestration Solar-Optical Calculations}\label{complex-fe
Distribution of solar radiation transmitted through exterior window is divided on diffuse and direct part.
-Diffuse solar transmitted through exterior complex fenestration and absorbed in interor walls is calculated and treated in same way as described in the section on Initial Distribution of Diffuse Solar Transmitted through Exterior and Interior Windows. Even though that BSDF is given for various directions, for purpose of diffuse solar radiation, transmittance and reflectances of fenestration system is integrated over incoming and outgoing hemisphere.~ Because incoming diffuse solar radiation is divided on ground and sky parts, integration of incoming hemisphere is also perfomed over ground and sky part (see Equation~\ref{eq:SSfnpTEquation}).
+Diffuse solar transmitted through exterior complex fenestration and absorbed in interior walls is calculated and treated in same way as described in the section on Initial Distribution of Diffuse Solar Transmitted through Exterior and Interior Windows. Even though that BSDF is given for various directions, for purpose of diffuse solar radiation, transmittance and reflectances of fenestration system is integrated over incoming and outgoing hemisphere.~ Because incoming diffuse solar radiation is divided on ground and sky parts, integration of incoming hemisphere is also performed over ground and sky part (see Equation~\ref{eq:SSfnpTEquation}).
Direct Solar Radiation Transmitted by Complex Fenestration
-Direct solar (beam) transmitted through exterior window is using same overlap calculations (see Figure~\ref{fig:vertical-section-through-a-two-zone-building}) for each outgoing basis direction.~ For certain sun position, algorithm calculatates equivalent incoming beam number.~ The inside beam solar irradiance is calculated in similar manner as described in the section titled Interior Beam Radiation.
+Direct solar (beam) transmitted through exterior window is using same overlap calculations (see Figure~\ref{fig:vertical-section-through-a-two-zone-building}) for each outgoing basis direction.~ For certain sun position, algorithm calculates equivalent incoming beam number.~ The inside beam solar irradiance is calculated in similar manner as described in the section titled Interior Beam Radiation.
\begin{equation}
\begin{split}
diff --git a/doc/engineering-reference/src/daylighting-and-window-calculations/window-heat-balance-calculation.tex b/doc/engineering-reference/src/daylighting-and-window-calculations/window-heat-balance-calculation.tex
index b4af846ae61..a6714f41d39 100644
--- a/doc/engineering-reference/src/daylighting-and-window-calculations/window-heat-balance-calculation.tex
+++ b/doc/engineering-reference/src/daylighting-and-window-calculations/window-heat-balance-calculation.tex
@@ -173,7 +173,7 @@ \subsection{Room-Side Convection}\label{room-side-convection}
Nu = 0.58Ra_H^{{\raise0.7ex\hbox{1} \!\mathord{\left/ {\vphantom {1 5}}\right.}\!\lower0.7ex\hbox{5}}};\;R{a_H} \le {10^{11}}
\end{equation}
-The material properties are evaluated at the mean film temperature.~ Standard EnergyPlus pyschrometric functions are used for \(\rho\) ~and \({c_p}\).~ Thermal conductivity is calculated using:
+The material properties are evaluated at the mean film temperature.~ Standard EnergyPlus psychrometric functions are used for \(\rho\) ~and \({c_p}\).~ Thermal conductivity is calculated using:
\begin{equation}
\lambda = 2.873 \times {10^{ - 3}} + 7.76 \times {10^{ - 5}}{T_{m,f}}
@@ -185,7 +185,7 @@ \subsection{Room-Side Convection}\label{room-side-convection}
\mu = 3.723 \times {10^{ - 6}} + 4.94 \times {10^{ - 8}}{T_{m,f}}
\end{equation}
-This correlation depends on the surface temperature of the room-side glazing surface and is therefore included inside the window heat balance interation loop.
+This correlation depends on the surface temperature of the room-side glazing surface and is therefore included inside the window heat balance iteration loop.
\subsection{Solving the Glazing Heat Balance Equations}\label{solving-the-glazing-heat-balance-equations}
@@ -2149,7 +2149,7 @@ \subsubsection{Calculation of the thermal performance caused by measured deflect
\begin{figure}[hbtp] % fig 112
\centering
\includegraphics[width=0.9\textwidth, height=0.9\textheight, keepaspectratio=true]{media/image1798.png}
-\caption{Sketch of the non-symetrically Deflected Glazing Panes \protect \label{fig:sketch-of-the-non-symetrically-deflected}}
+\caption{Sketch of the non-symmetrically Deflected Glazing Panes \protect \label{fig:sketch-of-the-non-symmetrically-deflected}}
\end{figure}
If we label the ratio of mean deflection and maximum deflection as R\(_{(i)}\), then:
@@ -2298,7 +2298,7 @@ \subsubsection{References}\label{references-1-019}
\subsection{Equivalent Layer Fenestration Model}\label{equivalent-layer-fenestration-model}
-The section describes the equivalent layer fenestration optical and thermal model. The Equivalent Layer fenestration model can have four types of attachments: drapes, venetian blinds, roller blinds and insect screens. In this model shading layers are assumed to be uniform and can be represented by an equivalent homogenous layer that has spatially-averaged ``effective'' optical and thermal properties (ASHRAE 1311-RP). Likewise, venetian blinds can be characterized using effective optical and thermal properties. When solar radiation strikes a window surface some fraction of the incident solar radiation passes unobstructed through openings in a shading layer and the remaining fraction is intercepted by the structure of the layer. The intercepted radiation is partly absorbed, partly reflected and partly transmitted. These reflected and transmitted components of the scattered solar radiation are assumed to be uniformly diffuse. Shading layers, because of their openness, generally transmit longwave radiation, and the effective infrared properties of shades account for that. Using effective optical properties and a beam/diffuse split of solar radiation at each layer, the equivalent layer approach can represent multi-layer systems. This representation provides virtually unlimited flexibility to combine different types of shading layers in a fenestration. The equivalent layer window model requires a few set of optical data to characterize a particular layer and this set of data is used to calculate effective layer properties. For instance, the effective solar optical properties of a venetian blind can be calculated as a function of slats optical properties and geometry. Also, it is possible to adjust slat angle at each time step in response to the changing angular position of the sun. Moreover, the model provides control strategies as a function of slat angle that can be changed at each time step as needed. Likewise, effective properties of a pleated drape are calculated as a function of fabric properties and a specified value of fullness. The only input data needed to fully characterize drapery fabrics, roller blinds and insect screens are material openness as area fraction, and the transmittance and reflectance at normal incidence. Shade openness area fraction is the same as the beam-beam transmittance at normal incidence. In multilayer fenestration, each layer is separated by a gap. A gap in equivalent layer model is defined by specifying the fill gas and the gap spacing. Currently five gas types are allowed: Air, Argon, Xenon, Krypton and Custom. The convective heat transfer coefficient in a gap is calculated depending on the spacing, the temperatures of the layers and the fill gas properties. Equivalent-layer concept -- offers wide range of multiple glazing and shading layers combination and can simulate multi-layer complex fenestration systems. The effective layer properties of venetian blinds, pleated drapes, roller blinds, and insect screens are calculated from geometric layer models and material properties. A set of empirical correlations for estimating off-normal material properties were developed under ASHRAE research project (ASHRAE 1311-RP). The equivalent layer window model supports many layers of glazing and shade combination in any order but does not support WindowShadingControl. However, the venetian blind model of equivalent layer window model provides three types of blind slat angle control.
+The section describes the equivalent layer fenestration optical and thermal model. The Equivalent Layer fenestration model can have four types of attachments: drapes, venetian blinds, roller blinds and insect screens. In this model shading layers are assumed to be uniform and can be represented by an equivalent homogeneous layer that has spatially-averaged ``effective'' optical and thermal properties (ASHRAE 1311-RP). Likewise, venetian blinds can be characterized using effective optical and thermal properties. When solar radiation strikes a window surface some fraction of the incident solar radiation passes unobstructed through openings in a shading layer and the remaining fraction is intercepted by the structure of the layer. The intercepted radiation is partly absorbed, partly reflected and partly transmitted. These reflected and transmitted components of the scattered solar radiation are assumed to be uniformly diffuse. Shading layers, because of their openness, generally transmit longwave radiation, and the effective infrared properties of shades account for that. Using effective optical properties and a beam/diffuse split of solar radiation at each layer, the equivalent layer approach can represent multi-layer systems. This representation provides virtually unlimited flexibility to combine different types of shading layers in a fenestration. The equivalent layer window model requires a few set of optical data to characterize a particular layer and this set of data is used to calculate effective layer properties. For instance, the effective solar optical properties of a venetian blind can be calculated as a function of slats optical properties and geometry. Also, it is possible to adjust slat angle at each time step in response to the changing angular position of the sun. Moreover, the model provides control strategies as a function of slat angle that can be changed at each time step as needed. Likewise, effective properties of a pleated drape are calculated as a function of fabric properties and a specified value of fullness. The only input data needed to fully characterize drapery fabrics, roller blinds and insect screens are material openness as area fraction, and the transmittance and reflectance at normal incidence. Shade openness area fraction is the same as the beam-beam transmittance at normal incidence. In multilayer fenestration, each layer is separated by a gap. A gap in equivalent layer model is defined by specifying the fill gas and the gap spacing. Currently five gas types are allowed: Air, Argon, Xenon, Krypton and Custom. The convective heat transfer coefficient in a gap is calculated depending on the spacing, the temperatures of the layers and the fill gas properties. Equivalent-layer concept -- offers wide range of multiple glazing and shading layers combination and can simulate multi-layer complex fenestration systems. The effective layer properties of venetian blinds, pleated drapes, roller blinds, and insect screens are calculated from geometric layer models and material properties. A set of empirical correlations for estimating off-normal material properties were developed under ASHRAE research project (ASHRAE 1311-RP). The equivalent layer window model supports many layers of glazing and shade combination in any order but does not support WindowShadingControl. However, the venetian blind model of equivalent layer window model provides three types of blind slat angle control.
\subsubsection{The Equivalent Layer Analysis}\label{the-equivalent-layer-analysis}
@@ -2615,7 +2615,7 @@ \subsubsection{Equivalent Layer Window Solar Model}\label{equivalent-layer-windo
\subsubsection{Equivalent Layer Window Thermal Model}\label{equivalent-layer-window-thermal-model}
-The equivalent layer thermal model is calculated only once for each time step. But the thermal model has internal iterative solutions scheme. During each time step, the procedure initially assumes that room air and means radiant temperatures are known. The surface heat balance loops through all zone surfaces while invoking the Equivalent Layer thermal model only once for each window surface at the first iteration. The window surfaces temperatures from the first iteration are used to complete the heat balances for the indoor (and implicitly the outdoor) face of each surface iteratively. Once indoor surface temperatures are calculated using the surface heat balance, the zone air temperature can be updated and the loads are predicted. Shaded fenestration in general do not have single inside temperature by virture their long-wave radiation transmittance. The equivalent layer window model accounts for this using effective emissivity of the composite layers derived for each fenestration (ASHRAE 1311-RP) as shown below:
+The equivalent layer thermal model is calculated only once for each time step. But the thermal model has internal iterative solutions scheme. During each time step, the procedure initially assumes that room air and means radiant temperatures are known. The surface heat balance loops through all zone surfaces while invoking the Equivalent Layer thermal model only once for each window surface at the first iteration. The window surfaces temperatures from the first iteration are used to complete the heat balances for the indoor (and implicitly the outdoor) face of each surface iteratively. Once indoor surface temperatures are calculated using the surface heat balance, the zone air temperature can be updated and the loads are predicted. Shaded fenestration in general do not have single inside temperature by virtue of their long-wave radiation transmittance. The equivalent layer window model accounts for this using effective emissivity of the composite layers derived for each fenestration (ASHRAE 1311-RP) as shown below:
\begin{equation}
{\varepsilon ^{eff}} = \sum\limits_{j = 0}^{nl} {\left[ {{\varepsilon_j} \cdot \prod\limits_{k = j{ + 1}}^{nl + {1}} {{\tau_k}} } \right]}
@@ -2631,7 +2631,7 @@ \subsubsection{Equivalent Layer Window Thermal Model}\label{equivalent-layer-win
\emph{nl~~~ = ~~~~~~~~~} number of layers in fenestration system (glazing and shade). Layers are numbered outside to inside (layer 1 is outermost, layer \emph{nl} is innermost).
-Each equivalent layer window surafce yields net longwave radiant flux exchanged with the zone surfaces. Net longwave radiation exchange from the window to the zone is recast for a composite surface temperature calculation as follows:
+Each equivalent layer window surface yields net longwave radiant flux exchanged with the zone surfaces. Net longwave radiation exchange from the window to the zone is recast for a composite surface temperature calculation as follows:
\begin{equation}
{T^{eff}} = \sqrt[4]{{\frac{{{Q_{lw}}}}{{\sigma {\varepsilon ^{eff}}}}}} + {T_0}
diff --git a/doc/engineering-reference/src/demand-limiting.tex b/doc/engineering-reference/src/demand-limiting.tex
index 4c3e3bc4e8a..4274666b567 100644
--- a/doc/engineering-reference/src/demand-limiting.tex
+++ b/doc/engineering-reference/src/demand-limiting.tex
@@ -32,7 +32,7 @@ \section{Algorithm}\label{algorithm}
HVAC system simulation (air and plant loops)
\end{itemize}
-The exterior energy use segment is completely independent of the zone heat balance and HVAC system simulation.~ Exterior energy use handles energy use accounting for exterior lights and exterior equipment that are outside of the building and are not part of the zone heat balance.~ The zone heat balance segment includes all of the surface heat balances, internal heat gains, and air flows.~ The HVAC system simulation includes air and plant loops with their associated HVAC components.~ The behaviour of the HVAC system depends on the results of the zone heat balance.~ The HVAC system simulation operates on a variable ``system'' time step which is automatically shortened if necessary for stability.
+The exterior energy use segment is completely independent of the zone heat balance and HVAC system simulation.~ Exterior energy use handles energy use accounting for exterior lights and exterior equipment that are outside of the building and are not part of the zone heat balance.~ The zone heat balance segment includes all of the surface heat balances, internal heat gains, and air flows.~ The HVAC system simulation includes air and plant loops with their associated HVAC components.~ The behavior of the HVAC system depends on the results of the zone heat balance.~ The HVAC system simulation operates on a variable ``system'' time step which is automatically shortened if necessary for stability.
The Demand Manager is called after the first pass through the HVAC system simulation, before the system time step is shortened.~ After evaluating the DemandManagerAssignmentList object, the Demand Manager decides if demand limiting is required.~ If demand limiting is required, the individual DemandManager objects are surveyed to determine which loads can be limited.~ Based on the \emph{Demand Manager Priority} selected, the Demand Manager then decides which DemandManager objects should be activated.~ In turn, the activated DemandManager objects set the demand limiting hooks on their respective load objects.~ Finally, depending on the type of DemandManager objects that were activated, one or more of the major segments of code must be called to be resimulated because the load conditions have changed.~ The code segments depend on the type of DemandManager and the relationship of its load objects to the overall solution method.~ The table below shows the different DemandManager types and the related code segments that must be resimulated.
diff --git a/doc/engineering-reference/src/economics-calculations/tariff-computation.tex b/doc/engineering-reference/src/economics-calculations/tariff-computation.tex
index 2ee0d888716..e84d9e8f20f 100644
--- a/doc/engineering-reference/src/economics-calculations/tariff-computation.tex
+++ b/doc/engineering-reference/src/economics-calculations/tariff-computation.tex
@@ -103,7 +103,7 @@ \subsection{Default Order of Computation}\label{default-order-of-computation}
The order in which the computation should be made is complicated by the fact that the objects can each have variables that are inputs and others that are outputs.~ Since any of the variables can be used as inputs, we must ensure that they are computed prior to being used. In other words, because the objects allow a great deal of flexibility, there is no simple default order that the computations should be made.
-Luckily there are known algorithms for sorting though these types of interdependencies.~ In fact, the method that spreadsheets use for sorting through the dependencies of cell formulas referencing other cells with formula is very similar.~ In addition, linkers (used as part of the computer language compiling process) face similar issues of sorting through dependences. Figuring out the optimal path in a complex project represented by a PERT Chart also uses a similar algorithm.
+Luckily there are known algorithms for sorting though these types of interdependencies.~ In fact, the method that spreadsheets use for sorting through the dependencies of cell formulas referencing other cells with formula is very similar.~ In addition, linkers (used as part of the computer language compiling process) face similar issues of sorting through dependencies. Figuring out the optimal path in a complex project represented by a PERT Chart also uses a similar algorithm.
Generically, dependency problems are usually characterized as Directed Acycle Graphs (DAGs). A DAG shows the individual formulas as circles and uses arrows between the circles to show which formula is dependent on which other formulas.~ One example algorithm that was used in EnergyPlus is described below:
diff --git a/doc/engineering-reference/src/integrated-solution-manager/zone-air-mass-flow-conservation.tex b/doc/engineering-reference/src/integrated-solution-manager/zone-air-mass-flow-conservation.tex
index c1cc6685b45..814f26c43d3 100644
--- a/doc/engineering-reference/src/integrated-solution-manager/zone-air-mass-flow-conservation.tex
+++ b/doc/engineering-reference/src/integrated-solution-manager/zone-air-mass-flow-conservation.tex
@@ -109,7 +109,7 @@ \subsubsection{Overall Return Air Balance}\label{overall-return-air-balance}
\subsubsection{Allocation of Excess Exhaust Flow}\label{allocation-of-excess-exhaust-flow}
-If the total (unbalanced) exhaust fan flow exceeds the supply flow in a given zone, this exhaust flow can be made up with outdoor air by any air loop serving the zone and the return air in other zones on the same air loop(s) will be reduced proportionally. First, the amount of excess exhaust for all zones on a given air loop is totalled. If a zone with excess exhuast is served by more than one air loop, the exhaust is shared by each air loop in proportion to the maximum available outdoor air for a given air loop.
+If the total (unbalanced) exhaust fan flow exceeds the supply flow in a given zone, this exhaust flow can be made up with outdoor air by any air loop serving the zone and the return air in other zones on the same air loop(s) will be reduced proportionally. First, the amount of excess exhaust for all zones on a given air loop is totaled. If a zone with excess exhaust is served by more than one air loop, the exhaust is shared by each air loop in proportion to the maximum available outdoor air for a given air loop.
\begin{equation}
{\dot m_{ExcessExh,i}} = {\sum\nolimits_{j} {\frac{\dot m_{ExcessExh,j} * \dot m_{MaxOA,i}} {\dot m_{TotOA,j}} }}
@@ -234,7 +234,7 @@ \subsection{Zone Mixing Flow Rate Calculations}\label{zone-mixing-flow-rate-calc
\subsection{Infiltration Flow Rate Adjustments}\label{infiltration-flow-rate-adjustments}
-There are three options for the treatement of infiltration in the zone air mass balance: None, AddInfiltrationFlow, and AdjustInfiltrationFlow. There are also two options to specify which zones are included in the infiltration adjustments: AllZones or MixingSourceZonesOnly.
+There are three options for the treatment of infiltration in the zone air mass balance: None, AddInfiltrationFlow, and AdjustInfiltrationFlow. There are also two options to specify which zones are included in the infiltration adjustments: AllZones or MixingSourceZonesOnly.
If a zone is excluded from infiltration adjustments, then the base infiltration rate specified by the Infiltration:* object(s) in the zone is assumed to be self-balanced, and infiltration is not included in the mass flow calculations for that zone.
@@ -244,7 +244,7 @@ \subsection{Infiltration Flow Rate Adjustments}\label{infiltration-flow-rate-adj
{\dot m_{Inf-required}} = MAX\left( {0.0,\,{{\dot m}_{XS}} + {{\dot m}_{EX}} + {{\dot m}_{R}} - {{\dot m}_S} - {\dot m_{XR,\,new}}} \right)
\end{equation}
-This infiltration air mass flow rate calculated is either added to the base infiltration air flow, which is calculated from user inputs, or overrides the base infiltration air flow depending on user choice. For AddInfiltrationFlow, the zoneinfiltration flow rate is:
+This infiltration air mass flow rate calculated is either added to the base infiltration air flow, which is calculated from user inputs, or overrides the base infiltration air flow depending on user choice. For AddInfiltrationFlow, the zone infiltration flow rate is:
\begin{equation}
{\dot m_{Inf}} = {\dot m_{Inf-base}} + {\dot m_{Inf-required}}
diff --git a/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/component-sizing.tex b/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/component-sizing.tex
index 4fe7e28ca9e..19413a69472 100644
--- a/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/component-sizing.tex
+++ b/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/component-sizing.tex
@@ -205,7 +205,7 @@ \subsubsection{Design Coil Load - System Coils}\label{design-coil-load---system-
\paragraph{\textbf{Coil in main air stream, outside air preconditioned} }\label{coil-in-main-air-stream-outside-air-preconditioned}
-The oustide air fraction is calculated as (where V\(_{cc,air}\) is calculated as above):
+The outside air fraction is calculated as (where V\(_{cc,air}\) is calculated as above):
\begin{itemize}
\item
@@ -382,7 +382,7 @@ \subsubsection{Design Air Inlet Humidity Ratio - Zone Coils}\label{design-air-in
\item
For fan coil units the design inlet humidity ratio is set to the mixed air humidity ratio: \(W_{air,in,des} = f_{oa}W_{oa,coolpeak} + \left(1-f_{oa}\right)W_{z,coolpeak}\) , where \(f_{oa} = \rho_a \dot V_{z,oa,des} / \dot m_{z,cool,des}\)
\item
- In all other cases the design inlet humidity ratio is set to the zone design cooling coil inlet hunidity ratio which is calculated in the zone sizing simulation and is basically the same calculation as the fan coil unit.
+ In all other cases the design inlet humidity ratio is set to the zone design cooling coil inlet humidity ratio which is calculated in the zone sizing simulation and is basically the same calculation as the fan coil unit.
\end{enumerate}
\subsubsection{Design Outlet Air Humidity Ratio - System Coils}\label{design-outlet-air-humidity-ratio---system-coils}
@@ -1182,7 +1182,7 @@ \subsubsection{System Coils}\label{system-coils-5}
FlowCapRatio_{max} = 0.00006041 m^{3}/s per watt (450 cfm/ton)
\end{equation}
-The sizing calculation for DX cooling coils for 100\% dedicated outdor air system (DOAS) are identical to regular DX cooling coils. However, they operate operate at different flow to capacity ratio ranges and are within the prescribed range below:
+The sizing calculation for DX cooling coils for 100\% dedicated outdoor air system (DOAS) are identical to regular DX cooling coils. However, they operate operate at different flow to capacity ratio ranges and are within the prescribed range below:
\begin{equation}
FlowCapRatio_{min} = 0.00001677 m^{3}/s per Watt (125 cfm/ton)
@@ -1276,7 +1276,7 @@ \subsubsection{Zone Coils}\label{zone-coils-5}
\emph{FlowCapRatio\(_{max}\)} = 0.00006041 m^{3}/s per watt (450 cfm/ton)
\end{equation}
-We check the design flow to the total cooling capacity rato for dedicated zone outdoor unit DX cooling coils to be within the limits prescribed below:
+We check the design flow to the total cooling capacity ratio for dedicated zone outdoor unit DX cooling coils to be within the limits prescribed below:
\begin{equation}
\emph{FlowCapRatio\(_{min}\)} = 0.00001677 m^{3}/s per Watt (125 cfm/ton)
@@ -1383,7 +1383,7 @@ \subsection{Coil:Cooling:DX:VariableSpeed Sizing}\label{coilcoolingdxvariablespe
where
-WB\(_{i}\) = wet-bulb temperature of the air entering thecooling coil, degC
+WB\(_{i}\) = wet-bulb temperature of the air entering the cooling coil, degC
DB\(_{o}\) = condenser entering air temperature, degC
@@ -1587,7 +1587,7 @@ \subsection{Boiler Sizing}\label{boiler-sizing}
Generally boilers will need nominal heating capacity and water volume flow rate. Both quantities can be straightforwardly obtained using the user specified loop sizing data and the loop design flow rates.
-All boilers on a loop are sized to meet the full loop load multipled by a component-level sizing factor. If there are multiple boilers on a loop that call for autosizing, they will all be assigned a heating capacity and flow rate using their own sizing factor.
+All boilers on a loop are sized to meet the full loop load multiplied by a component-level sizing factor. If there are multiple boilers on a loop that call for autosizing, they will all be assigned a heating capacity and flow rate using their own sizing factor.
\subsubsection{Nominal Capacity}\label{nominal-capacity}
@@ -2500,7 +2500,7 @@ \subsubsection{Minimum Air Flow Rate}\label{minimum-air-flow-rate}
{\dot V_{air,min,terminal}} = Fra{c_{air,\min }}*DesVolFlow_{zone}
\end{equation}
-where \emph{\(Frac_{air,min}\)} corresponds to the minimum flow fraction of the teminal unit. This value is provided as user input, typically as the field ``Zone Minimum Air Flow Fraction.'' For the VAV terminals that allow scheduling minimum flow fraction (e.g., AirTerminal:SingleDuct:VAV:Reheat), there are two ways that \emph{\(Frac_{air,min}\)} can be determined. If a value is entered in the input field Constant Minimum Air Flow Fraction, then it is always used for \emph{\(Frac_{air,min}\)}. If the mimimum air flow fraction method is ``Schedule'' and the Constant Minimum Air Flow Fraction is left blank, then the program uses the average of the minimum and maximum values in the schedule for \emph{\(Frac_{air,min}\)}.
+where \emph{\(Frac_{air,min}\)} corresponds to the minimum flow fraction of the terminal unit. This value is provided as user input, typically as the field ``Zone Minimum Air Flow Fraction.'' For the VAV terminals that allow scheduling minimum flow fraction (e.g., AirTerminal:SingleDuct:VAV:Reheat), there are two ways that \emph{\(Frac_{air,min}\)} can be determined. If a value is entered in the input field Constant Minimum Air Flow Fraction, then it is always used for \emph{\(Frac_{air,min}\)}. If the minimum air flow fraction method is ``Schedule'' and the Constant Minimum Air Flow Fraction is left blank, then the program uses the average of the minimum and maximum values in the schedule for \emph{\(Frac_{air,min}\)}.
\subsubsection{Fan On Flow Fraction}\label{fan-on-flow-fraction}
@@ -2558,7 +2558,7 @@ \subsection{Indirect Evaporative Cooler Sizing}\label{indirect-evaporative-coole
\subsubsection{Secondary Fan Flow Rate}\label{secondary-fan-flow-rate}
-The secondary fan is not part of an airstream that is directly modeled in EnergyPlus. Because the primary side air flows can be autosized as part of the air system, it is convenent to also scale the size of the secondary flow. If the cooler is part of the main loop of a central air system, then the secondary fan flow rate is sized to equal to the main design flow rate.
+The secondary fan is not part of an airstream that is directly modeled in EnergyPlus. Because the primary side air flows can be autosized as part of the air system, it is convenient to also scale the size of the secondary flow. If the cooler is part of the main loop of a central air system, then the secondary fan flow rate is sized to equal to the main design flow rate.
\begin{equation}
\dot V_{fan,max} = DesMainVolFlow_{sys}
@@ -2572,7 +2572,7 @@ \subsubsection{Secondary Fan Flow Rate}\label{secondary-fan-flow-rate}
\subsection{Secondary DX Coils Sizing}\label{secondary-dx-coils-sizing}
-The secondary DX coils model does not have a standalone object and it is models as add-on feature to the DX Coils. When the secondary DX coil is added to a primary DX cooling coil, the heat rejected to secondary zone is sensible only and is treated as tnternal gain, hence secondary air flow rate is not required in the model. Where as when the secondary DX coil is added to a primary DX heating coil, then the heat removed from secondary zone may have sensible and latent components and is treated as tnternal gain. The sensible/latent component split among other parameters requires secondary coil air flow rate. Hence secondary coil air flow rate sizing is added based on the primary DX cooling coil only.
+The secondary DX coils model does not have a standalone object and it is models as add-on feature to the DX Coils. When the secondary DX coil is added to a primary DX cooling coil, the heat rejected to secondary zone is sensible only and is treated as internal gain, hence secondary air flow rate is not required in the model. Where as when the secondary DX coil is added to a primary DX heating coil, then the heat removed from secondary zone may have sensible and latent components and is treated as internal gain. The sensible/latent component split among other parameters requires secondary coil air flow rate. Hence secondary coil air flow rate sizing is added based on the primary DX cooling coil only.
\begin{equation}
\dot{V}_{\rm{SecCoil}} = \dot{V}_{\rm{PriHeatCoil}} \cdot \text{ScalingFactor}
diff --git a/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/system-design-loads-and-air-flow-rates.tex b/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/system-design-loads-and-air-flow-rates.tex
index f422fa19524..c7428d785e9 100644
--- a/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/system-design-loads-and-air-flow-rates.tex
+++ b/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/system-design-loads-and-air-flow-rates.tex
@@ -164,7 +164,7 @@ \subsubsection{DuringDay}\label{duringday}
{\setlength\parindent{25pt} \(T_{outside}\) is the current outside air temperature {[}C{]}; }
{\setlength\parindent{25pt} \(W_{outside}\) is the current outside air humidity ratio {[}kg water / kg dry air{]}. }
-Note: When latent sizing is requested the zone design supply air humidity ratio used during zone latent sizing is used as the system cooling coil outlet air humidity ratio (\emph{w\(_{sup}\)}) for sytem cooling coil sizing. The system cooling coil outlet air humidity ratio is calculated as a mass flow rate weighted average of each zone's latent cooling supply air humidity ratio. See \emph{Sizing:Zone} field \emph{Zone Latent Cooling Design Supply Air Humidity Ratio Input Method}. This calculated value is used only when one or more zone latent load is found to be greater than that zone's sensible load, or latent only sizing is requested. A control method that enables the system cooling coil to dehumidify to the design latent supply air humidity ratio is suggested so that the system sensible load can be exceeded when additional dehumidification is required.
+Note: When latent sizing is requested the zone design supply air humidity ratio used during zone latent sizing is used as the system cooling coil outlet air humidity ratio (\emph{w\(_{sup}\)}) for system cooling coil sizing. The system cooling coil outlet air humidity ratio is calculated as a mass flow rate weighted average of each zone's latent cooling supply air humidity ratio. See \emph{Sizing:Zone} field \emph{Zone Latent Cooling Design Supply Air Humidity Ratio Input Method}. This calculated value is used only when one or more zone latent load is found to be greater than that zone's sensible load, or latent only sizing is requested. A control method that enables the system cooling coil to dehumidify to the design latent supply air humidity ratio is suggested so that the system sensible load can be exceeded when additional dehumidification is required.
\begin{enumerate}
@@ -239,7 +239,7 @@ \subsubsection{EndDay}\label{endday}
\emph{DesMainVolFlow\(_{sys}\)} = \textbf{Max}(\emph{DesCoolVolFlow\(_{sys}\)}, \emph{DesHeatVolFlow\(_{sys}\)})
-Based on the outdoor air method selected, the \emph{DesCoolVolFlow\(_{sys}\)} and \emph{DesHeatVolFlow\(_{sys}\)} are modified based on the system ventilation effciency calculated based on the maximum outdoor air fraction.
+Based on the outdoor air method selected, the \emph{DesCoolVolFlow\(_{sys}\)} and \emph{DesHeatVolFlow\(_{sys}\)} are modified based on the system ventilation efficiency calculated based on the maximum outdoor air fraction.
\subsubsection{EndSysSizingCalc}\label{endsyssizingcalc}
@@ -477,7 +477,7 @@ \subsection{System Design Outdoor Air Flow Rate}\label{Design-Outdoor-Air-Flow-R
\subsection{Scalable System HVAC Sizing}\label{scalable-system-HVAC-sizing}
-The scalable system sizing applies to system supply air flow rates and sysyem capacity in coolin and heating modes.
+The scalable system sizing applies to system supply air flow rates and system capacity in cooling and heating modes.
\textbf{Scalable System Air Flow Sizing}
diff --git a/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/zone-design-loads-and-air-flow-rates.tex b/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/zone-design-loads-and-air-flow-rates.tex
index ebae1962ad3..c0cffe63c7d 100644
--- a/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/zone-design-loads-and-air-flow-rates.tex
+++ b/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/zone-design-loads-and-air-flow-rates.tex
@@ -2,7 +2,7 @@ \section{Zone Design Loads and Air Flow Rates}\label{zone-design-loads-and-air-f
\subsection{Overview}\label{overview-030}
-There is no single best way to establish design HVAC flow rates and size HVAC equipment. Different building designs, climates, and HVAC systems will impose varying constraints on the designer. The method used to size an HVAC system in a hot, moist climate such as Miami will be different than the method used for a building in Albuquerque. The type of building is also relevant - a simple watts per square foot loads estimate could be adequate for a building containing a network server farm while a detailed, dynamic loads simulation would be necessary for a passive solar building. In the end the designer's experience and engineering judgement will play an important role in any sizing calculation.
+There is no single best way to establish design HVAC flow rates and size HVAC equipment. Different building designs, climates, and HVAC systems will impose varying constraints on the designer. The method used to size an HVAC system in a hot, moist climate such as Miami will be different than the method used for a building in Albuquerque. The type of building is also relevant - a simple watts per square foot loads estimate could be adequate for a building containing a network server farm while a detailed, dynamic loads simulation would be necessary for a passive solar building. In the end the designer's experience and engineering judgment will play an important role in any sizing calculation.
HVAC equipment sizing begins with the calculation of space heating and cooling sensible and/or latent loads. A space cooling (heating) sensible load is defined as the rate at which heat must be removed (added) to a space to maintain a constant zone temperature. A space cooling (heating) latent load is defined as the rate at which moisture must be removed (added) to a space to maintain a constant zone moisture/humidity ratio/relative humidity level. The current industry standard method for calculating space loads is the \emph{heat balance method} {[}ASHRAE Fundamentals (2001), page 29.1; Pedersen et al., (1997); Pedersen (2001). Since EnergyPlus is a heat balance based simulation program it is straightforward for the program to use this method for calculating zone loads.
@@ -111,7 +111,7 @@ \subsection{Zone Design Load Calculation}\label{zone-design-load-calculation}
In module \emph{HVACManager}, subroutine \emph{ManageHVAC} calls \emph{SimHVAC}. \emph{SimHVAC} checks \emph{ZoneSizingCalc}. If it is \emph{true}, \emph{SimHVAC} calls \emph{ManageZoneEquipment} and returns, rather than simulating the actual system. In turn \emph{ManageZoneEquipment} checks if \emph{ZoneSizingCalc} is \emph{true}; if it is it calls \emph{SizeZoneEquipment} rather than \emph{SimZoneEquipment}.
-\emph{SizeZoneEquipment} assumes that each controlled zone is served by an ideal air conditioning unit. This unit supplies sensible and latent (if latent sizing is requeted) heating or cooling air at a fixed, user input temperature and humidity (specified in the Sizing:Zone objects). The units have infinite capacity: the flow rate can be any amount. Zone humidity is controlled at a constant level when latent sizing is requested, otherwise zone humidity is allowed to float. The sensible and latent loads and air mass flow rates are saved and reported to \emph{eplusout.zsz}.
+\emph{SizeZoneEquipment} assumes that each controlled zone is served by an ideal air conditioning unit. This unit supplies sensible and latent (if latent sizing is requested) heating or cooling air at a fixed, user input temperature and humidity (specified in the Sizing:Zone objects). The units have infinite capacity: the flow rate can be any amount. Zone humidity is controlled at a constant level when latent sizing is requested, otherwise zone humidity is allowed to float. The sensible and latent loads and air mass flow rates are saved and reported to \emph{eplusout.zsz}.
Before the ideal zone load is calculated, the function checks whether the user wants to account for the heat gain or loss caused by the ventilation air from a Dedicated Outdoor Air System (DOAS). If the user has selected \emph{Account For Dedicated Outdoor Air = Yes} the function performs an ideal DOAS calculation. The DOAS supply temperature is set according to the user's choice of 1 of 3 possible control strategies: \emph{NeutralSupplyAir}, \emph{NeutralDehumidifiedSupplyAir}, or \emph{ColdSupplyAir}. This value is saved and reported to \emph{eplusout.zsz}. The different strategies are:
@@ -119,7 +119,7 @@ \subsection{Zone Design Load Calculation}\label{zone-design-load-calculation}
\item
\emph{DOAS Control Strategy = NeutralSupplyAir}. The purpose of this strategy is to cool or heat the outdoor air (OA) to keep it between the \emph{T\(_{l}\)} and \emph{T\(_{h}\)} setpoints.
\item
- \emph{DOAS Control Strategy = Neutral Dehumidified Supply Air}. The purpose of this strategy is to cool and dehumidify the outdoor air, then reheat it to a ``neutral'' temperature so that no sensible load is imposed on the space or AHU unit. The DOAS will with this strategy handle some or all of the latent load. If the outdoor air temperature is greater than \emph{T\(_{l}\)} the outdoor air is cooled to \emph{T\(_{l}\)} and reheated to \emph{T\(_{h}\)}. If the outdoor air temperaure is below \emph{T\(_{l}\)} it is heated to \emph{T\(_{h}\)}.
+ \emph{DOAS Control Strategy = Neutral Dehumidified Supply Air}. The purpose of this strategy is to cool and dehumidify the outdoor air, then reheat it to a ``neutral'' temperature so that no sensible load is imposed on the space or AHU unit. The DOAS will with this strategy handle some or all of the latent load. If the outdoor air temperature is greater than \emph{T\(_{l}\)} the outdoor air is cooled to \emph{T\(_{l}\)} and reheated to \emph{T\(_{h}\)}. If the outdoor air temperature is below \emph{T\(_{l}\)} it is heated to \emph{T\(_{h}\)}.
\item
\emph{DOAS Control Strategy = ColdSupplyAir}. The purpose of this strategy is to provide cool, dehumidified ventilation air to the zone. In this case the DOAS can handle part of the sensible zone cooling load as well as meet part or all of the latent load. If the outdoor air temperature is below \emph{T\(_{l}\)} it is heated to \emph{T\(_{h}\)}. If it is above \emph{T\(_{l}\)}, it is cooled to \emph{T\(_{l}\)}.
\end{itemize}
diff --git a/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/zone-outdoor-air-design-data.tex b/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/zone-outdoor-air-design-data.tex
index a29a15e7a04..46adde99728 100644
--- a/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/zone-outdoor-air-design-data.tex
+++ b/doc/engineering-reference/src/loop-equipment-sizing-and-other-design-data/zone-outdoor-air-design-data.tex
@@ -16,7 +16,7 @@ \section{Zone Outdoor Air Design Data}\label{zone-outdoor-air-design-data}
Outdoor air changes per hour
\end{itemize}
-This design data is entered in an outdoor air design data object and may be referenced by other objects during the simulation. A single specification for outdoor air design data may be used by all other appropriate objects within EnergyPlus, or multiple outdoor air design data objects may be specified and these design data objects may be used as necessary by other objects when outdoor air design quantaties vary for any reason.
+This design data is entered in an outdoor air design data object and may be referenced by other objects during the simulation. A single specification for outdoor air design data may be used by all other appropriate objects within EnergyPlus, or multiple outdoor air design data objects may be specified and these design data objects may be used as necessary by other objects when outdoor air design quantities vary for any reason.
\subsection{Design Outdoor Air Calculation}\label{design-outdoor-air-calculation}
diff --git a/doc/engineering-reference/src/on-site-generation/electric-load-center-distribution-manager.tex b/doc/engineering-reference/src/on-site-generation/electric-load-center-distribution-manager.tex
index fa71c1239cd..3322c95ce26 100644
--- a/doc/engineering-reference/src/on-site-generation/electric-load-center-distribution-manager.tex
+++ b/doc/engineering-reference/src/on-site-generation/electric-load-center-distribution-manager.tex
@@ -102,7 +102,7 @@ \subsection{Inverters}\label{inverters}
{P_{AC - out}} = {P_{DC - in}} \cdot {\varepsilon_{inverter}}
\end{equation}
-The inverter efficiency is determined using one of the three models. For the ``Simple'' inveter model, efficiency is constant and input by the user. For the ``Look Up Table'' model, the efficiency is calculated using linear interpolation. For the ``Function of Power'' model, the efficiency is calculating using a single-variable curve object. For both the Look Up Table and Function of Power models, the power production is normalized by \({P_{DC - in}}\).
+The inverter efficiency is determined using one of the three models. For the ``Simple'' inverter model, efficiency is constant and input by the user. For the ``Look Up Table'' model, the efficiency is calculated using linear interpolation. For the ``Function of Power'' model, the efficiency is calculating using a single-variable curve object. For both the Look Up Table and Function of Power models, the power production is normalized by \({P_{DC - in}}\).
The conversion power losses are calculated from the difference between ${P_{DC,in}}$ and ${P_{AC,out}}$ and are metered as negative values on PowerConversion:ElectricityProduced. The thermal losses include the conversion power losses plus any ancillary power consumed during standby. The ancillary electric power consumption occurs when the inverter is scheduled to be available but it is not conditioning any power flows at the time.
@@ -527,13 +527,13 @@ \subsubsection{References}\label{references-022-b}
N. DiOrio et al. Technoeconomic modeling of battery energy storage in SAM. Tech. rep. National Renewable Energy Lab. (NREL), Golden, CO (United States), 2015.
\noindent
-K. Smith et al. “Life prediction model for grid-connected Li-ion batteryenergy storage system”. In: 2017 American Control Conference (ACC). IEEE. 2017, pp. 4062–4068.
+K. Smith et al. “Life prediction model for grid-connected Li-ion battery energy storage system”. In: 2017 American Control Conference (ACC). IEEE. 2017, pp. 4062–4068.
\noindent
-O. Tremblay, L.-A. Dessaint, and A.-I. Dekkiche. “A generic battery modelfor the dynamic simulation of hybrid electric vehicles”. In: 2007 IEEE Vehicle Power and Propulsion Conference. Ieee. 2007, pp. 284–289.
+O. Tremblay, L.-A. Dessaint, and A.-I. Dekkiche. “A generic battery model for the dynamic simulation of hybrid electric vehicles”. In: 2007 IEEE Vehicle Power and Propulsion Conference. Ieee. 2007, pp. 284–289.
\noindent
-P. P. Mishra et al. “Analysis of degradation in residential battery energystorage systems for rate-based use-cases”. In: Applied Energy 264 (2020), p. 114632.
+P. P. Mishra et al. “Analysis of degradation in residential battery energy storage systems for rate-based use-cases”. In: Applied Energy 264 (2020), p. 114632.
\subsection{Electric Load Center Transformers}\label{electric-load-center-transformers}
diff --git a/doc/engineering-reference/src/on-site-generation/generators.tex b/doc/engineering-reference/src/on-site-generation/generators.tex
index 4e7719e8f68..29c998edcc0 100644
--- a/doc/engineering-reference/src/on-site-generation/generators.tex
+++ b/doc/engineering-reference/src/on-site-generation/generators.tex
@@ -1,6 +1,6 @@
\section{Generators}\label{generators}
-\subsection{Internal Cumbustion Engine}\label{internal-cumbustion-engine}
+\subsection{Internal Combustion Engine}\label{internal-combustion-engine}
The engine-driven generator model was originally developed for the BLAST program and was subsequently adapted for use in EnergyPlus. The model uses the following set of equations all of which are quadratic fits to the PLR (Part Load Ratio) of the generator.~ The coefficients must be derived from manufacturers data.
@@ -698,7 +698,7 @@ \subsection{Micro-Cogenerator}\label{micro-cogenerator}
The engine and heat recovery thermal conditions are modeled for all modes so, for example, an engine that is off but still warm could provide some hot water recovery.
-The engine model can use an arbitray fuel mixture that is defined by the user -- see the entry for Generator:FuelSupply.
+The engine model can use an arbitrary fuel mixture that is defined by the user -- see the entry for Generator:FuelSupply.
\subsubsection{References}\label{references-024}
diff --git a/doc/engineering-reference/src/on-site-generation/photovoltaic-arrays.tex b/doc/engineering-reference/src/on-site-generation/photovoltaic-arrays.tex
index 6b02fa6e619..7b5fda3dc7d 100644
--- a/doc/engineering-reference/src/on-site-generation/photovoltaic-arrays.tex
+++ b/doc/engineering-reference/src/on-site-generation/photovoltaic-arrays.tex
@@ -222,7 +222,7 @@ \subsubsection{Mathematical Description}\label{mathematical-description-1}
The PV model uses one of five methods for determining cell temperature data. The cell temperature of a PV module is important because the hotter the temperature of the panel, the lower its electrical output. The cell temperature calculation method is chosen by the user in the EnergyPlus IDF file through a parameter choice in the IDD entry called Integration and Cell Temperature Mode.
-If the value of this parameter is ``\textbf{Decoupled NOCT Conditions}'' then the cell temperature of the PV is modeled using the method from the Duffie and Beckman (1991) for estimating cell temperature. This is based upon the standard NOCT (Nominal Operating Cell Temperature) measurements to compute the module temperature \(T_c\) at each timestep. The NOCT temperature (\(T_c\),NOCT) is the operating temperature of the module with a wind speed of 1 m/s, no electrical load, and a certain specified insolation and ambient temperature {[}Beckman and Duffie, 1991{]}. The values for insolation GT,NOCT ~and ambient temperature \(T_{a,NOCT}\) are usually 800 W/m\(^{2}\) and 20\(^{\circ}\)C. \(\eta_{c}\) is the convesion efficiency of the module, which varies with ambient conditions. \({\tau \alpha}\) is a user-defined constant.
+If the value of this parameter is ``\textbf{Decoupled NOCT Conditions}'' then the cell temperature of the PV is modeled using the method from the Duffie and Beckman (1991) for estimating cell temperature. This is based upon the standard NOCT (Nominal Operating Cell Temperature) measurements to compute the module temperature \(T_c\) at each timestep. The NOCT temperature (\(T_c\),NOCT) is the operating temperature of the module with a wind speed of 1 m/s, no electrical load, and a certain specified insolation and ambient temperature {[}Beckman and Duffie, 1991{]}. The values for insolation GT,NOCT ~and ambient temperature \(T_{a,NOCT}\) are usually 800 W/m\(^{2}\) and 20\(^{\circ}\)C. \(\eta_{c}\) is the conversion efficiency of the module, which varies with ambient conditions. \({\tau \alpha}\) is a user-defined constant.
The equation is:
@@ -236,7 +236,7 @@ \subsubsection{Mathematical Description}\label{mathematical-description-1}
{\left. {{T_{cell}}} \right|_t} = {T_{ambient}} + \left( {{{\left. {{T_{cell}}} \right|}_{t - 1}} - {T_{ambient}}} \right)*{e^{\frac{{ - UL}}{{Cap}}\Delta t}}
\end{equation}
-In other words, the cell temperature is a function of the privious cell temperature and the thermal capacity of the PV module material.
+In other words, the cell temperature is a function of the previous cell temperature and the thermal capacity of the PV module material.
If the user specifies ``\textbf{Integrated Surface Outside Face''} for this parameter, then the temperature result from EnergyPlus's modeling of surfaces is used for the cell temperature. Also the energy exported from the surface as electricity becomes a sink in the internal source modeling for the heat transfer surface.
@@ -326,8 +326,8 @@ \subsubsection{Mathematical Description}\label{mathematical-description-2}
m\(_{\beta}\)\(_{Voco}\) & Coefficient for irradiance dependence of open-circuit-voltage-temperature coefficient, often zero (V/\(^{\circ}\)C) \tabularnewline
$\beta$\(_{Vmp}\)(E\(_{e}\)) & Temperature coefficient for module maximum-power-voltage as a function of E \tabularnewline
$\beta$\(_{Vmpo}\) & Temperature coefficient for module maximum-power-voltage at reference conditions \tabularnewline
-m\(_{\beta}\)\(_{Voco}\) & Cofficient for irradiance dependence of maximum-power-voltage-temperature coefficient, often zero (V/\(^{\circ}\)C) \tabularnewline
-T\(_{m}\) & PV module temperature at back suface (\(^{\circ}\)C) \tabularnewline
+m\(_{\beta}\)\(_{Voco}\) & Coefficient for irradiance dependence of maximum-power-voltage-temperature coefficient, often zero (V/\(^{\circ}\)C) \tabularnewline
+T\(_{m}\) & PV module temperature at back surface (\(^{\circ}\)C) \tabularnewline
T\(_{a}\) & Ambient outdoor drybulb temperature (\(^{\circ}\)C) \tabularnewline
E & Solar irradiance incident on module surface (W/m\(^{2}\)) \tabularnewline
WS & Wind speed at standard 10-m height (m/s) \tabularnewline
diff --git a/doc/engineering-reference/src/performance-curves-and-lookup-tables/performance-curves.tex b/doc/engineering-reference/src/performance-curves-and-lookup-tables/performance-curves.tex
index 011df508229..039f7cb1c15 100644
--- a/doc/engineering-reference/src/performance-curves-and-lookup-tables/performance-curves.tex
+++ b/doc/engineering-reference/src/performance-curves-and-lookup-tables/performance-curves.tex
@@ -94,7 +94,7 @@ \subsubsection{BiCubic Curves}\label{bicubic-curves}
z = a + bx + c{x^2} + dy + e{y^2} + fxy + g{x^3} + h{y^3} + i{x^2}y
\end{equation}
-Calulating performance curve coefficients in a spreadsheet is a simple matter of finding the data required to perform the regression analysis. For example, the biquadratic equation shown above is representative of the cooling capacity as a function of temperature performance curve for DX cooling coils. The fundamental equation for DX cooling coil capacity is:
+Calculating performance curve coefficients in a spreadsheet is a simple matter of finding the data required to perform the regression analysis. For example, the biquadratic equation shown above is representative of the cooling capacity as a function of temperature performance curve for DX cooling coils. The fundamental equation for DX cooling coil capacity is:
\begin{equation}
TotCapTempModFac = a + b\left( {{T_{wb,i}}} \right) + c{\left( {{T_{wb,i}}} \right)^2} + d\left( {{T_{c,i}}} \right) + e{\left( {{T_{c,i}}} \right)^2} + f\left( {{T_{wb,i}}} \right)\left( {{T_{c,i}}} \right)
@@ -106,7 +106,7 @@ \subsubsection{BiCubic Curves}\label{bicubic-curves}
\(T_{c,i}\) (or \(T_{db,i}\)) is the dry-bulb temperature of the air entering an air-cooled condenser (\(^{\circ}\)C).
-Given the data set shown in Figure~\ref{fig:dx-cooling-data-table}, each of the independent variables would be calculated according to the fundamental equation above (i.e., the T, T\(^{2}\), and cross-product terms would be multiplied out). The data would be converted to degrees celcius and the cooling capacity would be converted to Watts. The data would also be normalized using the ARI rating point shown as highlighted in Figure~\ref{fig:dx-cooling-data-normalized}.
+Given the data set shown in Figure~\ref{fig:dx-cooling-data-table}, each of the independent variables would be calculated according to the fundamental equation above (i.e., the T, T\(^{2}\), and cross-product terms would be multiplied out). The data would be converted to degrees Celsius and the cooling capacity would be converted to Watts. The data would also be normalized using the ARI rating point shown as highlighted in Figure~\ref{fig:dx-cooling-data-normalized}.
\begin{figure}[htbp]
\centering
@@ -122,7 +122,7 @@ \subsubsection{BiCubic Curves}\label{bicubic-curves}
\caption{Regression Analysis for Example \protect \label{fig:dx-cooling-data-normalized}}
\end{figure}
-The regression analysis and summary statistical output is shown below. The equation coefficients are shown highlighted. In this example, the equation coefficents are: a = 0.757382, b = 0.014666, c = 0.000459, d = -0.00095, e = -6.7E-05, and f = -0.00015. These coefficients would be entered in a Curve:BiQuadratic object and used to describe the cooling capacity as a function of temperature for the DX cooling coil model. Minimum and Maximum values from the tabular data are entered as Min/Max values for the curve object. The values may be relaxed slightly with care to allow extrapolation as needed. A performance table may be used to automatically perform the regression analysis as described in the following section.
+The regression analysis and summary statistical output is shown below. The equation coefficients are shown highlighted. In this example, the equation coefficients are: a = 0.757382, b = 0.014666, c = 0.000459, d = -0.00095, e = -6.7E-05, and f = -0.00015. These coefficients would be entered in a Curve:BiQuadratic object and used to describe the cooling capacity as a function of temperature for the DX cooling coil model. Minimum and Maximum values from the tabular data are entered as Min/Max values for the curve object. The values may be relaxed slightly with care to allow extrapolation as needed. A performance table may be used to automatically perform the regression analysis as described in the following section.
\begin{figure}[htbp]
\centering
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-001/coils.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-001/coils.tex
index 8bbb6116ccb..5e6118cbf05 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-001/coils.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-001/coils.tex
@@ -224,11 +224,11 @@ \subsubsection{Design Block Calculations}\label{design-block-calculations}
Airside combined heat and mass transfer coefficient = 140 (W/m\(^2\)-\(^{\circ}\)C)
\end{itemize}
-Interior and exterior U values (really UA's per unit exterior surface area) are calculated by dividing the above UA's by the area. The resulting U\(_{coil,ext}\) is assumed to be U\(_{coil,ext,wet}\); U\(_{coil,ext,dry}\) is set equal to U\(_{coil,ext,wet}\). We now have all the starting values needed for inverting the simple coil model using the chosen root solver iterative method. Once the iteration is completed, we have coil UA's and U's that yield the design outlet air and water enthalpies given the inlet design conditions and flow rates. Note that the simple coil model can not exactly match the specified design outlet air temperature and humidity ratio. It can only match the design air outlet enthalpy. Generally the simple coil model will yield outlet conditions near the saturation curve if any dehumidification is occuring. Typical outlet relative humidities are around 95\%.
+Interior and exterior U values (really UA's per unit exterior surface area) are calculated by dividing the above UA's by the area. The resulting U\(_{coil,ext}\) is assumed to be U\(_{coil,ext,wet}\); U\(_{coil,ext,dry}\) is set equal to U\(_{coil,ext,wet}\). We now have all the starting values needed for inverting the simple coil model using the chosen root solver iterative method. Once the iteration is completed, we have coil UA's and U's that yield the design outlet air and water enthalpies given the inlet design conditions and flow rates. Note that the simple coil model can not exactly match the specified design outlet air temperature and humidity ratio. It can only match the design air outlet enthalpy. Generally the simple coil model will yield outlet conditions near the saturation curve if any dehumidification is occurring. Typical outlet relative humidities are around 95\%.
\subsubsection{Variable UA}\label{variable-ua}
-The above calculations yield coil UA's for the design inlet conditions and air and water flow rates. As the flow rates vary during the time step calculations, the UA's need to be adjusted, since coil UA's are a rather strong function of air and water side flow rates. Each time step the coil UA's are modified using the same formulas as are used in the hot water coil model. Refer to that model for the flow dependences.
+The above calculations yield coil UA's for the design inlet conditions and air and water flow rates. As the flow rates vary during the time step calculations, the UA's need to be adjusted, since coil UA's are a rather strong function of air and water side flow rates. Each time step the coil UA's are modified using the same formulas as are used in the hot water coil model. Refer to that model for the flow dependencies.
\subsubsection{Operating Block Calculations:}\label{operating-block-calculations}
@@ -528,7 +528,7 @@ \subsubsection{Coil Part Wet Part Dry Calculations (operating block)}\label{coil
\subsubsection{References}\label{references-011}
-IBPSA BuildSim-2004. 2004. Colarado Boulder: An Improvement of Ashrae Secondary HVAC toolkit Simple Cooling Coil Model for Building Simulation, Rahul J Chillar, Richard J Liesen M\&IE ,UIUC.
+IBPSA BuildSim-2004. 2004. Colorado Boulder: An Improvement of Ashrae Secondary HVAC toolkit Simple Cooling Coil Model for Building Simulation, Rahul J Chillar, Richard J Liesen M\&IE ,UIUC.
Stoecker, W.F. \textless{}dates unspecified\textgreater{} Design of Thermal Systems,: ME 423 Class Notes , M\& IE Dept UIUC.
@@ -1258,7 +1258,7 @@ \subsubsection{SHR Calculation Using User Specified SHR Modifier Curves}\label{s
{h_{out}} = {h_{in}} - \frac{{{{\dot Q}_{total}}}}{{\dot m}}
\end{equation}
-The cooling coil outlet air enthalpy at the coil enlet air temperature and coil outlet humidity ratio is given by:
+The cooling coil outlet air enthalpy at the coil inlet air temperature and coil outlet humidity ratio is given by:
\begin{equation}
{h_{{T_{in}}{\omega_{out}}}} = {h_{in}} - \left( {1.0 - SHR} \right)\frac{{{{\dot Q}_{total}}}}{{\dot m}}
@@ -1362,7 +1362,7 @@ \subsubsection{Supply Air Fan Control: Cycling vs.~Continuous}\label{supply-air-
For the case of cycling fan/cycling compressor when humidity control is not specified, the conditions of the air leaving the cooling coil are the steady-state values calculated using Equations~\ref{eq:CoilSHRhout},~\ref{eq:CoilSHRomegaout}, and~\ref{eq:CoilSHRTdbout} above. However the air mass flow rate passed along to the next component (and eventually to the conditioned zone) is the average air mass flow rate for the system simulation time step (determined by the cooling system; see ZoneHVAC:WindowAirConditioner, AirLoopHVAC:Unitary:Furnace:HeatCool, AirLoopHVAC:UnitaryHeatCool, or AirLoopHVAC:UnitaryHeatPump:AirToAir).
-For the case of cycling fan/cyling compressor when humidity control is specified, the conditions of the air leaving the cooling coil are calculated as the average conditions during the fan operating period. When the compressor operates in tandem with the fan (i.e., compressor part-load ratio {[}PLR{]} is equal to the fan PLR), the outlet conditions are identical to the calculations described above. When the compressor operates for a shorter duration than the fan (i.e., the compressor PLR is less than the heating/fan PLR), the air properties leaving the cooling coil are calculated as the average conditions during the fan operating period. In this case the calculation of exiting air conditions is analogous to the calculations for continuous fan mode described below except that PLR in the equations represents the ratio of the compressor to the fan operating period. For cycling fan systems, the fan will only operate longer than the compressor, and therefore latent degradation may be modeled (user input), when humidity control is specified, a moisture load exists (i.e., the zone air humidistat senses a moisture load), and a heating load exists where the heating PLR is greater than the cooling PLR.
+For the case of cycling fan/cycling compressor when humidity control is specified, the conditions of the air leaving the cooling coil are calculated as the average conditions during the fan operating period. When the compressor operates in tandem with the fan (i.e., compressor part-load ratio {[}PLR{]} is equal to the fan PLR), the outlet conditions are identical to the calculations described above. When the compressor operates for a shorter duration than the fan (i.e., the compressor PLR is less than the heating/fan PLR), the air properties leaving the cooling coil are calculated as the average conditions during the fan operating period. In this case the calculation of exiting air conditions is analogous to the calculations for continuous fan mode described below except that PLR in the equations represents the ratio of the compressor to the fan operating period. For cycling fan systems, the fan will only operate longer than the compressor, and therefore latent degradation may be modeled (user input), when humidity control is specified, a moisture load exists (i.e., the zone air humidistat senses a moisture load), and a heating load exists where the heating PLR is greater than the cooling PLR.
Continuous Fan Mode:
@@ -1577,9 +1577,9 @@ \subsubsection{Special Calculations for Coil:Cooling:DX:TwoStageWithHumidityCont
\paragraph{Subcool Reheat Mode}\label{subcool-reheat-mode}
-When 3 operation modes are entered in the Coil:Cooling:DX:CurveFit:Performance object with a parent as Coil:Cooling:DX, the coil is considered as a Subcool Reheat Coil and can perfom normal DX coil operation alone, and combined sensible cooling and dehumidification simultaneously with combination of normal mode and subcool or reheat mode. Load sensible heat ratio (LoadSHR) ( Zone Sensible Load / ( Zone Sensible Load + Zone Latent Load)) determines which mode operates.
+When 3 operation modes are entered in the Coil:Cooling:DX:CurveFit:Performance object with a parent as Coil:Cooling:DX, the coil is considered as a Subcool Reheat Coil and can perform normal DX coil operation alone, and combined sensible cooling and dehumidification simultaneously with combination of normal mode and subcool or reheat mode. Load sensible heat ratio (LoadSHR) ( Zone Sensible Load / ( Zone Sensible Load + Zone Latent Load)) determines which mode operates.
-The zone sensible and latent loads determine the coil delivered energy between system supply node and controlled zone node. Due to fan heat and outdoor air introduction, the coil inlet node conditions are not equal to ones at the controlled zone node. In other words, the requested coil output sensible heat ratio (CoilSHR) (Sensible Coil output / (Sensible Coil Output + Latent Coile Output)) will be different from LoadSHR. The given LoadSHR needs to be converted into coil sensible heat ratio (CoilSHR), so that coil requested sensible and latent energy can be delivered correctly to control zone temperature and humidity ratio simultaneously.
+The zone sensible and latent loads determine the coil delivered energy between system supply node and controlled zone node. Due to fan heat and outdoor air introduction, the coil inlet node conditions are not equal to ones at the controlled zone node. In other words, the requested coil output sensible heat ratio (CoilSHR) (Sensible Coil output / (Sensible Coil Output + Latent Coil Output)) will be different from LoadSHR. The given LoadSHR needs to be converted into coil sensible heat ratio (CoilSHR), so that coil requested sensible and latent energy can be delivered correctly to control zone temperature and humidity ratio simultaneously.
CoilSHR calculation procedure
@@ -1593,7 +1593,7 @@ \subsubsection{Special Calculations for Coil:Cooling:DX:TwoStageWithHumidityCont
3. At the same time, coil sensible and latent outputs across the coil are obtained in Step 2 as SenCoilOutput and LatCoilOutput.
-4. If coil sensible and latent outputs are also propotional to the part load ratios, sensible (SenCoil) and latent (LatCoil) coil load at given part load ratios are calculated as
+4. If coil sensible and latent outputs are also proportional to the part load ratios, sensible (SenCoil) and latent (LatCoil) coil load at given part load ratios are calculated as
SenCoil = SenPLR * SenCoilOutput
@@ -1639,7 +1639,7 @@ \subsubsection{Special Calculations for Coil:Cooling:DX:TwoStageWithHumidityCont
Else
- Performreheatg operation
+ Perform reheating operation
SenLoad = SenOut\(_{Reheat}\) * PLR
@@ -1831,7 +1831,7 @@ \subsubsection{Seasonal Energy Efficiency Ratio (SEER) for Single-Speed DX Coil}
where \(\% Load\) is the part-load operating points, i.e., 75\% (B), 50\% (C), 25\% (D).
-The calculations for \(Q_{Total,Net,PartLoad}\) and \(Power_{Total,PartLoad}\) are calculated in nearly the same way as \(Q_{Total,Net,TestB}\) and \(Power_{Total,TestB}\) are calculated for SEER (defined above). The only difference is that these cooling capacity and power values, used for calculating \(EER_{B} / EER_{C} / EER_{D}\) for IEER, are calculated for a series of dry-bulb temperatures of air entering the air-cooled condenser (B = 27.5\(^{\circ}\)C, C = 20.0\(^{\circ}\)C, D = 18.3\(^{\circ}\)C) and part-load performance degradiation correction is also applied to the condensing unit electric power calculation.
+The calculations for \(Q_{Total,Net,PartLoad}\) and \(Power_{Total,PartLoad}\) are calculated in nearly the same way as \(Q_{Total,Net,TestB}\) and \(Power_{Total,TestB}\) are calculated for SEER (defined above). The only difference is that these cooling capacity and power values, used for calculating \(EER_{B} / EER_{C} / EER_{D}\) for IEER, are calculated for a series of dry-bulb temperatures of air entering the air-cooled condenser (B = 27.5\(^{\circ}\)C, C = 20.0\(^{\circ}\)C, D = 18.3\(^{\circ}\)C) and part-load performance degradation correction is also applied to the condensing unit electric power calculation.
\subsubsection{ANSI/ASHRAE 127 - Standard Ratings of Single-Speed DX Cooling Coils}\label{ansiashrae-127---standard-ratings-of-single-speed-dx-cooling-coils}
@@ -1960,7 +1960,7 @@ \subsubsection{Model Inputs}\label{model-inputs}
\subsubsection{Speed 1 Operation}\label{speed-1-operation}
-The calculation procedures in this model, including defrost and crankcase heater, are indentical to the Coil:Heating:DX:SingleSpeed object (Ref: Coil:Heating:DX:SingleSpeed) with one exception: outlet node condition calculation when the supply air fan operates continuously (i.e., supply air fan operating mode schedule value is not equal to 0; Ref. AirLoopHVAC:UnitaryHeatPump:AirToAir:MultiSpeed).
+The calculation procedures in this model, including defrost and crankcase heater, are identical to the Coil:Heating:DX:SingleSpeed object (Ref: Coil:Heating:DX:SingleSpeed) with one exception: outlet node condition calculation when the supply air fan operates continuously (i.e., supply air fan operating mode schedule value is not equal to 0; Ref. AirLoopHVAC:UnitaryHeatPump:AirToAir:MultiSpeed).
The following procedure provides the detailed description of the exception.
@@ -2305,7 +2305,7 @@ \subsubsection{Standard Rating of Multi-Speed DX Cooling Coils}\label{standard-r
For multi-speed direct expansion cooling coils, the following industry standard ratings are calculated and reported according to the industry standards listed below:
ANSI/AHRI Standard 210-240 (AHRI 2017 and 2023)
-[AHRI 2017] For multi-speed direct expansion cooling coils, the industry standard ratings are calculated according to ANSI/AHRI Standard 210-240 (AHRI 2017). These Standard Ratings are: Standard Rating Cooling Capacity and Seasonal Energy Efficiency Ratio (SEER). These standard ratings are calculated using the user-entered data in the Coil:Cooling:DX:MultiSpeed object. These AHRI Standard ratings apply only to air-to-air unitary heat pumps and air conditioners with rated cooling capacities less than 65,000 Btu/h (19,000 Watts). The equations required to calculate the net cooling capacity and SEER values aaccording to the AHRI 2017 standard are outlined in the next two sections. Further detail can be found in the AHRI Standard 210-240 (2017) (section 11).
+[AHRI 2017] For multi-speed direct expansion cooling coils, the industry standard ratings are calculated according to ANSI/AHRI Standard 210-240 (AHRI 2017). These Standard Ratings are: Standard Rating Cooling Capacity and Seasonal Energy Efficiency Ratio (SEER). These standard ratings are calculated using the user-entered data in the Coil:Cooling:DX:MultiSpeed object. These AHRI Standard ratings apply only to air-to-air unitary heat pumps and air conditioners with rated cooling capacities less than 65,000 Btu/h (19,000 Watts). The equations required to calculate the net cooling capacity and SEER values according to the AHRI 2017 standard are outlined in the next two sections. Further detail can be found in the AHRI Standard 210-240 (2017) (section 11).
[AHRI 2023] Support for the 2023 version of this Standard was added in EnergyPlus version 22.2. The updated Standard Ratings are designated as: Standard Rating (Net) Cooling Capacity, Energy Efficiency Ratio (EER2), and Seasonal Energy Efficiency Ratio (SEER2). As with th 2017 version, this standard and ratings apply only to air-to-air unitary heat pumps and air conditioners with rated cooling capacities less than 65,000 Btu/h (19 kW). The equations used in this implementation are detailed in the AHRI standard (Section 11). The reader can download the standard document to view these details from AHRI(https://www.ahrinet.org/search-standards/ahri-210240-2023-2020-performance-rating-unitary-air-conditioning-air-source-heat).
ANSI/AHRI Standard 340-360 (AHRI 2022)
@@ -2490,7 +2490,7 @@ \subsubsection{Seasonal Energy Efficiency Ratio (SEER) for Multi-Speed DX Coil}\
\(FanPowerPerVolFlowRat{e^{k = 2}}\) is the the Rated Evaporator (Indoor Coil) Fan Power Per Volume Flow rate at maximum (high) compressor speed specified value by the user (W/(m\(^3\)/s)).
-The above steps show how the cooling capacity and electric power inputs are determined when the DX cooling coil is operating at minimum (low) and maximum (high) compressor speeds.~ But the unit may operate at minimum (low) speed capacity, cycle on--off, cycle between successiave lower and higher compressor speed capacity, or operate at maximum (high) speed capacity depending on the building cooling load. The operating range of the DX cooling coil is determined based on the building cooling load for each binned outside air temperature. The building cooling load at an outdoor air temperature \(T_{j}\), is calculated as follows:
+The above steps show how the cooling capacity and electric power inputs are determined when the DX cooling coil is operating at minimum (low) and maximum (high) compressor speeds.~ But the unit may operate at minimum (low) speed capacity, cycle on--off, cycle between successive lower and higher compressor speed capacity, or operate at maximum (high) speed capacity depending on the building cooling load. The operating range of the DX cooling coil is determined based on the building cooling load for each binned outside air temperature. The building cooling load at an outdoor air temperature \(T_{j}\), is calculated as follows:
\begin{equation}
BL({T_j}) = \left( {\frac{{{T_j} - 18.3}}{{35.0 - 18.3}}} \right)\left( {\frac{{\dot Q_c^{k = 2}(35.0)}}{{1.1}}} \right)
@@ -3191,7 +3191,7 @@ \subsection{Electric Air Heating Coil}\label{electric-air-heating-coil}
~~~~~ QCoilCap = CapacitanceAir*(TempSetPoint - TempAirIn)
-~~~~~ ! check to see if setpoint above enetering temperature. If not, set
+~~~~~ ! check to see if setpoint above entering temperature. If not, set
~~~~~ ! output to zero.
@@ -3799,7 +3799,7 @@ \subsubsection{References}\label{references-5-001}
\subsection{Single-Speed DX Heating Coil Standard Ratings}\label{single-speed-dx-heating-coil-standard-ratings}
-For single-speed direct expansion (DX) heating coils, the industry standard ratings are calculated according to the ANSI/AHRI Standard 210-240 (AHRI 2008/AHRI 2017). The equations presented in this section are from these two versions of the standard. These ratings are: High Temperature Heating Standard (Net) Rating Capacity, Low Temperature Heating Standard (Net) Rating Capacity and Heating Seasonal Performance Factor (HSPF). The rated Energy Efficiency Ratio (EER) is not calculated for any DX heatings coils at this time.
+For single-speed direct expansion (DX) heating coils, the industry standard ratings are calculated according to the ANSI/AHRI Standard 210-240 (AHRI 2008/AHRI 2017). The equations presented in this section are from these two versions of the standard. These ratings are: High Temperature Heating Standard (Net) Rating Capacity, Low Temperature Heating Standard (Net) Rating Capacity and Heating Seasonal Performance Factor (HSPF). The rated Energy Efficiency Ratio (EER) is not calculated for any DX heating coils at this time.
For the Coil:Heating:DX:SingleSpeed object in EnergyPlus, these standard ratings are not direct inputs to the model. However, these standard ratings can are calculated using user-entered data for the Coil:Heating:DX:SingleSpeed object. These standard rating values are provided in the eplusout.eio output file (Ref. OutputDetailsAndExamples.pdf) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). Currently, the standard ratings for DX heating coils are only calculated and output for single-speed and multi-speed DX heating coils.
@@ -4020,7 +4020,7 @@ \subsubsection{Heating Seasonal Performance Factor (HSPF)}\label{heating-seasona
H2 Test (Required, Steady) & 21.11 & 15.56 & 1.67 & 0.56 & Heating Full-load \tabularnewline
H3 Test (Required, Steady) & 21.11 & 15.56 & -8.33 & -9.44 & Heating Full-load \tabularnewline
\bottomrule
-\multicolumn{6}{p{6in}}{\raggedright Notes: 1) Heating air volume arte are defined in section 3.1.4.4 of ANSI/AHRI 210/240-2008 2) Maintain the airflow nozzles static pressure difference ro velocity pressure during the ON periodat the same pressure difference or velocity pressure as measured during the H1 Test.} \tabularnewline
+\multicolumn{6}{p{6in}}{\raggedright Notes: 1) Heating air volume rate are defined in section 3.1.4.4 of ANSI/AHRI 210/240-2008 2) Maintain the airflow nozzles static pressure difference or velocity pressure during the ON period at the same pressure difference or velocity pressure as measured during the H1 Test.} \tabularnewline
\multicolumn{6}{p{6in}}{Source: Table 9, Page 74, ANSI/AHRI Standard 210/240-2008}
\end{longtable}
@@ -4103,7 +4103,7 @@ \subsubsection{Model Inputs}\label{model-inputs-3}
\subsubsection{Speed 1 Operation}\label{speed-1-operation-1}
-The calculation procedures in this model, including defrost and crankcase heater, are indentical to the Coil:Heating:DX:SingleSpeed object (Ref: Coil:Heating:DX:SingleSpeed) with one exception: outlet node condition calculation when the supply air fan operation mode is ContinuousFanWithCyclingCompressor. The following procedure provides the detailed description of the exception.
+The calculation procedures in this model, including defrost and crankcase heater, are identical to the Coil:Heating:DX:SingleSpeed object (Ref: Coil:Heating:DX:SingleSpeed) with one exception: outlet node condition calculation when the supply air fan operation mode is ContinuousFanWithCyclingCompressor. The following procedure provides the detailed description of the exception.
\begin{itemize}
\item Total delivered heating capacity
@@ -5400,7 +5400,7 @@ \subsection{Heat Exchanger Assisted Air Cooling Coil Systems}\label{heat-exchang
The heat exchanger assisted DX cooling coil may also be used with a DX system located in an air loop (ref. CoilSystem:Cooling:DX). This system object also has three options for dehumidification control (None, Multimode, and CoolReheat). When no dehumidification control is specified (None), the heat exchanger is always active when the cooling coil is operating. When multimode or coolreheat dehumidification control is specified, a humidistat and a maximum humidity setpoint manager are required as shown in Figure~\ref{fig:schematic-of-heat-exchanger-assisted-dx-coil} (setpoint needs to be placed on the DX system's control node). For multimode dehumidification control, the heat exchanger is only active when the zone humidity levels are above the humidistat setpoint (i.e., the system's cooling coil can't meet the maximum humidity ratio setpoint when operating without heat exchanger energy transfer) while the AC system operates to meet the sensible (dry-bulb cooling thermostat) load. For coolreheat dehumidification control, the heat exchanger is always active when the cooling coil operates and this system tries to meet both the sensible (thermostat) and latent (humidistat) loads.
-When the heat exchanger assisted cooling coil is used with a furnace or unitary system (ref. AirLoopHVAC:Unitary:Furnace:HeatCool or AirLoopHVAC:UnitaryHeatCool) or DX system (ref. CoilSystem:Cooling:DX) located in an air loop (or DX system used in an outside air system), an ecomizier function may be customized as necessary. For economizer control, an outdoor air controller (ref. Controller:OutdoorAir) is used to define the economizer control inputs and determine when economizer mode is active. The heat exchanger (ref. HeatExchanger:*) object provides an economizer lockout feature which disables heat recovery any time the economizer is active. This feature can be turned on and off using the heat exchanger lockout input. Heat exchanger assisted cooling coils used with the zone equipment described below disregard this economizer control feature.
+When the heat exchanger assisted cooling coil is used with a furnace or unitary system (ref. AirLoopHVAC:Unitary:Furnace:HeatCool or AirLoopHVAC:UnitaryHeatCool) or DX system (ref. CoilSystem:Cooling:DX) located in an air loop (or DX system used in an outside air system), an economizer function may be customized as necessary. For economizer control, an outdoor air controller (ref. Controller:OutdoorAir) is used to define the economizer control inputs and determine when economizer mode is active. The heat exchanger (ref. HeatExchanger:*) object provides an economizer lockout feature which disables heat recovery any time the economizer is active. This feature can be turned on and off using the heat exchanger lockout input. Heat exchanger assisted cooling coils used with the zone equipment described below disregard this economizer control feature.
\begin{figure}[hbtp] % fig 177
\centering
@@ -5930,7 +5930,7 @@ \subsubsection{Model Description}\label{model-description-9}
\end{itemize}
-The \emph{total cooling capacity modifier curve (function of temperature)} defines the performance of the DX cooling coil as a function of operating conditions. These operating conditions may be specified as either a linear, quadratic or cubic equation using coil entering air wet-bulb temperature as the independent variable or as a biquadratic equation using both coil entering air wet-bulb temperature and outdoor dry-bulb temperuate as the independent variables. Since the variable refrigerant flow system modulates the compressor speed to serve the individual cooling coils, the single independent variable equation is likely to be sufficient to define the DX cooling coil performance. However, if other more accurate information is available, a biquadratic curve using two independent variables may be used. The output of this curve is multiplied by the rated total cooling capacity to give the total cooling capacity at the specific entering air temperatures at which the DX coil unit is operating (i.e., at temperatures different from the rating point temperatures).
+The \emph{total cooling capacity modifier curve (function of temperature)} defines the performance of the DX cooling coil as a function of operating conditions. These operating conditions may be specified as either a linear, quadratic or cubic equation using coil entering air wet-bulb temperature as the independent variable or as a biquadratic equation using both coil entering air wet-bulb temperature and outdoor dry-bulb temperature as the independent variables. Since the variable refrigerant flow system modulates the compressor speed to serve the individual cooling coils, the single independent variable equation is likely to be sufficient to define the DX cooling coil performance. However, if other more accurate information is available, a biquadratic curve using two independent variables may be used. The output of this curve is multiplied by the rated total cooling capacity to give the total cooling capacity at the specific entering air temperatures at which the DX coil unit is operating (i.e., at temperatures different from the rating point temperatures).
\begin{equation}
TotCapTempModFac = a + b\left( {{T_{wb,i}}} \right) + c{\left( {{T_{wb,i}}} \right)^2} + d{\left( {{T_{wb,i}}} \right)^3}
@@ -6012,7 +6012,7 @@ \subsubsection{Model Description}\label{model-description-9}
For a given coil geometry, the bypass factor is only a function of air mass flow rate. The model calculates the parameter A\(_{o}\) in the equation above based on BF\(_{rated}\) and the rated air mass flow rate. With A\(_{o}\) known, the coil BF can be determined for non-rated air flow rates.
-For each simulation time step when the DX cooling coil operates, the total cooling capacity and coil bypass factor at the actual operating conditions are calculated. The coil bypass factor is used to calculate the operating sensible heat ratio (SHR) of the cooling coil using the following equations. Here is where the differnce in models occur for the VRF DX cooling coil and single-speed DX cooling coil. The original coil model (ref: Coil:Cooling:DX:SingleSpeed) calculates the full load outlet air enthalpy and, considering the bypass factor, finds the coil surface temperture (h\(_{ADP}\)) at full load (i.e., PLR = 1). Conversely, the VRF coil model modulates refrigerant flow to the VRF DX cooling coil which is why this model uses the full load coil capacity multipled by the part-load ratio (the modulated refrigerant flow). The effectively finds the coil surface temperature for a variable refrigerant flow DX cooling coil and the operating sensible heat ratio (SHR) can be calculated.
+For each simulation time step when the DX cooling coil operates, the total cooling capacity and coil bypass factor at the actual operating conditions are calculated. The coil bypass factor is used to calculate the operating sensible heat ratio (SHR) of the cooling coil using the following equations. Here is where the difference in models occur for the VRF DX cooling coil and single-speed DX cooling coil. The original coil model (ref: Coil:Cooling:DX:SingleSpeed) calculates the full load outlet air enthalpy and, considering the bypass factor, finds the coil surface temperature (h\(_{ADP}\)) at full load (i.e., PLR = 1). Conversely, the VRF coil model modulates refrigerant flow to the VRF DX cooling coil which is why this model uses the full load coil capacity multiplied by the part-load ratio (the modulated refrigerant flow). The effectively finds the coil surface temperature for a variable refrigerant flow DX cooling coil and the operating sensible heat ratio (SHR) can be calculated.
\begin{equation}
{h_{ADP}} = {h_{in}} - \frac{{\left( {{\dot{Q}_{total}}/ \dot{m}} \right)}}{{1 - BF}} ~~for a single-speed DX coil model (h_{ADP1} in figure below)
@@ -6592,7 +6592,7 @@ \subsubsection{Overview}\label{overview-14}
Variable-speed cooling coils lead to varied dehumidification behaviors, that the Bypass Factor (BF) is not only dependent on the indoor air flow rate, but also on the refrigerant mass flow rate, i.e.~the compressor speed. It is necessary to assess the BF approach for single-speed DX coil, to be used for the variable-speed systems.
-TheDOE/ORNL Heat Pump Design Model(HPDM) is a steady-state vapor compression equipment simulation model, which is able to simulate the performance of a VS WSHP system. We rana calibrated HPDM model to produce performance data of a 2.5-ton, VS WSHPunit in space cooling mode. We ran the model to get the total cooling capacities and SHRs, by specifying the EWT at 65\(^{\circ}\)F, indoor air DB at 80\(^{\circ}\)F and relative humidity at 0.5, and then varying the indoor air flow rate from 400 scfm to 1000 scfm, the compressor speed from 30 Hz to 90 Hz in a 7×7 matrix. Based on the performance results, we used EES (Engineering Equation Solver) to back-calculate the corresponding BF factors and the A\(_{o}\) (effective coil surface area) parameters,using the BF equations for the single speed DX cooling coil in EnergyPlus Engineering Reference.
+TheDOE/ORNL Heat Pump Design Model(HPDM) is a steady-state vapor compression equipment simulation model, which is able to simulate the performance of a VS WSHP system. We ran a calibrated HPDM model to produce performance data of a 2.5-ton, VS WSHPunit in space cooling mode. We ran the model to get the total cooling capacities and SHRs, by specifying the EWT at 65\(^{\circ}\)F, indoor air DB at 80\(^{\circ}\)F and relative humidity at 0.5, and then varying the indoor air flow rate from 400 scfm to 1000 scfm, the compressor speed from 30 Hz to 90 Hz in a 7×7 matrix. Based on the performance results, we used EES (Engineering Equation Solver) to back-calculate the corresponding BF factors and the A\(_{o}\) (effective coil surface area) parameters,using the BF equations for the single speed DX cooling coil in EnergyPlus Engineering Reference.
And then, we plotted the resultant A\(_{o}\) as a function of indoor air flow rate and compressor speed, as below:
@@ -7179,7 +7179,7 @@ \subsubsection{Sensible and Latent Split}\label{sensible-and-latent-split}
\(h_{Outlet}\) is the enthalpy of air leaving the passive coil (J/kg)
-\(h_{T_{in},\omega_{out}}\) is the enthalpy of air at the leaving humidity ratio and the entering dry bulb temerature
+\(h_{T_{in},\omega_{out}}\) is the enthalpy of air at the leaving humidity ratio and the entering dry bulb temperature
\(\dot{m}_{sec}\) is the secondary DX coil mass flow rate (kg/s)
@@ -7240,7 +7240,7 @@ \subsection{Packaged Thermal Storage Cooling Coil}\label{packaged-thermal-storag
\begin{figure}[hbtp] % fig 185
\centering
\includegraphics[width=0.9\textwidth, height=0.9\textheight, keepaspectratio=true]{media/image4293.png}
-\caption{Thermal Storage Coil Cooling Only Modee \protect \label{fig:thermal-storage-coil-cooling-only-modee}}
+\caption{Thermal Storage Coil Cooling Only Mode \protect \label{fig:thermal-storage-coil-cooling-only-mode}}
\end{figure}
The governing equations for Cooling Only Mode include:
@@ -7265,7 +7265,7 @@ \subsection{Packaged Thermal Storage Cooling Coil}\label{packaged-thermal-storag
{\dot Q_{Plant}} = \dot m{c_p}\varepsilon \left( {{T_{TES}} - {T_{w,in}}} \right)
\end{equation}
-The input correlations are used in the following manner to determine cooling capacity and energy consumption for a given set of operationg conditions.
+The input correlations are used in the following manner to determine cooling capacity and energy consumption for a given set of operating conditions.
One total evaporator cooling capacity modifier curve is a function of evaporator inlet wetbulb temperature and condenser inlet drybulb temperature.
@@ -7355,7 +7355,7 @@ \subsection{Packaged Thermal Storage Cooling Coil}\label{packaged-thermal-storag
{\dot Q_{Plant}} = \dot m{c_p}\varepsilon \left( {{T_{TES}} - {T_{w,in}}} \right)
\end{equation}
-The input correlations are used in the following manner to determine cooling capacity, chargine capacity, and energy consumption for a given set of operationg conditions.
+The input correlations are used in the following manner to determine cooling capacity, charging capacity, and energy consumption for a given set of operating conditions.
One total evaporator cooling capacity modifier curve is a function of evaporator inlet wetbulb and condenser inlet drybulb temperatures and state of TES, \({S_{TES}}\) ~(temperature of water or fraction of ice).
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-001/hvac-controllers.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-001/hvac-controllers.tex
index ea7c15d3c9d..a2cb42b72df 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-001/hvac-controllers.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-001/hvac-controllers.tex
@@ -93,7 +93,7 @@ \subsubsection{Model Description}\label{model-description-012}
\subsection{Outdoor Air Damper Controller for Air Systems}\label{outdoor-air-damper-controller-for-air-systems}
-When the heat exchanger assisted cooling coil is used with a furnace or unitary system (ref. AirLoopHVAC:Unitary:Furnace:HeatCool or AirLoopHVAC:UnitaryHeatCool) or DX system (ref. CoilSystem:Cooling:DX) located in an air loop (or DX system used in an outside air system), an ecomizier function may be customized as necessary. For economizer control, an outdoor air controller (ref. Controller:OutdoorAir) is used to define the economizer control inputs and determine when economizer mode is active. The heat exchanger (ref. HeatExchanger:*) object provides an economizer lockout feature which disables heat recovery any time the economizer is active. This feature can be turned on and off using the heat exchanger lockout input. Heat exchanger assisted cooling coils used with the zone equipment described below disregard this economizer control feature. The heat recovery bypass control input may also be used to selectively control heat recovery.
+When the heat exchanger assisted cooling coil is used with a furnace or unitary system (ref. AirLoopHVAC:Unitary:Furnace:HeatCool or AirLoopHVAC:UnitaryHeatCool) or DX system (ref. CoilSystem:Cooling:DX) located in an air loop (or DX system used in an outside air system), an economizer function may be customized as necessary. For economizer control, an outdoor air controller (ref. Controller:OutdoorAir) is used to define the economizer control inputs and determine when economizer mode is active. The heat exchanger (ref. HeatExchanger:*) object provides an economizer lockout feature which disables heat recovery any time the economizer is active. This feature can be turned on and off using the heat exchanger lockout input. Heat exchanger assisted cooling coils used with the zone equipment described below disregard this economizer control feature. The heat recovery bypass control input may also be used to selectively control heat recovery.
\subsubsection{Inputs}\label{inputs}
@@ -143,7 +143,7 @@ \subsubsection{Inputs}\label{inputs}
\item
High humidity control flag: \emph{Yes} \textbar{} \emph{No}
\item
- Humidstat control zone name (zone name where humidistat is located)
+ Humidistat control zone name (zone name where humidistat is located)
\item
Control high indoor humidity based on outdoor humidity ratio: \emph{Yes} \textbar{} \emph{No}
\item
@@ -229,14 +229,14 @@ \subsubsection{Step 3: Do the on/off and limit checks}\label{step-3-Do-the-onoff
\begin{itemize}
\item If \({T_i} > {T_{mix,set}}\), \({S_{oa,init}} = 1\).
-\item If Differential dry-bulb was input as Economizer choiceand \({T_i} > {T_r}\), then \({S_{oa,init}} = {f_{oa,\min }}\).
-\item If Differential Enthalpy was input as Economizer choiceand \({h_i} > {h_r}\) , then \({S_{oa,init}} = {f_{oa,\min }}\), where \emph{h\(_{i}\)} and \emph{h\(_{r}\)}~are the outside air inlet and return air enthalpies.
+\item If Differential dry-bulb was input as Economizer choice and \({T_i} > {T_r}\), then \({S_{oa,init}} = {f_{oa,\min }}\).
+\item If Differential Enthalpy was input as Economizer choice and \({h_i} > {h_r}\) , then \({S_{oa,init}} = {f_{oa,\min }}\), where \emph{h\(_{i}\)} and \emph{h\(_{r}\)}~are the outside air inlet and return air enthalpies.
\end{itemize}
Setpoints are checked after this which include check for Fixed dry-bulb temperature~ limit, Enthalpy Limit, Dewpoint Limit and Humidity ratio limit if specified.
\begin{itemize}
-\item If Differential Enthalpy was input as Economizer choiceand \({h_i} > {h_r}\) , then \({S_{oa,init}} = {f_{oa,\min }}\), where \emph{h\(_{i}\)} and \emph{h\(_{r}\)}~are the outside air inlet and return air enthalpies.
+\item If Differential Enthalpy was input as Economizer choice and \({h_i} > {h_r}\) , then \({S_{oa,init}} = {f_{oa,\min }}\), where \emph{h\(_{i}\)} and \emph{h\(_{r}\)}~are the outside air inlet and return air enthalpies.
\end{itemize}
Setpoints are checked after this which include check for Fixed dry-bulb temperature limit, Enthalpy Limit, Dewpoint Limit and Humidity ratio limit if specified.
@@ -257,14 +257,14 @@ \subsubsection{Step 3: Do the on/off and limit checks}\label{step-3-Do-the-onoff
Note: the above nine cases set the \emph{EconomizerOperationFlag} to \emph{false} (economizer not operating), otherwise the economizer is active.
\begin{itemize}
-\item If high humidity control is specified and the zone humidistat indicates a moisture load (i.e.~zone relative humidity greater than the relative humidity setpoint), the \emph{HighHumidityOperationFlag} is set to \emph{true.} If high humidity control is based on the outdoor humidity ratio then the \emph{HighHumidityOperationFlag} is set to \emph{true} only when the outdoor air humidity ratio is less than the humidstat's zone humidity ratio. A \emph{true} HIghHumidityOperationFlag also enables economizer operation in the heat exchangers as if the economizer flag used here was also set to \emph{true} (Ref. HeatExchanger:* - field Economizer Lockout).
+\item If high humidity control is specified and the zone humidistat indicates a moisture load (i.e.~zone relative humidity greater than the relative humidity setpoint), the \emph{HighHumidityOperationFlag} is set to \emph{true.} If high humidity control is based on the outdoor humidity ratio then the \emph{HighHumidityOperationFlag} is set to \emph{true} only when the outdoor air humidity ratio is less than the humidistat's zone humidity ratio. A \emph{true} HIghHumidityOperationFlag also enables economizer operation in the heat exchangers as if the economizer flag used here was also set to \emph{true} (Ref. HeatExchanger:* - field Economizer Lockout).
\end{itemize}
The economizer schedule is then checked to determine if a ``push-button'' type economizer control is used. When schedule values are greater than 0, the economizer is active (\emph{EconomizerOperationFlag} = \emph{true)}. This test overrides the economizer limit checks described above in Step 3.
\subsubsection{Step 4: Calculate the final outside air signal}\label{step-4-Calculate-the-final-outside-air-signal}
-If \emph{S\(_{oa,init}\)} is greater than \({f_{oa,\min }}\) and less than 1 and the mixed air mass flow rate is greater than \({\dot m_{verysmall}}\) (\({10^{ - 30}}\) ) and night venting is not occuring and \emph{HighHumidityOperationFlag} is false, then we calculate a final outside air signal \emph{S\(_{oa}\)} by using the root solver method routine \emph{SolveRegulaFalsi} to zero the residual \({T_{mix,set}} - {T_{mix}}\) by varying the outside air mass flow rate \({S_{oa}}\cdot {\dot m_{mix}}\) . Mass and energy balance are used to obtain the mixed air humidity ratio and enthalpy from the recirculated air and outside air inlet conditions. The psychrometric function \emph{PsyTdbFnHW} is used to obtain \emph{T\(_{mix}\)} from the mixed air enthalpy and humidity ratio.
+If \emph{S\(_{oa,init}\)} is greater than \({f_{oa,\min }}\) and less than 1 and the mixed air mass flow rate is greater than \({\dot m_{verysmall}}\) (\({10^{ - 30}}\) ) and night venting is not occurring and \emph{HighHumidityOperationFlag} is false, then we calculate a final outside air signal \emph{S\(_{oa}\)} by using the root solver method routine \emph{SolveRegulaFalsi} to zero the residual \({T_{mix,set}} - {T_{mix}}\) by varying the outside air mass flow rate \({S_{oa}}\cdot {\dot m_{mix}}\) . Mass and energy balance are used to obtain the mixed air humidity ratio and enthalpy from the recirculated air and outside air inlet conditions. The psychrometric function \emph{PsyTdbFnHW} is used to obtain \emph{T\(_{mix}\)} from the mixed air enthalpy and humidity ratio.
Otherwise, \({S_{oa}} = {S_{oa,init}}\).
@@ -278,7 +278,7 @@ \subsubsection{Step 5: calculate the outside air flow rate and apply final const
S_{oa} = \max\PB{f_{oa,min},OAFlowRatio_{HighRH}\frac{\dot{m}_{oa,max,des}}{\dot{m}_{mix}}}
\end{equation}
-If night ventilation is occuring, \({S_{oa}} = 1\). Note that night ventilation has priority over the above constraints.
+If night ventilation is occurring, \({S_{oa}} = 1\). Note that night ventilation has priority over the above constraints.
Now, the outside air flow rate is calculated:
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/air-system-compound-component-groups.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/air-system-compound-component-groups.tex
index a50586e0509..c87640be23b 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/air-system-compound-component-groups.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/air-system-compound-component-groups.tex
@@ -34,7 +34,7 @@ \subsubsection{Setpoint based control:}\label{setpoint-based-control}
\paragraph{Step 2a -- Humidity Control = MultiMode}\label{step-2a-humidity-control-multimode}
-If the humidity control type is MultiMode, then the coil's enhanced dehumidification mode is activated when the coil type is Coil:Cooling:DX:TwoStageWithHumidityControlMode and Step 1 above is repeated to meet the sensible load using the coil performance resulting from the enhanced dehumidificaiton mode. This is a semi-passive approach to dehumidification which may fall short or may exceed the dehumidification requirement.
+If the humidity control type is MultiMode, then the coil's enhanced dehumidification mode is activated when the coil type is Coil:Cooling:DX:TwoStageWithHumidityControlMode and Step 1 above is repeated to meet the sensible load using the coil performance resulting from the enhanced dehumidification mode. This is a semi-passive approach to dehumidification which may fall short or may exceed the dehumidification requirement.
\paragraph{Step 2b -- Humidity Control = CoolReheat}\label{step-2b-humidity-control-coolreheat}
@@ -69,7 +69,7 @@ \subsubsection{Load based control:}\label{load-based-control}
\label{eq:UnitarySystemCoolingLoad}
\end{equation}
-If the supply air fan operating mode schedule requests cycling fan operation, the model first checks for the presence of an ecomomizer in the outside air system serving the unitary system's air loop (Ref. AirLoopHVAC:OutdoorAirSystem). If an outside air system is not present or if an air-side economizer is not used, the unitary system's compressor is used to meet the unitary system cooling load. If an air-side economizer is used and is active (i.e., economizer controls indicate that conditions are favorable to increase the outside air flow rate), the unitary system will try to meet the cooling load by operating only the supply air fan. If the fan is able to satisfy the unitary system cooling load, the compressor remains off for the entire simulation time step. If the operation of the fan alone is unable to meet the entire cooling load, then the compressor is enabled and additional calculations are performed to determine the compressor's part-load ratio.
+If the supply air fan operating mode schedule requests cycling fan operation, the model first checks for the presence of an economizer in the outside air system serving the unitary system's air loop (Ref. AirLoopHVAC:OutdoorAirSystem). If an outside air system is not present or if an air-side economizer is not used, the unitary system's compressor is used to meet the unitary system cooling load. If an air-side economizer is used and is active (i.e., economizer controls indicate that conditions are favorable to increase the outside air flow rate), the unitary system will try to meet the cooling load by operating only the supply air fan. If the fan is able to satisfy the unitary system cooling load, the compressor remains off for the entire simulation time step. If the operation of the fan alone is unable to meet the entire cooling load, then the compressor is enabled and additional calculations are performed to determine the compressor's part-load ratio.
The model then calculates the unitary system's sensible cooling energy rate delivered to the zones being served when the system runs at full-load conditions and when the cooling coil is OFF. If the supply air fan cycles with the compressor, then the sensible cooling energy rate is zero when the cooling coil is OFF. However if the fan is configured to run continuously regardless of coil operation, then the sensible cooling energy rate will probably not be zero when the cooling coil is OFF. Calculating the sensible cooling energy rate involves modeling the supply air fan (and associated fan heat), the cooling coil, and the heating and reheat coil (simply to pass the air properties and mass flow rate from its inlet node to its outlet node). For each of these cases (full load and cooling coil OFF), the sensible cooling energy rate delivered by the unitary system is calculated as follows:
@@ -659,7 +659,7 @@ \subsubsection{High Humidity Control}\label{high-humidity-control}
\caption{Supplemental heating coil load when predicted zone air temperature is above the heating Setpoint \protect \label{fig:supplemental-heating-coil-load-when-predicted}}
\end{figure}
-If a heating load exists (Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-001}), the supplementalheating coil is used to meet the heating coil load and at the same time offset the entire sensible cooling energy rate of the cooling coil (to meet the humidistat setpoint). Note that when a heating load exists and high humidity control is required, the unitary system operates at the user-specified cooling air flow rate for the entire simulation time step. As with the fan, and cooling coil, report variables associated with supplemental heating coil performance (e.g., heating coil energy, heating coil rate, heating coil gas or electric energy, heating coil runtime fraction, etc.) are managed in the supplemental (heating) coil object.
+If a heating load exists (Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-001}), the supplemental heating coil is used to meet the heating coil load and at the same time offset the entire sensible cooling energy rate of the cooling coil (to meet the humidistat setpoint). Note that when a heating load exists and high humidity control is required, the unitary system operates at the user-specified cooling air flow rate for the entire simulation time step. As with the fan, and cooling coil, report variables associated with supplemental heating coil performance (e.g., heating coil energy, heating coil rate, heating coil gas or electric energy, heating coil runtime fraction, etc.) are managed in the supplemental (heating) coil object.
\begin{figure}[hbtp] % fig 220
\centering
@@ -828,7 +828,7 @@ \subsubsection{HeatOnly Configuration}\label{heatonly-configuration}
\emph{h\(_{out,coil~off}\)} is the enthalpy of air exiting the furnace with the heating coil OFF (J/kg)
-\(\Delta_{sen,full~load}\) is the ensible load difference between the system output node and the zone inlet node at full-load conditions.
+\(\Delta_{sen,full~load}\) is the sensible load difference between the system output node and the zone inlet node at full-load conditions.
\begin{equation}
\begin{array}{rl}
@@ -909,7 +909,7 @@ \subsubsection{HeatCool Configuration}\label{heatcool-configuration}
Furnace~Cooling~Load = \frac{{Control~Zone~Cooling~Load}}{{Control~Zone~Air~Flow~Fraction}}
\end{equation}
-If the supply air fan operating mode schedule requests cycling fan operation, the model first checks for the presence of an ecomomizer in the outside air system serving the furnace's air loop (Ref. AirLoopHVAC:OutdoorAirSystem). If an outside air system is not present or if an air-side economizer is not used, the furnace's compressor is used to meet the furnace cooling load. If an air-side economizer is used and is active (i.e., economizer controls indicate that conditions are favorable to increase the outside air flow rate), the furnace will try to meet the cooling load by operating only the supply air fan. If the fan is able to satisfy the furnace cooling load, the compressor remains off for the entire simulation time step. If the operation of the fan alone is unable to meet the entire cooling load, then the compressor is enabled and additional calculations are performed to determine the compressor's part-load ratio.
+If the supply air fan operating mode schedule requests cycling fan operation, the model first checks for the presence of an economizer in the outside air system serving the furnace's air loop (Ref. AirLoopHVAC:OutdoorAirSystem). If an outside air system is not present or if an air-side economizer is not used, the furnace's compressor is used to meet the furnace cooling load. If an air-side economizer is used and is active (i.e., economizer controls indicate that conditions are favorable to increase the outside air flow rate), the furnace will try to meet the cooling load by operating only the supply air fan. If the fan is able to satisfy the furnace cooling load, the compressor remains off for the entire simulation time step. If the operation of the fan alone is unable to meet the entire cooling load, then the compressor is enabled and additional calculations are performed to determine the compressor's part-load ratio.
The model then calculates the furnace's sensible cooling energy rate delivered to the zones being served when the system runs at full-load conditions and when the DX cooling coil is OFF. If the supply air fan cycles with the compressor, then the sensible cooling energy rate is zero when the cooling coil is OFF. However if the fan is configured to run continuously regardless of coil operation, then the sensible cooling energy rate will probably not be zero when the cooling coil is OFF. Calculating the sensible cooling energy rate involves modeling the supply air fan (and associated fan heat), the DX cooling coil, and the heating coil (simply to pass the air properties and mass flow rate from its inlet node to its outlet node). For each of these cases (full load and DX cooling coil OFF), the sensible cooling energy rate delivered by the furnace is calculated as follows:
@@ -1346,7 +1346,7 @@ \subsubsection{Cooling Operation}\label{cooling-operation-1}
Heat~Pump~Cooling~Load = \frac{{Control~Zone~Cooling~Load}}{{Control~Zone~Air~Flow~Fraction}}
\end{equation}
-If the supply air fan operating mode schedule requests cycling fan operation, the model first checks for the presence of an ecomomizer in the outside air system serving the heat pump's air loop (Ref. AirLoopHVAC:OutdoorAirSystem). If an outside air system is not present or if an air-side economizer is not used, the heat pump's compressor is used to meet the heat pump cooling load. If an air-side economizer is used and is active (i.e., economizer controls indicate that conditions are favorable to increase the outside air flow rate), the heat pump will try to meet the cooling load by operating only the supply air fan. If the fan is able to satisfy the heat pump cooling load, the compressor remains off for the entire simulation time step. If the operation of the fan alone is unable to meet the entire cooling load, then the compressor is enabled and additional calculations are performed to determine the compressor's part-load ratio.
+If the supply air fan operating mode schedule requests cycling fan operation, the model first checks for the presence of an economizer in the outside air system serving the heat pump's air loop (Ref. AirLoopHVAC:OutdoorAirSystem). If an outside air system is not present or if an air-side economizer is not used, the heat pump's compressor is used to meet the heat pump cooling load. If an air-side economizer is used and is active (i.e., economizer controls indicate that conditions are favorable to increase the outside air flow rate), the heat pump will try to meet the cooling load by operating only the supply air fan. If the fan is able to satisfy the heat pump cooling load, the compressor remains off for the entire simulation time step. If the operation of the fan alone is unable to meet the entire cooling load, then the compressor is enabled and additional calculations are performed to determine the compressor's part-load ratio.
The model then calculates the heat pump's sensible cooling energy rate delivered to the zones being served when the system runs at full-load conditions and when the DX cooling coil is OFF. If the supply air fan cycles with the compressor, then the sensible cooling energy rate is zero when the cooling coil is OFF. However if the fan is scheduled to run continuously regardless of coil operation, then the sensible cooling energy rate will not be zero when the cooling coil is OFF. Calculating the sensible cooling energy rate involves modeling the supply air fan (and associated fan heat) and the DX cooling coil. The DX heating coil and the supplemental heating coil are also modeled, but only to pass the air properties and mass flow rate from their inlet nodes to their outlet nodes. For each of these cases (full load and DX cooling coil OFF), the sensible cooling energy rate delivered by the heat pump is calculated as follows:
@@ -1565,7 +1565,7 @@ \subsubsection{High Humidity Control with AirToAir HeatPump Model}\label{high-hu
\(PL{R_{MIN}}\) is the minimum part-load ratio, which is usually 0.0. For the case when the latent capacity degradation model is used (Ref: DX Cooling Coil Model), this value is the minimum part-load ratio at which the cooling coil will dehumidify the air.
-When the predicted zone air temperature is above the heating setpoint and if there is a dehumidification load, the supplemental heating coil load is required to offset the excess cooling as shown in Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-002}. If the model determines that the LatentPartLoadRatio is to be used as the operating part-load ratio of the heatpump's cooling coil, the supplemental heating coil is used to offset the excess sensible capacity provided by the heat pump DX cooling coil. The model first checks the sensible load that exists for the current simulation time step (predicted zone temperature with no HVAC operation compared to the thermostat setpoint temperatures). If a sensible cooling load or no sensible cooling or heating load exists (see Figure~\ref{fig:flows-of-warmup-convergence-checks}), the model calculates the difference between the sensible heating load required to reach or maintain the heating dry-bulb temperature setpoint and the actual sensible cooling energy rate delivered by the unit (with LatentPartLoadRatio). In this case, thesupplemental heating coil is used to offset the excess sensible cooling energy provided by the DX cooling coil (if any) that could have caused an overshoot of the heating dry-bulb temperature setpoint. Note that when a humidistat is used and high humidity control is required, the zone dry-bulb temperature will typically move toward the heating temperature setpoint when a high moisture (latent) load exists.
+When the predicted zone air temperature is above the heating setpoint and if there is a dehumidification load, the supplemental heating coil load is required to offset the excess cooling as shown in Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-002}. If the model determines that the LatentPartLoadRatio is to be used as the operating part-load ratio of the heatpump's cooling coil, the supplemental heating coil is used to offset the excess sensible capacity provided by the heat pump DX cooling coil. The model first checks the sensible load that exists for the current simulation time step (predicted zone temperature with no HVAC operation compared to the thermostat setpoint temperatures). If a sensible cooling load or no sensible cooling or heating load exists (see Figure~\ref{fig:flows-of-warmup-convergence-checks}), the model calculates the difference between the sensible heating load required to reach or maintain the heating dry-bulb temperature setpoint and the actual sensible cooling energy rate delivered by the unit (with LatentPartLoadRatio). In this case, the supplemental heating coil is used to offset the excess sensible cooling energy provided by the DX cooling coil (if any) that could have caused an overshoot of the heating dry-bulb temperature setpoint. Note that when a humidistat is used and high humidity control is required, the zone dry-bulb temperature will typically move toward the heating temperature setpoint when a high moisture (latent) load exists.
\begin{figure}[hbtp] % fig 228
\centering
@@ -1573,7 +1573,7 @@ \subsubsection{High Humidity Control with AirToAir HeatPump Model}\label{high-hu
\caption{Supplemental heating coil load when predicted zone air temperature is above the heating Setpoint \protect \label{fig:supplemental-heating-coil-load-when-predicted-002}}
\end{figure}
-If a heating load exists (Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-003}), the supplementalheating coil is used to meet the heating coil load and at the same time offset the entire sensible cooling energy rate of the DX cooling coil (to meet the humidistat setpoint). Note that when a heating load exists and high humidity control is required, the heat pump operates at the user-specified cooling air flow rate for the entire simulation time step. As with the fan, and DX cooling coil, report variables associated with supplemental heating coil performance (e.g., heating coil energy, heating coil rate, heating coil gas or electric energy, heating coil runtime fraction, etc.) are managed in the supplemental (heating) coil object.
+If a heating load exists (Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-003}), the supplemental heating coil is used to meet the heating coil load and at the same time offset the entire sensible cooling energy rate of the DX cooling coil (to meet the humidistat setpoint). Note that when a heating load exists and high humidity control is required, the heat pump operates at the user-specified cooling air flow rate for the entire simulation time step. As with the fan, and DX cooling coil, report variables associated with supplemental heating coil performance (e.g., heating coil energy, heating coil rate, heating coil gas or electric energy, heating coil runtime fraction, etc.) are managed in the supplemental (heating) coil object.
\begin{figure}[hbtp] % fig 229
\centering
@@ -1928,7 +1928,7 @@ \subsubsection{Heating Operation}\label{heating-operation-1}
For this case where speed 1 operation was able to meet the required heating load, the speed ratio is set to zero and speed number is equal to 1.
-Finally, if the heat pump's heating output at full load for Speed 1 is insufficient to meet the entire heatling load, the Cycling ratio (PartLoadRatio) is set equal to 1.0 (compressor and fan are not cycling). Then the heating speed is increased and the delivered sensible capacity is calculated. If the full load sensible capacity at Speed n is greater than or equal to the sensible load, the speed ratio for the heat pump is estimated:
+Finally, if the heat pump's heating output at full load for Speed 1 is insufficient to meet the entire heating load, the Cycling ratio (PartLoadRatio) is set equal to 1.0 (compressor and fan are not cycling). Then the heating speed is increased and the delivered sensible capacity is calculated. If the full load sensible capacity at Speed n is greater than or equal to the sensible load, the speed ratio for the heat pump is estimated:
\begin{equation}
Speed~Ratio = \frac{{ABS(Heat~Pump~Heating~Load - AddedFanHeat - Full~Heat~Outpu{t_{Speedn-1}})}}{{ABS(Full~Heat~Outpu{t_{Speedn}} - Full~Heat~Outpu{t_{Speedn-1}})}}
@@ -2014,7 +2014,7 @@ \subsubsection{Controls}\label{controls-1}
\paragraph{Step 2a -- Humidity Control = MultiMode}\label{step-2a-humidity-control-multimode-1}
If the humidity control type is MultiMode, then the coil's enhanced dehumidification mode is activated when the coil type is Coil:Cooling:DX:TwoStageWithHumidityControlMode or the heat exchanger is activated when the coil type is \\
-CoilSystem:Cooling:DX:CoolingHeatExchangerAssisted and Step 1 above is repeated to meet the sensible load using the coil performance resulting from the enhanced dehumidificaiton mode. This is a semi-passive approach to dehumidification which may fall short or may exceed the dehumidification requirement. If the user has specified Run on Latent Load = Yes in the CoilSystem:Cooling:DX object, and there is no sensible load to be met, then the system will try to meet the entire dehumidification load. If dehumidification mode should not be active when there is no sensible load, then choose Run on Latent Load = No.
+CoilSystem:Cooling:DX:CoolingHeatExchangerAssisted and Step 1 above is repeated to meet the sensible load using the coil performance resulting from the enhanced dehumidification mode. This is a semi-passive approach to dehumidification which may fall short or may exceed the dehumidification requirement. If the user has specified Run on Latent Load = Yes in the CoilSystem:Cooling:DX object, and there is no sensible load to be met, then the system will try to meet the entire dehumidification load. If dehumidification mode should not be active when there is no sensible load, then choose Run on Latent Load = No.
\paragraph{Step 2b -- Humidity Control = CoolReheat}\label{step-2b-humidity-control-coolreheat-1}
@@ -2254,7 +2254,7 @@ \subsubsection{Coefficient estimation procedure:}\label{coefficient-estimation-p
\subsubsection{High Humidity Control with WaterToAir HeatPump Equation Fit model}\label{high-humidity-control-with-watertoair-heatpump-equation-fit-model}
-The specific configuration of the WaterToAir HeatPump with supplemental heating coil is shown above (see Figure~\ref{fig:source-side-and-load-side-configuration-of-a}). This figure shows the fan placement when a blow through fan is specified. If a draw through fan is specified, the fan is located between the heating coil and the reheat coil. The system is controlled to keep the high relative humidity in the control zone from exceeding the setpoint specified in the object ZoneControl:Humidistat. When high humidity control is specified and the compressor operates, the heatpump always operates at the cooling air flow rate when a zone heating load is present as determined by the zone thermostat. High humidity control is specified as either None, or CoolReheat in the Dehumidification Control Type input field. CoolReheat is specified when a DX cooling coil is used to over-cool the supply air stream in order to meet the zone latent load. In this case, a supplemental heating coil will ensure the zone temperature does not fall below the zone heating temperature set point. If the dehumidification control type is selected as None, the WaterToAir HeatPump uns only to meet the sensible cooling load. A supplemental heating coil is required for all dehumidification control types.
+The specific configuration of the WaterToAir HeatPump with supplemental heating coil is shown above (see Figure~\ref{fig:source-side-and-load-side-configuration-of-a}). This figure shows the fan placement when a blow through fan is specified. If a draw through fan is specified, the fan is located between the heating coil and the reheat coil. The system is controlled to keep the high relative humidity in the control zone from exceeding the setpoint specified in the object ZoneControl:Humidistat. When high humidity control is specified and the compressor operates, the heatpump always operates at the cooling air flow rate when a zone heating load is present as determined by the zone thermostat. High humidity control is specified as either None, or CoolReheat in the Dehumidification Control Type input field. CoolReheat is specified when a DX cooling coil is used to over-cool the supply air stream in order to meet the zone latent load. In this case, a supplemental heating coil will ensure the zone temperature does not fall below the zone heating temperature set point. If the dehumidification control type is selected as None, the WaterToAir HeatPump runs only to meet the sensible cooling load. A supplemental heating coil is required for all dehumidification control types.
The model first calculates the \emph{PartLoadRatio} required meeting the sensible cooling load.~ The heatpump's sensible cooling load is determined from the control zone sensible cooling load to the cooling setpoint and the control zone air flow fraction to maintain the dry-bulb temperature setpoint in the control zone:
@@ -2306,7 +2306,7 @@ \subsubsection{High Humidity Control with WaterToAir HeatPump Equation Fit model
\(PL{R_{MIN}}\) is the minimum part-load ratio, which is usually 0.0. For the case when the latent capacity degradation model is used (Ref: DX Cooling Coil Model), this value is the minimum part-load ratio at which the cooling coil will dehumidify the air.
-When the predicted zone air temperature is above the heating setpoint and if there is a dehumidification load, the supplemental heating coil load is required to offset the excess cooling as shown in Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-004}. If the model determines that the LatentPartLoadRatio is to be used as the operating part-load ratio of the heatpump's cooling coil, the supplemental coil is used to offset the excess sensible capacity provided by the unit. The model first checks the sensible load that exists for the current simulation time step (predicted zone temperature with no HVAC operation compared to the thermostat setpoint temperatures). If a sensible cooling load or no sensible cooling or heating load exists (see Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-004}),~ the model calculates the difference between the sensible heating load required to reach or maintain the heating dry-bulb temperature setpoint and the actual sensible cooling energy rate delivered by the heat pump (with LatentPartLoadRatio). In this case, thesupplemental heating coil is used to offset the excess sensible cooling energy provided by the DX cooling coil (if any) that could have caused an overshoot of the heating dry-bulb temperature setpoint. Note that when a humidistat is used and high humidity control is required, the zone dry-bulb temperature will typically move toward the heating temperature setpoint when a high moisture (latent) load exists.
+When the predicted zone air temperature is above the heating setpoint and if there is a dehumidification load, the supplemental heating coil load is required to offset the excess cooling as shown in Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-004}. If the model determines that the LatentPartLoadRatio is to be used as the operating part-load ratio of the heatpump's cooling coil, the supplemental coil is used to offset the excess sensible capacity provided by the unit. The model first checks the sensible load that exists for the current simulation time step (predicted zone temperature with no HVAC operation compared to the thermostat setpoint temperatures). If a sensible cooling load or no sensible cooling or heating load exists (see Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-004}),~ the model calculates the difference between the sensible heating load required to reach or maintain the heating dry-bulb temperature setpoint and the actual sensible cooling energy rate delivered by the heat pump (with LatentPartLoadRatio). In this case, the supplemental heating coil is used to offset the excess sensible cooling energy provided by the DX cooling coil (if any) that could have caused an overshoot of the heating dry-bulb temperature setpoint. Note that when a humidistat is used and high humidity control is required, the zone dry-bulb temperature will typically move toward the heating temperature setpoint when a high moisture (latent) load exists.
\begin{figure}[hbtp] % fig 236
\centering
@@ -2314,7 +2314,7 @@ \subsubsection{High Humidity Control with WaterToAir HeatPump Equation Fit model
\caption{Supplemental heating coil load when predicted zone air temperature is above the heating Setpoint \protect \label{fig:supplemental-heating-coil-load-when-predicted-004}}
\end{figure}
-If a heating load exists (Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-005}), the supplementalheating coil is used to meet the heating coil load and at the same time offset the entire sensible cooling energy rate of the DX cooling coil (to meet the humidistat setpoint). Note that when a heating load exists and high humidity control is required, the heat pump operates at the user-specified cooling air flow rate for the entire simulation time step. As with the fan, and DX cooling coil, report variables associated with supplemental heating coil performance (e.g., heating coil energy, heating coil rate, heating coil gas or electric energy, heating coil runtime fraction, etc.) are managed in the supplemental (heating) coil object.
+If a heating load exists (Figure~\ref{fig:supplemental-heating-coil-load-when-predicted-005}), the supplemental heating coil is used to meet the heating coil load and at the same time offset the entire sensible cooling energy rate of the DX cooling coil (to meet the humidistat setpoint). Note that when a heating load exists and high humidity control is required, the heat pump operates at the user-specified cooling air flow rate for the entire simulation time step. As with the fan, and DX cooling coil, report variables associated with supplemental heating coil performance (e.g., heating coil energy, heating coil rate, heating coil gas or electric energy, heating coil runtime fraction, etc.) are managed in the supplemental (heating) coil object.
\begin{figure}[hbtp] % fig 237
\centering
@@ -2502,7 +2502,7 @@ \subsubsection{Parameter estimation procedure}\label{parameter-estimation-proced
\begin{figure}[hbtp] % fig 240
\centering
\includegraphics[width=0.9\textwidth, height=0.9\textheight, keepaspectratio=true]{media/image5306.png}
-\caption{Information Flowchart for Water-To-Water Heat Pump Parameter Estimation Mmodel implementation (Jin 2002) \protect \label{fig:information-flowchart-for-water-to-water-heat}}
+\caption{Information Flowchart for Water-To-Water Heat Pump Parameter Estimation Model implementation (Jin 2002) \protect \label{fig:information-flowchart-for-water-to-water-heat}}
\end{figure}
where:
@@ -2584,12 +2584,12 @@ \subsection{Fuel-Fired Air to Water Heat Pumps}\label{fuel-fired-air-to-water-he
The underlying fuel-fired absorption heat pump model uses equation-fit models based on manufacturer data. The implemented model is as follows:
\subsubsection{Equipment Capacity}
-The heating and cooling capacities are derived from the nominal (rated) capacity and a capacity function of tempereatures.
+The heating and cooling capacities are derived from the nominal (rated) capacity and a capacity function of temperatures.
\begin{equation}
\mathrm{GAHP Heating/Cooling Capacity} = \mathrm{Rated Capacity} \times \mathrm{CAPFT}
\end{equation}
-The temperatures used for the equation model are the ambient air temperature ($T_{mathrm{amb}}$) and the returning (or entering) water temeprature ($T_{\mathrm{ret}}$) of the load side.
+The temperatures used for the equation model are the ambient air temperature ($T_{mathrm{amb}}$) and the returning (or entering) water temperature ($T_{\mathrm{ret}}$) of the load side.
\begin{equation}
\mathrm{CAPFT} = a_1 \times T_{\mathrm{amb}} + b_1 \times T_{\mathrm{amb}}^{2} + c_1 \times T_{\mathrm{ret}} + d_1 \times T_{\mathrm{ret}}^{2} + e_1 \times T_{\mathrm{amb}} \times T_{\mathrm{ret}} + f_1
\end{equation}
@@ -2601,14 +2601,14 @@ \subsubsection{Part Load Ratio}
\end{equation}
\subsubsection{Fuel Use}
-The fuel usage is calculated using the folloiwing formula, taking consideration of the load capacity, nominal COP, and the various adjustment factors (temperature, PLR, Defrosting, and Cycling Ratio):
+The fuel usage is calculated using the following formula, taking consideration of the load capacity, nominal COP, and the various adjustment factors (temperature, PLR, Defrosting, and Cycling Ratio):
\begin{equation}
\mathrm{Fuel Use} = \frac{\mathrm{Load} \times \mathrm{EIRFT} \times \mathrm{EIRFPLR} \times \mathrm{EIRDEFROST}}{\mathrm{COP}_\mathrm{nominal} \times \mathrm{CRF}}
\end{equation}
\subsubsection{EIR Temperature Adjustment}
-A typical EIR temperature correction function will involve two independent temperature variables---the ambient air temperature ($T_{mathrm{amb}}$) and the returning (or entering) water temeprature ($T_{\mathrm{ret}}$) of the load side.
+A typical EIR temperature correction function will involve two independent temperature variables---the ambient air temperature ($T_{mathrm{amb}}$) and the returning (or entering) water temperature ($T_{\mathrm{ret}}$) of the load side.
\begin{equation}
\mathrm{EIRFT} = a_2 \times Tamb + b_2 \times T_{\mathrm{amb}}^{2} + c_2 \times T_{\mathrm{ret}}^{2} + d_2 \times T_{\mathrm{ret}}^{2} + e_2 \times T_{\mathrm{amb}} \times T_{\mathrm{ret}} + f_2
\end{equation}
@@ -2620,7 +2620,7 @@ \subsubsection{EIR PLR Adjustment}
\end{equation}
\subsubsection{Defrosting Adjustment (Heating mode only)}
-If the defrost control type is OnDemand, then the defrost fuel use correction is modeled using the ambient air temperature as the independent varable. The inputs allows a cubic (or lower order) function. For example, one possible curve correlation can look like the following:
+If the defrost control type is OnDemand, then the defrost fuel use correction is modeled using the ambient air temperature as the independent variable. The inputs allows a cubic (or lower order) function. For example, one possible curve correlation can look like the following:
\begin{equation}
\mathrm{EIRDEFROST} = -0.0011 \times T_{\mathrm{amb}}^{2} - 0.006 \times T_{\mathrm{amb}} + 1.0317, \mathrm{for} -8.89^{\circ}\mathrm{C} \leq T_{\mathrm{amb}} \leq 3.33^{\circ}\mathrm{C}
\end{equation}
@@ -2637,12 +2637,12 @@ \subsubsection{Cycling Ratio Adjustment}
\mathrm{CR} = \frac{\mathrm{PLR}}{\mathrm{PLR}_{\mathrm{min}}}, \mathrm{for} 0.2 \leq \mathrm{PLR} \leq 0.25
\end{equation}
-Please note that since the object is based on curve inputs, the user also has the flexibility of defining the curves by themselves---e.g. from the capactity function of temperature to the defrost EIR corrections.
+Please note that since the object is based on curve inputs, the user also has the flexibility of defining the curves by themselves---e.g. from the capacity function of temperature to the defrost EIR corrections.
\subsubsection{Electricty Use}
-The electricity use for the fuel-fired absorption heat pump is modeled using EIR (Electricity based relation) input curves. The two part of electricity use is the ``auxiliary electricty'' and the ``standby electricity'':
+The electricity use for the fuel-fired absorption heat pump is modeled using EIR (Electricity based relation) input curves. The two part of electricity use is the ``auxiliary electricity'' and the ``standby electricity'':
\begin{equation}
-\mathrm{Electricity use} = \mathrm{Norminal Auxilary Power} \times \mathrm{EIR}_{\mathrm{auxiliary}} + \mathrm{Electricty}_{\mathrm{Standby}},
+\mathrm{Electricity use} = \mathrm{Norminal Auxiliary Power} \times \mathrm{EIR}_{\mathrm{auxiliary}} + \mathrm{Electricty}_{\mathrm{Standby}},
\end{equation}
-where $\mathrm{EIR}_{\mathrm{auxiliary}}$ are supplied by the curve input, and $\mathrm{Norminal Auxilary Power}$ and $\mathrm{Electricty}_{\mathrm{Standby}}$ are supplied by the equipment standby electricity inputs.
+where $\mathrm{EIR}_{\mathrm{auxiliary}}$ are supplied by the curve input, and $\mathrm{Norminal Auxiliary Power}$ and $\mathrm{Electricty}_{\mathrm{Standby}}$ are supplied by the equipment standby electricity inputs.
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/air-system-fans.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/air-system-fans.tex
index 4e03e24adec..32219cb08d4 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/air-system-fans.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/air-system-fans.tex
@@ -182,7 +182,7 @@ \subsubsection{Simulation}\label{simulation}
RTF = \frac{f_{flow}}{PLF}
\end{equation}
-The total fan power is then calculated as the maximum fan power multipled by the run time fraction.
+The total fan power is then calculated as the maximum fan power multiplied by the run time fraction.
\begin{equation}
{\dot{Q}_{tot}} = RTF\left[ {\dot{m} \cdot \Delta P/\left( {{\varepsilon_{tot}}\cdot {\rho_{air}}} \right)} \right]
@@ -228,7 +228,7 @@ \subsubsection{Simulation}\label{simulation}
{\dot{Q}_{tot}} = RTF\left[ {\frac{{\dot{m} \Delta P}}{{{\varepsilon_{tot}}{\rho_{air}}}}} \right]\left( {\frac{{PowerRatio}}{{EfficiencyRatio}}} \right)
\end{equation}
-Each of the performance curves described above may be used to model the performance of a multi-speed fan motor, however, the power ratio curve must be used to envoke the multi-speed simulation. These curves are used when the fan is used in an HVAC system having multiple flow rates (i.e., different flow rates in cooling and heating mode). If an HVAC system operates at the same speed in either cooling or heating mode, these curves are not required. When these curves are not used, the associated ratio term in the equation above is assumed to be 1. The remaining calculations are identical to the simple single-speed fan model described above.
+Each of the performance curves described above may be used to model the performance of a multi-speed fan motor, however, the power ratio curve must be used to invoke the multi-speed simulation. These curves are used when the fan is used in an HVAC system having multiple flow rates (i.e., different flow rates in cooling and heating mode). If an HVAC system operates at the same speed in either cooling or heating mode, these curves are not required. When these curves are not used, the associated ratio term in the equation above is assumed to be 1. The remaining calculations are identical to the simple single-speed fan model described above.
\emph{\textbf{Variable Speed Fan Model}}
@@ -570,7 +570,7 @@ \subsubsection{Simulation}\label{simulation}
\caption{Belt Maximum Efficiency vs. Fan Shaft Power Input \protect \label{fig:belt-maximum-efficiency-vs.-fan-shaft-power}}
\end{figure}
-The quardratic polynomial curves in Figure~\ref{fig:belt-maximum-efficiency-vs.-fan-shaft-power} and their coefficients are as follows:
+The quadratic polynomial curves in Figure~\ref{fig:belt-maximum-efficiency-vs.-fan-shaft-power} and their coefficients are as follows:
\begin{equation}
{\eta_{belt,max,ln}} = {c_1} + {c_2} \cdot {x_{belt,max}} + {c_3} \cdot x_{belt,max}^2 + {c_4} \cdot x_{belt,max}^3 + {c_5} \cdot x_{belt,max }^4
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/demand-controlled-ventilation.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/demand-controlled-ventilation.tex
index 3946a8f0194..18f78702518 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/demand-controlled-ventilation.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/demand-controlled-ventilation.tex
@@ -2,7 +2,7 @@ \section{Demand Controlled Ventilation }\label{demand-controlled-ventilation}
ASHRAE Standard 62.1, Ventilation for Acceptable Indoor Air Quality, contains provisions that allow building ventilation systems to vary the amount of outdoor ventilation air delivered to occupied zones based on feedback from sensors that monitor various indoor air contaminants (ASHRAE 2007). Although not a contaminant of concern in most buildings, carbon dioxide (CO\(_{2}\)) levels can be monitored as an indicator of building occupancy and the associated human bioeffluent concentration. Demand controlled ventilation (DCV) is being increasingly used to modulate outdoor ventilation air based on real-time occupancy (Emmerich and Persily 1997, Schell et al. 1998, Schell and Int-Hout 2001). Modulating the outdoor ventilation air while maintaining proper indoor air quality has the potential for large energy savings compared to constant rate ventilation systems that are typically designed to provide outdoor ventilation air based on maximum anticipated occupancy.
-EnergyPlus can model DCV by the ventilation rate procedure (VRP) defined in ASHRAE Standard 62.1-2007/2010 for single and multiple path systems, and the indoor air quality procedure (IAQP) defined in Standard 62. The VRP first calculates the breathing-zone outdoor air flow rate based on two components -- the zone occupant component and the zone floor area component, then it calculates the zone supply outdoor air flow rate considering the zone air distribution effectiveness and secondary recirculation (for mult-path systems only), and finally calculates the system outdoor air flow rate considering the zone diversity and system ventilation efficiency. The user must include the following five objects in their input data file in order to model DCV (using VRP or IAQP):
+EnergyPlus can model DCV by the ventilation rate procedure (VRP) defined in ASHRAE Standard 62.1-2007/2010 for single and multiple path systems, and the indoor air quality procedure (IAQP) defined in Standard 62. The VRP first calculates the breathing-zone outdoor air flow rate based on two components -- the zone occupant component and the zone floor area component, then it calculates the zone supply outdoor air flow rate considering the zone air distribution effectiveness and secondary recirculation (for multi-path systems only), and finally calculates the system outdoor air flow rate considering the zone diversity and system ventilation efficiency. The user must include the following five objects in their input data file in order to model DCV (using VRP or IAQP):
\begin{itemize}
\item \textbf{AirLoopHVAC:OutdoorAirSystem} to simulate the mixed air box of the air loop
@@ -90,7 +90,7 @@ \subsubsection{Calculation of system minimum outdoor air flow}\label{calculation
{V_{ot}} = min(V_{{ot}_{design}}, {V_{ou}}/{E_v})
\end{equation}
-The ``Standard62.1VentilationRateProcedureWithLimit'' option should be used when the system outdoor air intake must stay at or below the design minimum outdoor air flow rate. This option can be used to meet the ``Multiple-Zone VAV System Ventilation Optimization Control'' requirements in ASHRAE Standards 90.1-2010 (and onwards) as well as the ``Outdoor Airflow Set Point for ASHRAE Standard 62.1-2016 Ventilation'' in Section 5.16.3.1 in the ASHRAE Guideline 36-2018.
+The ``Standard62.1VentilationRateProcedureWithLimit'' option should be used when the system outdoor air intake must stay at or below the design minimum outdoor air flow rate. This option can be used to meet the ``Multiple-Zone VAV System Ventilation Optimization Control'' requirements in ASHRAE Standards 90.1-2010 (and onward) as well as the ``Outdoor Airflow Set Point for ASHRAE Standard 62.1-2016 Ventilation'' in Section 5.16.3.1 in the ASHRAE Guideline 36-2018.
where:
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/evaporative-coolers.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/evaporative-coolers.tex
index c02718b8913..a79a83fe057 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/evaporative-coolers.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/evaporative-coolers.tex
@@ -271,7 +271,7 @@ \subsubsection{Wet Mode Operation}\label{wet-mode-operation}
Calculate heat transfer rate
\end{enumerate}
-The secondary air entering wet-bulb temperature would be the loswest limit allowed, although this temperature cannot be attained in most practical situations. This is checked as a limiting case.
+The secondary air entering wet-bulb temperature would be the lowest limit allowed, although this temperature cannot be attained in most practical situations. This is checked as a limiting case.
\begin{equation}
\begin{array}{rl}
@@ -390,7 +390,7 @@ \subsubsection{Dry Mode Operation}\label{dry-mode-operation}
\setcounter{enumi}{4}
\tightlist
\item
- Recalculate leaving supply air dryblub using new heat transfer rate from step 4
+ Recalculate leaving supply air drybulb using new heat transfer rate from step 4
\end{enumerate}
\begin{equation}
@@ -584,7 +584,7 @@ \subsubsection{Indirect Evaporative Cooler Sizing}\label{indirect-evaporative-co
\paragraph{Secondary Air DesignFan Flow Rate}\label{secondary-air-designfan-flow-rate}
-The secondary air design flow rate fan is not part of an airstream that is directly modeled in EnergyPlus. Because the primary side air flows can be autosized as part of the air system, it is convenentconvenient to also scale the size of the secondary flow. If the cooler is part of the main loop of a central air system, then the secondary fan flow rate is sized to equal to the main design flow rate.
+The secondary air design flow rate fan is not part of an airstream that is directly modeled in EnergyPlus. Because the primary side air flows can be autosized as part of the air system, it is convenient to also scale the size of the secondary flow. If the cooler is part of the main loop of a central air system, then the secondary fan flow rate is sized to equal to the main design flow rate.
User inputs for autosizing scaling factors are included so that when modeling an autosized IEC, all the design values can be scaled off of Primary Design Air Flow Rate. User input for Secondary Air Flow Sizing Factor is multiplied by DesMainVolFlow\(_{sys}\) as follows:
@@ -600,7 +600,7 @@ \subsubsection{Indirect Evaporative Cooler Sizing}\label{indirect-evaporative-co
\paragraph{Secondary Fan Design Power}\label{secondary-fan-design-power}
-The Secondary Fan Design Power is outosized from secondary air design flow rate and user input for Secondary Fan Sizing Specific Power in units of W/(m3/s) as follows:
+The Secondary Fan Design Power is autosized from secondary air design flow rate and user input for Secondary Fan Sizing Specific Power in units of W/(m3/s) as follows:
\begin{equation}
P_{sec,fan,design} = \dot{V}_{sec,design}\cdot\text{FanPowerScalingFactor}
@@ -649,7 +649,7 @@ \subsection{Direct Evaporative Cooler Special Research Model}\label{direct-evapo
where:
-\({T_{db,out,sys}}\) is the drybub temperature of the air leaving the cooler (\(^{\circ}\)C)
+\({T_{db,out,sys}}\) is the drybulb temperature of the air leaving the cooler (\(^{\circ}\)C)
\({T_{db,in,sys}}\) is the drybulb temperature of the air entering the cooler (\(^{\circ}\)C)
\({T_{wb,in,sys}}\) is the wetbulb temperature of the air entering the cooler (\(^{\circ}\)C)
\(\varepsilon_{design}\) is the cooler design effectiveness
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/heat-exchangers.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/heat-exchangers.tex
index 5ffc0c86a3a..bd1fbaa531e 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/heat-exchangers.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/heat-exchangers.tex
@@ -499,7 +499,7 @@ \subsubsection{Model Description}\label{model-description-1-007}
UA = U{A_{des}}({r_{hA}} + 1)/({({\dot m_{p,des}}{T_{p,des}}/{\dot m_p}{T_p})^{.78}} + {r_{hA}}{({\dot m_{s,des}}{T_{s,des}}/{\dot m_s}{T_s})^{.78}})
\end{equation}
-where \emph{des} means \emph{design}, \emph{p} means \emph{primary}, \emph{s} means \emph{secondary}, \emph{T} is air stream temperature, and \(\dot m\) is air stream mass flow rate. From the \emph{UA} and the capacity flow ratio the \emph{NTU} is determined: \(NTU = UA/{C_{\min }}\). Then the NTU -- effectiveness formulas are used to calculate the effectiveness. From the effectiveness and the inlet conditions, outlet condtions are determined.
+where \emph{des} means \emph{design}, \emph{p} means \emph{primary}, \emph{s} means \emph{secondary}, \emph{T} is air stream temperature, and \(\dot m\) is air stream mass flow rate. From the \emph{UA} and the capacity flow ratio the \emph{NTU} is determined: \(NTU = UA/{C_{\min }}\). Then the NTU -- effectiveness formulas are used to calculate the effectiveness. From the effectiveness and the inlet conditions, outlet conditions are determined.
\subsubsection{Economizer Operation}\label{economizer-operation-1}
@@ -949,7 +949,7 @@ \subsubsection{Long Time-Step Response Factors}\label{long-time-step-response-fa
\(t\) is the simulation time
-\(u_1\) is the starting discretization point for borhole
+\(u_1\) is the starting discretization point for borehole
\(u_2\) is the final discretization point for borehole
@@ -986,7 +986,7 @@ \subsubsection{Description of the Load Aggregation Scheme}\label{description-of-
\begin{figure}[hbtp] % fig 256
\centering
\includegraphics[width=0.9\textwidth, height=0.9\textheight, keepaspectratio=true]{media/image5657.png}
-\caption{Schematic Showing the Calculation of Hourly Load from the Sub Houly Loads. \protect \label{fig:schematic-showing-the-calculation-of-hourly}}
+\caption{Schematic Showing the Calculation of Hourly Load from the Sub Hourly Loads. \protect \label{fig:schematic-showing-the-calculation-of-hourly}}
\end{figure}
The bottom text in the boxes represents the magnitude of the sub hourly loads in W/m for each time step. The duration of the occurrence of each time-step for the each block is shown below the respective block. The first hourly load is given by the expression:
@@ -1192,7 +1192,7 @@ \subsubsection{References}\label{references-2-006}
\subsection{GroundHeatExchanger:Slinky}\label{groundheatexchangerslinky}
-This model reuses much of the same code including the load aggregation and temperature response caluclations which are described above in the GroundHeatExchanger:Vertical model. As a result, that section can also be used as reference material. This model is unique in that it generates it's own temperature response factor g-functions, rather than relying on the other software or data to generate the g-functions. These are generated based on the work by Xiong et al. 2015.
+This model reuses much of the same code including the load aggregation and temperature response calculations which are described above in the GroundHeatExchanger:Vertical model. As a result, that section can also be used as reference material. This model is unique in that it generates it's own temperature response factor g-functions, rather than relying on the other software or data to generate the g-functions. These are generated based on the work by Xiong et al. 2015.
\subsubsection{Horizontal Slinky Temperature Response Functions}\label{horizontal-slinky-temperature-response-functions}
@@ -1265,11 +1265,11 @@ \subsubsection{Vertical Slinky Temperature Response Functions}\label{vertical-sl
\subsubsection{Model Simplifications for Computational Efficiency}\label{model-simplifications-for-computational-efficiency}
-Several simplifications were used to ensure the g-function temperature response factors are computationally efficient. The first simplification is achieved by taking advantage of symmetry. In the Figure~\ref{fig:slinky-first-and-second-improvements} below, we can see that by taking advantage of symmettry the temperature response for only one quarter of the rings needs be calculated.
+Several simplifications were used to ensure the g-function temperature response factors are computationally efficient. The first simplification is achieved by taking advantage of symmetry. In the Figure~\ref{fig:slinky-first-and-second-improvements} below, we can see that by taking advantage of symmetry the temperature response for only one quarter of the rings needs be calculated.
-The second simplification occurs by realizing that the effect between two rings decreases exponentially as the distance between the rings increases. Near-field rings are defined as rings whose centers are within 2.5m + D distance from the center of ring i as is seen in Figure~\ref{fig:slinky-first-and-second-improvements}. Far-field rings are defined as rings whose centers are beyond 10m + D, with middle-field rings occupying the space in between the near-field and far-field rings. Near-field ring temperature response factors are determined as indicated above for horzontal or vertical slinkys. Middle-field rings are considerably simplified -- the interaction between ring is approximated as that of two point sources at their centers. Thermal effect of far-field rings are ignored.
+The second simplification occurs by realizing that the effect between two rings decreases exponentially as the distance between the rings increases. Near-field rings are defined as rings whose centers are within 2.5m + D distance from the center of ring i as is seen in Figure~\ref{fig:slinky-first-and-second-improvements}. Far-field rings are defined as rings whose centers are beyond 10m + D, with middle-field rings occupying the space in between the near-field and far-field rings. Near-field ring temperature response factors are determined as indicated above for horizontal or vertical slinkys. Middle-field rings are considerably simplified -- the interaction between ring is approximated as that of two point sources at their centers. Thermal effect of far-field rings are ignored.
-The third and final simplification takes advantatge of geometric similarity that ring share. Ring pairs that are geometrically similar do not require recalculation of distances or reponse factors. Thus the calculations for geometrically similar ring pairs can be reused.
+The third and final simplification takes advantage of geometric similarity that ring share. Ring pairs that are geometrically similar do not require recalculation of distances or response factors. Thus the calculations for geometrically similar ring pairs can be reused.
For more information, see the Xiong et al. (2015) reference listed below.
@@ -1603,7 +1603,7 @@ \subsection{Plant Loop Fluid-to-Fluid Heat Exchanger}\label{plant-loop-fluid-to-
This component (Object: HeatExchanger:FluidToFluid) is a simple hydronic heat exchanger that can be used to couple two (hydronic) plant or condenser loops.~ Sizing and nominal capacity calculations are discussed elsewhere in this document, see the section called Plant Heat Exchanger Sizing. This section first discusses the heat transfer modeling and the control issues.
-Heat exchanger performance modeling uses classic effectiveness-NTU correlations. The heat exchanger model can be specified as one of seven types: ~cross flow both fluid streams unmixed, cross flow both fluid streams mixed, cross flow Loop Supply Side mixed and Loop Demand Side unmixed, cross flow Loop Supply Side unmixed and Loop Demand Side mixed, counter flow, parallel flow, or ideal. The model correlations determine a heat transfer effectiveness value, \(\varepsilon\), which is a function of heat exchanger UA, the mass flow rates through boths sides, and the specific heat of the fluids in the streams.~ The effectiveness of an ideal heat exchanger is set to 1.0 and no correlation is needed.
+Heat exchanger performance modeling uses classic effectiveness-NTU correlations. The heat exchanger model can be specified as one of seven types: ~cross flow both fluid streams unmixed, cross flow both fluid streams mixed, cross flow Loop Supply Side mixed and Loop Demand Side unmixed, cross flow Loop Supply Side unmixed and Loop Demand Side mixed, counter flow, parallel flow, or ideal. The model correlations determine a heat transfer effectiveness value, \(\varepsilon\), which is a function of heat exchanger UA, the mass flow rates through both sides, and the specific heat of the fluids in the streams.~ The effectiveness of an ideal heat exchanger is set to 1.0 and no correlation is needed.
Because the heat exchanger is intended to be generic, its two sides are distinguished by the nature of loop side being connected.~ One side is called ``Loop Supply Side'' to indicate the heat exchanger is situated on the supply side of a loop. The other side is called ``Loop Demand Side'' to indicate it is on the demand side of a loop.~ The heat exchanger is intended to act as a supply component for the loop connected to it as the ``Loop Supply Side'' and as a demand component for the loop connected to it as the ``Loop Demand Side.''~ From the point of view of the heat exchanger component itself, the Loop Demand Side acts like a supply source/sink for the Loop Supply Side which acts like a demand to the component.
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/variable-refrigerant-flow-heat-pumps.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/variable-refrigerant-flow-heat-pumps.tex
index 4bac955aa55..df0bb4f02cf 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/variable-refrigerant-flow-heat-pumps.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-002/variable-refrigerant-flow-heat-pumps.tex
@@ -1798,7 +1798,7 @@ \subsubsection{\emph{Modeling of the outdoor unit (O/U) - Heating Mode}}\label{m
\item
Initialize outdoor unit \(SH\) with the reference value (from IDF input, e.g., 1.5\(^{\circ}\)C)
\item
- Iinitialize the compressor power \(N_{comp}\) with the value calculated from the reference \(COP\) (e.g., 3.5):
+ Initialize the compressor power \(N_{comp}\) with the value calculated from the reference \(COP\) (e.g., 3.5):
\end{itemize}
\begin{equation}
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-003/pumps.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-003/pumps.tex
index 4c89cf2ec03..aa52bba1935 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-003/pumps.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-003/pumps.tex
@@ -129,7 +129,7 @@ \subsection{Pressure-based Flow for Variable Speed Pumps}\label{pressure-based-f
\subsection{Constant Speed Pump}\label{constant-speed-pump}
-The operation of a constant speed pump (object name: Pump:ConstantSpeed) is fairly straightforward. The user designates a maximum flow rate and when this pumpo operates it will run at that capacity. The main difference between the constant speed pump and the variable speed pump is that the fraction of full load power is always = 1. In the pseudo code below, the FracFullLoadPower is = 1.0, therefore the Power is always the full power.
+The operation of a constant speed pump (object name: Pump:ConstantSpeed) is fairly straightforward. The user designates a maximum flow rate and when this pump operates it will run at that capacity. The main difference between the constant speed pump and the variable speed pump is that the fraction of full load power is always = 1. In the pseudo code below, the FracFullLoadPower is = 1.0, therefore the Power is always the full power.
~~~~VolFlowRate = PumpMassFlowRate / LoopDensity
@@ -173,7 +173,7 @@ \subsection{Pump Heat Addition to the Loop}\label{pump-heat-addition-to-the-loop
where the pump motor efficiency is defined by the user input and the FracMotorLossToFluid is the amount of heat generated by the pump motor that is added to the fluid loop (as opposed to being lost to the environment where the pump is located). FracMotorLossToFluid is also a user input.
-Note that the shaft power relates to the increase in head through the pump. Since all of this head is lost through the piping network due to frictional heat, this represents a heat gain by the fluid throughout the network. For simplicity, this heat is added along with the heat resulting from the pump motor. The difference between the pump power and the shaft power is the inefficiency of the pump---or the amount of energy input into the pump that the motor converts to heat rather than mechanical energy. Some of this heat is added to the fluid being pumped. These two terms are shown in the PumpHeatToFluid equation shown above. Since EnergyPlus Version 7, this heat is added to the loop capacitance tank(s) rather than at the pump's outlet and so the outlet temperatue is equal to the inlet temperaure.
+Note that the shaft power relates to the increase in head through the pump. Since all of this head is lost through the piping network due to frictional heat, this represents a heat gain by the fluid throughout the network. For simplicity, this heat is added along with the heat resulting from the pump motor. The difference between the pump power and the shaft power is the inefficiency of the pump---or the amount of energy input into the pump that the motor converts to heat rather than mechanical energy. Some of this heat is added to the fluid being pumped. These two terms are shown in the PumpHeatToFluid equation shown above. Since EnergyPlus Version 7, this heat is added to the loop capacitance tank(s) rather than at the pump's outlet and so the outlet temperature is equal to the inlet temperature.
\subsection{Pump Heat Addition to Surrounding Zone}\label{pump-heat-addition-to-surrounding-zone}
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-003/zone-internal-gains.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-003/zone-internal-gains.tex
index dc69e6ac3a6..1735150d7d8 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-003/zone-internal-gains.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-003/zone-internal-gains.tex
@@ -8,7 +8,7 @@ \subsection{Heat Gain from Lights}\label{heat-gain-from-lights}
The input object Lights provides a model for internal gains from lights.~ Radiant gains from lights must be handled differently from other radiant gains for reasons described here (long wavelength description).~ The total radiant gains from lights must be divided into visible and thermal portions.~ For example, the total electric input to typical incandescent lights is converted to 10\% visible radiation, 80\% thermal radiation, and 10\% convective gain.~ In contrast, the electric input to typical fluorescent lights is converted to 20\% visible radiation, 20\% thermal radiation, and 60\% convective gain (see Carrier 1965).~ These percentage splits are under user control with the Lights input object.
-When the value of Return Air Fraction is greater than 0 and the return air flow rate is greater than 0, the portion of light heat will be added to the return air node. The added heat will make the node temperature rise. The temperature difference is calculated in the CalcZoneLeavingConditions funtion of the ZoneEquipmentManager module:
+When the value of Return Air Fraction is greater than 0 and the return air flow rate is greater than 0, the portion of light heat will be added to the return air node. The added heat will make the node temperature rise. The temperature difference is calculated in the CalcZoneLeavingConditions function of the ZoneEquipmentManager module:
\begin{equation}
@@ -43,7 +43,7 @@ \subsection{Heat Gain from Lights}\label{heat-gain-from-lights}
\(CpAir\) is the specific heat (J/kg-K)
-Although a single Lights object allows a return node and an exhaust node, it is possible to have multiple Lights objects with different return nodes and referrred to the same exhaust node. Therefore, the exhaust node will share return heat from different return nodes. The temperature rise at i-th return node is given below:
+Although a single Lights object allows a return node and an exhaust node, it is possible to have multiple Lights objects with different return nodes and referred to the same exhaust node. Therefore, the exhaust node will share return heat from different return nodes. The temperature rise at i-th return node is given below:
\begin{equation}
TempRetRise_i = \frac{QRetAir_i} {(MassFlowRA_i + MassFlowEx ) * CpAir}
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/radiant-system-models.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/radiant-system-models.tex
index ca61f33803d..38eef8b86ab 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/radiant-system-models.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/radiant-system-models.tex
@@ -443,7 +443,7 @@ \subsubsection{Two-Dimensional Solutions for Radiant Systems}\label{two-dimensio
ConstructionProperty:InternalHeatSource object. This tubing spacing is halved
to determine the perpendicular distance for the solution domain.
\item
-While the number of nodes used for each layer of a construction is determined by the thermo-physical properties of the material for the layer to maintain solution stability, the number of nodes in the perpendicular direction is fixed for all layers of the construction. Currently in EnergyPlus, the number of nodes in the perpendicular direction is fixed at 7. This number was chosen as a result of testing with an evaluation version of one of the precedessor programs of EnergyPlus. This number of nodes was a balance between accuracy requirements and solution speed. Because the speed of the process required to calculate conduction transfer functions increases greatly as the number of nodes used in the model increases, increasing the number of nodes in the perpendicular direction too much will result in an unacceptible increase in the time required to calculate the conduction transfer functions.
+While the number of nodes used for each layer of a construction is determined by the thermo-physical properties of the material for the layer to maintain solution stability, the number of nodes in the perpendicular direction is fixed for all layers of the construction. Currently in EnergyPlus, the number of nodes in the perpendicular direction is fixed at 7. This number was chosen as a result of testing with an evaluation version of one of the predecessor programs of EnergyPlus. This number of nodes was a balance between accuracy requirements and solution speed. Because the speed of the process required to calculate conduction transfer functions increases greatly as the number of nodes used in the model increases, increasing the number of nodes in the perpendicular direction too much will result in an unacceptable increase in the time required to calculate the conduction transfer functions.
\item
The heat source or sink is applied evenly over the entire node where the user
defines the location of the source through the
@@ -605,7 +605,7 @@ \subsubsection{Low Temperature Radiant System Controls}\label{low-temperature-ra
Since flow rate is varied in a variable flow radiant system, there is no explicit control on the inlet water temperature or mixing to achieve some inlet water temperature in a hydronic system.~ However, the user does have the ability to specify on an hourly basis through a schedule the temperature of the water that would be supplied to the radiant system. Graphical descriptions of the controls for the low temperature radiant system model in EnergyPlus are shown in Figure~\ref{fig:variable-flow-low-temperature-radiant-system} for a hydronic system.~ In a system that uses electric resistance heating, the power or heat addition to the system varies in a manner similar to mass flow rate variation shown in Figure~\ref{fig:variable-flow-low-temperature-radiant-system}.
-In the constant flow/variable temperature systems, the controls are also considered piecewise linear functions, but in this case the user selects both the control temperatures and the water temperatures via schedules. This offers greater flexibility for defining how the radiant system operates though it may not model every situation.~ Figure~\ref{fig:variable-temperature-low-temperature-radiant} shows how the ``desired'' inlet water temperature is controlled based on user schedules.~ The user has the ability to specify the high and low water and control temperature schedules for heating and cooling (separately; a total of eight temperature schedules).~ Note that this inlet temperature is a ``desired'' inlet temperature in that there is no guarantee that the system will provide water to the system at that temperature.~ The model includes a local loop that attempts to meet this demand temperature through mixing and recirculation. Finally, the control temperature options are the same for a constant flow/variable temperature system as they are for the variable flow and electric radiant systems: mean air temperautre, mean radiant temperature, operative temperature, outdoor dry-bulb temperature, outdoor wet-bulb temperature, surface inside face temperature, and surface interior temperature.
+In the constant flow/variable temperature systems, the controls are also considered piecewise linear functions, but in this case the user selects both the control temperatures and the water temperatures via schedules. This offers greater flexibility for defining how the radiant system operates though it may not model every situation.~ Figure~\ref{fig:variable-temperature-low-temperature-radiant} shows how the ``desired'' inlet water temperature is controlled based on user schedules.~ The user has the ability to specify the high and low water and control temperature schedules for heating and cooling (separately; a total of eight temperature schedules).~ Note that this inlet temperature is a ``desired'' inlet temperature in that there is no guarantee that the system will provide water to the system at that temperature.~ The model includes a local loop that attempts to meet this demand temperature through mixing and recirculation. Finally, the control temperature options are the same for a constant flow/variable temperature system as they are for the variable flow and electric radiant systems: mean air temperature, mean radiant temperature, operative temperature, outdoor dry-bulb temperature, outdoor wet-bulb temperature, surface inside face temperature, and surface interior temperature.
\begin{figure}[hbtp] % fig 271
\centering
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/refrigeration-equipment.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/refrigeration-equipment.tex
index e42db152530..b054115f592 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/refrigeration-equipment.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/refrigeration-equipment.tex
@@ -262,7 +262,7 @@ \subsubsection{Condenser Heat Rejection, Energy Use, and Water Use}\label{conden
\subsection{Refrigerated Cases}\label{refrigerated-cases}
-The refrigerated case object (Refrigration:Case) works in conjunction with the compressor rack, detailed refrigeration system, or secondary refrigeration system object (Refrigeration:CompressorRack, Refrigeration:System, or Refrigeration:SecondarySystem) to simulate the performance of a refrigerated case system. The refrigerated case model uses performance information at rated conditions along with performance curves for latent case credits and defrost heat load to determine performance at off-rated conditions. Energy use for lights, fans and anti-sweat heaters is modeled based on inputs for nominal power, schedules, and control type. The refrigerated case model accounts for the sensible and latent heat exchange with the surrounding environment (termed ``case credits'') which impacts the temperature and humidity in the zone where the case is located. The simplified model described here provides the flexibility to simulate a broad range of refrigerated case types.
+The refrigerated case object (Refrigeration:Case) works in conjunction with the compressor rack, detailed refrigeration system, or secondary refrigeration system object (Refrigeration:CompressorRack, Refrigeration:System, or Refrigeration:SecondarySystem) to simulate the performance of a refrigerated case system. The refrigerated case model uses performance information at rated conditions along with performance curves for latent case credits and defrost heat load to determine performance at off-rated conditions. Energy use for lights, fans and anti-sweat heaters is modeled based on inputs for nominal power, schedules, and control type. The refrigerated case model accounts for the sensible and latent heat exchange with the surrounding environment (termed ``case credits'') which impacts the temperature and humidity in the zone where the case is located. The simplified model described here provides the flexibility to simulate a broad range of refrigerated case types.
The total load on the refrigerated case evaporator is made up of various components:
@@ -1091,7 +1091,7 @@ \subsubsection{Unit Load Factor Capacity}\label{unit-load-factor-capacity}
{q_{sens}} = \dot m \times {c_p} \times \varepsilon \times ({T_{coil,inlet}} - {T_{evap}}) = \dot m \times {c_p} \times \varepsilon \times DT1
\end{equation}
-\emph{For a given size of coil operating with constant airflow rate, the effectiveness can be considered constant over the small op- erating temperature ranges typical of refrigeration applications, and therefore, capacity can be considered to be proportional to the ratio of DT1. Hence, if evaporator coil sensible capac- ity is known for a given DT1, then capacity at a new initial temperature difference, DT1*, can be found by multiplying the original capacity by the ratio DT1*/DT1.''}
+\emph{For a given size of coil operating with constant airflow rate, the effectiveness can be considered constant over the small operating temperature ranges typical of refrigeration applications, and therefore, capacity can be considered to be proportional to the ratio of DT1. Hence, if evaporator coil sensible capacity is known for a given DT1, then capacity at a new initial temperature difference, DT1*, can be found by multiplying the original capacity by the ratio DT1*/DT1.''}
where:
@@ -1105,7 +1105,7 @@ \subsubsection{Unit Load Factor Capacity}\label{unit-load-factor-capacity}
T\(_{coil,inlet}\) is the dry-bulb air temperature entering the coil (\(^{\circ}\)C)
-T\(_{evap}\) is the average refrigeratnt evaporating temperature (\(^{\circ}\)C)
+T\(_{evap}\) is the average refrigerant evaporating temperature (\(^{\circ}\)C)
T\(_{coil,exit}\) is the dry-bulb air temperature leaving the coil (\(^{\circ}\)C)
@@ -1135,7 +1135,7 @@ \subsubsection{Unit Load Factor Capacity}\label{unit-load-factor-capacity}
\({Q_{Total}}\) is the cooling capacity (total), actual.
-The total capacity is therefore a function of the sensible heat ratio, which is a function of the total capacity, and they are both, of course a function of the psychometrics of the air flowing through the chiller. This is handled with a two step estimation process.
+The total capacity is therefore a function of the sensible heat ratio, which is a function of the total capacity, and they are both, of course a function of the psychrometrics of the air flowing through the chiller. This is handled with a two step estimation process.
\begin{equation}
\begin{array}{rl}
@@ -1306,7 +1306,7 @@ \subsubsection{Compressor Energy Use}\label{compressor-energy-use-1}
\subsubsection{Two-Stage Compression Systems}\label{two-stage-compression-systems}
-In addition to the single-stage compression refrigeration system illustrated above, two-stage compression systems can be modeled.~ For low temperature applications where the pressure ratio between the low- and high-pressure sides of the system could be 1:10 or more, it may be beneficial to utilize two stages of compressions (Evans 2008).~ Two smaller compressors in series have a smaller displacement and usually operate more efficiently than one large compressor that covers the entire pressure range from the evaporator to the condenser.~ This is especially true in ammonia refrigeration systems due to the large amount of superheating that occurs during the compression process (ASHRAE 2009b).
+In addition to the single-stage compression refrigeration system illustrated above, two-stage compression systems can be modeled.~ For low temperature applications where the pressure ratio between the low- and high-pressure sides of the system could be 1:10 or more, it may be beneficial to utilize two stages of compression (Evans 2008).~ Two smaller compressors in series have a smaller displacement and usually operate more efficiently than one large compressor that covers the entire pressure range from the evaporator to the condenser.~ This is especially true in ammonia refrigeration systems due to the large amount of superheating that occurs during the compression process (ASHRAE 2009b).
Between the two stages of compression, an intercooler is used to cool the discharge gas exiting the low-stage compressor before it enters the high-stage compressor.~ The cooling is performed within the intercooler by refrigerant at an intermediate pressure.~ The degree to which intercooling reduces the power requirement of a refrigeration cycle depends on the refrigerant which is being used as well as the temperature lift between the evaporator and the condenser.
@@ -1334,7 +1334,7 @@ \subsubsection{Two-Stage Compression Systems}\label{two-stage-compression-system
The low-stage compressors operate between the evaporator pressure and the intercooler pressure while the high-stage compressors operate between the intercooler pressure and the condensing pressure.~ The performance of both the low-stage and high-stage compressors are modeled using the compressors' performance curves defined by ARI Standard 540 (ARI 2004), as discussed previously in the ``Compressor Energy Use'' section.~ In addition, capacity corrections are applied to the compressor performance curves to account for deviations between the actual operating conditions and the rated conditions.
-Refering to Figure~\ref{fig:two-stage-compression-system-with-a-shell} for a two-stage system with a shell-and-coil intercooler, the performance of the intercooler is modeled with a ``Shell-and-Coil Intercooler Effectiveness'', defined as follows:
+Referring to Figure~\ref{fig:two-stage-compression-system-with-a-shell} for a two-stage system with a shell-and-coil intercooler, the performance of the intercooler is modeled with a ``Shell-and-Coil Intercooler Effectiveness'', defined as follows:
\begin{equation}
\eta = \frac{{{T_4} - {T_{5a}}}}{{{T_4} - {T_3}}}
@@ -1372,7 +1372,7 @@ \subsubsection{Condenser Performance}\label{condenser-performance}
\(\sum {{{\dot Q}_{Reclaimed}}}\) is the sum of all the heat reclaimed by desuperheater coils and hot gas and hot brine defrost (W).
-Depending upon the condenser type, the heat rejection environment is set to the ambient conditions, conditions corresponding to a defined ouside air node (sometimes used to represent condensers located above ground level) or zone node, to a temperature specified for a water-cooled condenser, or according to the evaporating temperature for a higher-temperature loop (used for cascade condensers).
+Depending upon the condenser type, the heat rejection environment is set to the ambient conditions, conditions corresponding to a defined outside air node (sometimes used to represent condensers located above ground level) or zone node, to a temperature specified for a water-cooled condenser, or according to the evaporating temperature for a higher-temperature loop (used for cascade condensers).
The enthalpy of the condensed refrigerant leaving the condenser is equal to:
@@ -1451,7 +1451,7 @@ \subsubsection{Condenser Performance}\label{condenser-performance}
For a fixed-speed fan, the air flow is reduced through either the use of dampers or by cycling the fan on and off.
-For a cycling fan, the power variation with air flow volume is approximately linearabove the minimum air volume ratio as shown in the following equation for the option ``FixedLinear'':
+For a cycling fan, the power variation with air flow volume is approximately linear above the minimum air volume ratio as shown in the following equation for the option ``FixedLinear'':
\begin{equation}
{P_{CondFan}} = ({\rm{Air~Volume~Ratio}}){P_{CondFan,design}}
@@ -1617,7 +1617,7 @@ \subsubsection{Condenser Performance}\label{condenser-performance}
\paragraph{Water-Cooled Condensers}\label{water-cooled-condensers}
-If the condenser heat rejection is specified as water cooled (input object Refrigeration:Condenser:WaterCooled), the model uses the same algoithms described above for Refrigeration Compressor Racks. The condensing temperature is set equal to the inlet water temperature plus an approach temperature equal to the difference between the rated values for water inlet temperature and condensing temperature.
+If the condenser heat rejection is specified as water cooled (input object Refrigeration:Condenser:WaterCooled), the model uses the same algorithms described above for Refrigeration Compressor Racks. The condensing temperature is set equal to the inlet water temperature plus an approach temperature equal to the difference between the rated values for water inlet temperature and condensing temperature.
\paragraph{Cascade Condensers}\label{cascade-condensers}
@@ -1761,7 +1761,7 @@ \subsection{Secondary Refrigeration Systems}\label{secondary-refrigeration-syste
For a brine system, the secondary loop capacity is matched to the case and walk-in load by varying the brine flow rate. (\emph{Throughout this section, `brine' will be used when referring to the secondary loop heat transfer fluid for systems where the secondary circulating fluid remains in the liquid state.)} When selecting the brine loop design parameters, it is important to consider the performance trade-off between pumping energy and the temperature difference, or range, in the heat exchanger. The circulating fluid selection is also critical in determining the performance of brine loop, with large variations caused by differences in viscosity and density (which impact pumping power requirements) and specific heat (which determines the required fluid flow rate). ~(Kazachki, G. S., and Hinde, D. K., 2006, Faramarzi, R. T., and Walker, D. H. 2004, ASHRAE. 2006c)
-For a secondary loop to accommodate a two-phase secondary coolant, additional hardware is required and the system control mode changes. A separator/receiver is required to separate the wet mixture of liquid and gas returning from the refrigeration load, as shown in Figure~\ref{fig:secondary-loop-with-liquid-overfeed}. ~(In the following discussion, we will refer to the secondary fluid in a liquid-overfeed system as CO\(_{2}\).) In Figure~\ref{fig:thermodynamic-cycle-for-a-liquid-overfeed}, which focuses in on the secondary loop alone, the gaseous CO\(_{2}\) moves via thermosiphon effect to the secondary evaporator, where heat is absorbed by the primary system to condense the CO\(_{2}\), which then returns via gravity flow to the separator/revceiver.~ The liquid CO\(_{2}\) is pulled from the bottom of the separator/receiver and pumped to the load. The term `liquid overfeed ratio' refers to the ratio of the total pumped mass flow rate (at the point labeled ``1'' on Figure~\ref{fig:thermodynamic-cycle-for-a-liquid-overfeed}) of CO\(_{2}\) to the mass rate of CO\(_{2}\) evaporated at the load (vapor portion of the flow at the point labled ``5'' on Figure~\ref{fig:thermodynamic-cycle-for-a-liquid-overfeed}). With a variable flow rate(obtained with either a variable-speed pump or multiple constant-speed pumps), the liquid overfeed ratio is maintained at or above the specified value. With a constant flow rate (obtained by specifying a single constant-speed pump), the liquid overfeed ratio will vary to match the capacity of the variable refrigeration load.(Hinde et al 2009) Even though a greater amount of CO\(_{2}\) is circulated than is evaporated, the pumping power requirements are still much less than those for a single-phase secondary coolant.
+For a secondary loop to accommodate a two-phase secondary coolant, additional hardware is required and the system control mode changes. A separator/receiver is required to separate the wet mixture of liquid and gas returning from the refrigeration load, as shown in Figure~\ref{fig:secondary-loop-with-liquid-overfeed}. ~(In the following discussion, we will refer to the secondary fluid in a liquid-overfeed system as CO\(_{2}\).) In Figure~\ref{fig:thermodynamic-cycle-for-a-liquid-overfeed}, which focuses in on the secondary loop alone, the gaseous CO\(_{2}\) moves via thermosiphon effect to the secondary evaporator, where heat is absorbed by the primary system to condense the CO\(_{2}\), which then returns via gravity flow to the separator/receiver.~ The liquid CO\(_{2}\) is pulled from the bottom of the separator/receiver and pumped to the load. The term `liquid overfeed ratio' refers to the ratio of the total pumped mass flow rate (at the point labeled ``1'' on Figure~\ref{fig:thermodynamic-cycle-for-a-liquid-overfeed}) of CO\(_{2}\) to the mass rate of CO\(_{2}\) evaporated at the load (vapor portion of the flow at the point labeled ``5'' on Figure~\ref{fig:thermodynamic-cycle-for-a-liquid-overfeed}). With a variable flow rate(obtained with either a variable-speed pump or multiple constant-speed pumps), the liquid overfeed ratio is maintained at or above the specified value. With a constant flow rate (obtained by specifying a single constant-speed pump), the liquid overfeed ratio will vary to match the capacity of the variable refrigeration load.(Hinde et al 2009) Even though a greater amount of CO\(_{2}\) is circulated than is evaporated, the pumping power requirements are still much less than those for a single-phase secondary coolant.
\begin{figure}[hbtp] % fig 288
\centering
@@ -1843,7 +1843,7 @@ \subsubsection{Secondary Evaporator in a Single-Phase Secondary Loop (Brine or G
\(\rho_{Brine}\) is the brine density (kg/m\(^{3}\)).
-After the heat exchanger effectiveness has been calculated, the value for the heat exchanger design brine flow rate is compared to the design flow rate for the secondary loop pump(s).~ The maximum flow rate in the loop is limited to the smaller of these two values. The heat transfer capacity corresponding to this maximum flow rate is then calculated and compared to the rated heat exchanger capacity. The maximum load on the heat exchanger is limited to the lesser of these two values, the rated heat exchanger capacity or the capacity corresponding ot the maximum loop flow rate.
+After the heat exchanger effectiveness has been calculated, the value for the heat exchanger design brine flow rate is compared to the design flow rate for the secondary loop pump(s).~ The maximum flow rate in the loop is limited to the smaller of these two values. The heat transfer capacity corresponding to this maximum flow rate is then calculated and compared to the rated heat exchanger capacity. The maximum load on the heat exchanger is limited to the lesser of these two values, the rated heat exchanger capacity or the capacity corresponding to the maximum loop flow rate.
\begin{equation}
Flow_{MaxVol} = Minimum(Flow_{RatedVol}, Flow_{RatedPumpVol})
@@ -1854,7 +1854,7 @@ \subsubsection{Secondary Evaporator in a Single-Phase Secondary Loop (Brine or G
\end{equation}
\begin{equation}
-Capacity_{Max} = Minmum(Capacity_{Rated}, Capacity_{AtMaxVolFlow})
+Capacity_{Max} = Minimum(Capacity_{Rated}, Capacity_{AtMaxVolFlow})
\end{equation}
where:
@@ -1959,7 +1959,7 @@ \subsubsection{Secondary Loop Pumping Power and Secondary Loop Load}\label{secon
\({\dot Q_{{\rm{TotalSecondary}}}}\) is the total load the secondary loop transfers to the primary system, output variable ``Refrigeration Secondary Loop Total Heat Transfer Rate'' (W)
-\({\dot Q_{{\rm{Pump}}}}\) is hte pump power, function of Flow\(_{Needed}\), output variable ``Refrigeration Secondary Loop Pump Electric Power'' (W)
+\({\dot Q_{{\rm{Pump}}}}\) is the pump power, function of Flow\(_{Needed}\), output variable ``Refrigeration Secondary Loop Pump Electric Power'' (W)
\(Flow_{Needed}\) is the flow rate needed to meet the loop refrigeration load, , output variable ``Refrigeration Secondary Loop Volume Flow Rate'' (m\(^3\)/s).
@@ -2147,7 +2147,7 @@ \subsection{References}\label{references-040}
B.A.C. 2007. Baltimore AirCoil Company Product and Application Handbook, Volume II, Baltimore, MD
-Baek, J.S., Groll, E.A., and Lawless, P.B. 2005. Theoretical Perfromance of Transcritical Carbon Dioxide Cycle with Two-Stage Compression and Intercooling. \emph{Proceedings of the Institution of Mechanical Engineers, Part E: Journal of Process Mechanical Engineering} 219, 187-195.
+Baek, J.S., Groll, E.A., and Lawless, P.B. 2005. Theoretical Performance of Transcritical Carbon Dioxide Cycle with Two-Stage Compression and Intercooling. \emph{Proceedings of the Institution of Mechanical Engineers, Part E: Journal of Process Mechanical Engineering} 219, 187-195.
Baxter, V. D., Mei, V.C. 2002.Warm Liquid Defrosting Technology For Supermarket Display Cases, P.S. Hrnjak, Ed., International Conference New Technologies in Commercial Refrigeration, University of Illinois at Urbana-Champaign, Urbana, IL, July 22-23, 2002
@@ -2179,7 +2179,7 @@ \subsection{References}\label{references-040}
Kazachki, G. S., and Hinde, D. K. 2006, Secondary Cooplant Systems for Supermarkets, ASHRAE Journal, Atlanta: American Society of Heating, Refrigerating and Air-Conditioning Engineers, Inc., September 2006
-Lawrence Berkeley Laboratory and Resource Dynamics, Improving Fan Systrem Performance, A Sourcebook for Industry, DOE/GO-102003-1294, April 2003
+Lawrence Berkeley Laboratory and Resource Dynamics, Improving Fan System Performance, A Sourcebook for Industry, DOE/GO-102003-1294, April 2003
Lee, T-S., Liu, C-H., and Chen, T-W. 2006. Thermodynamic Analysis of Optimal Condensing Temperature of Cascade-Condenser in CO\(_{2}\)/NH\(_{3}\) Cascade Refrigeration Systems, International Journal of Refrigeration 29 (2006) 1100-1108, Elsevier Ltd.
@@ -2191,7 +2191,7 @@ \subsection{References}\label{references-040}
Mitchell, J.W., et al. 1992.Analysis of Supermarket Dehumidification Alternatives. Final Report to Electric Power Research Institute, Report TR-100352, November.
-NASA. 1976. U. S. Standard Atmosphere, NASA-TM-74335, National Oceanic and Atmosperic Administration , National Aeronautics and Space Administration
+NASA. 1976. U. S. Standard Atmosphere, NASA-TM-74335, National Oceanic and Atmospheric Administration , National Aeronautics and Space Administration
Nelson, B. I., 2010, Refrigeration Air Cooler Rating Methods, ASHRAE Journal, American Society of Heating, Refrigeration and Air-Conditioning Engineers, Inc., August
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/setpoint-managers.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/setpoint-managers.tex
index 9dfc6caa2a0..2165539f721 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/setpoint-managers.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/setpoint-managers.tex
@@ -149,7 +149,7 @@ \subsection{Single Zone Cooling Only}\label{single-zone-cooling-only}
\emph{SetPoint} is the setpoint temperature applied to the specified setpoint node(s)
-\emph{ZoneTemp} is the current zone temeprature
+\emph{ZoneTemp} is the current zone temperature
\emph{ZoneLoadtoCoolSP} is the zone cooling load (Report Variable ``Zone Predicted Sensible Load to Cooling Setpoint Heat Transfer Rate {[}W{]}'')
@@ -280,7 +280,7 @@ \subsection{Coldest Zone Supply Air Reset}\label{coldest-zone-supply-air-reset}
\subsection{Return Air Bypass Flow}\label{return-air-bypass-flow}
-The input object SetpointManager:ReturnAirBypassFlow provides a setpoint manager that sets the air flow rate in a bypass duct such that when the bypassed and non-bypassed air are mixed the resutant air stream will be at the user-specified setpoint temperature.
+The input object SetpointManager:ReturnAirBypassFlow provides a setpoint manager that sets the air flow rate in a bypass duct such that when the bypassed and non-bypassed air are mixed the resultant air stream will be at the user-specified setpoint temperature.
The user specifies the desired setpoint temperature \emph{T\(_{set}\)} through a input temperature schedule.
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/solar-collectors.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/solar-collectors.tex
index e9d6a5bcc8d..46e8e5e341d 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/solar-collectors.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/solar-collectors.tex
@@ -186,7 +186,7 @@ \subsubsection{References}\label{references-042}
\subsection{Integral-collector-storage (ICS) Solar Collector}\label{integral-collector-storage-ics-solar-collector}
-Solar collectors with integral storage unit models use SolarCollector:IntegralCollectorStorage object, and the characteristics parameter inputs of this collector are provided by the SolarCollectorPerformance:IntegralCollectorStorage object. This model is based on detailed Energy Balance equations of solar collectors that integrates storage in it. This model has two options to represent the collector bottom outside boundary conditions: AmbientAir, and OtherSideConditionsModel. AmbientAir simply applies outside air temperature using combined convection and radiation conductance, and the OtherSideConditionsModel applies combined radiation and convection models that exiats in a naturally ventilated cavity to represent the collector bottom outside boundary condition. The later boundary condition accounts for the shading of the collector on the underlying surface, hence, the ICS collector can be assumed as an integral part of the building envelope. Schematic diagram of a rectangular ICS solar collector is shown in Figure~\ref{fig:schematic-diagram-of-rectangular-integrated} below:
+Solar collectors with integral storage unit models use SolarCollector:IntegralCollectorStorage object, and the characteristics parameter inputs of this collector are provided by the SolarCollectorPerformance:IntegralCollectorStorage object. This model is based on detailed Energy Balance equations of solar collectors that integrates storage in it. This model has two options to represent the collector bottom outside boundary conditions: AmbientAir, and OtherSideConditionsModel. AmbientAir simply applies outside air temperature using combined convection and radiation conductance, and the OtherSideConditionsModel applies combined radiation and convection models that exist in a naturally ventilated cavity to represent the collector bottom outside boundary condition. The later boundary condition accounts for the shading of the collector on the underlying surface, hence, the ICS collector can be assumed as an integral part of the building envelope. Schematic diagram of a rectangular ICS solar collector is shown in Figure~\ref{fig:schematic-diagram-of-rectangular-integrated} below:
\begin{figure}[hbtp] % fig 295
\centering
@@ -700,17 +700,17 @@ \subsection{References:}\label{references-1-016}
Kumar, R. and M.A.~Rosen. Thermal performance of integrated collector storage solar water heater with corrugated absorber surface. Applied Thermal Engineering:~ 30 (2010) 1764--1768.
-Fujii, T., and H. Imura. Natural convection heat transfer from aplate with arbitrary inclination. International Journal of Heat and Mass Transfer: 15(4), (1972), 755-764.
+Fujii, T., and H. Imura. Natural convection heat transfer from a plate with arbitrary inclination. International Journal of Heat and Mass Transfer: 15(4), (1972), 755-764.
\subsection{Photovoltaic Thermal Flat-Plate Solar Collectors}\label{photovoltaic-thermal-flat-plate-solar-collectors}
-Photovoltaic-Thermal solar collectors (PVT) combine solar electric cells and thermal working fluid to collect both electricity and heat.~ Athough there are currently comparatively few commercial products, PVT research has been conducted for the past 30 years and many different types of collectors have been studied.~ Zondag (2008) and Charalambous et. al (2007) provide reviews of the PVT literature.~ Because PVT is much less commercially-mature, there are no standards or rating systems such as for thermal-only, hot-water collectors.~ EnergyPlus currently has one simple model based on user-defined efficiencies.
+Photovoltaic-Thermal solar collectors (PVT) combine solar electric cells and thermal working fluid to collect both electricity and heat.~ Although there are currently comparatively few commercial products, PVT research has been conducted for the past 30 years and many different types of collectors have been studied.~ Zondag (2008) and Charalambous et. al (2007) provide reviews of the PVT literature.~ Because PVT is much less commercially-mature, there are no standards or rating systems such as for thermal-only, hot-water collectors.~ EnergyPlus currently has one simple model based on user-defined efficiencies.
The PVT models reuse the PV models for electrical production. These are described elsewhere in this document in the section on Photovoltaic Arrays-Simple Model
\subsubsection{Simple PVT Thermal Model}\label{simple-pvt-thermal-model}
-The input object SolarCollector:FlatPlate:PhotovoltaicThermal provides a simple PVT model that is provided for quick use during design or policy studies.~ The user simply provides values for a thermal efficiency and the incident solar heats the working fuild.~ The model also includes a cooling mode for air-based systems where a user-provided surface emmittance is used to model cooling of the working fluid to the night sky (water-based cooling will be made available once a chilled water storage tank is available).~ No other details of the PVT collector's construction are required as input data.
+The input object SolarCollector:FlatPlate:PhotovoltaicThermal provides a simple PVT model that is provided for quick use during design or policy studies.~ The user simply provides values for a thermal efficiency and the incident solar heats the working fluid.~ The model also includes a cooling mode for air-based systems where a user-provided surface emittance is used to model cooling of the working fluid to the night sky (water-based cooling will be made available once a chilled water storage tank is available).~ No other details of the PVT collector's construction are required as input data.
The simple model can heat either air or liquid.~ If it heats air, then the PVT is part of HVAC air system loop with air nodes connected to an air system.~ If it heats liquid, then the PVT is part of plant loop with nodes connected to a plant loop and the plant operating scheme determines flows.
@@ -718,7 +718,7 @@ \subsubsection{Simple PVT Thermal Model}\label{simple-pvt-thermal-model}
Plant-based PVT do not include a bypass (although one could be used in the plant loop).~ The collector requests its design flow rate but it otherwise relies on the larger plant loop for control.
-When the PVT themal collector is controlled to be ``on,'' in heating mode, and working fluid is flowing, the model calculates the outlet temperature based on the inlet temperature and the collected heat using the following equations.
+When the PVT thermal collector is controlled to be ``on,'' in heating mode, and working fluid is flowing, the model calculates the outlet temperature based on the inlet temperature and the collected heat using the following equations.
\begin{equation}
{Q_{therm}} = {A_{surf}} \cdot {f_{activ}} \cdot {G_T} \cdot {\eta_{thermal}}
@@ -730,7 +730,7 @@ \subsubsection{Simple PVT Thermal Model}\label{simple-pvt-thermal-model}
\({A_{surf}}\) is the net area of the surface (m\(^{2}\))
-\({f_{activ}}\) is the fraction of surface aire with active PV/T collector
+\({f_{activ}}\) is the fraction of surface area with active PV/T collector
\({\eta_{thermal}}\) is the thermal conversion efficiency.
@@ -754,7 +754,7 @@ \subsubsection{Simple PVT Thermal Model}\label{simple-pvt-thermal-model}
{f_{bypass}} = \frac{{\left( {{T_{set,out}} - {T_{out}}} \right)}}{{\left( {{T_{in}} - {T_{out}}} \right)}}
\end{equation}
-When the PVT themal collector is controlled to be ``on,'' in cooling mode, and working fluid is flowing, the model calculates the outlet temperature based on the inlet temperature and the heat radiated and convected to the ambient using a heat balance on the outside face of the collector:
+When the PVT thermal collector is controlled to be ``on,'' in cooling mode, and working fluid is flowing, the model calculates the outlet temperature based on the inlet temperature and the heat radiated and convected to the ambient using a heat balance on the outside face of the collector:
\begin{equation}
\dot m{c_p}\left( {{T_{in}} - {T_{out}}} \right) = {\dot Q_{LWR}} + {\dot Q_{conv}}
@@ -935,7 +935,7 @@ \subsubsection{Collector Heat Balance}\label{collector-heat-balance}
\(q''_{LWR,plen}\) is net long wavelength (thermal) radiation flux exchange with the outside face of the underlying surface(s).
-\({q''_{source}}\) is a source/sink term that accounts for energy exported out of the control volume when the collecter's absorber plate is a hybrid device such as a photovoltaic panel.
+\({q''_{source}}\) is a source/sink term that accounts for energy exported out of the control volume when the collector's absorber plate is a hybrid device such as a photovoltaic panel.
While the heat balance on the passive collector surface control volume is:
@@ -1155,7 +1155,7 @@ \subsubsection{Local Wind Speed Calculations}\label{local-wind-speed-calculation
\(z\) is the height of the centroid of the UTSC
-\(z_{met}\) is the height of the standard metereological wind speed measurement
+\(z_{met}\) is the height of the standard meteorological wind speed measurement
\(a\) and \({\delta}\) are terrain-dependent coefficients.~ \({\delta}\) is the boundary layer thickness for the given terrain type.~ The values of a and \({\delta}\) are shown in the Table~\ref{table:terrain-dependent-coefficients-ashrae-2001.-001}.
@@ -1227,9 +1227,9 @@ \subsubsection{Radiation Coefficients}\label{radiation-coefficients-000}
\({\sigma_{SB}}\) is the Stefan-Boltzmann constant
-\({e_{coll}}\) is the longwave thermal emmittance of the collector
+\({e_{coll}}\) is the longwave thermal emittance of the collector
-\({e_{so}}\) is the longwave thermal emmittance of the underlying heat transfer surface.
+\({e_{so}}\) is the longwave thermal emittance of the underlying heat transfer surface.
The three other coefficients, \({h_{r,atm}}\), \({h_{r,sky}}\), and \({h_{r,gnd}}\) are used elsewhere in EnergyPlus for the outside face surface heat balance and are calculated in the same manner as equation for UTSC collectors.~ {[}This is accomplished by calling subroutine InitExteriorConvectionCoeffs in the file HeatBalanceConvectionCoeffs.f90.{]}
@@ -1694,7 +1694,7 @@ \subsubsection{Solving energy balance equations for zero flow condition}\label{B
\subsubsection{References}\label{BIPVT-references}
-Candanedo, L.M., Athienitis, A., Park, K.W., 2011. Convective heat transfer coefficients in a building-integraged photovoltaic/thermal system. \emph{Journal of Solar Energy Engineering}. March 2011, Vol. 133
+Candanedo, L.M., Athienitis, A., Park, K.W., 2011. Convective heat transfer coefficients in a building-integrated photovoltaic/thermal system. \emph{Journal of Solar Energy Engineering}. March 2011, Vol. 133
Delisle, V., Kummert, M., 2014. A novel approach to compare building-integrated \mbox{photovoltaics/thermal} air collectors to side-by-side PV modules and solar thermal collectors. \emph{Solar Energy}. February 2014, Vol. 100, p.~50.
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/system-availability-managers.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/system-availability-managers.tex
index 1d9ae0a6167..4c51da33fef 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/system-availability-managers.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-004/system-availability-managers.tex
@@ -406,4 +406,4 @@ \subsubsection{Adaptive ASHRAE Algorithm}\label{adaptive-ashrae-algorithm}
\(q_{(i-1)}\) is the energy extracted or added during last time step
-\(q_{max}\) is the maximum capacity of the equipments.
+\(q_{max}\) is the maximum capacity of the equipment.
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/water-systems.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/water-systems.tex
index b6d06c8f926..8618831619e 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/water-systems.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/water-systems.tex
@@ -115,7 +115,7 @@ \subsection{Unconnected Water Use Equipment}\label{unconnected-water-use-equipme
Even though hot and cold flow rates are unlimited in ``unconnected'' mode, it is still possible to fail to meet the target conditions if \({T_{target}}\) ~\textgreater{} \({T_{hot}}\).~ In this case, the actual mixed water temperature at the tap, \({T_{mixed}}\), is set equal to \({T_{hot}}\).~ The target flow rate is always met.
-Water equipment that omits schedules for the target temperature and/or hot water suppy temperature implies that no hot water is needed.~ The result is all cold water at the target flow rate.
+Water equipment that omits schedules for the target temperature and/or hot water supply temperature implies that no hot water is needed.~ The result is all cold water at the target flow rate.
For ``unconnected'' water equipment, the heating rate and energy that is required to supply the hot water is calculated by the following equations.
@@ -387,7 +387,7 @@ \subsubsection{Calculate Connections Drain Temperature}\label{calculate-connecti
{T_{drain}} = \frac{{\mathop \sum \limits_i {{\dot m}_{drain,i}}{t_{drain,i}}}}{{{{\dot M}_{drain}}}}
\end{equation}
-In the case of no drainwater heat recovery, the subsystem wastewater temperature, \({T_{waste}}\), is equal to the drainwater temperature, \({T_{drain}}\).~ (For drainwater heat recovery, see below.)~ The wastewater temperature and flow rate are propogated to the reclamation water storage tank, if specified.
+In the case of no drainwater heat recovery, the subsystem wastewater temperature, \({T_{waste}}\), is equal to the drainwater temperature, \({T_{drain}}\).~ (For drainwater heat recovery, see below.)~ The wastewater temperature and flow rate are propagated to the reclamation water storage tank, if specified.
\subsubsection{Update Connections Nodes}\label{update-connections-nodes}
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/water-thermal-tanks-includes-water-heaters.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/water-thermal-tanks-includes-water-heaters.tex
index c26b6604cc4..2a56caf02c5 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/water-thermal-tanks-includes-water-heaters.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/water-thermal-tanks-includes-water-heaters.tex
@@ -179,7 +179,7 @@ \subsubsection{Water Heater Control Algorithm}\label{water-heater-control-algori
An illustration of how the control algorithm cycles on and off is shown below.~ Ambient losses cool the tank temperature until the bottom of the deadband is reached (50\(^{\circ}\)C) at which point the heater cycles on and reheats the tank back to the setpoint (60\(^{\circ}\)C).~ A water draw causes hot water to be replaced with cold water from the water mains.~ The incoming cold water rapidly cools the tank.~ In this example the heater cannot keep up with the water draw and the tank temperature continues to drop until the water draw ends.
-Although the instantaneous tank water temperature may vary considerably within a timestep (due to cycling, etc.), only the average temperature over the timestep is reported.~ The model calculates the average by piece-wise integration of the area under the instantaneous temperature curve for each unique set of conditions.~ The instantaneous temperature is preserved internally by the program and is propogated from the end of one timestep to the beginning of the next.
+Although the instantaneous tank water temperature may vary considerably within a timestep (due to cycling, etc.), only the average temperature over the timestep is reported.~ The model calculates the average by piece-wise integration of the area under the instantaneous temperature curve for each unique set of conditions.~ The instantaneous temperature is preserved internally by the program and is propagated from the end of one timestep to the beginning of the next.
\begin{figure}[hbtp] % fig 311
\centering
@@ -189,7 +189,7 @@ \subsubsection{Water Heater Control Algorithm}\label{water-heater-control-algori
\subsubsection{Chilled Water Tank Control Algorithm}\label{chilled-water-tank-control-algorithm}
-The input objects ThermalStorage:ChilledWater:Mixed and ThermalStorage:ChilledWater:Stratified provide chilled water tank models that do not include active cooling elements, there is only indirect cooling by remote devices such as a chiller.~ The tank's setpoint controls are used to determine if flow is to be requested through the source side of the tank.~ The setpont and deadband control scheme is similar to the water heater but the logic is flipped around for cooling instead of heating.~ The setpoint temperatue is the ``cut-out'' temperature and the setpoint plus deadband is the ``cut-in'' temperature.~ If the tank temperature ( or tank sensing node for stratified tanks) is above the ``cut-in'' temperature, then flow is requested.~ If temperatures are below the ``cut-out'' temperature, then flow is not requested.~ The chilled water tanks also have separate availability schedules for the use side and source side for additional control options.
+The input objects ThermalStorage:ChilledWater:Mixed and ThermalStorage:ChilledWater:Stratified provide chilled water tank models that do not include active cooling elements, there is only indirect cooling by remote devices such as a chiller.~ The tank's setpoint controls are used to determine if flow is to be requested through the source side of the tank.~ The setpoint and deadband control scheme is similar to the water heater but the logic is flipped around for cooling instead of heating.~ The setpoint temperature is the ``cut-out'' temperature and the setpoint plus deadband is the ``cut-in'' temperature.~ If the tank temperature ( or tank sensing node for stratified tanks) is above the ``cut-in'' temperature, then flow is requested.~ If temperatures are below the ``cut-out'' temperature, then flow is not requested.~ The chilled water tanks also have separate availability schedules for the use side and source side for additional control options.
\subsubsection{Standard Ratings}\label{standard-ratings-000}
@@ -817,7 +817,7 @@ \subsubsection{Autosizing Tank Volume}\label{autosizing-tank-volume}
\begin{itemize}
\item Peak Draw. The volume is determined from the loop design flow rate.~ The water heater is positioned on the supply side of a plant loop.~ After the plant sizing routines have run, the model~ obtains the design flow rate for all components on the demand side.~ The tank volume is then: \(V = {\dot V_{loop.des}}*{t_{draw}}\)
- \item Residential HUD-FHA Minimum. The volume is determined from a set of rules defined in Table~\ref{table:residential-hud-fha-minimum}.~ This is from Chapter 48 of 1999 ASHRAE Handbook HVAC Applications, Americal Society of Heating Refrigeration and Air-conditioning Engineeers, Atlanta GA.~ (also used in the Building America Benchmark).
+ \item Residential HUD-FHA Minimum. The volume is determined from a set of rules defined in Table~\ref{table:residential-hud-fha-minimum}.~ This is from Chapter 48 of 1999 ASHRAE Handbook HVAC Applications, American Society of Heating Refrigeration and Air-conditioning Engineers, Atlanta GA.~ (also used in the Building America Benchmark).
\end{itemize}
% table 85
@@ -879,7 +879,7 @@ \subsubsection{Autosizing Heater Capacity}\label{autosizing-heater-capacity}
\end{equation}
\begin{itemize}
-\item Residential HUD-FHA Minimum.~ The heater capacity is determined from a set of rules defined by the table above.~ This is from 1999 ASHRAE Handbook HVAC Applications, Americal Society of Heating Refrigeration and Air-conditioning Engineeers, Atlanta GA.~ (also used the Building America Benchmark).
+\item Residential HUD-FHA Minimum.~ The heater capacity is determined from a set of rules defined by the table above.~ This is from 1999 ASHRAE Handbook HVAC Applications, American Society of Heating Refrigeration and Air-conditioning Engineers, Atlanta GA.~ (also used the Building America Benchmark).
\item Per Person.~ The heater capacity is determined by summing the design level of people in the model and using a user-entered factor for recovery capacity per person.~ The heater capacity is then:
\end{itemize}
@@ -917,7 +917,7 @@ \subsubsection{Autosizing Tank Height}\label{autosizing-tank-height}
\subsubsection{Autosizing Plant Connection Flow Rates}\label{autosizing-plant-connection-flow-rates}
-When the water thermal tank is connected to a plant loop, it is convient to autosize the design volume flow rates through the plant connections.~ When the water thermal tank is connected to the supply side of plant loop and flow rates are autosized, the flow rate is the sum of the flow requests of all the various components on the demand side of that plant loop.~ When the water thermal tank is connected on the demand side of a plant loop (e.g.~as for indirect water heating with a boiler) and flow rates are autosized, the design flow rates are calculated with the following equation:
+When the water thermal tank is connected to a plant loop, it is convenient to autosize the design volume flow rates through the plant connections.~ When the water thermal tank is connected to the supply side of plant loop and flow rates are autosized, the flow rate is the sum of the flow requests of all the various components on the demand side of that plant loop.~ When the water thermal tank is connected on the demand side of a plant loop (e.g.~as for indirect water heating with a boiler) and flow rates are autosized, the design flow rates are calculated with the following equation:
\begin{equation}
\dot V = - \left( \frac{V}{t_{Recover} * 3600 * \varepsilon } \right) * Ln\left( \frac{T_{PlantDesign} - T_{Setpoint}}{T_{PlantDesign} - T_{start}} \right)
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/zone-controls.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/zone-controls.tex
index 5bdcee5a0cb..e32fcd06111 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/zone-controls.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/zone-controls.tex
@@ -324,7 +324,7 @@ \subsection{Humidistat}\label{humidistat}
The input object ZoneControl:Humidistat provides a way for the zone to be controlled to a single relative humidity setpoint schedule, or dual humidity schedules (humidifying and dehumidifying with deadband). The schedules consist of relative humidities, expressed as a percentage (0-100), to be used for the zone moisture prediction calculation. Only one control statement can be specified for each zone.~ Individual relative humidity values can be defined for every time step, thus giving the user a full range of flexibility. For a single setpoint humidistat, if the control relative humidity is below the calculated load and the equipment specified can humidify then that equipment will try and meet the requirement.~ The opposite is true if the calculated value is above the setpoint and the equipment can dehumidify. For a dual setpoint humidistat, if the zone relative humidity is below the \textbf{humidifying} relative humidity setpoint and the equipment specified can humidify then that equipment will try and meet the zone's humidification load. The opposite is true if the zone relative humidity is above the \textbf{dehumidifying} relative humidity setpoint and the equipment can dehumidify.
-If the ZoneControl:Humidistat is used by a furnace or unitary system then no other objects are required. The signal from the humidistat is used directly by that component. If the Zone Control:Humidistat is used to control a Humidifier or used in conjunction with the Controller:Simple object with control variable ``TemperatureAndHumidityRatio'', then either the ``SetpointManager:SingleZone:Humidity:Minimum'', ``SetpointManager:MultiZone:Humidity:Minimum'',~ ``SetpointManager:SingleZone:Humidity:Maximum'' or ``SetpointManager:MultiZone:Humidity:Maximum'' objects are required to determine a setpoint for those components to meet for the single setpoint humidistat. For a dual setpoint humidistat, a minimum humidity setpoint manager object~ (``SetpointManager:SingleZone:Humidity:Minimum'' or ``SetpointManager:MultiZone:Humidity:Minimum'') and a maximum humidity setpoint manager object (``SetpointManager:SingleZone:Humidity:Maximum'' or ``SetpointManager:MultiZone:Hu-midity:Maximum'') are required to determine the setpoints for the corresponding humidification and dehumidification components. Note that the ``SetpointManager:Scheduled'' object can also be used to directly set humidity ratio setpoints on the exit node of the humidifier component.
+If the ZoneControl:Humidistat is used by a furnace or unitary system then no other objects are required. The signal from the humidistat is used directly by that component. If the Zone Control:Humidistat is used to control a Humidifier or used in conjunction with the Controller:Simple object with control variable ``TemperatureAndHumidityRatio'', then either the ``SetpointManager:SingleZone:Humidity:Minimum'', ``SetpointManager:MultiZone:Humidity:Minimum'',~ ``SetpointManager:SingleZone:Humidity:Maximum'' or ``SetpointManager:MultiZone:Humidity:Maximum'' objects are required to determine a setpoint for those components to meet for the single setpoint humidistat. For a dual setpoint humidistat, a minimum humidity setpoint manager object~ (``SetpointManager:SingleZone:Humidity:Minimum'' or ``SetpointManager:MultiZone:Humidity:Minimum'') and a maximum humidity setpoint manager object (``SetpointManager:SingleZone:Humidity:Maximum'' or ``SetpointManager:MultiZone:Humidity:Maximum'') are required to determine the setpoints for the corresponding humidification and dehumidification components. Note that the ``SetpointManager:Scheduled'' object can also be used to directly set humidity ratio setpoints on the exit node of the humidifier component.
For the single setpoint humidistat case, the model takes into account all of the moisture gains and/or losses from sources except the HVAC system contribution, and then calculates a moisture removal or addition rate based on the provided setpoint value, like the temperature predictor. The algorithm uses a 3rd Order derivative to predict zone moisture addition or removal to smooth the changes using the zone air capacitance. Positive values of moisture load mean that this amount of moisture must be added to the zone to reach the setpoint. Negative values represent the amount of moisture that must be removed by the system.
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/zone-equipment-and-zone-forced-air-units.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/zone-equipment-and-zone-forced-air-units.tex
index bd33aa362e4..5c6a1ac8b9d 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/zone-equipment-and-zone-forced-air-units.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference-005/zone-equipment-and-zone-forced-air-units.tex
@@ -412,7 +412,7 @@ \subsubsection{Overview}\label{overview-5-002}
\subsubsection{Model}\label{model-4}
-The window air conditioner is modeled as a compound component consisting of 3 sub-components: an outdoor air mixer, a fan, and a DX coil. In terms of EnergyPlus objects these are OutdoorAir:Mixer, Fan:ConstantVolume or Fan:OnOff, and Coil:Coolilng:DX:SingleSpeed or CoilSystem:Cooling:DX:HeatExchangerAssisted. The unit is a forward model: its inputs are defined by the state of its inlets: namely its 2 air streams -- recirculated and outdoor air. The outputs of the model are the conditions of the outlet air stream: flow rate, temperature and humidity ratio. The model is also an averaged model: the performance of the unit is averaged over the time step. That is, the unit is assumed to cycle on/off during the time step and this on/off cycling is averaged over the simulation time step. The unit data and simulation are encapsulated in the module WindowAC.
+The window air conditioner is modeled as a compound component consisting of 3 sub-components: an outdoor air mixer, a fan, and a DX coil. In terms of EnergyPlus objects these are OutdoorAir:Mixer, Fan:ConstantVolume or Fan:OnOff, and Coil:Cooling:DX:SingleSpeed or CoilSystem:Cooling:DX:HeatExchangerAssisted. The unit is a forward model: its inputs are defined by the state of its inlets: namely its 2 air streams -- recirculated and outdoor air. The outputs of the model are the conditions of the outlet air stream: flow rate, temperature and humidity ratio. The model is also an averaged model: the performance of the unit is averaged over the time step. That is, the unit is assumed to cycle on/off during the time step and this on/off cycling is averaged over the simulation time step. The unit data and simulation are encapsulated in the module WindowAC.
\subsubsection{Inputs and Data}\label{inputs-and-data-5}
@@ -1432,7 +1432,7 @@ \subsubsection{Controls}\label{controls-000}
There are three choices for control methods.
-\textbf{ZoneTemperatureDeadbandOnOffCycling}. This control method operates the cooler unit in a manner similar to how a normal, real-world themostat operates.~ The control uses input for throttling temperature range, \(\Delta {T_{throttle}}\), the most recent result for zone air node temperature, \({T_{zone}}\), and the current cooling setpoint temperature, \({T_{set}}\).~ The controller also stores the history of whether or not the unit was operating during the previous timestep to model hysteresis control where the unit retains its mode when it passes through the throttling range (to avoid short cycling).
+\textbf{ZoneTemperatureDeadbandOnOffCycling}. This control method operates the cooler unit in a manner similar to how a normal, real-world thermostat operates.~ The control uses input for throttling temperature range, \(\Delta {T_{throttle}}\), the most recent result for zone air node temperature, \({T_{zone}}\), and the current cooling setpoint temperature, \({T_{set}}\).~ The controller also stores the history of whether or not the unit was operating during the previous timestep to model hysteresis control where the unit retains its mode when it passes through the throttling range (to avoid short cycling).
The following algorithm is used to determine if the unit will operate.
@@ -1470,7 +1470,7 @@ \subsubsection{Overview}
\subsubsection{Model}
ZoneHVAC:HybridUnitaryHVAC will operate to provide cooling, heating, ventilation, humidification, or dehumidification for a zone. A ZoneHVAC:HybridUnitaryHVAC object is assigned to a zone using ZoneHVAC:EquipmentList and ZoneHVAC:EquipmentConnections. The object must be assigned a supply air node (which must be a zone inlet node), a return air node (which must be a zone outlet node), and an outdoor air node. In the case when the hybrid system modeled does not utilize either return air or outdoor air, a return air node and an outdoor air node must still be assigned. The resulting mass flow rate on those nodes will be zero.
-The zone sensible cooling or heating load is determined in each time step according to temperature set points specified in a ZoneControl:Thermostat object. The zone humidification or dehumidifaction load is determined in each time step according to relative humidity set points specified in a ZoneControl:Humidistat object (Ref: Zone Controls). The intended zone ventilation rate is specified in a DesignSpecification:OutdoorAir object (Ref: Design Outdoor Air Calculation).
+The zone sensible cooling or heating load is determined in each time step according to temperature set points specified in a ZoneControl:Thermostat object. The zone humidification or dehumidification load is determined in each time step according to relative humidity set points specified in a ZoneControl:Humidistat object (Ref: Zone Controls). The intended zone ventilation rate is specified in a DesignSpecification:OutdoorAir object (Ref: Design Outdoor Air Calculation).
The performance of a hybrid system is not directly given as a result of the loads and the environmental conditions. A hybrid system may have numerous discrete operating modes, within which other variables may be adjusted in fine intervals. There may be many settings in which a hybrid system could feasibly operate at a given time. Therefore, ZoneHVAC:HybridUnitaryHVAC is structured as a constrained optimization problem that is solved in each time step. The feasible settings are the unique combinations of operating mode, outdoor air fraction, and supply air mass flow rate that satisfy constraints. In each time step the hybrid model will choose to operate at one or more settings so as to best satisfy the sensible load, latent load, and scheduled ventilation rate while minimizing resource consumption.
@@ -2003,18 +2003,19 @@ \subsubsection{Simulation and Control}\label{simulation-and-control-5-000}
\subsection{Earthtube}\label{earthtube}
-The earth tube model (input object ZoneEarthtube) provides a simple earth tube model that uses a complex ground heat transfer model to establish the temperature of the soil at the depth of the earth tube.~ The following information defines the basis for the model including the assumptions and mathematical equations.~ It supplements the information for the ZoneEarthtube input object given in the Input/Output Reference for EnergyPlus.
+The earth tube model (input object ZoneEarthtube) provides the choice of either a simple earth tube model (Basic model) that uses a complex ground heat transfer model to establish the temperature of the soil at the depth of the earth tube and an enhanced model which applies a finite difference scheme to simulate vertical temperature variations (Vertical model). The following information defines the basis for the model including the assumptions and mathematical equations. It supplements the information for the ZoneEarthtube input object given in the Input/Output Reference for EnergyPlus.
\emph{\textbf{Input Requirements}}
\begin{itemize}
\tightlist
-\item Pipe : Pipe radius(m), Pipe thickness(m), Pipe length(m)
+\item Pipe : Pipe radius (m), Pipe thickness (m), Pipe length (m)
\item Distance between the pipe outer surface and undisturbed soil (m),
\item Pipe thermal conductivity (W/m-\(^{\circ}\)C),
\item Air velocity inside pipe(m/s), Depth of the radial center of pipe below ground (m)
-\item Soil : Soil density(kg/m\(^{3}\)), Soil specific heat(J/kg-\(^{\circ}\)C),
-\item Soil thermal Conductivity(W/m-\(^{\circ}\)C), Absorption coefficient, Fraction of evaporation rate
+\item Soil : Soil density (kg/m\(^{3}\)), Soil specific heat (J/kg-\(^{\circ}\)C),
+\item Soil thermal Conductivity (W/m-\(^{\circ}\)C), Absorption coefficient, Fraction of evaporation rate
+\item Width of soil domain in the horizontal direction (m), only applies to the Vertical model
\end{itemize}
\emph{\textbf{Assumption(s)}}
@@ -2023,15 +2024,17 @@ \subsection{Earthtube}\label{earthtube}
\item
Convection flow inside the pipe is hydrodynamically and thermally developed.
\item
- Soil temperature in the pipe vicinity is uniform after the particular distance from the center of the pipe(thickness of the annulus), so that pipe surface temperature is uniform after the distance `r' from the center of the pipe, where `r'is the pipe radius.
+ For the Basic model, the soil temperature in the pipe vicinity is uniform after the particular distance from the center of the pipe(thickness of the annulus), so that pipe surface temperature is uniform after the distance `r' from the center of the pipe, where `r'is the pipe radius. In addition, the temperature profile in the pipe vicinity is not affected by the presence of the pipe, so that pipe surface temperature is uniform at axial direction.
\item
- The temperature profile in the pipe vicinity is not affected by the presence of the pipe, so that pipe surface temperature is uniform at axial direction.
+ For the Vertical model, the soil temperature varies in the vertical direction only (not horizontally or axially). The solution domain is bounded at the top and bottom by temperature boundary conditions for soil at those depths for undisturbed conditions. A finite difference modeling technique is used to track horizontal temperature variation as a result of both the boundary conditions at the top and bottom of the solution space as well as the impact of air flowing through the earth tube at the depth of the earth tube. No heat transfer is modeled either horizontally or axially (adiabatic in those directions). More information about the Vertical model is provided below.
\item
The soil surrounding the pipe has homogeneous thermal conductivity.
\item
- Pipe has uniform cross section area at axial direction.
+ Pipe has a uniform cross section area in the axial direction.
\end{itemize}
+\emph{\textbf{Ground Temperature Modeling and Generation of EnergyPlus Ground Inputs}}
+
Wind velocity (m/s), u, is the annual average value. This is calculated from EnergyPlus weather data by averaging individual wind velocity values of the whole year. The convective heat transfer coefficient at the soil surface (W/m\(^{2}\)-\(^{\circ}\)C), \(h_{s}\), is function of wind speed u. According to McAdams(1954), \(h_{s}\) can be approximated by the following correlation (Krarti, 1995):
\begin{equation}
@@ -2160,6 +2163,8 @@ \subsection{Earthtube}\label{earthtube}
\end{array}
\end{equation}
+\emph{\textbf{Basic Model--Direct Use of Undisturbed Ground Temperature}}
+
Assuming a homogeneous soil of constant thermal diffusivity, the temperature at any depth z and time t can be estimated by the following expression:
\begin{equation}
@@ -2168,24 +2173,9 @@ \subsection{Earthtube}\label{earthtube}
In this expression, the unit of time, \emph{t}, and phase constant of the soil surface, \(t_{0}\), should be converted into days. Similarly, the unit of soil thermal diffusivity, \({\alpha_{s}}\), should also be converted into m\(^{2}\)/days.
-By integrating the expression with respect to depth, the average temperature of a vertical soil profile ranging between depth \(z_{1}\) and \(z_{2}\) (\(^{\circ}\)C) can be determined as follows:
-
-{\scriptsize
-\begin{equation}
-{T_{{z_1},{z_2},t}} = {T_m} + \frac{{{A_s}}}{{\left( {{z_2} - {z_1}} \right)\gamma \sqrt 2 }}\left\{ {{e^{ - \gamma {z_1}}}\cos \left[ {\frac{{2\pi }}{{{\rm{365}}}}\left( {t - {t_0} - {z_1}L - 45.6} \right)} \right] - {e^{ - \gamma {z_2}}}\cos \left[ {\frac{{2\pi }}{{{\rm{365}}}}\left( {t - {t_0} - {z_2}L - 45.6} \right)} \right]} \right\}
-\end{equation}}
+In the Basic model for earth tubes, the above equation is used to calculate the temperature of the ground at the depth of the earth tube and this value is used to evaluate the heat transfer between the soil around the earth tube and the air passing through the earth tube. This heat exchange involves determining convective heat transfer coefficient between the air passing through the earth tube and the surface of the tube itself, converting this to a thermal resistance value, and then adding on the thermal resistance for the earth tube pipe itself and the surrounding soil to the user defined distance to the "undisturbed" region. The equations used to model the thermal resistances are shown in the following paragraphes.
-where:
-
-\begin{equation}
-\gamma = {\left( {\pi /{\rm{365}}{\alpha_s}} \right)^{1/2}}
-\end{equation}
-
-\begin{equation}
-L = \frac{1}{2}{\left( {{\rm{365}}/\pi {\alpha_s}} \right)^{1/2}}
-\end{equation}
-
-As the final step with regard to the heat transfer between soil and earth tube system, thermal conductivity of air (W/m-\(^{\circ}\)C), \(k_{air}\), and kinetic viscosity of air (m\(^{2}\)/s), \({\upsilon}\), should calculated first:
+With regard to the heat transfer between soil and earth tube system, thermal conductivity of air (W/m-\(^{\circ}\)C), \(k_{air}\), and kinetic viscosity of air (m\(^{2}\)/s), \({\upsilon}\), should calculated first:
\begin{equation}
{k_{air}} = 0.02442 + ({10^{ - 4}}(0.6992{T_a}))
@@ -2255,6 +2245,256 @@ \subsection{Earthtube}\label{earthtube}
Initial condition of inlet air temperature is equal to the ambient air temperature. Outlet air temperature is finally evaluated by solving the heat transfer equation above.
+\emph{\textbf{Vertical Model--1-D Solution of Temperature Variation in the Vertical Direction}}
+In EnergyPlus, the Basic model simply calculates the ground temperature at the depth of the earth tube and assumes that the impact of the earth tube is minimal. The Vertical model acknowledges that the soil temperature will be impacted by the presence of the heat transfer associated with the earth tube and looks to evaluate the impact that the earth tube air flow has on soil temperature in the vertical direction. While there is also an impact on the soil temperatures horizontally and axially along the earth tube, the vertical model focuses on the potential temperature variation in the vertical direction as a result of heat exchange between the ground around the earth tube and the air passing through it.
+
+The mathematical approach used to model vertical temperature variation due to the presence and heat transfer impact of the earth tube is a finite difference scheme. This finite difference modeling technique looks at various nodes in the vertical direction and uses the following assumptions:
+
+\begin{itemize}
+\item
+The finite difference grid of nodes contains a single row of nodes in the vertical direction only.
+\item
+The finite difference grid is bound at the top and the bottom with a temperature boundary condition. The temperature at the top and the bottom is variable and based on the undisturbed ground temperature equation used in the Basic model for the depth at the top and bottom of the domain.
+\item
+There is no heat transfer horizontally or axially for the nodes (adiabatic in all directions except vertically).
+\item
+Heat transfer via conduction is modeled between adjacent nodes in the vertical direction.
+\item
+The impact of the air passing through the earth tube is felt at a single node, the earth tube node.
+\item
+The width of the solution horizontally is set by user input.
+\item
+The number of nodes above and below the earth tube node as well as how tall the solution space is above and below the earth tube is controlled by user input. These parameters will set the thickness of nodes above and below the earth tube node. The total height of the earth tube node will be set to twice the diameter of the earth tube itself.
+\item
+An implicit finite difference solution scheme is used to promote solution stability. Nodal equations are based on this implicit scheme.
+\item
+The nodal equations will be arranged as a matrix-based system of equations that will be solved using the description given below.
+\end{itemize}
+
+The solution of the finite difference scheme used for the Vertical model starts with the development of nodal equations throughout the solution space. The figure below shows a representative nodal diagram for the Vertical earth tube model. Note that the number of nodes above and below the earth tube are determined by the user and set in the input file. The minimum number of nodes allowed either above or below the earth tube is 3 while the maximum is 10. The example shown below has five nodes above the earth tube and four below.
+
+\begin{figure}[hbtp]
+\centering
+\includegraphics[width=0.9\textwidth, height=0.9\textheight, keepaspectratio=true]{media/earth_tube_solution_space_diagram.png}
+\caption{Earth Tube Vertical Model Solution Space \protect \label{fig:earth-tube-solution-space-diagram}}
+\end{figure}
+
+As can be seen in the node diagram, there are seven types of nodes. One is a node at the top of the solution space that is in contact with the upper temperature boundary and the next node down. Similarly, there is another node that is at the bottom of the solution space that is contact with the lower temperature boundary and the next node up. Two of the node types are simply generic "interior" nodes in the upper and lower areas of the solution space. The equations for these generic nodes are very similar with the only difference being the height of the node (which is based on user input). Two other nodes types are those adjacent to the earth tube node (one above the earth tube and one below). Again, these equations will be very similar since they only differ in the size of the node height and the nodes to which they are connected in the grid. Finally, the earth tube itself is an additional node type that is different than the other nodes due to the fact that it also has a connection with conduction and convection to the air in the earth tube. The equation for each node type is shown below. Each node equation will be rearranged so as to fit with the matrix form: Ax = b where x is a vector of node temperatures.
+
+\emph{\textit{Node Type 1: First Node (Below Upper Temperature Boundary)}}
+
+The first node includes conduction between the upper boundary and the node as well as the second node and the first node. The equation for this node is:
+
+\begin{equation}
+\rho x_t w L c_p \frac{T_{1,new} - T_{1,old}}{\Delta t} = k w L \frac{T_{u,t}-T_{1,new}}{x_t / 2} + k w L \frac{T_{2,new}-T_{1,new}}{x_t}
+\end{equation}
+
+This can be rearranged to:
+
+\begin{equation}
+(1 + \frac{3 k \Delta t}{\rho c_p {x_t}^2}) T_{1,new} + (\frac{-k \Delta t}{\rho c_p {x_t}^2}) T_{2,new} = \frac{2 k \Delta t}{\rho c_p {x_t}^2} T_{u,t} + T_{1,old}
+\end{equation}
+
+or:
+
+\begin{equation}
+(1 + \frac{3 \alpha_s \Delta t}{{x_t}^2}) T_{1,new} + (\frac{-\alpha_s \Delta t}{{x_t}^2}) T_{2,new} = \frac{2 \alpha_s \Delta t}{{x_t}^2} T_{u,t} + T_{1,old}
+\end{equation}
+
+
+\emph{\textit{Node Type 2: Generic Node Upper Region}}
+
+The second through fourth nodes in the above diagram are all "generic" nodes in the upper region. They all have the same basic equation. Using "i" as the number for such a generic node, the equation for these nodes can be written as:
+
+\begin{equation}
+\rho x_t w L c_p \frac{T_{i,new} - T_{i,old}}{\Delta t} = k w L \frac{T_{i+1,new}-T_{i,new}}{x_t} + k w L \frac{T_{i-1,new}-T_{i,new}}{x_t}
+\end{equation}
+
+This can be rearranged to:
+
+\begin{equation}
+(\frac{-k \Delta t}{\rho c_p {x_t}^2}) T_{i+1,new} + (1 + \frac{2 k \Delta t}{\rho c_p {x_t}^2}) T_{i,new} + (\frac{-k \Delta t}{\rho c_p {x_t}^2}) T_{i+1,new} = T_{i,old}
+\end{equation}
+
+or:
+
+\begin{equation}
+(\frac{-\alpha_s \Delta t}{{x_t}^2}) T_{i+1,new} + (1 + \frac{2 \alpha_s \Delta t}{{x_t}^2}) T_{i,new} + (\frac{-\alpha_s \Delta t}{{x_t}^2}) T_{i+1,new} = T_{i,old}
+\end{equation}
+
+
+\emph{\textit{Node Type 3: Last Node in Upper Region}}
+The last node in the upper region connects to both the node above this one as well as the node at the earth tube ("et"). Since the thickness of the earth tube node and the nodes in the upper region are not the same, this requires a slight adjustment in the equations for a different thickness in the vertical direction. Here is the equation for this node:
+
+\begin{equation}
+\rho x_t w L c_p \frac{T_{et-1,new} - T_{et-1,old}}{\Delta t} = k w L \frac{T_{et,new}-T_{et-1,new}}{(x_t + x_{et})/2} + k w L \frac{T_{et-2,new}-T_{et-1,new}}{x_t}
+\end{equation}
+
+This can be rearranged to:
+
+\begin{equation}
+(\frac{-k \Delta t}{\rho c_p {x_t}^2}) T_{et-2,new} + [1 + \frac{k \Delta t}{\rho c_p {x_t}^2} + \frac{k \Delta t}{\rho c_p x_t (x_t+x_{et})/2}] T_{et-1,new} + [\frac{-k \Delta t}{\rho c_p x_t (x_t+x_{et})/2}] T_{et,new} = T_{et-1,old}
+\end{equation}
+
+or:
+
+\begin{equation}
+(\frac{-\alpha_s \Delta t}{{x_t}^2}) T_{et-2,new} + [1 + \frac{\alpha_s \Delta t}{{x_t}^2} + \frac{\alpha_s \Delta t}{x_t (x_t+x_{et})/2}] T_{et-1,new} + [\frac{-\alpha_s \Delta t}{x_t (x_t+x_{et})/2}] T_{et,new} = T_{et-1,old}
+\end{equation}
+
+
+\emph{\textit{Node Type 4: Earth Tube Node}}
+
+The earth tube node is connected to nodes above and below it via conduction and also accounts for the convection between the air flowing through the tube and the conduction through the earth tube pipe material. The equation for this node, assuming an effectiveness-NTU model for heat exchange between the air and ground (see below), is:
+
+\begin{equation}
+\rho x_{et} w L c_p \frac{T_{et,new} - T_{et,old}}{\Delta t} = k w L \frac{T_{et+1,new}-T_{et,new}}{(x_b + x_{et})/2} + k w L \frac{T_{et-1,new}-T_{et,new}}{(x_t + x_{et})/2} + {\dot m_a}{C_a} \eta (T_{air} - T_{et,new})
+\end{equation}
+
+This can be rearranged to:
+
+\begin{equation}
+\begin{split}
+[ \frac{-2k \Delta t}{\rho c_p x_{et} (x_t + x_{et})} ] T_{et-1,new} \\
+ + [ 1 + \frac{2 k \Delta t}{\rho c_p x_{et} (x_t + x_{et})} + \frac{2 k \Delta t}{\rho c_p x_{et} (x_b+x_{et})} + \frac{\dot m_a {C_a} \eta \Delta t}{\rho c_p x_{et} w L} ] T_{et,new} \\
+ + [ \frac{-2k \Delta t}{\rho c_p x_{et} (x_b + x_{et})} ] T_{et+1,new} \\
+ = T_{et,old} + \frac{\dot m_a {C_a} \eta \Delta t}{\rho c_p x_{et} w L} T_{air,in}
+\end{split}
+\end{equation}
+
+or:
+
+\begin{equation}
+\begin{split}
+[ \frac{-2 \alpha_s \Delta t}{x_{et} (x_t + x_{et})} ] T_{et-1,new} \\
+ + [ 1 + \frac{2 \alpha_s \Delta t}{x_{et} (x_t + x_{et})} + \frac{2 \alpha_s \Delta t}{x_{et} (x_b+x_{et})} + \frac{\dot m_a {C_a} \eta \Delta t}{\rho c_p x_{et} w L} ] T_{et,new} \\
+ + [ \frac{-2 \alpha_s \Delta t}{x_{et} (x_b + x_{et})} ] T_{et+1,new} \\
+ = T_{et,old} + \frac{\dot m_a {C_a} \eta \Delta t}{\rho c_p x_{et} w L} T_{air,in}
+\end{split}
+\end{equation}
+
+\emph{\textit{Node Type 5: First Node in Lower Region}}
+
+The region below the earth tube node is physically very similar to the region above the earth tube (reflected in a sense at the earth tube itself). The main difference is the number of nodes and the overall thickness of the region can lead to a node height that is different than for the upper region. Above this first node in the lower region, there is the earth tube node. Below it is one or more generic lower region nodes (Type 6 below). The equation for this node is:
+
+\begin{equation}
+\rho x_b w L c_p \frac{T_{et+1,new} - T_{et+1,old}}{\Delta t} = k w L \frac{T_{et,new}-T_{et+1,new}}{(x_b + x_{et})/2} + k w L \frac{T_{et+2,new}-T_{et+1,new}}{x_b}
+\end{equation}
+
+This can be rearranged to:
+
+\begin{equation}
+[\frac{-k \Delta t}{\rho c_p x_b (x_b + x_{et})/2}] T_{et,new} + [1 + \frac{k \Delta t}{\rho c_p {x_b}^2} + \frac{k \Delta t}{\rho c_p x_b (x_b+x_{et})/2}] T_{et+1,new} + [\frac{-k \Delta t}{\rho c_p {x_b}^2}] T_{et+2,new} = T_{et+1,old}
+\end{equation}
+
+or:
+
+\begin{equation}
+[\frac{-\alpha_s \Delta t}{x_b (x_b + x_{et})/2}] T_{et,new} + [1 + \frac{\alpha_s \Delta t}{{x_b}^2} + \frac{\alpha_s \Delta t}{x_b (x_b+x_{et})/2}] T_{et+1,new} + [\frac{-\alpha_s \Delta t}{{x_b}^2}] T_{et+2,new} = T_{et+1,old}
+\end{equation}
+
+\emph{\textit{Node Type 6: Generic Node in Lower Region}}
+
+The generic node equation in the lower region is nearly identical to generic node equation for the upper region except that the lower region node height replaces the upper region node height. The equation is therefore:
+
+\begin{equation}
+\rho x_b w L c_p \frac{T_{i,new} - T_{i,old}}{\Delta t} = k w L \frac{T_{i+1,new}-T_{i,new}}{x_b} + k w L \frac{T_{i-1,new}-T_{i,new}}{x_b}
+\end{equation}
+
+This can be rearranged to:
+
+\begin{equation}
+(\frac{-k \Delta t}{\rho c_p {x_b}^2}) T_{i+1,new} + (1 + \frac{2 k \Delta t}{\rho c_p {x_b}^2}) T_{i,new} + (\frac{-k \Delta t}{\rho c_p {x_b}^2}) T_{i+1,new} = T_{i,old}
+\end{equation}
+
+or:
+
+\begin{equation}
+(\frac{-\alpha_s \Delta t}{{x_b}^2}) T_{i+1,new} + (1 + \frac{2 \alpha_s \Delta t}{{x_b}^2}) T_{i,new} + (\frac{-\alpha_s \Delta t}{{x_b}^2}) T_{i+1,new} = T_{i,old}
+\end{equation}
+
+\emph{\textit{Node Type 7: Last Node (Above Lower Temperature Boundary)}}
+
+Finally, the last node temperature is in contact with the node above it as well as the temperature at the lower boundary condition. The actual temperature of the lower boundary condition is set by the undisturbed ground temperature equation used in the basic model for the depth of the lower boundary condition. The equation is similar to the first node:
+
+\begin{equation}
+\rho x_b w L c_p \frac{T_{n,new} - T_{n,old}}{\Delta t} = k w L \frac{T_{l,t} - T_{n,new}}{x_b / 2} + k w L \frac{T_{n-1,new} - T_{n,new}}{x_t}
+\end{equation}
+
+This can be rearranged to:
+
+\begin{equation}
+(\frac{-k \Delta t}{\rho c_p {x_b}^2}) T_{n-1,new} + (1 + \frac{3 k \Delta t}{\rho c_p {x_b}^2}) T_{n,new} = \frac{2 k \Delta t}{\rho c_p {x_b}^2} T_{l,t} + T_{n,old}
+\end{equation}
+
+or:
+
+\begin{equation}
+(\frac{-\alpha_s \Delta t}{{x_b}^2}) T_{n-1,new} + (1 + \frac{3 \alpha_s \Delta t}{{x_b}^2}) T_{n,new} = \frac{2 \alpha_s \Delta t}{{x_b}^2} T_{l,t} + T_{n,old}
+\end{equation}
+
+\emph{\textit{Calculation of Effectiveness for Heat Transfer Between the Air and Ground}}
+
+Similar to the low temperature radiant system where a fluid of variable temperature is passing through a solid that is assumed to be at a single temperature, the relationship between effectiveness and heat transfer between the air and the ground can be summarized using the following relationship:
+
+\begin{equation}
+q = \dot m_a * C_{p,a} * (T_{air,in} - T_{air,out})
+\end{equation}
+
+where \(T_{air,in}\) is the outside air temperatre and \(T_{air,out}\) is the temperature of the air leaving the earth tube and entering the zone.
+
+\begin{equation}
+q_{max} = \dot m_a * C_{p,a} * (T_{air,in} - T_{et})
+\end{equation}
+
+where \(T_{et}\) is the temperature of the ground at the depth of the earth tube (i.e., at the earth tube node).
+
+The effectiveness (\(\eta\)) is the ratio of these two terms or:
+
+\begin{equation}
+\eta = \frac{q}{q_{max}}
+\end{equation}
+
+For the situation where a fluid of varying temperature flows through a solid of constant temperature, the effectiveness can be related to the number of transfer units (NTU) by:
+
+\begin{equation}
+\eta = 1 - e^{-NTU}
+\end{equation}
+
+NTU is calculated using the following equation:
+
+\begin{equation}
+NTU = U A / (\dot m C_p)_{min}
+\end{equation}
+
+Since the solid is not moving, \((\dot m C_p)_{min}\) is evaluated for the air side. The U-value for this situation includes the heat conduction through the pipe wall and the convection between the inside surface of the earth tube and the air passing through it. The relations for both the conduction and convection terms rely on the relationships developed for the Basic model. With the effectiveness determined for a particular flow rate, the overall matrix equation is set and can be solved for the new node temperatures.
+
+\emph{\textit{Solution Strtegy}}
+
+The node equations above result in a system of equations that can be arranged as a matrix in the form of [A][x] = [b], where the number of node (n) is the index of the matrices. The A matrix (n by n square matrix) consists primarily of constant terms that relate to the thermo-physical properties of the solution space. The vector x consists of the new temperatures of the nodes (again, using the implicit formulation for stability) and the algorithm needs to solve for these. The vector b includes terms such as the old temperatures at the nodes, the impact of boundary conditions at the top and bottom of the solution space, and the impact of the earth tube on the earth tube node. The values of the vector b will vary with every time step since the temperatures of the nodes, ground, and air will vary with time. The seven equation types that were rearranged above were done so to fit with the [A][x] = [b] format.
+
+Upon inspection of the terms that make up the A matrix, it is clear that A will be a tridiagonal matrix. Tridiagonal matrices can be solved more efficiently using what is known as the Thomas algorithm which require operations on the order of the index (n) whereas solution strategies such as matrix inversion require operations on the order of the index (n) cubed. In addition, there is only one term in the A matrix that might potentially vary--the term associated with the air flow rate and efficiency of heat exchange between the earth tube and the air flow through it at the earth tube node. Since it is not known ahead of time what this flow rate or efficiency will be, the matrix system will have to go through a full solution at any time step. The only exception to this when there is no air flow through the earth tube. Since there will be significant time when the earth tube is dormant (no flow through it), the first step of the Thomas algorithm will be done for the zero flow situation and the values stored to reduce the number of calculations required by the solution. Note that while in many cases when the earth tube is running that the effectiveness (\(\eta\)) will be unity, the flow rate may still vary based on the user input flow coefficients. As a result, it does not make sense to store an intermediate step in the solution for when effectiveness is unity.
+
+In general, many of the related calculations (such as air flow rate, thermal properties of air, etc.) are identical to the Basic earth tube model. The main difference is the calculation of the temperature at the earth tube location--the Basic model uses the undisturbed ground temperature relationship while the Vertical solution uses the implicit finite difference scheme and the Thomas algorithm.
+
+Once the node (ground) temperatures have been determined, the calculation of the air temperature leaving the earth tube can be calculated using the effectiveness-NTU formulation above. Cancelling out the common flow rate and air specific heat, the equation for effectiveness simplifies to:
+
+\begin{equation}
+\eta = \frac{T_{air,in} - T_{air,out}}{T_{air,in} - T_{et}}
+\end{equation}
+
+Rearranging this equation to find the temperature of the air leaving the earth tube (inlet to the zone):
+
+\begin{equation}
+T_{air,in} - T_{air,out} = \eta * (T_{air,in} - T_{et})
+\end{equation}
+
+or:
+
+\begin{equation}
+T_{air,out} = T_{air,in} - \eta * (T_{air,in} - T_{et})
+\end{equation}
+
% table 87
\begin{longtable}[c]{p{1.5in}p{3.0in}p{1.5in}}
\caption{Nomenclature for Earthtube Model \label{table:nomenclature-for-earthtube-model}} \tabularnewline
@@ -2271,13 +2511,14 @@ \subsection{Earthtube}\label{earthtube}
A\(_{s}\) & amplitude of the soil surface temperature variation & \(^{\circ}\)C \tabularnewline
C\(_{a}\) & specific heat of air & J/kg-\(^{\circ}\)C \tabularnewline
+c\(_{p}\) & specific heat of soil & J/kg-\(^{\circ}\)C \tabularnewline
h\(_{c}\) & convective heat transfer coefficient at the inner pipe surface & W/m\(^{2}\)-\(^{\circ}\)C \tabularnewline
h\(_{s}\) & convective heat transfer coefficient at the soil surface & W/m\(^{2}\)-\(^{\circ}\)C \tabularnewline
k\(_{air}\) & thermal conductivity of the air & W/m-\(^{\circ}\)C \tabularnewline
k\(_{p}\) & pipe thermal conductivity & W/m-\(^{\circ}\)C \tabularnewline
-k\(_{s}\) & soil thermal conductivity & W/m-\(^{\circ}\)C \tabularnewline
+k\(_{s}\) or k & soil thermal conductivity & W/m-\(^{\circ}\)C \tabularnewline
L & pipe length & m \tabularnewline
-m\(_{a}\) & mass flow rate of ambient air through pipe & kg/s \tabularnewline
+\(\dot m_a\) & mass flow rate of ambient air through pipe & kg/s \tabularnewline
r\(_{a}\) & relative humidity & ~ \tabularnewline
R\(_{c}\) & thermal resistance due to convection heat transfer between the air in the pipe and the pipe inner surface & m-\(^{\circ}\)C/W \tabularnewline
R\(_{p}\) & thermal resistance due to conduction heat transfer between the pipe inner and outer surface & m-\(^{\circ}\)C/W \tabularnewline
@@ -2291,6 +2532,10 @@ \subsection{Earthtube}\label{earthtube}
S\(_{v}\) & amplitude of the solar radiation & W/m\(^{2}\) \tabularnewline
t & time elapsed from beginning of calendar year & days \tabularnewline
T\(_{a}\)(y) & air temperature of the pipe at the distance y from the pipe inlet & \(^{\circ}\)C \tabularnewline
+T\(_{et,new}\)(y) & earth tube node temperature (current) & \(^{\circ}\)C \tabularnewline
+T\(_{et,old}\)(y) & earth tube node temperature (previous) & \(^{\circ}\)C \tabularnewline
+T\(_{i,new}\)(y) & node temperature for node "i" (current) & \(^{\circ}\)C \tabularnewline
+T\(_{i,old}\)(y) & node temperature for node "i" (previous) & \(^{\circ}\)C \tabularnewline
T\(_{m}\) & average soil surface temperature & \(^{\circ}\)C \tabularnewline
T\(_{ma}\) & average air temperature & \(^{\circ}\)C \tabularnewline
t\(_{o}\) & phase constant of the soil surface & sec, days \tabularnewline
@@ -2301,14 +2546,20 @@ \subsection{Earthtube}\label{earthtube}
u & ~wind velocity above the ground surface & m/s \tabularnewline
U\(_{t}\) & overall heat transfer coefficient of the whole earth tube system & W/m-\(^{\circ}\)C \tabularnewline
V\(_{a}\) & average pipe air velocity & m/s \tabularnewline
+w & node width (user input) in the vertical solution & m \tabularnewline
+x\(_{t}\) & node thickness in the upper (top) region in the vertical solution & m \tabularnewline
+x\(_{et}\) & node thickness for the earth tube node in the vertical solution & m \tabularnewline
+x\(_{b}\) & node thickness in the lower (bottom) region in the vertical solution & m \tabularnewline
z & depth of the radial center of pipe below soil surface & m \tabularnewline
z\(_{1}\) & upper bounds of some vertical profile in soil & m \tabularnewline
z\(_{2}\) & lower bounds of some vertical profile in soil & m \tabularnewline
-$\alpha$\(_{s}\) & soil thermal diffusivity & m\(^{2}\)/s; m\(^{2}\)/days \tabularnewline
+$\alpha$\(_{s}\) & soil thermal diffusivity & m\(^{2}\)/s; m\(^{2}\)/days; m\(^{2}\)/hr \tabularnewline
$\beta$ & soil absorption coefficient ( = 1 – soil albedo) & ~ \tabularnewline
+$\Delta$t & time step & hr \tabularnewline
$\varepsilon$ & hemispherical emittance of the ground surface & ~ \tabularnewline
$\varphi$\(_{I}\) & phase angle between the insolation and the air temperature & rad \tabularnewline
$\phi$\(_{s}\) & phase angle difference between the air and soil surface temperature & rad \tabularnewline
+$\rho$ & soil density & kg/m\(^3\) \tabularnewline
$\upsilon$ & kinetic viscosity of air & m\(^{2}\)/s \tabularnewline
w & annual angular frequency ( = 1.992 x 10\(^{-7}\)rad/s) & rad/s \tabularnewline
\bottomrule
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference/air-system-distribution-terminals.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference/air-system-distribution-terminals.tex
index d497bf96fd1..e13d8ebfd4c 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference/air-system-distribution-terminals.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference/air-system-distribution-terminals.tex
@@ -628,9 +628,9 @@ \subsubsection{Model Description}\label{model-description-1-000}
\({\rho_{CW}}\) is the density of chilled water, in kg/m\(^{3}\)
-\({T_{SA}}\) is the dryblub temperature of the (central) primary air entering the air terminal unit, in degrees C.
+\({T_{SA}}\) is the drybulb temperature of the (central) primary air entering the air terminal unit, in degrees C.
-\({T_{Z}}\) is the dryblub temperature of the zone air, in \(^{\circ}\)C.
+\({T_{Z}}\) is the drybulb temperature of the zone air, in \(^{\circ}\)C.
\({T_{CW,in}}\) is the temperature of chilled water entering the convector, in \(^{\circ}\)C.
@@ -662,7 +662,7 @@ \subsubsection{Model Description}\label{model-description-1-000}
{T_{CW,out}} = {T_{CW,in}} - \frac{{\dot Q_{Beam}}}{{\dot m_{CW}} \cdot {c_{p,CW}} }
\end{equation}
-However, to protect from a non-physical result the leaving chilled water temperature is constrained to be no warmer than a 1.0\(^{\circ}\)C approach temperature compared to the zone air or the primary supply air. If the above result is too warm the leaving temperature and beam cooling capacity are adjusted using the following equations, and a recurring warning is issued to alert the user that there may be a problem with the cooliong performance input data.
+However, to protect from a non-physical result the leaving chilled water temperature is constrained to be no warmer than a 1.0\(^{\circ}\)C approach temperature compared to the zone air or the primary supply air. If the above result is too warm the leaving temperature and beam cooling capacity are adjusted using the following equations, and a recurring warning is issued to alert the user that there may be a problem with the cooling performance input data.
\begin{equation}
{T_{CW,out}} = { max( {T_{SA}} , {T_{Z}}) - 1.0 }
@@ -1226,4 +1226,4 @@ \subsubsection{Model Description}\label{model-description-4-000}
\subsubsection{References}\label{references-6}
-Sekhar, S. C., K. W. Tham, et al. (2004). Development of energy-efficient single-coil twin-fan air-conditioning system with zonal ventilation control, Nashville, TX, United states, Amer. Soc. Heating, Ref. Air-Conditoning Eng. Inc.
+Sekhar, S. C., K. W. Tham, et al. (2004). Development of energy-efficient single-coil twin-fan air-conditioning system with zonal ventilation control, Nashville, TX, United states, Amer. Soc. Heating, Ref. Air-Conditioning Eng. Inc.
diff --git a/doc/engineering-reference/src/simulation-models-encyclopedic-reference/chillers.tex b/doc/engineering-reference/src/simulation-models-encyclopedic-reference/chillers.tex
index f029f60b981..dbef26c420b 100644
--- a/doc/engineering-reference/src/simulation-models-encyclopedic-reference/chillers.tex
+++ b/doc/engineering-reference/src/simulation-models-encyclopedic-reference/chillers.tex
@@ -4,7 +4,7 @@ \subsection{Absorption Chiller}\label{absorption-chiller}
The input object Chiller:Absorption provides a model for absorption chillers that is an empirical model of a standard absorption refrigeration cycle.~ The condenser and evaporator are similar to that of a standard chiller, which are both water-to-water heat exchangers.~ The assembly of a generator and absorber provides the compression operation.~ Low-pressure vapor from the evaporator is absorbed by the liquid solution in the absorber.~ A pump receives low-pressure liquid from the absorber, elevates the pressure of the liquid, and delivers the liquid to the generator.~ In the generator, heat from a high temperature source (hot water or steam) drives off the vapor that has been absorbed by the solution.~ The liquid solution returns to the absorber through a throttling valve whose purpose is to provide a pressure drop to maintain the pressure difference between the generator and absorber.~ The heat supplied to the absorber can be waste heat from a diesel jacket, or the exhaust heat from diesel, gas, and steam turbines.~ For more information on absorption chillers, see the Input/Output Reference Document (Object: Chiller:Absorption).
-The part-load ratio of the absoprtion chiller's evaporator is simply the actual cooling effect produced by the chiller divided by the maximum cooling effect available.
+The part-load ratio of the absorption chiller's evaporator is simply the actual cooling effect produced by the chiller divided by the maximum cooling effect available.
\begin{equation}
PLR = \frac{\dot{Q}_{evap}}{\dot{Q}_{evap,rated}}
@@ -54,7 +54,7 @@ \subsection{Absorption Chiller}\label{absorption-chiller}
\({\dot Q_{generator}}\) is the generator input power (W)
-\({\dot Q_{pump}}\) is the absorbtion chiller pumping power (W).
+\({\dot Q_{pump}}\) is the absorption chiller pumping power (W).
The evaporator water mass flow rate is calculated based on the Chiller Flow Mode as follows.
@@ -218,7 +218,7 @@ \subsection{Indirect Absorption Chiller}\label{indirect-absorption-chiller}
\(CAPF{T_{generator}}\) is the capacity correction (function of generator temperature) factor
-\({T_{evaporator}}\) is the evaporator outet water temperature (\(^{\circ}\)C)
+\({T_{evaporator}}\) is the evaporator outlet water temperature (\(^{\circ}\)C)
\({T_{condenser}}\) is the condenser inlet water temperature (\(^{\circ}\)C)
@@ -228,7 +228,7 @@ \subsection{Indirect Absorption Chiller}\label{indirect-absorption-chiller}
\({\dot Q_{evap,rated}}\) is the rated chiller capacity (W).
-The part-load ratio of the indirect absoprtion chiller's evaporator is simply the actual cooling effect required (load) divided by the maximum cooling effect available.
+The part-load ratio of the indirect absorption chiller's evaporator is simply the actual cooling effect required (load) divided by the maximum cooling effect available.
\begin{equation}
PLR = \frac{\dot{Q}_{evap}}{\dot{Q}_{evap,max}}
@@ -240,7 +240,7 @@ \subsection{Indirect Absorption Chiller}\label{indirect-absorption-chiller}
\({\dot Q_{evap}}\) is the chiller evaporator operating capacity (W).
-The generator's heat input is also a function of several parameters. The primary input for determining the heat input requirements is the Generator Heat Input function of Part-Load Ratio Curve. The curve is a quadratic or cubic equation that determines the ratio of the generator heat input to the chiller's maximum capacity (Q\(_{evap,\, max}\)) and is solely a function of part-load ratio. Typical generator heat input ratios at full load (i.e., PLR = 1) are between 1 and 2. Two additional curves are available to modifiy the heat input requirement based on the generator inlet water temperature and the evaporator outlet water temperature.
+The generator's heat input is also a function of several parameters. The primary input for determining the heat input requirements is the Generator Heat Input function of Part-Load Ratio Curve. The curve is a quadratic or cubic equation that determines the ratio of the generator heat input to the chiller's maximum capacity (Q\(_{evap,\, max}\)) and is solely a function of part-load ratio. Typical generator heat input ratios at full load (i.e., PLR = 1) are between 1 and 2. Two additional curves are available to modify the heat input requirement based on the generator inlet water temperature and the evaporator outlet water temperature.
\begin{equation}
GeneratorHIR = a + b\left( {PLR} \right) + c{\left( {PLR} \right)^2} + d{\left( {PLR} \right)^3}
@@ -366,7 +366,7 @@ \subsection{Indirect Absorption Chiller}\label{indirect-absorption-chiller}
\subsubsection{Steam Loop Calculations}\label{steam-loop-calculations-1}
-When a steam loop is used and the inlet and outlet node names are specified (i.e.~the nodes are connected to a steam loop), the generator outlet node steam mass flow rate and temperature are calculated based on the generator heat input, latent heat of steam, the specific heat of water, and the amount of subcooling in the steam generator. The model assumes dry saturated steam enters the generator and exits the generator as a subcooled liquid. The temperature leaving the generator is calculated based on the user entered amount of liquid subcooling in the generator. The effect of subcooling of the liquid (condensate) in the pipe returning to the boiler is also modeled using the user entered abount of steam condensate loop subcooling.
+When a steam loop is used and the inlet and outlet node names are specified (i.e.~the nodes are connected to a steam loop), the generator outlet node steam mass flow rate and temperature are calculated based on the generator heat input, latent heat of steam, the specific heat of water, and the amount of subcooling in the steam generator. The model assumes dry saturated steam enters the generator and exits the generator as a subcooled liquid. The temperature leaving the generator is calculated based on the user entered amount of liquid subcooling in the generator. The effect of subcooling of the liquid (condensate) in the pipe returning to the boiler is also modeled using the user entered amount of steam condensate loop subcooling.
\begin{equation}
{\dot m_{steam}}\,\,\,\, = \,\,\,\,\,\frac{{{{\dot Q}_{generator}}}}{{{h_{fg}} + {c_{p,water}} \times \Delta {T_{sc}}}}
@@ -1185,7 +1185,7 @@ \subsection{Hot Water Heat Recovery from Chillers}\label{hot-water-heat-recovery
{T_{Cond,out,Avg}} = \frac{{\left( {{{\dot Q}_{HR}}{T_{HR,out}} + {{\dot Q}_{Cond}}{T_{Cond,out}}} \right)}}{{\left( {{{\dot Q}_{HR}} + {{\dot Q}_{Cond}}} \right)}}
\end{equation}
-Both of these are available as an output variable called Chiller Effective Heat Rejection Tempeature in \(^{\circ}\)C.
+Both of these are available as an output variable called Chiller Effective Heat Rejection Temperature in \(^{\circ}\)C.
\subsubsection{Chiller Basin Heater}\label{chiller-basin-heater-2}
@@ -1905,7 +1905,7 @@ \subsubsection{Electric Reformulated EIR Chiller with Heat Recovery Option}\labe
\subsubsection{Standard Rating (Integrated Part Load Value)}\label{standard-rating-integrated-part-load-value-1}
-Integrated Part Laod Value (IPLV) calculations for Reformulated EIR chiller are similar to what are described above for EIR chillers. The only difference with Reformulated EIR chiller is that it calls an iterative subroutine (SolveRegulaFalsi) to obtain a condenser water outlet temperature which corresponds to condenser inlet temperature at reduced capacity conditions as outlined in Table~\ref{table:standard-rating-integrated-part-load-value} above. SolveRegulaFalsi is a general utility routine for finding the zero of a function. In this case it finds the condenser inlet temperature that will zero the residual function -- the difference between calculated condenser inlet temperature and desired condenser inlet temperature per ANSI/AHRI 550/590, 2011 (Table~\ref{table:standard-rating-integrated-part-load-value} above) divided by desired condenser inlet temperature.
+Integrated Part Load Value (IPLV) calculations for Reformulated EIR chiller are similar to what are described above for EIR chillers. The only difference with Reformulated EIR chiller is that it calls an iterative subroutine (SolveRegulaFalsi) to obtain a condenser water outlet temperature which corresponds to condenser inlet temperature at reduced capacity conditions as outlined in Table~\ref{table:standard-rating-integrated-part-load-value} above. SolveRegulaFalsi is a general utility routine for finding the zero of a function. In this case it finds the condenser inlet temperature that will zero the residual function -- the difference between calculated condenser inlet temperature and desired condenser inlet temperature per ANSI/AHRI 550/590, 2011 (Table~\ref{table:standard-rating-integrated-part-load-value} above) divided by desired condenser inlet temperature.
\subsubsection{References}\label{references-1-003}
diff --git a/doc/engineering-reference/src/solar-radiation-reflected-from-exterior/diffuse-reflection-of-beam-solar-and-sky.tex b/doc/engineering-reference/src/solar-radiation-reflected-from-exterior/diffuse-reflection-of-beam-solar-and-sky.tex
index 21f18104d17..ea519de6ca0 100644
--- a/doc/engineering-reference/src/solar-radiation-reflected-from-exterior/diffuse-reflection-of-beam-solar-and-sky.tex
+++ b/doc/engineering-reference/src/solar-radiation-reflected-from-exterior/diffuse-reflection-of-beam-solar-and-sky.tex
@@ -1,6 +1,6 @@
\section{Diffuse Reflection of Beam Solar and Sky Solar Radiation}\label{diffuse-reflection-of-beam-solar-and-sky-solar-radiation}
-A ray-tracing method is used to calculate beam solar and sky solar radiation that is diffusely reflected onto each of a building's exterior surfaces (walls, roofs, windows and doors), called here ``receiving surfaces.'' The calculation begins by generating a set of rays proceeding into the outward hemisphere at each receiving point on a receiving surface. Then it determinines whether each ray hits the sky, ground or an obstruction. The radiance at the hit point from reflection of incident beam or sky solar is determined and the contribution of this radiance to the receiving surface is calculated, added to the contribution from other hit points, and averaged over the receiving points. Separate calculations are done for beam-to-diffuse and sky solar reflection from all obstructions and beam-to-diffuse and sky solar reflection from the ground. (For beam-to-beam reflection see ``Beam Solar Radiation Specularly Reflected from Obstructions,'' below.)
+A ray-tracing method is used to calculate beam solar and sky solar radiation that is diffusely reflected onto each of a building's exterior surfaces (walls, roofs, windows and doors), called here ``receiving surfaces.'' The calculation begins by generating a set of rays proceeding into the outward hemisphere at each receiving point on a receiving surface. Then it determines whether each ray hits the sky, ground or an obstruction. The radiance at the hit point from reflection of incident beam or sky solar is determined and the contribution of this radiance to the receiving surface is calculated, added to the contribution from other hit points, and averaged over the receiving points. Separate calculations are done for beam-to-diffuse and sky solar reflection from all obstructions and beam-to-diffuse and sky solar reflection from the ground. (For beam-to-beam reflection see ``Beam Solar Radiation Specularly Reflected from Obstructions,'' below.)
\subsection{Receiving points}\label{receiving-points}
@@ -139,7 +139,7 @@ \subsection{Sky Solar Radiation Diffusely Reflected from the Ground}\label{sky-s
\end{array}
\end{equation}
-The view factor weighted average reflectance of multiple ground surfaces is calculated from the ground refelctances and view factors of the ground surfaces viewed by an exterior surface and is given by:
+The view factor weighted average reflectance of multiple ground surfaces is calculated from the ground reflectances and view factors of the ground surfaces viewed by an exterior surface and is given by:
\begin{equation}
{\rho_{gnd,avg}} = \sum\limits_{j = 1}^{{N_{gnd}}} {\rho_{gnd,j}} * {F_{gnd,j}} / \sum\limits_{j = 1}^{{N_{gnd}}} {F_{gnd,j}}
@@ -204,7 +204,7 @@ \subsection{Beam Solar Radiation Diffusely Reflected from the Ground}\label{beam
\(Hi{t_{gnd,i}}\) = 1 if ray \emph{i} hits the ground, = 0 otherwise,
-\(Hi{t_{gnd,i,sun}}\) = 1 if the line from ray \emph{i}'s hit point ot the sun is unobstructed, = 0 otherwise,
+\(Hi{t_{gnd,i,sun}}\) = 1 if the line from ray \emph{i}'s hit point to the sun is unobstructed, = 0 otherwise,
\({\alpha_{sun,gnd}}\) = angle of incidence of sun on ground ( = solar zenith angle).
@@ -228,7 +228,7 @@ \subsection{Beam Solar Radiation Diffusely Reflected from the Ground}\label{beam
\end{split}
\end{equation}
-The beam solar radiation is assumed to be reflected uniformaly to all directions. The view factor weighed ground solar reflectance of multiple ground surfaces viewed by an exterior surface is given by:
+The beam solar radiation is assumed to be reflected uniformly to all directions. The view factor weighed ground solar reflectance of multiple ground surfaces viewed by an exterior surface is given by:
\begin{equation}
{\rho_{gnd,avg}} = \sum\limits_{j = 1}^{{N_{gnd}}} {\rho_{gnd,j}} * {F_{gnd,j}} / \sum\limits_{j = 1}^{{N_{gnd}}} {F_{gnd,j}}
@@ -294,7 +294,7 @@ \subsection{Beam Solar Radiation Specularly Reflected from Obstructions}\label{b
The program assumes that specular reflection from a surface is due to glazing. If the reflecting surface is a window belonging to the building itself (as in Figure~\ref{fig:solar-reflection-from-building-surfaces-onto}), then \({f_{C,glazed}}\) is the fraction of the window that is glazed (which is 1.0 unless the window has dividers).
-If the surface is a shading surface (that represents, for example, the glazed façade of a neigboring building) the surface reflection information is entered with the Shading Surface Reflectance object. This object contains values for:
+If the surface is a shading surface (that represents, for example, the glazed façade of a neighboring building) the surface reflection information is entered with the Shading Surface Reflectance object. This object contains values for:
1.~~~~Diffuse solar reflectance of the unglazed part of the shading surface
diff --git a/doc/engineering-reference/src/special-modules-reporting/resilience-metrics.tex b/doc/engineering-reference/src/special-modules-reporting/resilience-metrics.tex
index ed52c567af4..8f2b0d478dc 100644
--- a/doc/engineering-reference/src/special-modules-reporting/resilience-metrics.tex
+++ b/doc/engineering-reference/src/special-modules-reporting/resilience-metrics.tex
@@ -486,7 +486,7 @@ \subsection{References}
17–25. doi:10.1016/j.enbuild.2013.04.019.
{[}8{]} L.G. Gagge, A. P., Fobelets, A. P. and Berglund, A standard predictive
-Index of human reponse to thermal enviroment, Am. Soc. Heating, Refrig.
+Index of human response to thermal environment, Am. Soc. Heating, Refrig.
Air-Conditioning Eng. (1986) 709–731.
{[}9{]} ASHRAE, ASHRAE STANDARD 55-2010: Thermal Environmental Conditions for
diff --git a/doc/engineering-reference/src/special-modules-reporting/zone-component-loads-summary.tex b/doc/engineering-reference/src/special-modules-reporting/zone-component-loads-summary.tex
index e60b87f5d61..61c97f41087 100644
--- a/doc/engineering-reference/src/special-modules-reporting/zone-component-loads-summary.tex
+++ b/doc/engineering-reference/src/special-modules-reporting/zone-component-loads-summary.tex
@@ -4,7 +4,7 @@ \section{Component Loads Summary}\label{component-loads-summary}
The heat balance algorithms used by EnergyPlus result in a single combined design load for a given zone and some, but not all, of the zone instantaneous heat gains. This section describes the estimation procedure for the three Component Loads Summary reports that shows an estimated breakdown of load components from each type of of heat gain for each zone. The three different reports are the Zone Component Loads Summary, the AirLoop Component Loads Summary and the Facility Component Loads Summary. The procedure described below is used for each zone and then the AirLoop and Facility level reports are generated by aggregating the results for the appropriate zones.
-If the time of the peak load for each Zone for cooling exactly matches the time of the peak load for the AirLoop or Facility than the Estimated Cooling Peak Load Components will represent a sum of the values from the corresponding zones. Likewise the Estimated Heating Peak Load Components will add up for the AirLoop or Facility if the times of the heating peaks exactly match. This is not necessarily the case for Peak Conditions or the Engineering Checks tables. Since the sizing of Airloops is based on the system sizing they usually will be different than the sum of the corresonding zones.
+If the time of the peak load for each Zone for cooling exactly matches the time of the peak load for the AirLoop or Facility than the Estimated Cooling Peak Load Components will represent a sum of the values from the corresponding zones. Likewise the Estimated Heating Peak Load Components will add up for the AirLoop or Facility if the times of the heating peaks exactly match. This is not necessarily the case for Peak Conditions or the Engineering Checks tables. Since the sizing of Airloops is based on the system sizing they usually will be different than the sum of the corresponding zones.
The Estimated Cooling Peak Load Components and Estimated Heating Peak Load Components subtables of the Zone Component Loads Summary report contain values that are estimated and are not part of the normal heat balance algorithms used in the rest of EnergyPlus.~ In particular, the column described as Sensible-Delayed represents an estimate of the sensible load contributed at the peak time based on radiant contributions from various load components that have radiant portions in previous timesteps. The focus of this section will be on the Sensible-Delayed column.
@@ -23,7 +23,7 @@ \section{Component Loads Summary}\label{component-loads-summary}
\item
When zone sizing is performed for cooling or heating, the heat convected from each opaque surface for each timestep during sizing day is saved to an array.
\item
- For each type of internal gain, HVAC equipment gain, and solar energy entering the zone, the radiant and convective portions are saved for every timestep during sizing. In addition, for each type of radiant gain, the amount that lands on each surface in the zone is saved for evergy timestep during sizing.
+ For each type of internal gain, HVAC equipment gain, and solar energy entering the zone, the radiant and convective portions are saved for every timestep during sizing. In addition, for each type of radiant gain, the amount that lands on each surface in the zone is saved for every timestep during sizing.
\item
An additional ``pulse sizing'' run is performed for cooling and heating during zone sizing that includes an additional small, single timestep, pulse of radiant-only heat for each zone but is otherwise the same as a normal zone sizing simulation. This is equivalent to adding an ElectricEquipment object that is scheduled for a single timestep and is 100\% radiant heat. The heat convected from each opaque surface for each timestep during sizing is saved to an array. This run is not used for sizing, but just to gather the impact of the pulse of radiant heat.
\item
@@ -53,7 +53,7 @@ \section{Component Loads Summary}\label{component-loads-summary}
\subsection{Estimated Component Load Details}\label{estimated-component-load-details}
-In HeatBalanceInternalHeatGains, in the InitInternalHeatGains routine, the single timestep pulse is added to the thermal radiation absorbed on the inside surface. It is based on 0.01 W per square meter of the zone area. The time of the pulse and the amount received by each surface is also saved. A new routine GatherComponentLoadsIntGain was also added to that file that gathers the instantenous heat gains from people, lights, equipment, refrigeration equipment, water use, hvac losses, and power generation. Latent gains from people and refrigeration are also gathered along with the radiant portion of the gains from these same sources. EnergyPlus tracks internal gains by type, and these are grouped as follows for the rows of the report:
+In HeatBalanceInternalHeatGains, in the InitInternalHeatGains routine, the single timestep pulse is added to the thermal radiation absorbed on the inside surface. It is based on 0.01 W per square meter of the zone area. The time of the pulse and the amount received by each surface is also saved. A new routine GatherComponentLoadsIntGain was also added to that file that gathers the instantaneous heat gains from people, lights, equipment, refrigeration equipment, water use, hvac losses, and power generation. Latent gains from people and refrigeration are also gathered along with the radiant portion of the gains from these same sources. EnergyPlus tracks internal gains by type, and these are grouped as follows for the rows of the report:
The gains from ``People'' contain:
diff --git a/doc/engineering-reference/src/surface-heat-balance-manager-processes/combined-heat-and-moisture-transfer-hamt.tex b/doc/engineering-reference/src/surface-heat-balance-manager-processes/combined-heat-and-moisture-transfer-hamt.tex
index 4fa93dd3cb9..9a2d19937ea 100644
--- a/doc/engineering-reference/src/surface-heat-balance-manager-processes/combined-heat-and-moisture-transfer-hamt.tex
+++ b/doc/engineering-reference/src/surface-heat-balance-manager-processes/combined-heat-and-moisture-transfer-hamt.tex
@@ -125,11 +125,11 @@ \subsubsection{Porosity P}\label{porosity-p}
The porosity of a material (P) is an input variable and defined as the maximum fraction, by volume, of a material that can be taken up with moisture. It is used to calculate the maximum point on the sorption isotherm curve. ~The porosity is entered for each material via the MaterialProperty:HeatAndMoistureTransfer:Settings object, as described in the Input Output Reference document.
-\subsubsection{Moisture Dependant Thermal Conductivity k\(^{w}\)}\label{moisture-dependant-thermal-conductivity-kw}
+\subsubsection{Moisture Dependent Thermal Conductivity k\(^{w}\)}\label{moisture-dependent-thermal-conductivity-kw}
The thermal conductivity (k\(^{w}\)) of the cell is determined by interpolating between data points of thermal conductivity versus the moisture content of the material, entered into EnergyPlus via the MaterialProperty:HeatAndMoistureTransfer:ThermalConductivity object. The moisture content is determined via the sorption isotherm which gives the moisture content as a function of Relative Humidity.
-\subsubsection{Moisture Dependant Moisture Diffusion Coefficient μ}\label{moisture-dependant-moisture-diffusion-coefficient-ux3bc}
+\subsubsection{Moisture Dependent Moisture Diffusion Coefficient μ}\label{moisture-dependent-moisture-diffusion-coefficient-ux3bc}
This is used in the third term of Equation~\ref{eq:HAMTHeatBalanceEquation} to describe the heat transfer due to vapor movement. It is determined by interpolating between data points of moisture diffusion coefficient versus the moisture content of the material, entered into EnergyPlus via the MaterialProperty:HeatAndMoistureTransfer:Diffusion object. A simple linear interpolation is used to obtain the conductivity between measured points.
@@ -163,7 +163,7 @@ \subsubsection{Moisture Transfer}\label{moisture-transfer}
\subsubsection{Liquid Transport Coefficient D\(^{w}\)}\label{liquid-transport-coefficient-dw}
-The Moisture Dependant Liquid Transport Coefficient is entered as a series of moisture density and liquid transport coefficient data points. There are two different coefficients, one for suction, where the surface is wet due to rain, and one for redistribution where the surface is no longer wet. If the weather file has a rain flag it is used to switch between these two types of coefficient. HAMT-SUCTION and HAMT-REDISTRIBUTION.
+The Moisture Dependent Liquid Transport Coefficient is entered as a series of moisture density and liquid transport coefficient data points. There are two different coefficients, one for suction, where the surface is wet due to rain, and one for redistribution where the surface is no longer wet. If the weather file has a rain flag it is used to switch between these two types of coefficient. HAMT-SUCTION and HAMT-REDISTRIBUTION.
\subsubsection{Moisture Dependent Moisture Capacity \(\frac{\partial w}{\partial \phi}\)}\label{moisture-dependent-moisture-capacity-fracpartial-wpartial-phi}
diff --git a/doc/engineering-reference/src/surface-heat-balance-manager-processes/conduction-finite-difference-solution.tex b/doc/engineering-reference/src/surface-heat-balance-manager-processes/conduction-finite-difference-solution.tex
index 8039711092e..7d2453ac846 100644
--- a/doc/engineering-reference/src/surface-heat-balance-manager-processes/conduction-finite-difference-solution.tex
+++ b/doc/engineering-reference/src/surface-heat-balance-manager-processes/conduction-finite-difference-solution.tex
@@ -55,7 +55,7 @@ \subsection{Basic Finite Difference Solution Approach}\label{basic-finite-differ
\item[\rho] density of material
\end{wherelist}
%
-with superscipts and subscripts:
+with superscripts and subscripts:
%
\begin{wherelist}
\item[i] node being modeled
diff --git a/doc/engineering-reference/src/surface-heat-balance-manager-processes/effective-moisture-penetration-depth-empd.tex b/doc/engineering-reference/src/surface-heat-balance-manager-processes/effective-moisture-penetration-depth-empd.tex
index dfedb961f81..891554fb435 100644
--- a/doc/engineering-reference/src/surface-heat-balance-manager-processes/effective-moisture-penetration-depth-empd.tex
+++ b/doc/engineering-reference/src/surface-heat-balance-manager-processes/effective-moisture-penetration-depth-empd.tex
@@ -43,7 +43,7 @@ \subsection{EMPD Model Description}\label{empd-model-description}
\begin{figure}[hbtp]
\centering
\includegraphics[width=0.9\textwidth, height=0.9\textheight, keepaspectratio=true]{media/EMPDschematic.png}
-\caption{Nodal network for effective moisture pentration depth model \protect \label{fig:Nodal-network-for-effective-moisture-penetration-depth-model}}
+\caption{Nodal network for effective moisture penetration depth model \protect \label{fig:Nodal-network-for-effective-moisture-penetration-depth-model}}
\end{figure}
The surface layer resistance is calculated with:
@@ -82,7 +82,7 @@ \subsection{EMPD Model Description}\label{empd-model-description}
R_{MT,BL} = \frac{\rho_{air} Cp_{air}}{h_{conv}}
\end{equation}
-Behind the surface layer is a deep layer (labeled with subscipt 2 below) of thickness \(d_{EMPD,2}\). The surface layer accounts for buffering of high-frequency changes in the zone air humidity, while the deep layer accounts for the material's response to longer term changes in the zone air humidity. The model calculates the moisture flux between the surface and deep layers with:
+Behind the surface layer is a deep layer (labeled with subscript 2 below) of thickness \(d_{EMPD,2}\). The surface layer accounts for buffering of high-frequency changes in the zone air humidity, while the deep layer accounts for the material's response to longer term changes in the zone air humidity. The model calculates the moisture flux between the surface and deep layers with:
\begin{equation}
j_{2} = \frac {\rho_{v,1} - \rho_{v,2}} {R_{MT,2}}
diff --git a/doc/engineering-reference/src/surface-heat-balance-manager-processes/outside-surface-heat-balance.tex b/doc/engineering-reference/src/surface-heat-balance-manager-processes/outside-surface-heat-balance.tex
index a2a8eb15dc4..22f145526a9 100644
--- a/doc/engineering-reference/src/surface-heat-balance-manager-processes/outside-surface-heat-balance.tex
+++ b/doc/engineering-reference/src/surface-heat-balance-manager-processes/outside-surface-heat-balance.tex
@@ -31,7 +31,7 @@ \subsection{External Shortwave Radiation}\label{external-shortwave-radiation}
\subsection{External Longwave Radiation}\label{external-longwave-radiation}
-\({q''_{LWR}}\) is a standard radiation exchange formulation between the surface, the sky, and the ground. The radiation heat flux is calculated from the surface absorptivity, surface temperature, sky and ground temperatures, and sky and ground view factors.
+\({q''_{LWR}}\) is a standard radiation exchange formulation between the surface, the sky, the ground, and the surrounding surfaces. The radiation heat flux is calculated from the surface absorptivity, surface temperature, sky, ground and surrounding surfaces temperatures, and sky, ground and surrounding surfaces view factors.
The longwave radiation heat exchange between surfaces is dependent on surface temperatures, spatial relationships between surfaces and surroundings, and material properties of the surfaces. The relevant material properties of the surface, emissivity e and absorptivity a, are complex functions of temperature, angle, and wavelength for each participating surface. However, it is generally agreed that reasonable assumptions for building loads calculations are (Chapman 1984; Lienhard 1981):
@@ -43,7 +43,11 @@ \subsection{External Longwave Radiation}\label{external-longwave-radiation}
\item
energy flux leaving a surface is evenly distributed across the surface,
\item
- the medium within the enclosure is non-participating.
+ the medium within the enclosure is non-participating,
+\item
+ the long-wave emissivity of the surrounding surfaces is assumed to be the same as that of the exterior surface viewing them,
+\item
+ the sum of view factors from an exterior surface to the ground, the sky and the surrounding surfaces must be equal to 1.
\end{itemize}
These assumptions are frequently used in all but the most critical engineering applications.
@@ -68,24 +72,26 @@ \subsection{External Longwave Radiation}\label{external-longwave-radiation}
$T_{air}$ & Outside air temperature & $K$ & --- \tabularnewline
$T_{gnd}$ & Environmental ground surface temperature & $K$ & --- \tabularnewline
$T_{sky}$ & Sky Effective temperature & $K$ & --- \tabularnewline
+$T_{srd}$ & Surrounding surfaces average temperature & $K$ & --- \tabularnewline
$F_{gnd}$ & view factor of wall surface to ground surface & --- & 0--1 \tabularnewline
$F_{sky}$ & View factor of wall surface to sky & --- & 0--1 \tabularnewline
$F_{air}$ & View factor of wall surface to air & --- & 0--1 \tabularnewline
+$F_{srd}$ & View factor of wall surface to surrounding surfaces & --- & 0--1 \tabularnewline
$\varepsilon$ & Surface long-wave emissivity & --- & 0--1 \tabularnewline
$\sigma$ & Stefan-Boltzmann constant & $W/m^2.K^4$ & $5.67 \times 10^{-8}$ \tabularnewline
\bottomrule
\end{longtable}
-Consider an enclosure consisting of building exterior surface, surrounding ground surface, and sky.~ Using the assumptions above, we can determine the longwave radiative heat flux at the building exterior surface (Walton 1983; McClellan and Pedersen 1997).~ The total longwave radiative heat flux is the sum of components due to radiation exchange with the ground, sky, and air.
+Consider an enclosure consisting of building exterior surface, surrounding ground surface, and sky.~ Using the assumptions above, we can determine the longwave radiative heat flux at the building exterior surface (Walton 1983; McClellan and Pedersen 1997).~ The total longwave radiative heat flux is the sum of components due to radiation exchange with the ground, sky, air, and surrounding surfaces.
\begin{equation}
-{q''_{LWR}} = {q''_{gnd}} + {q''_{sky}} + {q''_{air}}
+{q''_{LWR}} = {q''_{gnd}} + {q''_{sky}} + {q''_{air}} + {q''_{srd}}
\end{equation}
Applying the Stefan-Boltzmann Law to each component yields:
\begin{equation}
-{q''_{LWR}} = \varepsilon \sigma {F_{gnd}}(T_{gnd}^4 - T_{surf}^4) + \varepsilon \sigma {F_{sky}}(T_{sky}^4 - T_{surf}^4) + \varepsilon \sigma {F_{air}}(T_{air}^4 - T_{surf}^4)
+{q''_{LWR}} = \varepsilon \sigma {F_{gnd}}(T_{gnd}^4 - T_{surf}^4) + \varepsilon \sigma {F_{sky}}(T_{sky}^4 - T_{surf}^4) + \varepsilon \sigma {F_{air}}(T_{air}^4 - T_{surf}^4) + \varepsilon \sigma {F_{srd}}(T_{srd}^4 - T_{surf}^4)
\end{equation}
where
@@ -100,6 +106,8 @@ \subsection{External Longwave Radiation}\label{external-longwave-radiation}
F\(_{air}\) = view factor of wall surface to air temperature
+F\(_{srd}\) = view factor of wall surface to surrounding surfaces
+
T\(_{surf}\) = outside surface temperature
T\(_{gnd}\) = ground surface temperature
@@ -108,10 +116,12 @@ \subsection{External Longwave Radiation}\label{external-longwave-radiation}
T\(_{air}\) = air temperature
+T\(_{srd}\) = average temperature of the surrounding surfaces
+
Linearized radiative heat transfer coefficients are introduced to render the above equation more compatible with the heat balance formulation,
\begin{equation}
-{q''_{LWR}} = {h_{r,gnd}}({T_{gnd}} - {T_{surf}}) + {h_{r,sky}}({T_{sky}} - {T_{surf}}) + {h_{r,air}}({T_{air}} - {T_{surf}})
+{q''_{LWR}} = {h_{r,gnd}}({T_{gnd}} - {T_{surf}}) + {h_{r,sky}}({T_{sky}} - {T_{surf}}) + {h_{r,air}}({T_{air}} - {T_{surf}}) + {h_{r,srd}}({T_{srd}} - {T_{surf}})
\end{equation}
where
@@ -128,6 +138,10 @@ \subsection{External Longwave Radiation}\label{external-longwave-radiation}
{h_{r,air}} = \frac{{\varepsilon \sigma {F_{air}}(T_{surf}^4 - T_{air}^4)}}{{{T_{surf}} - {T_{air}}}}
\end{equation}
+\begin{equation}
+{h_{r,srd}} = \frac{{\varepsilon \sigma {F_{srd}}(T_{surf}^4 - T_{srd}^4)}}{{{T_{surf}} - {T_{srd}}}}
+\end{equation}
+
The longwave view factors to ground and sky are calculated with the following expressions (Walton 1983):
\begin{equation}
@@ -177,7 +191,7 @@ \subsubsection{External Longwave Radiation With Multiple Ground Surfaces}\label{
{q''_{gnd}} = \varepsilon \sigma \sum\limits_{j = 1}^{{N_{gnd}}} {F_{gnd,j}} \left(T_{gnd,j}^4 - T_{surf}^4 \right)
\end{equation}
-The above equation can be recast using average temperature of multiple ground surfaces viewed by an exterior surface as follows:
+The above equation assumes that the building exterior surface and the ground surfaces it views have the same long-wave emissivity and can be recast using average temperature of multiple ground surfaces viewed by an exterior surface as follows:
\begin{equation}
{q''_{gnd}} = \varepsilon \sigma {F_{gnd,sum}} (T_{gnd,avg}^4 - T_{surf}^4)
@@ -216,6 +230,53 @@ \subsubsection{External Longwave Radiation With Multiple Ground Surfaces}\label{
h\(_{r,gnd,avg}\) = linearized average radiative heat transfer coefficient between an exterior surface and multiple ground surfaces
+\subsubsection{External Longwave Radiation With Multiple Surrounding Surfaces}\label{external-longwave-radiation-with-multiple-surrounding-surfaces}
+
+Long-wave radiation exchange of an exterior surface with multiple surrounding surfaces is given by:
+
+\begin{equation}
+{q''_{srd}} = \varepsilon \sigma \sum\limits_{j = 1}^{{N_{srd}}} {F_{srd,j}} \left(T_{srd,j}^4 - T_{surf}^4 \right)
+\end{equation}
+
+The above equation assumes that the building exterior surface and the surrounding surfaces it views have the same long-wave emissivity and can be recast using average temperature of multiple surrounding surfaces viewed by an exterior surface as follows:
+
+\begin{equation}
+{q''_{srd}} = \varepsilon \sigma {F_{srd,sum}} (T_{srd,avg}^4 - T_{surf}^4)
+\end{equation}
+
+\begin{equation}
+{F_{srd,sum}} = \sum\limits_{j = 1}^{{N_{srd}}} {F_{srd,j}}
+\end{equation}
+
+\begin{equation}
+{T_{srd,avg}} = ((\sum\limits_{j = 1}^{{N_{srd}}} {F_{srd,j}} {T_{srd,j}^4}) / {F_{srd,sum}})^{1/4}
+\end{equation}
+
+\begin{equation}
+{h_{r,srd,avg}} = \frac{{\varepsilon \sigma {F_{srd, sum}}(T_{surf}^4 - T_{srd,avg}^4)}}{{{T_{surf}} - {T_{srd,avg}}}}
+\end{equation}
+
+where
+
+$\varepsilon$ = long-wave emittance of an exterior surface
+
+$\sigma$ = Stefan-Boltzmann constant
+
+F\(_{srd,j}\) = view factor of an exterior surface to surrounding surface j
+
+T\(_{srd,j}\) = temperature of surrounding surface j
+
+T\(_{surf}\) = outside temperature of an exterior surface
+
+N\(_{srd}\) = number surrounding surfaces viewed by an exterior surface
+
+T\(_{srd,avg}\) = view factor weighted average surface temperature of multiple surrounding surfaces seen by an exterior surface
+
+F\(_{srd,sum}\) = sum of the view factors of an exterior surfaces to multiple surrounding surfaces
+
+h\(_{r,srd,avg}\) = linearized average radiative heat transfer coefficient between an exterior surface and multiple surrounding surfaces
+
+
\subsection{References}\label{references-034}
ASHRAE. 1993. 1993 ASHRAE Handbook -- Fundamentals. Atlanta: American Society of Heating, Refrigerating, and Air-Conditioning Engineers, Inc.
@@ -592,7 +653,7 @@ \subsubsection{MoWiTT Algorithm}\label{mowitt-algorithm}
{h_c} = \sqrt {{{\left[ {{C_t}{{\left( {\Delta T} \right)}^{\frac{1}{3}}}} \right]}^2} + {{\left[ {aV_z^b} \right]}^2}}
\end{equation}
-Constants a, b and turbulent natural convection constant C\(_{t}\) are given in Table~\ref{table:mowitt-coefficients-yazdanian-and-klems-1994}.~ The original MoWiTT model has been modified for use in EnergyPlus so that it is sensitive to the local suface's wind speed which varies with the height above ground.~ The original MoWiTT model was formulated for use with the air velocity at the location of the weather station.~ As of Version 7.2, EnergyPlus uses the ``a'' model coefficients derived by Booten et al. (2012) rather than the original values from Yazdanian and Klems (1994).
+Constants a, b and turbulent natural convection constant C\(_{t}\) are given in Table~\ref{table:mowitt-coefficients-yazdanian-and-klems-1994}.~ The original MoWiTT model has been modified for use in EnergyPlus so that it is sensitive to the local surface's wind speed which varies with the height above ground.~ The original MoWiTT model was formulated for use with the air velocity at the location of the weather station.~ As of Version 7.2, EnergyPlus uses the ``a'' model coefficients derived by Booten et al. (2012) rather than the original values from Yazdanian and Klems (1994).
NOTE:~ The MoWiTT algorithm may not be appropriate for rough surfaces, high-rise surfaces, or surfaces that employ movable insulation.
diff --git a/doc/engineering-reference/src/surface-heat-balance-manager-processes/surface-heat-balance-with-moveable-insulation.tex b/doc/engineering-reference/src/surface-heat-balance-manager-processes/surface-heat-balance-with-moveable-insulation.tex
index 6da514bbe3f..7970399947e 100644
--- a/doc/engineering-reference/src/surface-heat-balance-manager-processes/surface-heat-balance-with-moveable-insulation.tex
+++ b/doc/engineering-reference/src/surface-heat-balance-manager-processes/surface-heat-balance-with-moveable-insulation.tex
@@ -13,7 +13,7 @@ \subsection{Inside Heat Balance with Interior Moveable Insulation}\label{inside-
One significant complication of the inside heat balance is the fact that surfaces within the same zone can interact with each other radiatively. This means that a solution for all surface temperatures must be done at the same time to maintain a radiation heat balance among the surfaces. This requires some iteration of the inside surface heat balance as will be seen in the equations that are shown later in this subsection.
-Another complication of the inside heat balance relates to the presense of moveable insulation. When moveable insulation is present, a second heat balance equation is required to determine the temperature at both the air-moveable insulation interface as well as the moveable insulation-surface interface. This sets up a system of two equations with two unknowns: the temperatures at the air-moveable insulation interface and the moveable insulation-surface interface.
+Another complication of the inside heat balance relates to the presence of moveable insulation. When moveable insulation is present, a second heat balance equation is required to determine the temperature at both the air-moveable insulation interface as well as the moveable insulation-surface interface. This sets up a system of two equations with two unknowns: the temperatures at the air-moveable insulation interface and the moveable insulation-surface interface.
Applying the basic steady state heat balance equation at each of these interfaces results in the following two equations:
diff --git a/doc/engineering-reference/src/surface-heat-balance-manager-processes/undisturbed-ground-temperature-model-kusuda.tex b/doc/engineering-reference/src/surface-heat-balance-manager-processes/undisturbed-ground-temperature-model-kusuda.tex
index 8a8e4c6f573..96b5fd7d6d4 100644
--- a/doc/engineering-reference/src/surface-heat-balance-manager-processes/undisturbed-ground-temperature-model-kusuda.tex
+++ b/doc/engineering-reference/src/surface-heat-balance-manager-processes/undisturbed-ground-temperature-model-kusuda.tex
@@ -18,7 +18,7 @@ \subsubsection{Approach}\label{approach-004}
\(\theta\) is the phase shift, or day of minimum surface temperature
-\(\alpha\) is the themal diffusivity of the ground
+\(\alpha\) is the thermal diffusivity of the ground
\(\tau\) is time constant, 365.
diff --git a/doc/engineering-reference/src/surface-heat-balance-manager-processes/undisturbed-ground-temperature-model-xing.tex b/doc/engineering-reference/src/surface-heat-balance-manager-processes/undisturbed-ground-temperature-model-xing.tex
index b09571ac1f3..471f0ba2578 100644
--- a/doc/engineering-reference/src/surface-heat-balance-manager-processes/undisturbed-ground-temperature-model-xing.tex
+++ b/doc/engineering-reference/src/surface-heat-balance-manager-processes/undisturbed-ground-temperature-model-xing.tex
@@ -16,7 +16,7 @@ \subsubsection{Approach}\label{approach-005}
\(\theta_{n}\) is the n-th phase shift, or day of minimum surface temperature
-\(\alpha\) is the themal diffusivity of the ground
+\(\alpha\) is the thermal diffusivity of the ground
\(\tau\) is time constant, 365.
diff --git a/doc/input-output-reference/src/appendix-a-units-and-abbreviations/standard-energyplus-units.tex b/doc/input-output-reference/src/appendix-a-units-and-abbreviations/standard-energyplus-units.tex
index 644a08c0fb5..58c9758b6b4 100644
--- a/doc/input-output-reference/src/appendix-a-units-and-abbreviations/standard-energyplus-units.tex
+++ b/doc/input-output-reference/src/appendix-a-units-and-abbreviations/standard-energyplus-units.tex
@@ -48,7 +48,7 @@ \section{Standard EnergyPlus Units}\label{standard-energyplus-units}
heating or cooling capacity & Watts & W \tabularnewline
electric potential & volts & V \tabularnewline
electric current & Amperes & A \tabularnewline
-illuminace & lux & lx \tabularnewline
+illuminance & lux & lx \tabularnewline
luminous flux & lumen & lm \tabularnewline
luminous intensity & candelas & cd \tabularnewline
luminance & candelas per square meter & cd/m2 \tabularnewline
diff --git a/doc/input-output-reference/src/energyplus-economics/complex-tariff-modeling.tex b/doc/input-output-reference/src/energyplus-economics/complex-tariff-modeling.tex
index b6cbe88fd89..c76dab3bb17 100644
--- a/doc/input-output-reference/src/energyplus-economics/complex-tariff-modeling.tex
+++ b/doc/input-output-reference/src/energyplus-economics/complex-tariff-modeling.tex
@@ -179,4 +179,4 @@ \subsubsection{Operator:~ NOT (2)}\label{operator-not-2}
\subsubsection{Operator:~ FROM (Unlimited)}\label{operator-from-unlimited}
-Indicates what variables a variable is dependant on (or derived from). No computation is performed. The algorithm that creates the automatic sequence of equations uses these to indicate when variables are dependant on other variables so that they can be sorted into the correct order.
\ No newline at end of file
+Indicates what variables a variable is dependent on (or derived from). No computation is performed. The algorithm that creates the automatic sequence of equations uses these to indicate when variables are dependent on other variables so that they can be sorted into the correct order.
\ No newline at end of file
diff --git a/doc/input-output-reference/src/energyplus-economics/life-cycle-costing.tex b/doc/input-output-reference/src/energyplus-economics/life-cycle-costing.tex
index 882dd59eb46..0679c8953d5 100644
--- a/doc/input-output-reference/src/energyplus-economics/life-cycle-costing.tex
+++ b/doc/input-output-reference/src/energyplus-economics/life-cycle-costing.tex
@@ -1,6 +1,6 @@
\section{Life-Cycle Costing}\label{life-cycle-costing}
-Life-cycle costing is used with building energy simulation in order to justify energy efficiency upgrades. Many alterative building technologies that result in energy savings cost more initially, or may cost more to maintain, than traditional solutions. In order to justify selecting these energy savings technologies, it is essential to combine both initial and future costs in the decision process. Using life-cycle costs provides a framework to combine initial costs and future costs into a single combined measure, called the ``present value.'' Present value is a metric that combines all costs and reduces (or discounts) those costs that occur in the future. Discounting future costs is based on the principal of the time value of money.
+Life-cycle costing is used with building energy simulation in order to justify energy efficiency upgrades. Many alternative building technologies that result in energy savings cost more initially, or may cost more to maintain, than traditional solutions. In order to justify selecting these energy savings technologies, it is essential to combine both initial and future costs in the decision process. Using life-cycle costs provides a framework to combine initial costs and future costs into a single combined measure, called the ``present value.'' Present value is a metric that combines all costs and reduces (or discounts) those costs that occur in the future. Discounting future costs is based on the principal of the time value of money.
The calculations are based on discounting the future values according to normal life-cycle costing techniques as described in NIST Handbook 135 ``Life-Cycle Costing Manual for the Federal Energy Management Program.''
diff --git a/doc/input-output-reference/src/energyplus-economics/utilitycost-ratchet.tex b/doc/input-output-reference/src/energyplus-economics/utilitycost-ratchet.tex
index 82705433260..a31cdb65b73 100644
--- a/doc/input-output-reference/src/energyplus-economics/utilitycost-ratchet.tex
+++ b/doc/input-output-reference/src/energyplus-economics/utilitycost-ratchet.tex
@@ -44,7 +44,7 @@ \section{UtilityCost:Ratchet}\label{utilitycostratchet}
If multiple ratchets occur in the same tariff, multiple UtilityCost:Ratchet commands should be ``chained'' together with the Baseline Source Variable subsequent ratchets referencing the Ratchet Variable Name of the previous UtilityCost:Ratchet.
-Since the ratchet command can add together two variables, mutliply two variables, or take the maximum value between two variables, it may be used for other difficult to model tariffs without needing to use \hyperref[utilitycostcomputation]{UtilityCost:Computation}. Clever use of UtilityCost:Ratchet should be well documented with comments.
+Since the ratchet command can add together two variables, multiply two variables, or take the maximum value between two variables, it may be used for other difficult to model tariffs without needing to use \hyperref[utilitycostcomputation]{UtilityCost:Computation}. Clever use of UtilityCost:Ratchet should be well documented with comments.
\subsection{Inputs}\label{inputs-071}
diff --git a/doc/input-output-reference/src/hvac-template-objects/group-hvac-templates.tex b/doc/input-output-reference/src/hvac-template-objects/group-hvac-templates.tex
index 160dd7a9370..40478f5a655 100644
--- a/doc/input-output-reference/src/hvac-template-objects/group-hvac-templates.tex
+++ b/doc/input-output-reference/src/hvac-template-objects/group-hvac-templates.tex
@@ -679,7 +679,7 @@ \subsubsection{Inputs}\label{inputs-3-018}
\end{itemize}
The default is \emph{ChilledWater}.
-
+
\paragraph{Field: Cooling Coil Availability Schedule Name}\label{field-cooling-coil-availability-schedule-name}
Usually set to blank, which allows the cooling coil to be available anytime the system is operating. If a schedule name is specified, it defines when the coil is available. This is most often used when cooling is only available seasonally. A schedule value of one indicates that the cooling coil can be on during a given time period. A value of zero denotes that the cooling coil cannot be used during that time period.
@@ -733,7 +733,7 @@ \subsubsection{Inputs}\label{inputs-3-018}
This input denotes how the unit's output is controlled in order to meet zone heating or cooling requirement. The choices are:
\begin{itemize}
\item
- \emph{ConstantFanVariableFlow}: The fan speed is held constant to produce a fixed air flow rate whenever the unit is scheduled on. The hot water or chilled flow rate is varied so that the unit output matches the zone heating or cooling requirement.
+ \emph{ConstantFanVariableFlow}: The fan speed is held constant to produce a fixed air flow rate whenever the unit is scheduled on. The hot water or chilled flow rate is varied so that the unit output matches the zone heating or cooling requirement.
\item
\emph{CyclingFan}: The fan speed is chosen so that the unit capacity is greater than or equal to the heating / cooling load and the fan is cycled to match unit output with the load.
\item
@@ -743,9 +743,9 @@ \subsubsection{Inputs}\label{inputs-3-018}
\item
\emph{MultiSpeedFan}: The water flow rate is at full flow when there is load or fully closed when there is no load and the supply air flow rate is varied by varying the fan speed in order to match the load.
\item
- \emph{ASHRAE90VariableFan}: The fan air flow rate is reduced according to the low speed supply air flow ratio when the zone sensible load is less than the zone sensible load multiplied by the low speed supply air flow ratio.
+ \emph{ASHRAE90VariableFan}: The fan air flow rate is reduced according to the low speed supply air flow ratio when the zone sensible load is less than the zone sensible load multiplied by the low speed supply air flow ratio.
\end{itemize}
-
+
The default is \emph{ConstantFanVariableFlow} except when a Dedicated Outdoor Air System is specified (see above) the default is \emph{CyclingFan}.
\paragraph{Field: Low Speed Supply Air Flow Ratio}\label{field-low-speed-supply-air-flow-ratio}
@@ -1184,7 +1184,7 @@ \subsubsection{Inputs}\label{inputs-5-014}
\paragraph{Field: Heat Pump Heating Coil Gross Rated Capacity}\label{field-heat-pump-heating-coil-gross-rated-capacity}
-Enter autosize to let the automatic sizing algorithm determine the heat pump heating coil gorss rated capacity based on the maximum heating loads during the heating design day. If a value is entered, it represents the full load gross heating capacity, in watts of the DX heat pump unit at rated conditions. Rated conditions are air entering the heat pump heating coil at the heating supply air flow rate at 21.11°C drybulb/15.55°C wetbulb with air entering the outdoor coil at 8.33°C drybulb/6.11C wetbulb. Capacity should be the ``gross'', i.e., the effect of supply air fan heat is not accounted for. The units are in W. The default is autosize.
+Enter autosize to let the automatic sizing algorithm determine the heat pump heating coil gross rated capacity based on the maximum heating loads during the heating design day. If a value is entered, it represents the full load gross heating capacity, in watts of the DX heat pump unit at rated conditions. Rated conditions are air entering the heat pump heating coil at the heating supply air flow rate at 21.11°C drybulb/15.55°C wetbulb with air entering the outdoor coil at 8.33°C drybulb/6.11C wetbulb. Capacity should be the ``gross'', i.e., the effect of supply air fan heat is not accounted for. The units are in W. The default is autosize.
\paragraph{Field: Heat Pump Heating Coil Gross Rated COP}\label{field-heat-pump-heating-coil-gross-rated-cop}
@@ -1453,7 +1453,7 @@ \subsubsection{Inputs}\label{inputs-6-011}
\paragraph{Field: Cooling Coil Gross Rated Sensible Heat Ratio}\label{field-cooling-coil-gross-rated-sensible-heat-ratio-2}
-Enter Autosize to allow the sizing algorithm to determine the sensible heat ratio based on the rated capacity and air flow rate. Otherwise, enter the value of the ratio of the gross sensible capacity divided by gross total cooling capacity of the DX cooling coil at rated conditions (26.7C (80F) entering air dry-bulb temperature, 19.4C (67F) entering air wet-bulb temperature, and 29.4C (85F) entering water temperature). Both the sensible and total cooling capacities used to define the Rated Sensible Heat Ratio (SHR) should be ``gross'' , i.e., the effect of supply air fan heat is not accounted for. The default is autosize. If the Cooling Coil Rated Capacity is autosized, this field should also be autosized (any value specified for Cooling Coil Rate Sensibe Heat Ratio will be ignored). If the Cooling Coil Rated Capacity has a specified value, then this field should also have a specified value. This is because the \hyperref[coilcoolingwatertoairheatpumpequationfit]{Coil:Cooling:WaterToAirHeatPump:EquationFit} object has fields for Rated Total Cooling Capacity and Rated Sensible Cooling Capacity. If this field is autosized, a specified value for Cooling Coil Rated Capacity will not be used when the coil object sensible capacity is autosized.
+Enter Autosize to allow the sizing algorithm to determine the sensible heat ratio based on the rated capacity and air flow rate. Otherwise, enter the value of the ratio of the gross sensible capacity divided by gross total cooling capacity of the DX cooling coil at rated conditions (26.7C (80F) entering air dry-bulb temperature, 19.4C (67F) entering air wet-bulb temperature, and 29.4C (85F) entering water temperature). Both the sensible and total cooling capacities used to define the Rated Sensible Heat Ratio (SHR) should be ``gross'' , i.e., the effect of supply air fan heat is not accounted for. The default is autosize. If the Cooling Coil Rated Capacity is autosized, this field should also be autosized (any value specified for Cooling Coil Rate Sensible Heat Ratio will be ignored). If the Cooling Coil Rated Capacity has a specified value, then this field should also have a specified value. This is because the \hyperref[coilcoolingwatertoairheatpumpequationfit]{Coil:Cooling:WaterToAirHeatPump:EquationFit} object has fields for Rated Total Cooling Capacity and Rated Sensible Cooling Capacity. If this field is autosized, a specified value for Cooling Coil Rated Capacity will not be used when the coil object sensible capacity is autosized.
\paragraph{Field: Cooling Coil Gross Rated COP}\label{field-cooling-coil-gross-rated-cop-1}
@@ -1489,7 +1489,7 @@ \subsubsection{Inputs}\label{inputs-6-011}
\caption{}
\end{figure}
-\paragraph{Field: Heat Pump Time Constant}\label{field-heat-pump-time-constant}
+\paragraph{Field: Latent Capacity Time Constant}\label{field-heat-pump-time-constant}
This numeric field contains the time constant for the cooling coil's capacity to reach steady state after startup. Suggested values are shown below (Henderson et al. 1999):
@@ -1499,19 +1499,9 @@ \subsubsection{Inputs}\label{inputs-6-011}
\caption{}
\end{figure}
-\paragraph{Field: Fraction of On-Cycle Power Use}\label{field-fraction-of-on-cycle-power-use}
-
-This numeric field contains the fraction of on-cycle power use to adjust the part load fraction based on the off-cycle power consumption due to crankcase heaters, controls, fans, and etc. Suggested value values are below (Henderson et al. 1999):
-
-\begin{figure}[htbp]
-\centering
-\includegraphics{media/image607.png}
-\caption{}
-\end{figure}
-
\paragraph{Field: Heat Pump Fan Delay Time}\label{field-heat-pump-fan-delay-time}
-This numeric field contains the time delay in seconds for the heat pump supply air fan to shut off after compressor cycle off. This value can be obtained from the manufacturer or the heat pump catalog. Suggested value is 60 seconds. This value is disregared at times when the WaterToAirHeatPump's fan operating mode schedule value is greater than 0 (i.e., continuous fan mode).
+This numeric field contains the time delay in seconds for the heat pump supply air fan to shut off after compressor cycle off. This value can be obtained from the manufacturer or the heat pump catalog. Suggested value is 60 seconds. This value is disregarded at times when the WaterToAirHeatPump's fan operating mode schedule value is greater than 0 (i.e., continuous fan mode).
\paragraph{Field: Dedicated Outdoor Air System Name}\label{field-dedicated-outdoor-air-system-name-4}
@@ -1567,7 +1557,7 @@ \subsubsection{Inputs}\label{inputs-6-011}
ConstantOnDemand
\end{itemize}
-\textbf{Cycling} varies water flow through the coil based on the heat pump Part Load Ratio. This control method is appropriate for modeling heat pumps that are outfitted with a soleniod valve which allows water to flow through the coil only when the compressor is active. This is the \textbf{default} for EnergyPlus V8 and later.
+\textbf{Cycling} varies water flow through the coil based on the heat pump Part Load Ratio. This control method is appropriate for modeling heat pumps that are outfitted with a solenoid valve which allows water to flow through the coil only when the compressor is active. This is the \textbf{default} for EnergyPlus V8 and later.
\textbf{Constant} provides a constant water flow regardless of heat pump operation. Remember that EnergyPlus has two coils (a heating coil and a cooling coil) to approximate the operation of one coil that can operate in either heating mode or cooling mode. Therefore, when the water flow mode is constant, there will be full flow through either the heating coil or the cooling coil, but not both at the same time.
@@ -1636,8 +1626,7 @@ \subsubsection{Inputs}\label{inputs-6-011}
, !- Supplemental Heating Coil Availability Schedule Name
autosize, !- Supplemental Heating Coil Capacity {W}
2.5, !- Maximum Cycling Rate {cycles/hr}
- 60, !- Heat Pump Time Constant {s}
- 0.01, !- Fraction of On-Cycle Power Use
+ 60, !- Latent Capacity Time Constant {s}
60, !- Heat Pump Fan Delay Time {s}
, !- Dedicated Outdoor Air System Name
Electric, !- Supplemental Heating Coil Type
@@ -1783,7 +1772,7 @@ \subsubsection{Inputs}\label{inputs-7-011}
\paragraph{Field: Heat Pump Heating Coil Gross Rated Capacity}\label{field-heat-pump-heating-coil-gross-rated-capacity-2}
-Enter autosize to let the automatic sizing algorithm determine the heat pump heating coil gorss rated capacity based on the maximum heating loads during the heating design day. If a value is entered, it represents the full load gross heating capacity, in watts of the DX heat pump unit at rated conditions. Rated conditions are air entering the heat pump heating coil at the heating supply air flow rate at 21.11°C drybulb/15.55°C wetbulb with air entering the outdoor coil at 8.33°C drybulb/6.11C wetbulb. Capacity should be the ``gross'', i.e., the effect of supply air fan heat is not accounted for. The units are in W. The default is autosize.
+Enter autosize to let the automatic sizing algorithm determine the heat pump heating coil gross rated capacity based on the maximum heating loads during the heating design day. If a value is entered, it represents the full load gross heating capacity, in watts of the DX heat pump unit at rated conditions. Rated conditions are air entering the heat pump heating coil at the heating supply air flow rate at 21.11°C drybulb/15.55°C wetbulb with air entering the outdoor coil at 8.33°C drybulb/6.11C wetbulb. Capacity should be the ``gross'', i.e., the effect of supply air fan heat is not accounted for. The units are in W. The default is autosize.
\paragraph{Field: Zone Terminal Unit On Parasitic Electricity Energy Use}\label{field-zone-terminal-unit-on-parasitic-electric-energy-use}
@@ -2085,7 +2074,7 @@ \subsubsection{Inputs}\label{inputs-9-008}
\paragraph{Field: Minimum Air Flow Fraction Schedule Name}\label{field-minimum-air-flow-fraction-schedule-name-000}
-The name of a schedule that determines the value of the minimum air flow fraction. The schedule should contain fractions from 0.0 to 1.0. These values will define the minimum flow rate to the zone while the system is operating, specified as a fraction of the maximum air flow rate. The reheat coil operates only when the damper is at this minimum flow rate when Damper Heating Action is set to Normal (the default). This field is used if the previous field is set to Scheduled. If the previous field is left blank (and the field Maximum Hot Water or Steam Flow Rate is set to autosize), then the air flow rate usedfor sizing normal-action reheat coils is the average of the minimum and maximum values in this schedule. The air flow rate used for reheat coil sizing is reported with other component sizing information as ``Reheat Coil Sizing Air Volume Flow Rate.''
+The name of a schedule that determines the value of the minimum air flow fraction. The schedule should contain fractions from 0.0 to 1.0. These values will define the minimum flow rate to the zone while the system is operating, specified as a fraction of the maximum air flow rate. The reheat coil operates only when the damper is at this minimum flow rate when Damper Heating Action is set to Normal (the default). This field is used if the previous field is set to Scheduled. If the previous field is left blank (and the field Maximum Hot Water or Steam Flow Rate is set to autosize), then the air flow rate used for sizing normal-action reheat coils is the average of the minimum and maximum values in this schedule. The air flow rate used for reheat coil sizing is reported with other component sizing information as ``Reheat Coil Sizing Air Volume Flow Rate.''
\paragraph{Field: Outdoor Air Method}\label{field-outdoor-air-method-8}
@@ -2338,7 +2327,7 @@ \subsubsection{Inputs}\label{inputs-2016-06-16-1620}
ParallelFromPlenum -- Parallel configuration with recirculation from the return plenum
\end{itemize}
-See descriptions of these configurations in the general description for this object, above. For all types, the secondary fan will run according to the Zone PIU Fan Schedule (see below) and any Night Cycle Control specified in the system which serves this terminal unit (see Template VAV System Name above). For Parallel PIU, there is an additional secondary fan control based on the primary air flow fraction (see Parallel Fan On Flow Fraction below). For recirculation from plenum, a Return Plenum Name must be specificed in this object or in the system object (\hyperref[hvactemplatesystemvav]{HVACTemplate:System:VAV} or \hyperref[hvactemplatesystempackagedvav]{HVACTemplate:System:PackagedVAV}) which serves this terminal unit. The default is Parallel.
+See descriptions of these configurations in the general description for this object, above. For all types, the secondary fan will run according to the Zone PIU Fan Schedule (see below) and any Night Cycle Control specified in the system which serves this terminal unit (see Template VAV System Name above). For Parallel PIU, there is an additional secondary fan control based on the primary air flow fraction (see Parallel Fan On Flow Fraction below). For recirculation from plenum, a Return Plenum Name must be specified in this object or in the system object (\hyperref[hvactemplatesystemvav]{HVACTemplate:System:VAV} or \hyperref[hvactemplatesystempackagedvav]{HVACTemplate:System:PackagedVAV}) which serves this terminal unit. The default is Parallel.
\paragraph{Field: Parallel Fan On Flow Fraction}\label{field-parallel-fan-on-flow-fraction}
@@ -3127,7 +3116,7 @@ \subsubsection{Inputs}\label{inputs-14-005}
\paragraph{Field: Resistive Defrost Heater Capacity}\label{field-resistive-defrost-heater-capacity-000}
-This numeric field defines the capacity of the resistive defrost heating element in Watts. This input field is used only when the selected defrost strategy is `resistive' (see input field ``Defrost Strategy'' above). The value for this input field must be greater than or equal to 0 and it is auotsizable. If this input field is left blank, the default is autosize.
+This numeric field defines the capacity of the resistive defrost heating element in Watts. This input field is used only when the selected defrost strategy is `resistive' (see input field ``Defrost Strategy'' above). The value for this input field must be greater than or equal to 0 and it is autosizable. If this input field is left blank, the default is autosize.
\paragraph{Field: Maximum Outdoor Dry-bulb Temperature for Defrost Operation}\label{field-maximum-outdoor-dry-bulb-temperature-for-defrost-operation-000}
@@ -3248,7 +3237,7 @@ \subsubsection{Inputs}\label{inputs-14-005}
\subsection{HVACTemplate:System:Unitary}\label{hvactemplatesystemunitary}
-This object simulates the system portion of a constant volume air handler with electric, gas, or hot water heating and optional direct-expansion (DX) cooling. This system may serve one or more \hyperref[hvactemplatezoneunitary]{HVACTemplate:Zone:Unitary} objects. If this system serves more than one zone, only one zone is specified as the control zone. Common names for this sytem type include packaged rooftop systems commonly seen in commercial buildings and split systems (furnace with air conditioner) commonly seen in residential buildings.
+This object simulates the system portion of a constant volume air handler with electric, gas, or hot water heating and optional direct-expansion (DX) cooling. This system may serve one or more \hyperref[hvactemplatezoneunitary]{HVACTemplate:Zone:Unitary} objects. If this system serves more than one zone, only one zone is specified as the control zone. Common names for this system type include packaged rooftop systems commonly seen in commercial buildings and split systems (furnace with air conditioner) commonly seen in residential buildings.
\subsubsection{Inputs}\label{inputs-15-005}
@@ -3611,7 +3600,7 @@ \subsubsection{Inputs}\label{inputs-15-005}
\subsection{HVACTemplate:System:UnitaryHeatPump:AirToAir}\label{hvactemplatesystemunitaryheatpumpairtoair}
-This object simulates the system portion of a constant volume air handler with a direct-expansion (DX) air-to-air heat pump and supplemental heating (electric, gas, or hot water). This system may serve one or more \hyperref[hvactemplatezoneunitary]{HVACTemplate:Zone:Unitary} objects. If this system serves more than one zone, only one zone is specified as the control zone. Common names for this sytem type include packaged rooftop heat pumps commonly seen in commercial buildings and split system heat pumps commonly seen in residential buildings.
+This object simulates the system portion of a constant volume air handler with a direct-expansion (DX) air-to-air heat pump and supplemental heating (electric, gas, or hot water). This system may serve one or more \hyperref[hvactemplatezoneunitary]{HVACTemplate:Zone:Unitary} objects. If this system serves more than one zone, only one zone is specified as the control zone. Common names for this system type include packaged rooftop heat pumps commonly seen in commercial buildings and split system heat pumps commonly seen in residential buildings.
\subsubsection{Inputs}\label{inputs-16-004}
@@ -4004,7 +3993,7 @@ \subsubsection{Inputs}\label{inputs-16-004}
\subsection{HVACTemplate:System:UnitarySystem}\label{hvactemplatesystemunitarysystem}
-This object simulates a unitary system with option cooling coil (air-cooled DX, water-cooled DX, and chilled water), options heating coil (gas, electric, hot water, air-to-air heat pump, and water-to-air heat pump) with cycling or continous fan controls. Often a single \hyperref[hvactemplatezoneunitary]{HVACTemplate:Zone:Unitary} object will be used with a single \hyperref[hvactemplatesystemunitary]{HVACTemplate:System:Unitary}System object to simulate single zone system. In addition, multiple \hyperref[hvactemplatezoneunitary]{HVACTemplate:Zone:Unitary} objects may reference the same \hyperref[hvactemplatesystemunitary]{HVACTemplate:System:Unitary}System object in a multiple zone version. For a multiple zone system, only one zone is specified as the control zone. The model can simulate chilled water or heat pump systems seen in commercial buildings and split systems commonly seen in residential buildings. \hyperref[hvactemplatesystemunitary]{HVACTemplate:System:Unitary}System is similar to \hyperref[hvactemplatesystemunitary]{HVACTemplate:System:Unitary} and \hyperref[hvactemplatesystemunitaryheatpumpairtoair]{HVACTemplate:System:UnitaryHeatPump:AirToAir}, but it offers more flexilbility by using the more general \hyperref[airloophvacunitarysystem]{AirLoopHVAC:UnitarySystem} object instead of the more specific unitary furnace and heat pump objects.
+This object simulates a unitary system with option cooling coil (air-cooled DX, water-cooled DX, and chilled water), options heating coil (gas, electric, hot water, air-to-air heat pump, and water-to-air heat pump) with cycling or continuous fan controls. Often a single \hyperref[hvactemplatezoneunitary]{HVACTemplate:Zone:Unitary} object will be used with a single \hyperref[hvactemplatesystemunitary]{HVACTemplate:System:Unitary}System object to simulate single zone system. In addition, multiple \hyperref[hvactemplatezoneunitary]{HVACTemplate:Zone:Unitary} objects may reference the same \hyperref[hvactemplatesystemunitary]{HVACTemplate:System:Unitary}System object in a multiple zone version. For a multiple zone system, only one zone is specified as the control zone. The model can simulate chilled water or heat pump systems seen in commercial buildings and split systems commonly seen in residential buildings. \hyperref[hvactemplatesystemunitary]{HVACTemplate:System:Unitary}System is similar to \hyperref[hvactemplatesystemunitary]{HVACTemplate:System:Unitary} and \hyperref[hvactemplatesystemunitaryheatpumpairtoair]{HVACTemplate:System:UnitaryHeatPump:AirToAir}, but it offers more flexibility by using the more general \hyperref[airloophvacunitarysystem]{AirLoopHVAC:UnitarySystem} object instead of the more specific unitary furnace and heat pump objects.
\subsubsection{Inputs}\label{inputs-2016-06-16-1621}
@@ -4111,7 +4100,7 @@ \subsubsection{Inputs}\label{inputs-2016-06-16-1621}
\paragraph{Field: Number of Speeds for Cooling}\label{field-number-of-speeds-for-cooling}
-This field defines the number of cooling speeds is a multi-speed cooling coil is specifiedl. The default is 1, and the maximum allowed is 10. This field only applies if Cooling Coil Type is MultiSpeedDX.
+This field defines the number of cooling speeds is a multi-speed cooling coil is specified. The default is 1, and the maximum allowed is 10. This field only applies if Cooling Coil Type is MultiSpeedDX.
\paragraph{Field: Cooling Coil Availability Schedule Name}\label{field-cooling-coil-availability-schedule-name-6}
@@ -4131,7 +4120,7 @@ \subsubsection{Inputs}\label{inputs-2016-06-16-1621}
For air-cooled DX coils the rated conditions are air entering the cooling coil at the maximum supply air flow rate at 26.7°C drybulb/19.4°C wetbulb with air entering the outdoor air-cooled condenser coil at 35°C drybulb.
-For water-cooled DX coilst the rated conditions are 26.7C (80F) entering air dry-bulb temperature, 19.4C (67F) entering air wet-bulb temperature, and 29.4C (85F) entering water temperature.
+For water-cooled DX coils the rated conditions are 26.7C (80F) entering air dry-bulb temperature, 19.4C (67F) entering air wet-bulb temperature, and 29.4C (85F) entering water temperature.
For two-speed DX coils, the low-speed SHR is assumed to be equal to this value. For two-stage DX coils, the stage 1 SHR is assumed to be equal to this value. For two-stage DX coil with humidity control, the humidity control mode SHR is assumed to be 0.9 times this value (for both stage 1 and stage 2).
@@ -5326,7 +5315,7 @@ \subsubsection{Inputs}\label{inputs-19-002}
\item
Warmest -- reset the cooling supply air temperature to the highest supply air temperature that will meet the cooling requirements of all the zones at the maximum supply air flow rate. The minimum setpoint allowed is the Cooling Coil Design Setpoint. The maximum setpoint allowed is defaulted to the greater of 18C or the Heating Coil Design Setpoint plus 1.0C. (Reference \hyperref[setpointmanagerwarmest]{SetpointManager:Warmest})
\item
- OutdoorAirTemperatureReset -- reset the cooling supply air temperature based on the following default rules. When the outdoor dry-bulb temperature (ODB) is at or below 15.6C the setpoint isthe Cooling Coil Design Setpoint plus 5.2C. When the ODB is at or above 26.7C the setpoint is the Cooling Coil Design Setpoint. In between, the setpoint is varied linearly. (Reference \hyperref[setpointmanageroutdoorairreset]{SetpointManager:OutdoorAirReset})
+ OutdoorAirTemperatureReset -- reset the cooling supply air temperature based on the following default rules. When the outdoor dry-bulb temperature (ODB) is at or below 15.6C the setpoint is the Cooling Coil Design Setpoint plus 5.2C. When the ODB is at or above 26.7C the setpoint is the Cooling Coil Design Setpoint. In between, the setpoint is varied linearly. (Reference \hyperref[setpointmanageroutdoorairreset]{SetpointManager:OutdoorAirReset})
\item
WarmestTemperatureFirst -- find the highest setpoint temperature that will satisfy all the zone cooling loads at minimum supply air flow rate. If this setpoint temperature is less than the Cooling Coil Design Setpoint, the setpoint temperature is set to the minimum, and the supply air flow rate is increased to meet the loads. This option is appropriate when modeling a single-zone VAV system. The maximum setpoint allowed is defaulted to the greater of 18C or the Heating Coil Design Setpoint plus 1.0C. (Reference \hyperref[setpointmanagerwarmesttemperatureflow]{SetpointManager:WarmestTemperatureFlow})
\end{itemize}
@@ -5341,7 +5330,7 @@ \subsubsection{Inputs}\label{inputs-19-002}
\item
None -- no reset, use the Heating Coil Setpoint Schedule or Heating Coil Design Setpoint.
\item
- OutdoorAirTemperatureReset -- reset the heating supply air temperature based on the following default rules. When the outdoor dry-bulb temperature (ODB) is at or below --6.7C the setpoint is the Heating Coil Design Setpoint. When the ODB is at or above 10.0C the setpoint isthe Heating Coil Design Setpoint minus 5.2C. In between, the setpoint is varied linearly. (Reference \hyperref[setpointmanageroutdoorairreset]{SetpointManager:OutdoorAirReset}).
+ OutdoorAirTemperatureReset -- reset the heating supply air temperature based on the following default rules. When the outdoor dry-bulb temperature (ODB) is at or below --6.7C the setpoint is the Heating Coil Design Setpoint. When the ODB is at or above 10.0C the setpoint is the Heating Coil Design Setpoint minus 5.2C. In between, the setpoint is varied linearly. (Reference \hyperref[setpointmanageroutdoorairreset]{SetpointManager:OutdoorAirReset}).
\end{itemize}
The default is \emph{None}.
@@ -5960,7 +5949,7 @@ \subsubsection{Inputs}\label{inputs-20-002}
ChilledWater, !- Cooling Coil Type
, !- Cooling Coil Availability Schedule Name
ControlZone, !- Cooling Coil Setpoint Control Type
- SPACE 1-1, !- Cooling Coil Conrol Zone
+ SPACE 1-1, !- Cooling Coil Control Zone
12.8, !- Cooling Coil Design Setpoint {C}
, !- Cooling Coil Setpoint Schedule Name
, !- Cooling Coil Setpoint at Outdoor Dry-Bulb Low {C}
@@ -5974,7 +5963,7 @@ \subsubsection{Inputs}\label{inputs-20-002}
50, !- Heating Coil Design Setpoint {C}
, !- Heating Coil Setpoint Schedule Name
, !- Heating Coil Setpoint at Outdoor Dry-Bulb Low {C}
- , !- Hedating Coil Reset Outdoor Dry-Bulb Low {C}
+ , !- Heating Coil Reset Outdoor Dry-Bulb Low {C}
, !- Heating Coil Setpoint at Outdoor Dry-Bulb High {C}
, !- Heating Coil Reset Outdoor Dry-Bulb High {C}
Autosize, !- Heating Coil Capacity {W}
@@ -6650,7 +6639,7 @@ \subsubsection{Inputs}\label{inputs-21-002}
50, !- Heating Coil Design Setpoint {C}
, !- Heating Coil Setpoint Schedule Name
, !- Heating Coil Setpoint at Outdoor Dry-Bulb Low {C}
- , !- Hedating Coil Reset Outdoor Dry-Bulb Low {C}
+ , !- Heating Coil Reset Outdoor Dry-Bulb Low {C}
, !- Heating Coil Setpoint at Outdoor Dry-Bulb High {C}
, !- Heating Coil Reset Outdoor Dry-Bulb High {C}
Autosize, !- Heating Coil Capacity {W}
diff --git a/doc/input-output-reference/src/input-for-output.tex b/doc/input-output-reference/src/input-for-output.tex
index 1b13eea4b66..3075c3b30ee 100644
--- a/doc/input-output-reference/src/input-for-output.tex
+++ b/doc/input-output-reference/src/input-for-output.tex
@@ -64,7 +64,7 @@ \subsubsection{Inputs}\label{inputs-040}
Output:Surfaces:List, Lines;
\end{lstlisting}
-The above IDF line will produce a simple file of line segments that constitute the surfaces in the IDF file. This file is the~ ``lines'' report (\textbf{eplusout.sln}) and is decribed in more detail in the Output Details and Examples document.
+The above IDF line will produce a simple file of line segments that constitute the surfaces in the IDF file. This file is the~ ``lines'' report (\textbf{eplusout.sln}) and is described in more detail in the Output Details and Examples document.
\paragraph{Field: Report Specifications}\label{field-report-specifications}
@@ -348,7 +348,7 @@ \subsubsection{Inputs}\label{inputs-7-021}
\subsection{Output:Variable}\label{outputvariable}
-This input object is used request results reporting.~ As shown above in the Variable Dictionary Report section, there are many different output variables available for reporting results from EnergyPlus.~ The Output:Variable object is primarily used for reporting time series data at various frequencys.
+This input object is used request results reporting.~ As shown above in the Variable Dictionary Report section, there are many different output variables available for reporting results from EnergyPlus.~ The Output:Variable object is primarily used for reporting time series data at various frequencies.
Each Output:Variable object causes a specific number assignment for outputs. For example, you could request separate reporting for the outside temperature:
@@ -712,7 +712,7 @@ \subsubsection{Inputs}\label{inputs-10-017}
\paragraph{Field: Total Carbon Equivalent Emission Factor From N2O}\label{field-total-carbon-equivalent-emission-factor-from-n2o}
-The Intergovernmental Panel on Climate Change has studied the effects on the relative radiative forcing effects of various greenhouse gases. This effect, called Global Warming Potential (GWP), is described in terms of the Carbon Equivalent of a particular greenhouse gase. N\(_{2}\)O (nitrous oxide) can be produced by some Fuel Types and has a default of carbon equivalent emission factor of 80.7272 kg C/kg N\(_{2}\)O.
+The Intergovernmental Panel on Climate Change has studied the effects on the relative radiative forcing effects of various greenhouse gases. This effect, called Global Warming Potential (GWP), is described in terms of the Carbon Equivalent of a particular greenhouse gas. N\(_{2}\)O (nitrous oxide) can be produced by some Fuel Types and has a default of carbon equivalent emission factor of 80.7272 kg C/kg N\(_{2}\)O.
\paragraph{Field: Total Carbon Equivalent Emission Factor From CH4}\label{field-total-carbon-equivalent-emission-factor-from-ch4}
@@ -806,7 +806,7 @@ \subsubsection{Inputs}\label{inputs-11-015}
\paragraph{Field: CO Emission Factor}\label{field-co-emission-factor}
-The environmental impact coefficient for the Fuel for calculating the mass of carbon monoxide (CO) released into the atmosphere. The units are grams per MegaJoule. Carbon monoxide is a colorless, odorless and poisonous gas produced by incomplete fossil fuel combustion. Carbon monoxide combines with the haemoglobin of human beings, reducing its oxygen carrying capacity, with effects harmful to human beings.
+The environmental impact coefficient for the Fuel for calculating the mass of carbon monoxide (CO) released into the atmosphere. The units are grams per MegaJoule. Carbon monoxide is a colorless, odorless and poisonous gas produced by incomplete fossil fuel combustion. Carbon monoxide combines with the hemoglobin of human beings, reducing its oxygen carrying capacity, with effects harmful to human beings.
\paragraph{Field: CO Emission Factor Schedule Name}\label{field-co-emission-factor-schedule-name}
@@ -894,7 +894,7 @@ \subsubsection{Inputs}\label{inputs-11-015}
\paragraph{Field: Pb Emission Factor}\label{field-pb-emission-factor}
-The Environmental impact coefficient for the Fuel for calculating the masss of lead (Pb) released into the atmosphere. The units are grams per MegaJoule. A heavy metal that is hazardous to health if breathed or swallowed. Its use in gasoline, paints, and plumbing compounds has been sharply restricted or eliminated by federal laws and regulations.
+The Environmental impact coefficient for the Fuel for calculating the mass of lead (Pb) released into the atmosphere. The units are grams per MegaJoule. A heavy metal that is hazardous to health if breathed or swallowed. Its use in gasoline, paints, and plumbing compounds has been sharply restricted or eliminated by federal laws and regulations.
\paragraph{Field: Pb Emission Factor Schedule Name}\label{field-pb-emission-factor-schedule-name}
@@ -1369,7 +1369,7 @@ \subsubsection{Outputs}\label{outputs-029}
\paragraph{Environmental Impact OtherFuel2 CO2 Emissions Mass {[}kg{]}}\label{environmental-impact-otherfuel2-co2-emissions-mass-kg}
-These outputs provide results for the carbon dioxide reelases associated with consumption of each type of fuel that might be used at the site.~ The units are kg.
+These outputs provide results for the carbon dioxide releases associated with consumption of each type of fuel that might be used at the site.~ The units are kg.
\paragraph{Environmental Impact Electricity CO Emissions Mass {[}kg{]}}\label{environmental-impact-electricity-co-emissions-mass-kg}
@@ -1479,7 +1479,7 @@ \subsubsection{Outputs}\label{outputs-029}
\paragraph{Environmental Impact OtherFuel2 SO2 Emissions Mass {[}kg{]}}\label{environmental-impact-otherfuel2-so2-emissions-mass-kg}
-These outputs provide results for the sulphur dioxide releases associated with consumption of each type of fuel that might be used at the site.~ The units are kg.
+These outputs provide results for the sulfur dioxide releases associated with consumption of each type of fuel that might be used at the site.~ The units are kg.
\paragraph{Environmental Impact Electricity PM Emissions Mass {[}kg{]}}\label{environmental-impact-electricity-pm-emissions-mass-kg}
diff --git a/doc/input-output-reference/src/overview/group-advanced-surface-concepts.tex b/doc/input-output-reference/src/overview/group-advanced-surface-concepts.tex
index c129227bab0..250aa6c2f6c 100644
--- a/doc/input-output-reference/src/overview/group-advanced-surface-concepts.tex
+++ b/doc/input-output-reference/src/overview/group-advanced-surface-concepts.tex
@@ -217,7 +217,7 @@ \subsection{SurfaceControl:MovableInsulation}\label{surfacecontrolmovableinsulat
TIM exterior layers can be used with the ConductionFiniteDifference (CondFD) solution algorithm. With this addition, TIM layers can be used in conjunction with wall layers that have phase change materials (PCM) included, or any other advanced capability of the CondFD algorithm such as variable conductivity. The input requirements are exactly the same as when used with the CTF algorithm. The Solution Algorithm needs to be changed to CondFD, and as with CTF, the ``SurfaceControl:MovableInsulation'' object must be completed to specify the insulated surface and the ``\hyperref[windowmaterialglazing]{WindowMaterial:Glazing}'' or ``\hyperref[windowmaterialglazingequivalentlayer]{WindowMaterial:Glazing:EquivalentLayer}'' object is needed to provide the TIM layer properties.
-Basically, the addition of movable insulation allows the user to schedule an extra amount of insulation on either the inside or outside surface of a wall (or both). The insulation must be a simple, homogenous material layer (linked to a material definition within the input data file). Note that EnergyPlus allows the exterior movable insulation layer to be transparent to short wavelength radiation (solar). In this case, incident solar is split between the plane between the movable insulation and the surface and the plane between the movable insulation and the surrounding air. This calculation is fairly basic and based on the solar transmittance of the insulation layer (material properties). Using transparent layers for exterior movable insulation allows solar energy to penetrate deeper into a construction where it can be stored for later use in the building (similar in concept to a Trombe Wall).
+Basically, the addition of movable insulation allows the user to schedule an extra amount of insulation on either the inside or outside surface of a wall (or both). The insulation must be a simple, homogeneous material layer (linked to a material definition within the input data file). Note that EnergyPlus allows the exterior movable insulation layer to be transparent to short wavelength radiation (solar). In this case, incident solar is split between the plane between the movable insulation and the surface and the plane between the movable insulation and the surrounding air. This calculation is fairly basic and based on the solar transmittance of the insulation layer (material properties). Using transparent layers for exterior movable insulation allows solar energy to penetrate deeper into a construction where it can be stored for later use in the building (similar in concept to a Trombe Wall).
\subsubsection{Field: Insulation Type}\label{field-insulation-type}
@@ -1485,11 +1485,11 @@ \subsubsection{Inputs}\label{inputs-6}
The SurfaceConvectionAlgorithm:UserCurve named in this field is used when the previous field is set to UserCurve.
-\paragraph{Field: Mixed Regime Buoyancy Opposing Flow on Walls Equation Source}\label{field-mixed-regime-buoyancy-oppossing-flow-on-walls-equation-source}
+\paragraph{Field: Mixed Regime Buoyancy Opposing Flow on Walls Equation Source}\label{field-mixed-regime-buoyancy-opposing-flow-on-walls-equation-source}
The key choice options include: BeausoleilMorrisonMixedOpposingWall, AlamdariHammondVerticalWall, FohannoPolidoriVerticalWall, ASHRAEVerticalWall, FisherPedersenCeilingDiffuserWalls, GoldsteinNovoselacCeilingDiffuserWalls, or UserCurve
-\paragraph{Field: Mixed Regime Buoyancy Opposing Flow on Walls Equation User Curve Name}\label{field-mixed-regime-buoyancy-oppossing-flow-on-walls-equation-user-curve-name}
+\paragraph{Field: Mixed Regime Buoyancy Opposing Flow on Walls Equation User Curve Name}\label{field-mixed-regime-buoyancy-opposing-flow-on-walls-equation-user-curve-name}
The SurfaceConvectionAlgorithm:UserCurve named in this field is used when the previous field is set to UserCurve
@@ -2058,7 +2058,7 @@ \subsubsection{Surface Inside Face Convection Classification Index}\label{surfac
\subsubsection{Surface Inside Face Convection Model Equation Index}\label{surface-inside-face-convection-model-equation-index}
-This variable reports the specific model equation used to calculate the inside face convection coefficient.~ This can vary when using the adaptive convection algorithm and so the result of that selection algorithm is reported here.~ The following table lists the models associated with specific interger codes reported here.~ The models correspond to key words used in input objects.
+This variable reports the specific model equation used to calculate the inside face convection coefficient.~ This can vary when using the adaptive convection algorithm and so the result of that selection algorithm is reported here.~ The following table lists the models associated with specific integer codes reported here.~ The models correspond to key words used in input objects.
\begin{longtable}[c]{@{}ll@{}}
\toprule
@@ -2091,7 +2091,7 @@ \subsubsection{Surface Inside Face Convection Model Equation Index}\label{surfac
217 & AwbiHattonHeatedFloor~~~~~~~~~~~~~~~~~~ \tabularnewline
218 & AwbiHattonHeatedWall~~~~~~~~~~~~~~~~~~~ \tabularnewline
219 & BeausoleilMorrisonMixedAssistingWall~~~ \tabularnewline
-220 & BeausoleilMorrisonMixedOppossingWall~~~ \tabularnewline
+220 & BeausoleilMorrisonMixedopposingWall~~~ \tabularnewline
221 & BeausoleilMorrisonMixedStableCeiling~~~ \tabularnewline
222 & BeausoleilMorrisonMixedUnstableCeiling~ \tabularnewline
223 & BeausoleilMorrisonMixedStableFloor~~~~~ \tabularnewline
@@ -2432,7 +2432,7 @@ \subsection{SurfaceProperty:IncidentSolarMultiplier}
\paragraph{Field: Incident Solar Multiplier}\label{field-shading-multiplier-IncidentSolarMultiplier}
A constant multiplier for the incident solar radiation. The value should be
-between 0 and 1 (both inclussive). If not specified, the default 1.0 will be
+between 0 and 1 (both inclusive). If not specified, the default 1.0 will be
used. If the Incident Solar Multiplier Schedule Name is defined, the product of
these two will be the final Incident Solar Multiplier. Otherwise, this constant
multiplier will be applied throughout the simulation.
@@ -2565,7 +2565,7 @@ \subsection{SurfaceProperty:SurroundingSurfaces}\label{surfacePropertySurroundin
The object also defines the sky and ground temperature and view factors to the external surface. The sum of all defined view factors should not exceed 1.0. If only sky view is defined in this object, the ground view factor to this surface will be 1.0 subtracted with the ground view factor and all other defined surface view factors. If only ground view is defined in this object, the sky view factor to this surface will be 1.0 subtracted with the sky view factor and all other defined surface view factors. If neither of the sky and ground view factors are explicitly declared here, the sum of the sky and ground view factor would be 1.0 subtracted with all other defined surface view factors and the proportion will be set as the same with the global setting.
-If ground surfaces view factors are defined in \textit{SurfaceProperty:GroundSurfaces} object, then this ground view factors overrides the gorund view factors specified in \textit{SurfaceProperty:SurroundingSurfaces} object. The sum of the sky view factors and the surrounding surfaces view factors defined in \textit{SurfaceProperty:SurroundingSurfaces} and the ground surfaces view factors defined in \textit{SurfaceProperty:GroundSurfaces} object should not exceed 1.0. The \textit{SurfaceProperty:GroundSurfaces} object allows specifying multiple ground surfaces viewed by an exterior surfaces.
+If ground surfaces view factors are defined in \textit{SurfaceProperty:GroundSurfaces} object, then this ground view factors overrides the ground view factors specified in \textit{SurfaceProperty:SurroundingSurfaces} object. The sum of the sky view factors and the surrounding surfaces view factors defined in \textit{SurfaceProperty:SurroundingSurfaces} and the ground surfaces view factors defined in \textit{SurfaceProperty:GroundSurfaces} object should not exceed 1.0. The \textit{SurfaceProperty:GroundSurfaces} object allows specifying multiple ground surfaces viewed by an exterior surfaces.
\subsubsection{Field: Name}\label{field-srd-surfs-name}
@@ -2624,9 +2624,9 @@ \subsubsection{Field: Surrounding Surface 1 Temperature Schedule Name}\label{fie
\subsection{SurfaceProperty:GroundSurfaces}\label{surfacePropertyGroundSurfaces}
-This object is used for calculating building exterior surfaces long-wave radation exchange with the ground and the calculation of solar radiation reflection from ground surfaces to a building exterior surface. A given exterior surface can view multiple ground surfaces with different surface properties and view factors. Thus, this object allows specifying multiple ground view factors, ground surfaces temperature, and ground surfaces refelectance properties viewed by a given exterior surface. View factors are assumed to be constant values. The ground surface temperature and ground surface reflectance are specified using schedule object. Ground surface view factors and ground surface temperature defined in this object overrides the ground surface view factor and ground temperature specified in \textit{SurfaceProperty:SurroundingSurfaces} object.
+This object is used for calculating building exterior surfaces long-wave radiation exchange with the ground and the calculation of solar radiation reflection from ground surfaces to a building exterior surface. A given exterior surface can view multiple ground surfaces with different surface properties and view factors. Thus, this object allows specifying multiple ground view factors, ground surfaces temperature, and ground surfaces reflectance properties viewed by a given exterior surface. View factors are assumed to be constant values. The ground surface temperature and ground surface reflectance are specified using schedule object. Ground surface view factors and ground surface temperature defined in this object overrides the ground surface view factor and ground temperature specified in \textit{SurfaceProperty:SurroundingSurfaces} object.
-The sum of all defined view factors that include the sky virew factor, the ground surfaces view factors and surrounding surfaces view factors seen by a given building exterior surface should be 1.0, or the sum of the ground view factors for a given exterior surface should not exceed 1 subtracted the sky view factor and the sum of view factors of all surrounding surfaces defined in \textit{SurfaceProperty:SurroundingSurfaces} object. If the ground view factor input field is blank in \textbf{SurfaceProperty:GroundSurfaces} object, the ground view factor to this surface will be 1.0 subtracted the sky view factor and all other defined surrounding surface view factors defined in \textit{SurfaceProperty:SurroundingSurfaces} object. If neither \textbf{SurfaceProperty:GroundSurfaces} object nor the \textbf{SurfaceProperty:SurroundingSurfaces} object is specified for an exterior surface, the default view factor specified in \textbf{BuildingSurface:Detailed} or \textbf{FenestrationSurface:Detailed} object is used.
+The sum of all defined view factors that include the sky view factor, the ground surfaces view factors and surrounding surfaces view factors seen by a given building exterior surface should be 1.0, or the sum of the ground view factors for a given exterior surface should not exceed 1 subtracted the sky view factor and the sum of view factors of all surrounding surfaces defined in \textit{SurfaceProperty:SurroundingSurfaces} object. If the ground view factor input field is blank in \textbf{SurfaceProperty:GroundSurfaces} object, the ground view factor to this surface will be 1.0 subtracted the sky view factor and all other defined surrounding surface view factors defined in \textit{SurfaceProperty:SurroundingSurfaces} object. If neither \textbf{SurfaceProperty:GroundSurfaces} object nor the \textbf{SurfaceProperty:SurroundingSurfaces} object is specified for an exterior surface, the default view factor specified in \textbf{BuildingSurface:Detailed} or \textbf{FenestrationSurface:Detailed} object is used.
\subsubsection{Field: Name}\label{field-gnd-surfs-name}
@@ -2646,11 +2646,11 @@ \subsubsection{Field: Ground Surface 1 Temperature Schedule Name}\label{field-gr
\subsubsection{Field: Ground Surface 1 Reflectance Schedule Name}\label{field-ground-surface-1-reflectance-schedule-name}
-This field is used to provide a schedule name of a ground surface reflectance. The ground surface reflectance is used to calculate ground surface reflected solar radition to a building exterior surface. If the field is left blank, the global reflectance object defined else where or default values will be used.
+This field is used to provide a schedule name of a ground surface reflectance. The ground surface reflectance is used to calculate ground surface reflected solar radiation to a building exterior surface. If the field is left blank, the global reflectance object defined else where or default values will be used.
-This object is extensible, so the last four fields can be repeated to define ground surface name, ground surface view factor, ground surface temperature, and ground surface reflectace sets.
+This object is extensible, so the last four fields can be repeated to define ground surface name, ground surface view factor, ground surface temperature, and ground surface reflectance sets.
-Ground surfaces solar reflectance values derived from satelite data for common ground surfaces obtained from Ground Albedo Measurements and Modeling (Bill Marion, 2018) are summerized in table below.
+Ground surfaces solar reflectance values derived from satellite data for common ground surfaces obtained from Ground Albedo Measurements and Modeling (Bill Marion, 2018) are summarized in table below.
\begin{longtable}[c]{p{1.0in}p{2.5in}p{2.5in}}
\toprule
@@ -2726,7 +2726,7 @@ \subsection{References}\label{references-gnd-srfs}
\subsection{SurfaceProperty:LocalEnvironment}\label{surfacePropertylocalEnvironment}
-The object links to an exterior surface object \textbf{BuildingSurface:Detailed} or an exterior fenestration object \textbf{FenestrationSurface:Detailed} and is used when there is a need to calculate surface level environmental data externally and import them into the simulation to override existing environmental data, including external solar shading fractions, local air velocity, temperature and humidity, and surrounding surface temperatures, sky view factor, ground surfaces view factors, ground surfaces temperature and ground surfaces refelectance. The object links to four optional objects including a schedule object declared by \textbf{Field: External Shading Fraction Schedule Name}, a \textbf{\hyperref[surfacePropertySurroundingSurfaces]{SurfaceProperty:SurroundingSurfaces}} object declared by \textbf{Field: Surrounding Surfaces Object Name}, an \textbf{\hyperref[outdoorairnode]{OutdoorAir:Node}} object declared by \textbf{Field: Outdoor Air Node Name}, and a \textbf{\hyperref[surfacePropertyGroundSurfaces]{SurfaceProperty:GroundSurfaces}} object declared by
+The object links to an exterior surface object \textbf{BuildingSurface:Detailed} or an exterior fenestration object \textbf{FenestrationSurface:Detailed} and is used when there is a need to calculate surface level environmental data externally and import them into the simulation to override existing environmental data, including external solar shading fractions, local air velocity, temperature and humidity, and surrounding surface temperatures, sky view factor, ground surfaces view factors, ground surfaces temperature and ground surfaces reflectance. The object links to four optional objects including a schedule object declared by \textbf{Field: External Shading Fraction Schedule Name}, a \textbf{\hyperref[surfacePropertySurroundingSurfaces]{SurfaceProperty:SurroundingSurfaces}} object declared by \textbf{Field: Surrounding Surfaces Object Name}, an \textbf{\hyperref[outdoorairnode]{OutdoorAir:Node}} object declared by \textbf{Field: Outdoor Air Node Name}, and a \textbf{\hyperref[surfacePropertyGroundSurfaces]{SurfaceProperty:GroundSurfaces}} object declared by
\textbf{Field: Ground Surfaces Object Name}. The object provides inputs to calculate shading, solar radiation, zone air balance, and surface exterior heat balance.
\subsubsection{Field: Name}\label{field-surf-localenv-name}
diff --git a/doc/input-output-reference/src/overview/group-air-distribution-equipment.tex b/doc/input-output-reference/src/overview/group-air-distribution-equipment.tex
index e1316969d68..819b98dd60f 100644
--- a/doc/input-output-reference/src/overview/group-air-distribution-equipment.tex
+++ b/doc/input-output-reference/src/overview/group-air-distribution-equipment.tex
@@ -270,7 +270,7 @@ \subsubsection{Inputs}\label{inputs-2-001}
\paragraph{Field: Maximum Flow Fraction During Reheat}\label{field-maximum-flow-fraction-during-reheat}
-This fraction is multiplied by the Maximum Air Flow Rate to determine the maximum volume flow rate (m\(^{3}\)/s) allowed during reheat operation (see detailed explanation above). This field is autosizeable and is defaulted to autosize. If autosizeable is selected or the field is blank, the value is set to 0.002032 m\(^{3}\)/s-m\(^{2}\) (0.4 cfm/ft\(^{2}\)) multiplied by the zone floor area divided by the Maximum Air Flow Rate. If this field and the previous field are entered, the greater of the two inputs is used. This field and the following field are only used if Damper Heating Action = ReverseWithLimits.
+This fraction is multiplied by the Maximum Air Flow Rate to determine the maximum volume flow rate (m\(^{3}\)/s) allowed during reheat operation (see detailed explanation above). This field is autosizable and is defaulted to autosize. If autosizable is selected or the field is blank, the value is set to 0.002032 m\(^{3}\)/s-m\(^{2}\) (0.4 cfm/ft\(^{2}\)) multiplied by the zone floor area divided by the Maximum Air Flow Rate. If this field and the previous field are entered, the greater of the two inputs is used. This field and the following field are only used if Damper Heating Action = ReverseWithLimits.
\paragraph{Field: Maximum Reheat Air Temperature}\label{field-maximum-reheat-air-temperature-1}
@@ -1306,7 +1306,7 @@ \subsubsection{Inputs}\label{inputs-9-000}
\paragraph{Field: Zone Mixer Name}\label{field-zone-mixer-name-2}
-The name of an zone mixer component (object: \hyperref[airloophvaczonemixer]{AirLoopHVAC:ZoneMixer}) which composes part of the terminal unit. Note that some of the zone mixer's inputs will duplicate some of the terminal units's inputs. One of the zone mixer inlet nodes should be the same as the supply air inlet node of the terminal unit; the other inlet node of the zone mixer should be the same as the cooling coil air outlet node. The outlet node of the zone mixer should be the same as the outlet node of the terminal unit.
+The name of an zone mixer component (object: \hyperref[airloophvaczonemixer]{AirLoopHVAC:ZoneMixer}) which composes part of the terminal unit. Note that some of the zone mixer's inputs will duplicate some of the terminal unit's inputs. One of the zone mixer inlet nodes should be the same as the supply air inlet node of the terminal unit; the other inlet node of the zone mixer should be the same as the cooling coil air outlet node. The outlet node of the zone mixer should be the same as the outlet node of the terminal unit.
An IDF example:
@@ -1640,7 +1640,7 @@ \subsubsection{Inputs}\label{inputs-11-000}
\paragraph{Field: Model Parameter a (a)}\label{field-model-parameter-a-a}
-This is ain the above equations. The default is 15.3
+This is in the above equations. The default is 15.3
\paragraph{Field: Model Parameter n1}\label{field-model-parameter-n1}
diff --git a/doc/input-output-reference/src/overview/group-air-distribution.tex b/doc/input-output-reference/src/overview/group-air-distribution.tex
index 4a4b45a4276..03109516dfd 100644
--- a/doc/input-output-reference/src/overview/group-air-distribution.tex
+++ b/doc/input-output-reference/src/overview/group-air-distribution.tex
@@ -417,7 +417,7 @@ \subsection{Systems Level Reporting}\label{systems-level-reporting}
\subsection{System Loads Outputs}\label{system-loads-outputs}
-In this category, the total system load is reported. Two aspects are reported here: Heating and Cooling. The following two variables report the heat energy that system components (including packaged equipment, fans, main coils, reheat coils, humidifiers, desiccant dehumidifiers, evaporative coolers and heat exchangers) add or remove from the air loop. Each variable within these grouping wil
+In this category, the total system load is reported. Two aspects are reported here: Heating and Cooling. The following two variables report the heat energy that system components (including packaged equipment, fans, main coils, reheat coils, humidifiers, desiccant dehumidifiers, evaporative coolers and heat exchangers) add or remove from the air loop.
\subsubsection{Air System Total Heating Energy}\label{air-system-total-heating-energy}
@@ -692,7 +692,7 @@ \subsubsection{Inputs}\label{inputs-2-002}
\paragraph{Field Set (Availability Manager Object Type, Name)}\label{field-set-availability-manager-object-type-name}
-Managers are listed by pairs of data items:~ \emph{Availability Manager Object Type} and \emph{Availability Manager Name}. The managers are simulated down the list and calculate a control status for use by the \hyperref[airloophvac]{AirLoopHVAC} or \hyperref[plantloop]{PlantLoop}. The priority of each manager used for a specific loop is based on the rules described above. Availability managers are not currently used for condenser loops. The availability managers, along with the \hyperref[airloophvac]{AirLoopHVAC} and \hyperref[plantloop]{PlantLoop} object, report the control status calculated each simulation timestep. These output variables can be used to prioritize the managers according to the required control strategy. Six managers are accomodated in the list by default. This object is extensible, so additional pairs of the next two fields may be added.
+Managers are listed by pairs of data items:~ \emph{Availability Manager Object Type} and \emph{Availability Manager Name}. The managers are simulated down the list and calculate a control status for use by the \hyperref[airloophvac]{AirLoopHVAC} or \hyperref[plantloop]{PlantLoop}. The priority of each manager used for a specific loop is based on the rules described above. Availability managers are not currently used for condenser loops. The availability managers, along with the \hyperref[airloophvac]{AirLoopHVAC} and \hyperref[plantloop]{PlantLoop} object, report the control status calculated each simulation timestep. These output variables can be used to prioritize the managers according to the required control strategy. Six managers are accommodated in the list by default. This object is extensible, so additional pairs of the next two fields may be added.
\paragraph{Field: Availability Manager \textless{}x\textgreater{} Object Type}\label{field-availability-manager-x-object-type}
diff --git a/doc/input-output-reference/src/overview/group-air-path.tex b/doc/input-output-reference/src/overview/group-air-path.tex
index 72baebedbd9..a72bc44f8db 100644
--- a/doc/input-output-reference/src/overview/group-air-path.tex
+++ b/doc/input-output-reference/src/overview/group-air-path.tex
@@ -421,9 +421,9 @@ \subsubsection{Inputs}
\subsection{AirLoopHVAC:DedicatedOutdoorAirSystem}\label{airloophvacdedicatedoutdoorairsystem}
-The AirLoopHVAC:DedicatedOutdoorAirSystem is a central dedicated outdoor air system (DOAS) and deliveres outdoor air to multiple \hyperref[airloophvac]{AirLoopHVAC} systems. The amount of delivered outdoor air is based on a sum of outdoor air flow rates from outdoor air stream nodes defined in the \hyperref[outdoorairmixer]{OutdoorAir:Mixer}. These OutdoorAir:Mixer objects are a component of served multiple AirLoopHVAC systems. The central DOAS system also pretreates outdoor air before outdoor air distribution into multiple AirLoopHVAC, with given precool and preheat air conditions.
+The AirLoopHVAC:DedicatedOutdoorAirSystem is a central dedicated outdoor air system (DOAS) and delivers outdoor air to multiple \hyperref[airloophvac]{AirLoopHVAC} systems. The amount of delivered outdoor air is based on a sum of outdoor air flow rates from outdoor air stream nodes defined in the \hyperref[outdoorairmixer]{OutdoorAir:Mixer}. These OutdoorAir:Mixer objects are a component of served multiple AirLoopHVAC systems. The central DOAS system also pretreats outdoor air before outdoor air distribution into multiple AirLoopHVAC, with given precool and preheat air conditions.
-After the object name, the object has four fields to provide the name of AirLoopHVAC:OutdoorAirSystem, system availability, and names of AirLoopHVAC:Mixer and AirLoopHVAC:Splitter. The AirLoopHVAC:OutdoorAirSystem lists a controller to perform controls, and coils and fans to pretreat outdoor air before delivery to served AirLoopHVAC. The Availability Schedule determines times when a system is operationa or shutdownl. The AirLoopHVAC:Mixer and AirLoopHVAC:Splitter provide connection into distribution and relief nodes, respectively.
+After the object name, the object has four fields to provide the name of AirLoopHVAC:OutdoorAirSystem, system availability, and names of AirLoopHVAC:Mixer and AirLoopHVAC:Splitter. The AirLoopHVAC:OutdoorAirSystem lists a controller to perform controls, and coils and fans to pretreat outdoor air before delivery to served AirLoopHVAC. The Availability Schedule determines times when a system is operational or shutdown. The AirLoopHVAC:Mixer and AirLoopHVAC:Splitter provide connection into distribution and relief nodes, respectively.
The next four fields requires inputs for pretreat air conditions, including precooling and preheating.
diff --git a/doc/input-output-reference/src/overview/group-airflow-network.tex b/doc/input-output-reference/src/overview/group-airflow-network.tex
index 84c01428de8..488041495a6 100644
--- a/doc/input-output-reference/src/overview/group-airflow-network.tex
+++ b/doc/input-output-reference/src/overview/group-airflow-network.tex
@@ -479,7 +479,7 @@ \subsubsection{Field: Indoor and Outdoor Temperature Difference Lower Limit For
See Figure~\ref{fig:modulation-of-venting-area-according-to}. This field applies only if Ventilation Control Mode = Temperature. This value may be from zero to less than \SI{100}{\celsius}, with the default being \SI{0}{\celsius}. The value for this field must be less than the value specified for the following field.
-\subsubsection{Field: Indoor and Outdoor Temperature Difference Upper Limit for Minimun Venting Open Factor}\label{field-indoor-and-outdoor-temperature-difference-upper-limit-for-minimun-venting-open-factor}
+\subsubsection{Field: Indoor and Outdoor Temperature Difference Upper Limit for Minimum Venting Open Factor}\label{field-indoor-and-outdoor-temperature-difference-upper-limit-for-minimum-venting-open-factor}
See Figure~\ref{fig:modulation-of-venting-area-according-to}. This field applies only if Ventilation Control Mode = Temperature. This value must be greater than \SI{0}{\celsius}, with the default being \SI{100}{\celsius}. The value for this field must be greater than the value specified for the previous field..
@@ -487,7 +487,7 @@ \subsubsection{Field: Indoor and Outdoor Enthalpy Difference Lower Limit For Max
See Figure~\ref{fig:modulation-of-venting-area-according-to-001}. This field applies only if Ventilation Control Mode = Enthalpy. This value may be from zero to less than 300,000 J/kg, with the default being 0 J/kg. The value for this field must be less than the value specified for the following field.
-\subsubsection{Field: Indoor and Outdoor Enthalpy Difference Upper Limit for Minimun Venting Open Factor}\label{field-indoor-and-outdoor-enthalpy-difference-upper-limit-for-minimun-venting-open-factor}
+\subsubsection{Field: Indoor and Outdoor Enthalpy Difference Upper Limit for Minimum Venting Open Factor}\label{field-indoor-and-outdoor-enthalpy-difference-upper-limit-for-minimum-venting-open-factor}
See Figure~\ref{fig:modulation-of-venting-area-according-to-001}. This field applies only if Ventilation Control Mode = Enthalpy. This value must be greater than zero, with the default being 300,000 J/kg. The value for this field must be greater than the value specified for the previous field.
@@ -648,7 +648,7 @@ \subsubsection{Field: External Node Name}\label{field-external-node-name}
object, this field is not used and a blank may be entered. If the surface is an
interior (i.e., interzone) surface, leave this field blank.
-When there is an input object of either \hyperref[ZonePropertylocalEnvironment]{ZoneProperty:LocalEnvironment} or \hyperref[surfacePropertylocalEnvironment]{SurfaceProperty:LocalEnvironment}, LocalEnvironment is enable, so that entered names of \hyperref[outdoorairnode]{OutdoorAir:Node} can be used as inputs for this field. More descrption of use can be found in OutdoorAir:Node.
+When there is an input object of either \hyperref[ZonePropertylocalEnvironment]{ZoneProperty:LocalEnvironment} or \hyperref[surfacePropertylocalEnvironment]{SurfaceProperty:LocalEnvironment}, LocalEnvironment is enable, so that entered names of \hyperref[outdoorairnode]{OutdoorAir:Node} can be used as inputs for this field. More description of use can be found in OutdoorAir:Node.
\subsubsection{Field: Window/Door Opening Factor, or Crack Factor}\label{field-windowdoor-opening-factor-or-crack-factor}
@@ -752,7 +752,7 @@ \subsubsection{Field: Indoor and Outdoor Temperature Difference Lower Limit For
See Figure~\ref{fig:modulation-of-venting-area-according-to}. This field applies only if Ventilation Control Mode = Temperature. This value may be from zero to less than 100°C, with the default being 0°C. The value for this field must be less than the value specified for the following field.
-\subsubsection{Field: Indoor and Outdoor Temperature Difference Upper Limit for Minimun Venting Open Factor}\label{field-indoor-and-outdoor-temperature-difference-upper-limit-for-minimun-venting-open-factor-1}
+\subsubsection{Field: Indoor and Outdoor Temperature Difference Upper Limit for Minimum Venting Open Factor}\label{field-indoor-and-outdoor-temperature-difference-upper-limit-for-minimum-venting-open-factor-1}
See Figure~\ref{fig:modulation-of-venting-area-according-to}. This field applies only if Ventilation Control Mode = Temperature. This value must be greater than 0°C, with the default being 100°C. The value for this field must be greater than the value specified for the previous field.
@@ -760,7 +760,7 @@ \subsubsection{Field: Indoor and Outdoor Enthalpy Difference Lower Limit For Max
See Figure~\ref{fig:modulation-of-venting-area-according-to-001}. This field applies only if Ventilation Control Mode = Enthalpy. This value may be from zero to less than 300,000 J/kg, with the default being 0 J/kg. The value for this field must be less than the value specified for the following field.
-\subsubsection{Field: Indoor and Outdoor Enthalpy Difference Upper Limit for Minimun Venting Open Factor}\label{field-indoor-and-outdoor-enthalpy-difference-upper-limit-for-minimun-venting-open-factor-1}
+\subsubsection{Field: Indoor and Outdoor Enthalpy Difference Upper Limit for Minimum Venting Open Factor}\label{field-indoor-and-outdoor-enthalpy-difference-upper-limit-for-minimum-venting-open-factor-1}
See Figure~\ref{fig:modulation-of-venting-area-according-to-001}. This field applies only if Ventilation Control Mode = Enthalpy. This value must be greater than zero, with the default being 300,000 J/kg. The value for this field must be greater than the value specified for the previous field.
@@ -856,7 +856,7 @@ \subsubsection{Inputs}\label{inputs-1-004}
\paragraph{Field: Name}\label{field-name-1-003}
-The name of this Reference Crack Conditons object. This name is referenced by an \hyperref[airflownetworkmultizonesurfacecrack]{AirflowNetwork:MultiZone:Surface:Crack} object.
+The name of this Reference Crack Conditions object. This name is referenced by an \hyperref[airflownetworkmultizonesurfacecrack]{AirflowNetwork:MultiZone:Surface:Crack} object.
\paragraph{Field: Reference Temperature}\label{field-reference-temperature}
@@ -1078,7 +1078,7 @@ \subsubsection{Inputs}\label{inputs-4-003}
Crack flow is assumed when the window or door is closed. In this case, the value of this field is the exponent, \emph{n}, in the crack air flow equation. The valid range for this exponent is 0.5 to 1.0, with the default value being 0.65. Mass Flow Rate = Air Mass Flow Coefficient (deltaP) Air Mass Flow Exponent.
-\paragraph{Field: Type of Rectanguler Large Vertical Opening (LVO)}\label{field-type-of-rectanguler-large-vertical-opening-lvo}
+\paragraph{Field: Type of Rectangular Large Vertical Opening (LVO)}\label{field-type-of-rectangular-large-vertical-opening-lvo}
This alpha field specifies the type of rectangular window or door. (Open windows or doors are also called Large Vertical Openings (LVOs). The choices for the opening type are \textbf{NonPivoted} (LVO Type 1) and \textbf{HorizontallyPivoted} (LVO Type 2) with the default being \textbf{NonPivoted}. The NonPivoted type represents a regular window or door. The HorizontallyPivoted type represents a window with a horizontal axis (i.e., a horizontally-pivoting window) and cannot be used for a door.
@@ -1733,7 +1733,7 @@ \subsection{AirflowNetwork:Distribution:DuctViewFactors}\label{airflownetworkdis
\paragraph{Field: Surface Emittance}\label{field-surface-emittance}
The air duct surface emittance factor in the range 0 to 1 based on the material properties (dimensionless).
-\paragraph{Field: Surface \textless{}\#\textgreater{} Name}\label{field-suface-1-name}
+\paragraph{Field: Surface \textless{}\#\textgreater{} Name}\label{field-surface-1-name}
This field specifies the name of the surface seen by the duct.
\paragraph{Field: View Factor \textless{}\#\textgreater{}}\label{field-surface-1-view-factor}
@@ -2069,7 +2069,7 @@ \subsubsection{Inputs}\label{inputs-15-001}
\paragraph{Field: Heat Transmittance Coefficient (U-Factor) for Duct Wall Construction}\label{field-heat-transmittance-coefficient-u-factor-from-duct-construction}
-This numeric field is defines the heat transmittance coefficient (U value, W/m\(^{2}\)-K) for the duct wall construction. Film coefficents are calculated automatically, unless directly specified below.
+This numeric field is defines the heat transmittance coefficient (U value, W/m\(^{2}\)-K) for the duct wall construction. Film coefficients are calculated automatically, unless directly specified below.
\paragraph{Field: Overall Moisture Transmittance Coefficient from Air to Air}\label{field-overall-moisture-transmittance-coefficient-from-air-to-air}
@@ -2077,11 +2077,11 @@ \subsubsection{Inputs}\label{inputs-15-001}
\paragraph{Field: Outside Convection Coefficient}\label{field-outside-convection-coefficent}
-This numeric field defines the outside convection coefficient (W/m\(^{2}\)-K). If the field is omitted, the film coeffient is calculated automatically as described in ASTM C1340.
+This numeric field defines the outside convection coefficient (W/m\(^{2}\)-K). If the field is omitted, the film coefficient is calculated automatically as described in ASTM C1340.
\paragraph{Field: Inside Convection Coefficient}\label{field-inside-convection-coefficent}
-This numeric field defines the inside convection coefficient (W/m\(^{2}\)-K). If the field is omitted, the film coeffient is calculated automatically as described in ASTM C1340.
+This numeric field defines the inside convection coefficient (W/m\(^{2}\)-K). If the field is omitted, the film coefficient is calculated automatically as described in ASTM C1340.
An IDF example is provided below:
@@ -2545,7 +2545,7 @@ \subsubsection{Inputs}\label{inputs-AFN-DuctSizing}
\paragraph{Field: Maximum Airflow Velocity}\label{maximum-airflow-velocity}
-This is an optional field to represent the maximum velopcity in trunk ducts with units m/s. The default value is 5 m/s. The value is used when the choice of Duct Sizing Method is either MaximumVelocity or PressureLossWithMaximumVelocity. The duct diameter is calculated at D = flow rate / Cross section area.
+This is an optional field to represent the maximum velocity in trunk ducts with units m/s. The default value is 5 m/s. The value is used when the choice of Duct Sizing Method is either MaximumVelocity or PressureLossWithMaximumVelocity. The duct diameter is calculated at D = flow rate / Cross section area.
\paragraph{Field: Total Pressure Loss Across Supply Truck}\label{total-pressure-loss-across-supply-truck}
diff --git a/doc/input-output-reference/src/overview/group-airflow.tex b/doc/input-output-reference/src/overview/group-airflow.tex
index c369fac0153..4ab70c6c1fb 100644
--- a/doc/input-output-reference/src/overview/group-airflow.tex
+++ b/doc/input-output-reference/src/overview/group-airflow.tex
@@ -1504,7 +1504,7 @@ \subsubsection{Outputs}\label{outputs-4-000}
\paragraph{Zone Mixing Latent Heat Gain Energy {[}J{]}}\label{zone-mixing-latent-heat-gain-energy-j-1}
-The latent heat transfer due tothe sum of mixing, cross-mixing, and refrigeration-door mixing in the host (receiving) zone is the sum of all the incoming air mass flow rates multiplied by the elapsed time, the heat of vaporization (calculated for the average conditions (temperature and humidity) between the ``source'' and ``receiving'' zones)and the humidity ratio differences between the host zone and corresponding source zones. If the heat transfer is negative, the heat transfer is considered to be a zone mixing latent heat loss. If the heat transfer is positive, the heat transfer is considered to be a zone mixing latent heat gain.
+The latent heat transfer due to the sum of mixing, cross-mixing, and refrigeration-door mixing in the host (receiving) zone is the sum of all the incoming air mass flow rates multiplied by the elapsed time, the heat of vaporization (calculated for the average conditions (temperature and humidity) between the ``source'' and ``receiving'' zones)and the humidity ratio differences between the host zone and corresponding source zones. If the heat transfer is negative, the heat transfer is considered to be a zone mixing latent heat loss. If the heat transfer is positive, the heat transfer is considered to be a zone mixing latent heat gain.
\paragraph{Zone Mixing Total Heat Loss Energy {[}J{]}}\label{zone-mixing-total-heat-loss-energy-j-1}
@@ -1752,11 +1752,40 @@ \subsubsection{Inputs}
This number is the ``D'' parameter in the above earth tube equation. It is part of the user specified modifying parameters that are a function of environmental factors. This parameter is modified by square of the speed of wind being experienced outside the building. The units for this parameter are s\(^{2}\)/m\(^{2}\).
+\paragraph{Field: Earth Tube Model Type}\label{field-earth-tube-model-type}
+
+This field determines which modeling technique will be used to assess the performance of the earth tube. The options are: Simple and Vertical. In the Simple modeling approach, the temperature of the soil at the earth tube is approximated by the undisturbed ground conditions. In the Vertical modeling approach, the temperature of the soil around the earth tube is modeled using a finite difference scheme to account for the impact of the earth tube on the surrounding soil conditions in a single direction (1-D). For more information on the model type, reference the Earth Tube section of the EnergyPlus Engineering Reference. This input is optional, and the default value is Simple.
+
+\paragraph{Field: Earth Tube Model Parameters}\label{field-earth-tube-model-parameters}
+
+This field refers to separate input syntax (see below) that is used for controlling parameters for the 1-D (Vertical) solution technique. This input field is ignored for the Simple model. If the user selects the Vertical solution and leaves this field blank, the default values for all of the parameters will be assumed.
+
+\paragraph{ZoneEarthtube:Parameters}\label{field-earth-tube-parameters}
+For the 1-D (Vertical) model, some additional optional parameters are available for the user to potentially control the solution space (number of nodes, distances) for the finite difference solution. These are described below.
+
+\paragraph{Field: Earth Tube Parameters Name}\label{field-earth-tube-parameters-name}
+This name is used as a reference in the main EarthTube input syntax. It is used to identify the parameters that the user desires to use to control what is being modeled and how detailed the model is.
+
+\paragraph{Field: Earth Tube Nodes Above}\label{field-earth-tube-nodes-above}
+This parameter sets the number of nodes above the earth tube, between the earth tube and the ground surface. It has a minimum of three nodes and a maximum of ten nodes. These limits were chosen to avoid the extremes of excessive execution times and overly simplified results. The default value for this parameter is 5 (nodes).
+
+\paragraph{Field: Earth Tube Nodes Below}\label{field-earth-tube-nodes-below}
+This parameter sets the number of nodes below the earth tube, between the earth tube and the deep ground boundary. It has a minimum of three nodes and a maximum of ten nodes. These limits were chosen to avoid the extremes of excessive execution times and overly simplified results. The default value for this parameter is 3 (nodes) or the minimum.
+
+\paragraph{Field: Earth Tube Dimensionless Boundary Above}\label{field-earth-tube-dimensionless-boundary-above}
+This parameter sets the dimensionless distance above the earth tube for the solution space. The maximum value is 1.0, and the minimum value is 0.25. When this parameter is set to 1.0, the upper boundary is set to be half of the diameter below the ground surface and the solution space thickness above the earth tube is the depth of the earth tube minus the earth tube diameter. This maximum distance (earth tube depth minus diameter) is multiplied by this parameter to constrain the solution space to less than the maximum (when the parameter is less than 1.0). The default value for this parameter is 1.0 (the maximum value).
+
+\paragraph{Field: Earth Tube Dimensionless Boundary Below}\label{field-earth-tube-dimensionless-boundary-below}
+This parameter sets the dimensionless distance below the earth tube for the solution space. The maximum value is 1.0, and the minimum value is 0.25. This parameter is interpretted in a similar fashion as the previous parameter where the depth of the solution space below the earth tube is determined by the maximum distance above the earth tube (earth tube depth minus radius). This allows the user to have different thickness for the modeled portion of the ground above and below the earth tube. The default value for this parameter is 0.25 (the minimum value).
+
+\paragraph{Field: Earth Tube Dimensionless Solution Space Width}\label{field-earth-tube-dimensionless-solution-space-width}
+This parameter sets the dimensionless width of the solution space horizontally as a function of the earth tube radius as defined in the main earth tube input syntax. The maximum value is 20.0, and the minimum value is 3.0. The default value for this parameter is 4.0 which means that the width of the solution space is four times the radius. In other words, this would include soil one radius length beyond the edges of the tube on either side of the earth tube.
+
An IDF example:
\begin{lstlisting}
-EARTHTUBE,
+ZoneEarthtube,
Zone 2, !- Zone Name
Simple EarthTube, !- Schedule Name
3.425198, !- Design Volume Flow Rate
@@ -1775,10 +1804,20 @@ \subsubsection{Inputs}
15.0, !- Average Soil Surface Temperature
5.6, !- Amplitude of Soil Surface Temperature
0.0, !- Phase Constant of Soil Surface Temperature
- 0.6060000 , !- Constant Term Flow Coef
+ 0.6060000, !- Constant Term Flow Coef
2.0199999E-02, !- Temp Term Flow Coef
5.9800001E-04, !- Velocity Term Flow Coef
- 0.0000000E+00; !- Velocity**2 Term Flow Coef
+ 0.0000000E+00, !- Velocity**2 Term Flow Coef
+ Vertical, !- Earth Tube Model Type
+ EarthTubeParams; !- Earth Tube Model Parameters
+
+ZoneEarthtube:Parameters,
+ EarthTubeParams, !- Earth Tube Model Parameters (Name)
+ 5, !- Nodes Above Earth Tube
+ 3, !- Nodes Below Earth Tube
+ 1.0, !- Earth Tube Dimensionless Boundary Above
+ 0.5, !- Earth Tube Dimensionless Boundary Below
+ 4.0; !- Earth Tube Dimensionless Solution Space Width
\end{lstlisting}
\subsubsection{Outputs}\label{zoneearthtube-outputs}
@@ -1820,6 +1859,14 @@ \subsubsection{Outputs}\label{zoneearthtube-outputs}
HVAC,Average,Earth Tube Inlet Wet Bulb Temperature {[}C{]}
\item
HVAC,Average,Earth Tube Inlet Humidity Ratio {[}kgWater/kgDryAir{]}
+\item
+ Zone,Average,Earth Tube Node Temperature {[}C{]}
+\item
+ Zone,Average,Earth Tube Undisturbed Ground Temperature {[}C{]}
+\item
+ Zone,Average,Earth Tube Upper Boundary Ground Temperature {[}C{]}
+\item
+ Zone,Average,Earth Tube Lower Boundary Ground Temperature {[}C{]}
\end{itemize}
\paragraph{Earth Tube Zone Sensible Cooling Energy {[}J{]}}\label{earth-tube-zone-sensible-cooling-energy-j}
@@ -1884,6 +1931,22 @@ \subsubsection{Outputs}\label{zoneearthtube-outputs}
This is the humidity ratio of the air entering the zone after passing through the earth tube {[}kgWater/kgDryAir{]}.
+\paragraph{Earth Tube Node Temperature {[}C{]}}\label{earth-tube-node-temperatures-c}
+
+This will generate the internal node temperatures {[}C{]} for the earth tube as a result of the 1-D finite difference model. This is only valid for the 1-D (Vertical) model.
+
+\paragraph{Earth Tube Undisturbed Ground Temperature {[}C{]}}\label{earth-tube-undisturbed-node-temperatures-c}
+
+This will report the theoretical undisturbed ground temperature at the location of the internal node temperatures {[}C{]} as well as the average for the location of the earth tube for the 1-D finite difference model. This is only valid for the 1-D (Vertical) model and provides a comparison of conditions for the simple model and the 1-D (Vertical) model.
+
+\paragraph{Earth Tube Upper Boundary Ground Temperature {[}C{]}}\label{earth-tube-upper-boundary-temperature-c}
+
+This will report the theoretical undisturbed ground temperature at the upper boundary for the 1-D finite difference model. This is only valid for the 1-D (Vertical) model.
+
+\paragraph{Earth Tube Lower Boundary Ground Temperature {[}C{]}}\label{earth-tube-lower-boundary-temperature-c}
+
+This will report the theoretical undisturbed ground temperature at the lower boundary for the 1-D finite difference model. This is only valid for the 1-D (Vertical) model.
+
\subsection{ZoneCoolTower:Shower}\label{zonecooltowershower}
A cooltower (which is sometimes referred to as a wind tower or a shower cooling tower) is a component that is intended to model a passive downdraught evaporative cooling (PDEC) that is designed to capture the wind at the top of a tower and cool the outside air using water evaporation before delivering it to a space.~ The air flow in these systems is natural as the evaporation process increases the density of the air causing it to fall through the tower and into the space without the aid of a fan. ~A cooltower typically consists of a water spray or an evaporative pad, a shaft, and a water tank or reservoir. ~Wind catchers to improve the wind-driven performance at the top of the tower are optional. ~Water is pumped over an evaporative device by water pump which is the only component consumed power for this system.~ This water cools and humidifies incoming air and then the cool, dense air naturally falls down through shaft and leaves through large openings at the bottom of cooltowers.
@@ -2052,7 +2115,7 @@ \subsubsection{Outputs}\label{outputs-6-000}
\paragraph{Zone Cooltower Air Inlet Humidity Ratio {[}kgWater/kgDryAir{]}}\label{zone-cooltower-air-inlet-humidity-ratio-kgwaterkgdryair}
-~The humidity ratio of the outdoorair at the inlet of the cooltower
+~The humidity ratio of the outdoor air at the inlet of the cooltower
\paragraph{Zone Cooltower Air Outlet Temperature {[}C{]}}\label{zone-cooltower-air-outlet-temperature-c}
@@ -2220,7 +2283,7 @@ \subsection{ZoneAirMassFlowConservation}\label{zoneairmassflowconservation}
This global object allows users to trigger the zone air mass flow conservation calculation when desired. This object has three input fields; the first choice input field allows the user whether to adjust mixing flows, the return air flow, or a combination of mixing and return air flows to enforce the zone air mass flow conservation; and the other fields allows the user to specify how infiltration object mass flow rate is calculated for zone air mass flow balance calculation.~Currently supported options are: \textbf{AdjustMixingOnly}, \textbf{AdjustReturnOnly}, \textbf{AdjustMixingThenReturn}, \textbf{AdjustReturnThenMixing}, or \textbf{None}. If adjustments for either of mixing, return, or a combination of mixing and return or infiltration is specified then the zone air mass balance attempts to enforce conservation. If adjustment choice is None and infiltration adjustments are off, then the zone air mass flow calculation uses the default method which does not include zone mixing objects and assumes self-balanced simple infiltration. The default method may not necessarily enforce zone air mass flow conservation unless the user has specified a balanced flow to begin with. The zone air mass flow conservation primarily accounts for the zone mixing objects and return air flows in the zone air flow mass balance calculation. In addition to the zone mixing object and zone return air flows, the procedure accounts for zone supply, exhaust, and adjusts infiltration air flows (up or down) when required in order to balance the zone air mass flow.~ Mixing and infiltration adjustments will only be made in zones which have zone mixing or infiltration objects defined in the input. For example, if a zone does not have any infiltration objects, then no infiltration adjustment will be made for that zone.
-The zone mixing object and return flows adjusting options to enforce zone air mass flow conseravtion are defined as follows. \textbf{AdjustMixingOnly} adjusts the zone mixing object flow only to enforce zone air mass flow balance. \textbf{AdjustReturnOnly} adjusts the zone return air flow only to enforce zone air mass flow balance while the zone mixing object flow are kept at user specified values. \textbf{AdjustMixingThenReturn} adjusts the zone mixing object flow first, and followed with adjusting the return air flows to enforce zone air mass flow balance. \textbf{AdjustReturnThenMixing} adjusts the zone return air flow first, and followed with adjusting the zone mixing object flow to enforce zone air mass flow balance. \textbf{None} does not adjust either the zone mixing or the zone return air flow, and the zone air mass flow balance uses the default method.
+The zone mixing object and return flows adjusting options to enforce zone air mass flow conservation are defined as follows. \textbf{AdjustMixingOnly} adjusts the zone mixing object flow only to enforce zone air mass flow balance. \textbf{AdjustReturnOnly} adjusts the zone return air flow only to enforce zone air mass flow balance while the zone mixing object flow are kept at user specified values. \textbf{AdjustMixingThenReturn} adjusts the zone mixing object flow first, and followed with adjusting the return air flows to enforce zone air mass flow balance. \textbf{AdjustReturnThenMixing} adjusts the zone return air flow first, and followed with adjusting the zone mixing object flow to enforce zone air mass flow balance. \textbf{None} does not adjust either the zone mixing or the zone return air flow, and the zone air mass flow balance uses the default method.
First, depending user choice either the \hyperref[zonemixing]{ZoneMixing} object mass flow rate, the zone total return air flow rate, or a combination zone mixing and zone total return flow rates are adjusted or modified in order to balance zone air mass flow while assuming any zone infiltration objects are self-balanced.
diff --git a/doc/input-output-reference/src/overview/group-coil-cooling-dx.tex b/doc/input-output-reference/src/overview/group-coil-cooling-dx.tex
index 5b819eb1ae9..203b5be4df0 100644
--- a/doc/input-output-reference/src/overview/group-coil-cooling-dx.tex
+++ b/doc/input-output-reference/src/overview/group-coil-cooling-dx.tex
@@ -12,7 +12,7 @@ \subsection{Coil:Cooling:DX}\label{coilcoolingdx}
\item Coil:Cooling:DX:CurveFit:Speed - Defines DX cooling coil performance for a specific speed within a single operating mode.
\end{enumerate}
-Note: The Coil:Cooling:DX:CurveFit:Performance object also allows users to input 3 operating modes: Base Operating Mode, Alternative Operating Mode 1, and Alternative Operating Mode 2. When the Base Operating Mode is an only mode input, the coil performs like a regular cooling DX coil and no specific dehumidication capability. The alternative operating mode 1 is used for enhanced dehumidification. When all 3 modes are inputs, the coil performs as a subcool rehat coil. When load sensible heat ratio (SHR), defined as sensible cooling load / (sensible cooling load + latent cooling load), is greater than the SHR in the Base Operating Mode at given inlet air conditions, the coil performs in Base Operating Mode only. When the load SHR is less than the SHR in the Base Operating Mode and greater than the SHR in the Alternative Operating Mode 1 at the same given inlet air conditions, the coil performs combination of both Base Operating Mode, and Alternative Operating Mode 1. Mode ratio determines a fraction of time Alternative Operating Mode 1 operates and the rest (1 - Mode ratio) of time Base Operating Mode operates in a single time step. When the load SHR is less than the SHR in the Alternative Operating Mode 1 and greater than the SHR in the Alternative Operating Mode 2 at the same given inlet air conditions, the coil performs combination of both Base Operating Mode, and Alternative Operating Mode 2. Mode ratio determines a fraction of time Alternative Operating Mode 2 operates and (1 - Mode ratio) of time Base Operating Mode operates in a single time step. When the load SHR is greater than the SHR in the Alternative Operating Mode 2, the coil performs as Alternative Operating Mode 2 alone.
+Note: The Coil:Cooling:DX:CurveFit:Performance object also allows users to input 3 operating modes: Base Operating Mode, Alternative Operating Mode 1, and Alternative Operating Mode 2. When the Base Operating Mode is an only mode input, the coil performs like a regular cooling DX coil and no specific dehumidification capability. The alternative operating mode 1 is used for enhanced dehumidification. When all 3 modes are inputs, the coil performs as a subcool reheat coil. When load sensible heat ratio (SHR), defined as sensible cooling load / (sensible cooling load + latent cooling load), is greater than the SHR in the Base Operating Mode at given inlet air conditions, the coil performs in Base Operating Mode only. When the load SHR is less than the SHR in the Base Operating Mode and greater than the SHR in the Alternative Operating Mode 1 at the same given inlet air conditions, the coil performs combination of both Base Operating Mode, and Alternative Operating Mode 1. Mode ratio determines a fraction of time Alternative Operating Mode 1 operates and the rest (1 - Mode ratio) of time Base Operating Mode operates in a single time step. When the load SHR is less than the SHR in the Alternative Operating Mode 1 and greater than the SHR in the Alternative Operating Mode 2 at the same given inlet air conditions, the coil performs combination of both Base Operating Mode, and Alternative Operating Mode 2. Mode ratio determines a fraction of time Alternative Operating Mode 2 operates and (1 - Mode ratio) of time Base Operating Mode operates in a single time step. When the load SHR is greater than the SHR in the Alternative Operating Mode 2, the coil performs as Alternative Operating Mode 2 alone.
Figure~\ref{fig:diagram-of-coil-object-references} below represents the hierarchy how these four input objects reference each other. Arrows pointing from one object to another represents where one object has an input field that references the name of a different object. For example, an input field of the Coil:Cooling:DX object references the name of a Coil:Cooling:DX:CurveFit:Performance object. For this coil input structure, one Coil:Cooling:DX object can only reference one Coil:Cooling:DX:CurveFit:Performance object. However, one Coil:Cooling:DX:CurveFit:Performance object can reference multiple Coil:Cooling:DX:CurveFit:OperatingMode objects, and each Coil:Cooling:DX:CurveFit:OperatingMode object can reference multiple Coil:Cooling:DX:CurveFit:Speed objects. In the image below, the cooling coil has one single-speed operating mode and a second two-speed operating mode.
@@ -42,7 +42,7 @@ \subsubsection{Inputs}\label{inputs-01}
\paragraph{Field: Condenser Zone Name}\label{field-condenser-zone-name-6-001}
-The name of a conditioned or unconditioned zone where the secondary coil (condenser) of DX system or a heat pump is to be placed. This is an optional input field specified only when user desires to reject the condenser heat into a zone. The heat rejected is modelled as internal sensible heat gain of the zone.
+The name of a conditioned or unconditioned zone where the secondary coil (condenser) of DX system or a heat pump is to be placed. This is an optional input field specified only when user desires to reject the condenser heat into a zone. The heat rejected is modeled as internal sensible heat gain of the zone.
\paragraph{Field: Condenser Inlet Node Name}\label{field-condenser-inlet-node-name-6-001}
@@ -119,13 +119,13 @@ \subsubsection{Inputs}\label{inputs-02}
\paragraph{Field: Alternate Operating Mode 1}\label{field-alternate-operating-mode-1}
-The name corresponding to a Coil:Cooling:DX:CurveFit:OperatingMode object. Operating Mode is used as the alternate operating mode operating mode to be used for enhanced deumidification when needed. If field is blank, the base operating mode will be used. This field is optional.
+The name corresponding to a Coil:Cooling:DX:CurveFit:OperatingMode object. Operating Mode is used as the alternate operating mode operating mode to be used for enhanced dehumidification when needed. If field is blank, the base operating mode will be used. This field is optional.
\paragraph{Field: Alternate Operating Mode 1}\label{field-alternate-operating-mode-2}
The name corresponding to a Coil:Cooling:DX:CurveFit:OperatingMode object. Operating Mode is used as to represent a reheat mode as a subcool reheat coil. If field is blank, the base operating mode will be used. This field is optional.
-If there are 3 operating modes, it represents a subcool-reheat mode coil. The Operating Mode 1 represents a base operating mode coil. The Operating Mode 2 represents a subcool mode coil with lower SHR than the Operating Mode 1. The Operating Mode 3 represents a rehaet mode coil with lower SHR than the Operating Mode 2. All 3 operation modes work together to represent a subcool reheat coil model. The operation procedure is described in \ref{coilcoolingdx}
+If there are 3 operating modes, it represents a subcool-reheat mode coil. The Operating Mode 1 represents a base operating mode coil. The Operating Mode 2 represents a subcool mode coil with lower SHR than the Operating Mode 1. The Operating Mode 3 represents a reheat mode coil with lower SHR than the Operating Mode 2. All 3 operation modes work together to represent a subcool reheat coil model. The operation procedure is described in \ref{coilcoolingdx}
\subsection{Coil:Cooling:DX:CurveFit:OperatingMode}\label{coilcoolingdxcurvefitoperatingmode}
@@ -841,7 +841,7 @@ \subsubsection{Outputs}\label{outputs-01}
\paragraph{SubcoolReheat Cooling Coil Operation Mode Ratio {[]}}\label{subcoolreheat-cooling-coil-operation-mode-ratio}
-This output variable reports the ratio of time in a system timestep between normal mode and subcool mode when the operation mode = 2. The mode ratio represents how long the subcool mode runs as a fraction of the system timestep, and the normal mode runs in the rest of the system timestep. The output variable also reports the ratio of time in a system tiemstep between normal mode and reheat mode when the operation mode = 3. The value is 0.0 when the operation mode = 1.
+This output variable reports the ratio of time in a system timestep between normal mode and subcool mode when the operation mode = 2. The mode ratio represents how long the subcool mode runs as a fraction of the system timestep, and the normal mode runs in the rest of the system timestep. The output variable also reports the ratio of time in a system timestep between normal mode and reheat mode when the operation mode = 3. The value is 0.0 when the operation mode = 1.
\paragraph{SubcoolReheat Cooling Coil Recovered Heat Energy Rate {[}W{]}}\label{subcoolreheat-cooling-coil-recovered-heat-energy-rate-w}
@@ -849,5 +849,5 @@ \subsubsection{Outputs}\label{outputs-01}
\paragraph{SubcoolReheat Cooling Coil Recovered Heat Energy {[}J{]}}\label{subcoolreheat-cooling-coil-recovered-heat-energy-j}
-This output is the recovered heat energy rate output of the DX coil in Jouals. This is determined by energy use difference between normal mode and subcool or reheat mode, multiplied by the mode ratio.
+This output is the recovered heat energy rate output of the DX coil in Joules. This is determined by energy use difference between normal mode and subcool or reheat mode, multiplied by the mode ratio.
diff --git a/doc/input-output-reference/src/overview/group-condenser-equipment.tex b/doc/input-output-reference/src/overview/group-condenser-equipment.tex
index 0bf4e70b13d..07457dadedc 100644
--- a/doc/input-output-reference/src/overview/group-condenser-equipment.tex
+++ b/doc/input-output-reference/src/overview/group-condenser-equipment.tex
@@ -107,7 +107,7 @@ \subsubsection{Inputs}\label{inputs-007}
\paragraph{Field: Free Convection Capacity}\label{field-free-convection-capacity}
-This numeric input field contains the ``nominal'' heat rejection capacity of the cooling tower in watts when the tower is in the ``free convection'' regime (water flow exists but tower fan is turned off), with entering water at 35C (95F), leaving water at 29.4C (85F), entering air at 25.6C (78F) wetbulb and 35C (95F) drybulb temperatures. The design water flow rate is assumed to be 5.382E-8 m\(^{3}\)/s per watt of nominal tower capacity (input field above). The heat rejection capacity and nominal capacity sizing ratio is applied tof this free convection tower capacity to give the actual tower heat rejection at these operating conditions (typical value is 1.25 based on historical assumption that the tower must dissipate 0.25W of compressor heat for every watt of heat removed by the evaporator). The value specified for this field must be less than the value specified for the field ``Tower Nominal Capacity''. If the user does not wish to model ``free convection'', then this field should be set to 0.0. If the user specifies a value greater than zero, then the ``Air Flow Rate in Free Convection Regime'' field must contain a value greater than zero. This field can be automatically calculated using the sizing factor in the following field.
+This numeric input field contains the ``nominal'' heat rejection capacity of the cooling tower in watts when the tower is in the ``free convection'' regime (water flow exists but tower fan is turned off), with entering water at 35C (95F), leaving water at 29.4C (85F), entering air at 25.6C (78F) wetbulb and 35C (95F) drybulb temperatures. The design water flow rate is assumed to be 5.382E-8 m\(^{3}\)/s per watt of nominal tower capacity (input field above). The heat rejection capacity and nominal capacity sizing ratio is applied to this free convection tower capacity to give the actual tower heat rejection at these operating conditions (typical value is 1.25 based on historical assumption that the tower must dissipate 0.25W of compressor heat for every watt of heat removed by the evaporator). The value specified for this field must be less than the value specified for the field ``Tower Nominal Capacity''. If the user does not wish to model ``free convection'', then this field should be set to 0.0. If the user specifies a value greater than zero, then the ``Air Flow Rate in Free Convection Regime'' field must contain a value greater than zero. This field can be automatically calculated using the sizing factor in the following field.
\paragraph{Field: Free Convection Nominal Capacity Sizing Factor}\label{field-free-convection-nominal-capacity-sizing-factor}
@@ -488,7 +488,7 @@ \subsection{CoolingTower:TwoSpeed}\label{coolingtowertwospeed}
The model assumes that part-load operation is represented by a simple linear interpolation between two steady-state regimes (i.e., tower fan at high speed for the entire simulation timestep and tower fan at low speed for the entire simulation timestep, or tower fan at low speed for the entire simulation timestep and tower fan off for the entire simulation timestep). Cyclic losses are not taken into account.
-Cooling towers here are ``wet'' and consume water through evaporation, drift, and blowdown. The model can be used to predict water consumed by the towers. The last six input fields are optional and provide methods of controlling details of the water consumption calculations. The user can specifiy connections to the rest of the buildings water system by providing the name of a \hyperref[waterusestorage]{WaterUse:Storage} object.
+Cooling towers here are ``wet'' and consume water through evaporation, drift, and blowdown. The model can be used to predict water consumed by the towers. The last six input fields are optional and provide methods of controlling details of the water consumption calculations. The user can specify connections to the rest of the buildings water system by providing the name of a \hyperref[waterusestorage]{WaterUse:Storage} object.
For the operation of multi-cell towers, the first step is to determine the number of cells to operate based on the cell control method -- between the minimum number of cells subject to the maximum water flow rate fraction per cell, and maximum number of cells subject to the minimum water flow rate fraction per cell. If the calculated cells do not meet the loads, additional cells will be operating to help meet the loads. Inside each cell, the existing capacity controls still apply.
@@ -1131,7 +1131,7 @@ \subsubsection{Inputs}\label{inputs-2-006}
\paragraph{Field: U-Factor Times Area Modifier Function of Wetbulb Temperature Difference Curve Name}\label{field-u-factor-times-area-modifier-function-of-wetbulb-temperature-difference-curve-name}
-This alpha field contains the name of a curve or table object that describes how the UA value varies as a function of the current wetbulb temperature.~ The result of this curve is multiplied by the design UA value to adjust for wetbulb temperatures that differ from design conditions at 25.56°C (78°F), along with the two other modifiers discussed in the previous and following fields.~ The independe variable is the design wetbulb minus the current outdoor air wetbulb, in units of degrees Celsius.~ The curve or table object must be for one independent variable and should be normalized to 1.0 at a wetbulb temperature difference of 0.0.~ This field is required.
+This alpha field contains the name of a curve or table object that describes how the UA value varies as a function of the current wetbulb temperature.~ The result of this curve is multiplied by the design UA value to adjust for wetbulb temperatures that differ from design conditions at 25.56°C (78°F), along with the two other modifiers discussed in the previous and following fields.~ The independent variable is the design wetbulb minus the current outdoor air wetbulb, in units of degrees Celsius.~ The curve or table object must be for one independent variable and should be normalized to 1.0 at a wetbulb temperature difference of 0.0.~ This field is required.
\paragraph{Field: U-Factor Times Area Modifier Function of Water Flow Ratio Curve Name}\label{field-u-factor-times-area-modifier-function-of-water-flow-ratio-curve-name}
@@ -1482,7 +1482,7 @@ \subsection{CoolingTower:VariableSpeed}\label{coolingtowervariablespeed}
The cooling tower seeks to maintain the temperature of the water exiting the cooling tower at (or below) a set point. The set point schedule is defined by the field ``Condenser Loop Temperature Setpoint Node Name or Reference'' for the \hyperref[condenserloop]{CondenserLoop} object. The model first checks to determine the impact of ``free convection'' on the tower exiting water temperature. If the exiting water temperature based on ``free convection'' is at or below the set point, then the variable-speed tower fan is not turned on. If the exiting water temperature is above the set point after ``free convection'' is modeled, then the variable-speed tower fan is turned on to reduce the exiting water temperature. Tower fan power is calculated based on the tower air flow rate required to achieve the exiting water set point temperature.
-Cooling towers here are ``wet'' and consume water through evaporation, drift, and blowdown. The model can be used to predict water consumed by the towers. The last six input fields are optional and provide methods of controlling details of the water consumption calculations. The user can specifiy connections to the rest of the buildings water system by providing the name of a \hyperref[waterusestorage]{WaterUse:Storage} object.
+Cooling towers here are ``wet'' and consume water through evaporation, drift, and blowdown. The model can be used to predict water consumed by the towers. The last six input fields are optional and provide methods of controlling details of the water consumption calculations. The user can specify connections to the rest of the buildings water system by providing the name of a \hyperref[waterusestorage]{WaterUse:Storage} object.
For the operation of multi-cell towers, the first step is to determine the number of cells to operate based on the cell control method -- between the minimum number of cells subject to the maximum water flow rate fraction per cell, and maximum number of cells subject to the minimum water flow rate fraction per cell. If the calculated cells do not meet the loads, additional cells will be operating to help meet the loads. Inside each cell, the existing capacity controls still apply.
@@ -2891,7 +2891,7 @@ \subsubsection{Inputs}\label{inputs-9-003}
\paragraph{Field: Low Fan Speed Fan Power Sizing Factor}\label{field-low-fan-speed-fan-power-sizing-factor-2}
-This numeric field contains the sizing factor to use whe calculating the Low Fan Speed Fan Power.~ The default is 0.16.
+This numeric field contains the sizing factor to use when calculating the Low Fan Speed Fan Power.~ The default is 0.16.
\paragraph{Field: Outdoor Air Inlet Node Name}\label{field-outdoor-air-inlet-node-name-7}
@@ -2912,9 +2912,9 @@ \subsubsection{Inputs}\label{inputs-9-003}
58601., !- High Speed Nominal Capacity {W}
28601., !- Low Speed Nominal Capacity {W}
. 0.6, !- Low Speed Nominal Capacity Sizing Factor
- 51.67, !- Design Entering Water tempereture {C}
- 35, !- Design Entering Air tempereture {C}
- 25.6, !- Design Entering Air Wet-bulb tempereture {C}
+ 51.67, !- Design Entering Water temperature {C}
+ 35, !- Design Entering Air temperature {C}
+ 25.6, !- Design Entering Air Wet-bulb temperature {C}
0.001388, !- Design Water Flow Rate {m3/s}
9.911, !- High Fan Speed Air Flow Rate {m3/s}
autosize, !- High Fan Speed Fan Power {W}
@@ -3044,7 +3044,7 @@ \subsubsection{Inputs}\label{inputs-10-002}
\paragraph{Field: GHE:Vertical:Single names}
-The unique names of all single, vertical GLHE objects which are used to define and arbitrarily shaped GHE array. This field is exensible.
+The unique names of all single, vertical GLHE objects which are used to define and arbitrarily shaped GHE array. This field is extensible.
The following is are example inputs corresponding to the input variations allowed which were described previously. The first example uses the \hyperref[groundheatexchangerverticalarray]{GroundHeatExchanger:Vertical:Array} object. The g-functions will be generated automatically by EnergyPlus and cached for later use.
@@ -4113,8 +4113,8 @@ \subsubsection{Inputs}\label{inputs-15-002}
\begin{description}
\item [CrossFlowBothUnMixed] Specifies a single-pass, cross-flow heat exchanger. The effectiveness will be calculated using a cross-flow heat exchanger correlation for both streams unmixed.
\item [CrossFlowBothMixed] Specifies a single-pass, cross-flow heat exchanger. The effectiveness will be calculated using a cross-flow heat exchanger correlation for both streams mixed.
-\item [CrossFlowSupplyMixedDemandUnMixed] Specifes a single-pass, cross-flow heat exchanger. The effectiveness will be calculated using a cross-flow heat exchanger correlation for flow mixed on the Loop Supply side and flow unmixed on the Loop Demand Side.
-\item [CrossFlowSupplyUnMixedDemandMixed] Specifes a single-pass, cross-flow heat exchanger. The effectiveness will be calculated using a cross-flow heat exchanger correlation for flow unmixed on the Loop Supply side and flow mixed on the Loop Demand Side.
+\item [CrossFlowSupplyMixedDemandUnMixed] Specifies a single-pass, cross-flow heat exchanger. The effectiveness will be calculated using a cross-flow heat exchanger correlation for flow mixed on the Loop Supply side and flow unmixed on the Loop Demand Side.
+\item [CrossFlowSupplyUnMixedDemandMixed] Specifies a single-pass, cross-flow heat exchanger. The effectiveness will be calculated using a cross-flow heat exchanger correlation for flow unmixed on the Loop Supply side and flow mixed on the Loop Demand Side.
\item [CounterFlow] Specifies a counter-flow shell and tube heat exchanger (one fluid has the opposite direction to the other fluid). The effectiveness will be calculated using a counter-flow shell and tube heat exchanger correlation.
\item [ParallelFlow] Specifies a parallel-flow shell and tube heat exchanger (both fluids have the same direction). The effectiveness will be calculated using a parallel-flow shell and tube heat exchanger correlation.
\item [Ideal] Specifies an ideal heat exchanger. The effectiveness will be set to `1.0' and the specified UA will be ignored. The heat transfer rate will be calculated as the maximum possible heat transfer rate.
@@ -4152,7 +4152,7 @@ \subsubsection{Inputs}\label{inputs-15-002}
\item
\textbf{CoolingDifferentialOnOff}.~ This control mode is applicable to situations where the Loop Demand Side can provide useful cooling to the Loop Supply Side.~ This mode is similar to CoolingSetpointOnOff except that it ignores any cooling setpoint and its control is based only on the temperature difference between Loop Demand Side and the Loop Supply Side.~ The inlet temperatures must differ by more than the value set in the field called Minimum Temperature Difference to Activate Heat Exchanger for the heat exchanger to operate.~ ~This control mode corresponds to that available in the HeatExchanger:WatersideEconomizer object prior to version 8.0.
\item
- \textbf{CoolingSetpointOnOffWithComponentOverride}. This control mode is applicable to situations where the heat exchanger operation is integrated with the operation of a specific chiller. Typically the heat exchanger and chiller are in parallel on separate branches. When conditions are favorable for the heat exchanger to provide cooling to the Loop Supply Side, the heat exchanger is run and the integrated chiller is turned off. When conditions are not favorable, the heat exchanger is competely off and the chiller is allowed to run as usual. A cooling setpoint is obtained from a node named in the following field. If it runs it will run at full capacity and may undershoot the setpoint. The chiller that is integrated with the heat exchanger is identified by entering the names of the chiller's inlet nodes in the input fields below.~ The control decision can be based on one of three different temperature signals selected in the field below called Component Override Cooling Control Temperature Mode.~ The setpoint and control signal temperatures must differ by more than the value set in the field called Minimum Temperature Difference to Activate Heat Exchanger for the heat exchanger to operate. This control mode corresponds to that available in the HeatExchanger:Hydronic object prior to version 8.0.
+ \textbf{CoolingSetpointOnOffWithComponentOverride}. This control mode is applicable to situations where the heat exchanger operation is integrated with the operation of a specific chiller. Typically the heat exchanger and chiller are in parallel on separate branches. When conditions are favorable for the heat exchanger to provide cooling to the Loop Supply Side, the heat exchanger is run and the integrated chiller is turned off. When conditions are not favorable, the heat exchanger is completely off and the chiller is allowed to run as usual. A cooling setpoint is obtained from a node named in the following field. If it runs it will run at full capacity and may undershoot the setpoint. The chiller that is integrated with the heat exchanger is identified by entering the names of the chiller's inlet nodes in the input fields below.~ The control decision can be based on one of three different temperature signals selected in the field below called Component Override Cooling Control Temperature Mode.~ The setpoint and control signal temperatures must differ by more than the value set in the field called Minimum Temperature Difference to Activate Heat Exchanger for the heat exchanger to operate. This control mode corresponds to that available in the HeatExchanger:Hydronic object prior to version 8.0.
\end{itemize}
\paragraph{Field: Heat Exchanger Setpoint Node Name}\label{field-heat-exchanger-setpoint-node-name}
diff --git a/doc/input-output-reference/src/overview/group-controllers.tex b/doc/input-output-reference/src/overview/group-controllers.tex
index adcc7babe95..a3bebb76e9a 100644
--- a/doc/input-output-reference/src/overview/group-controllers.tex
+++ b/doc/input-output-reference/src/overview/group-controllers.tex
@@ -57,7 +57,7 @@ \subsubsection{Inputs}\label{inputs-008}
\begin{lstlisting}
Controller:WaterCoil,
- Central Cooling Coil Contoller 1, !- Name
+ Central Cooling Coil Controller 1, !- Name
TemperatureAndHumidityRatio, !- Control Variable
Reverse, !- Action
Flow, !- Actuator Variable
@@ -226,7 +226,7 @@ \subsubsection{Inputs}\label{inputs-1-007}
\paragraph{Field: Lockout Type}\label{field-lockout-type}
-Choices for this field are NoLockout, LockoutWithHeating, and LockoutWithCompressor. This field is used for packaged systems with DX coils. LockoutWithHeating means that if the packaged unit is in heating mode, the economizer is locked out i.e., the economizer dampers are closed and there is minimum outdoor air flow. LockoutWithCompressor means that in addition to locking out the economizer when the unit is in heating mode the economizer is locked out when the DX unit compressor is operating to provide cooling. In other words, the economizer must meet the entire cooling load; it is not allowed to operate in conjunction with the DX cooling coil. This option (LockoutWithCompressor) is sometimes called a nonintegrated economizer.
+Choices for this field are NoLockout, LockoutWithHeating, and LockoutWithCompressor. This field is used for packaged systems with DX coils. LockoutWithHeating means that if the packaged unit is in heating mode, the economizer is locked out i.e., the economizer dampers are closed and there is minimum outdoor air flow. LockoutWithCompressor means that in addition to locking out the economizer when the unit is in heating mode the economizer is locked out when the DX unit compressor is operating to provide cooling. In other words, the economizer must meet the entire cooling load; it is not allowed to operate in conjunction with the DX cooling coil. This option (LockoutWithCompressor) is sometimes called a non-integrated economizer.
When LockoutWithHeating or LockoutWithCompressor is selected, the lockout may also be applied to non-packaged systems for heating. If any air loop heating coil is operating, the lockout control compares the mixed air temperature at minimum outdoor air flow without heat recovery (if any) to the mixed air temperature set point. If the mixed air temperature at minimum outdoor air flow is less than the mixed air temperature set point, then the economizer is locked out and the outdoor air flow rate is set to the minimum. When the economizer is locked out, the heat recovery bypass control will be set to activate heat recovery (no bypass), if present. This action is meant to minimize heating energy (this action may also disable the heating coil on subsequent iterations, see output variable Air System Outdoor Air Heat Recovery Bypass Heating Coil Activity Status).
@@ -275,7 +275,7 @@ \subsubsection{Inputs}\label{inputs-1-007}
\paragraph{Field: High Humidity Control}\label{field-high-humidity-control}
-This choice field establishes whether or not the outdoor air flow rate is modified in response to high indoor relative humidity. Valid choices are Yes and No. If Yes is selected, the outdoor air flow rate may be modified when the indoor relative humidity is above the humidstat setpoint. If No is selected, this option is disabled and the following three fields are not used.
+This choice field establishes whether or not the outdoor air flow rate is modified in response to high indoor relative humidity. Valid choices are Yes and No. If Yes is selected, the outdoor air flow rate may be modified when the indoor relative humidity is above the humidistat setpoint. If No is selected, this option is disabled and the following three fields are not used.
\paragraph{Field: Humidistat Control Zone Name}\label{field-humidistat-control-zone-name}
@@ -287,7 +287,7 @@ \subsubsection{Inputs}\label{inputs-1-007}
\paragraph{Field: Control High Indoor Humidity Based on Outdoor Humidity Ratio}\label{field-control-high-indoor-humidity-based-on-outdoor-humidity-ratio}
-This choice field determines if high humidity control is activated based on high indoor relative humidity alone or is activated only when the indoor relative humidity is above the humidstat setpoint \emph{and} the indoor humidity ratio is greater than the outdoor humidity ratio. Valid choices are \textbf{Yes} and \textbf{No}. If No is selected, high humidity control is active any time the zone humidistat senses a moisture load. If Yes is selected, the model also verifies that the outdoor humidity ratio is less than the humidistat's zone air humidity ratio. This field is used only when the input field High Humidity Control is specified as Yes. The default value is \textbf{Yes}.
+This choice field determines if high humidity control is activated based on high indoor relative humidity alone or is activated only when the indoor relative humidity is above the humidistat setpoint \emph{and} the indoor humidity ratio is greater than the outdoor humidity ratio. Valid choices are \textbf{Yes} and \textbf{No}. If No is selected, high humidity control is active any time the zone humidistat senses a moisture load. If Yes is selected, the model also verifies that the outdoor humidity ratio is less than the humidistat's zone air humidity ratio. This field is used only when the input field High Humidity Control is specified as Yes. The default value is \textbf{Yes}.
\paragraph{Field: Heat Recovery Bypass Control Type}\label{field-heat-recovery-bypass-control-type}
@@ -386,7 +386,7 @@ \subsubsection{Outputs}\label{outputs-005}
\paragraph{Air System Outdoor Air Heat Recovery Bypass Minimum Outdoor Air Mixed Air Temperature {[}C{]}}\label{air-system-outdoor-air-heat-recovery-bypass-minimum-outdoor-air-mixed-air-temperature-c}
-Reports the outdoor air mixer's mixed air node temperature at minimum outdoor air flow rate when the heat exchanger is disabled (off). This temperature is calculated as the return air temperature multiplied by the return air mass flow rate plus the mixer's inlet node temperature multipled by the minimum outdoor air flow rate. This quantity is then divided by the mixed air mass flow rate. If this temperature is less than the outdoor air mixer's mixed air node set point temperature, and the Heat Recovery Bypass Control Type = BypassWhenOAFlowGreaterThanMinimum, the outdoor air flow rate is set to the minimum. This output variable is only available when using Heat Recovery Bypass Control Type = BypassWhenOAFlowGreaterThanMinimum.
+Reports the outdoor air mixer's mixed air node temperature at minimum outdoor air flow rate when the heat exchanger is disabled (off). This temperature is calculated as the return air temperature multiplied by the return air mass flow rate plus the mixer's inlet node temperature multiplied by the minimum outdoor air flow rate. This quantity is then divided by the mixed air mass flow rate. If this temperature is less than the outdoor air mixer's mixed air node set point temperature, and the Heat Recovery Bypass Control Type = BypassWhenOAFlowGreaterThanMinimum, the outdoor air flow rate is set to the minimum. This output variable is only available when using Heat Recovery Bypass Control Type = BypassWhenOAFlowGreaterThanMinimum.
\paragraph{Air System Outdoor Air High Humidity Control Status {[]}}\label{air-system-outdoor-air-high-humidity-control-status}
@@ -435,7 +435,7 @@ \subsubsection{Outputs}\label{outputs-005}
\paragraph{Air System Outdoor Air Maximum Flow Fraction {[]}}\label{air-system-outdoor-air-maximum-flow-fraction}
-Reports the average maximum limit of the outdoor air fraction for the outdoor air controller over the reporting interval. The maximum flow fraction is used to prevent DX cooling coils from freezing, specified by ASHRAE Stadard 90.1. This output variable is available when a corresponding SetpointManager:MixedAir object specifies optional inputs of Cooling Coil Inlet Node Name, Cooling coil Outlet Node Name, and Minimum Temperature at Cooling Coil Outlet Node.
+Reports the average maximum limit of the outdoor air fraction for the outdoor air controller over the reporting interval. The maximum flow fraction is used to prevent DX cooling coils from freezing, specified by ASHRAE Standard 90.1. This output variable is available when a corresponding SetpointManager:MixedAir object specifies optional inputs of Cooling Coil Inlet Node Name, Cooling coil Outlet Node Name, and Minimum Temperature at Cooling Coil Outlet Node.
\paragraph{Air System Outdoor Air Mechanical Ventilation Requested Mass Flow Rate {[}kg/s{]}}\label{air-system-mechvent-air-mass-flow-rate-kgs}
@@ -592,7 +592,7 @@ \subsubsection{Inputs}\label{inputs-3-006}
\paragraph{Field: High Humidity Control Flag}\label{field-high-humidity-control-flag}
-This optional choice field establishes whether or not the supply and exhaust air flow rates are modified in response to high indoor relative humidity. Valid choices are Yes and No. If Yes is selected, the supply and exhaust air flow rates may be modified when the indoor relative humidity is above the humidstat set point. If No is selected, this option is disabled and the following three fields are not used. Note that heat exchange between the air streams is suspended during times when high humidity control is active. The default value is No.
+This optional choice field establishes whether or not the supply and exhaust air flow rates are modified in response to high indoor relative humidity. Valid choices are Yes and No. If Yes is selected, the supply and exhaust air flow rates may be modified when the indoor relative humidity is above the humidistat set point. If No is selected, this option is disabled and the following three fields are not used. Note that heat exchange between the air streams is suspended during times when high humidity control is active. The default value is No.
\paragraph{Field: Humidistat Control Zone Name}\label{field-humidistat-control-zone-name-1}
@@ -604,7 +604,7 @@ \subsubsection{Inputs}\label{inputs-3-006}
\paragraph{Field: Control High Indoor Humidity based on Outdoor Humidity Ratio}\label{field-control-high-indoor-humidity-based-on-outdoor-humidity-ratio-1}
-This optional choice field determines if high humidity control is activated based on high indoor relative humidity alone or is activated only when the indoor relative humidity is above the humidstat set point \emph{and} the outdoor humidity ratio is less than the indoor humidity ratio. Valid choices are Yes and No. If No is selected, high humidity control is active any time the zone humidistat senses a moisture load. If yes is selected, the model also verifies that the outdoor humidity ratio is less than the humidistat's zone air humidity ratio. This field is used only when the High Humidity Control Flag is specified as Yes. The default value is Yes.
+This optional choice field determines if high humidity control is activated based on high indoor relative humidity alone or is activated only when the indoor relative humidity is above the humidistat set point \emph{and} the outdoor humidity ratio is less than the indoor humidity ratio. Valid choices are Yes and No. If No is selected, high humidity control is active any time the zone humidistat senses a moisture load. If yes is selected, the model also verifies that the outdoor humidity ratio is less than the humidistat's zone air humidity ratio. This field is used only when the High Humidity Control Flag is specified as Yes. The default value is Yes.
Following is an example input for this stand alone ERV controller object:
diff --git a/doc/input-output-reference/src/overview/group-daylighting.tex b/doc/input-output-reference/src/overview/group-daylighting.tex
index 43c25641a0e..340e6df8e8d 100644
--- a/doc/input-output-reference/src/overview/group-daylighting.tex
+++ b/doc/input-output-reference/src/overview/group-daylighting.tex
@@ -8,7 +8,7 @@ \section{Group -- Daylighting}\label{group-daylighting}
\subsection{Daylighting:Controls}\label{daylightingcontrols-000}
-When this object is used, daylighting illuminance levels are calculated and then used to determine how much the electric lighting can be reduced. The daylight illuminance level in a zone depends on many factors, including sky condition; sun position; calculation point; location, size, and glass transmittance of windows; window shading devices; and reflectance of interior surfaces. Reduction of electric lighting depends on daylight illuminance level, illuminance set point, fraction of zone controlled and type of lighting control. Two different methods of computing the daylighitng illuminance and subsequent lighting reduction called SplitFlux and DElight. After the object description below is are sections that describe the two methodologies in more detail.
+When this object is used, daylighting illuminance levels are calculated and then used to determine how much the electric lighting can be reduced. The daylight illuminance level in a zone depends on many factors, including sky condition; sun position; calculation point; location, size, and glass transmittance of windows; window shading devices; and reflectance of interior surfaces. Reduction of electric lighting depends on daylight illuminance level, illuminance set point, fraction of zone controlled and type of lighting control. Two different methods of computing the daylighting illuminance and subsequent lighting reduction called SplitFlux and DElight. After the object description below is are sections that describe the two methodologies in more detail.
\subsubsection{Inputs}\label{inputs-009}
diff --git a/doc/input-output-reference/src/overview/group-electric-load-center-generator.tex b/doc/input-output-reference/src/overview/group-electric-load-center-generator.tex
index d53e6a6a489..745b1b1333e 100644
--- a/doc/input-output-reference/src/overview/group-electric-load-center-generator.tex
+++ b/doc/input-output-reference/src/overview/group-electric-load-center-generator.tex
@@ -1,6 +1,6 @@
\section{Group -- Electric Load Center-Generator Specifications}\label{group-electric-load-center-generator-specifications}
-This group of input objects is related to electric power serving the facility. EnergyPlus has models for various types of electric generators and power conditioning devices that might be part of the electric power system serving the building being modeled. Buildings with simple utility electric power service will not necesarily need any of the models in this group. All EnergyPlus models that have any electric power consumption are assumed to have a straightforward connection to utility grid service and no extra input is needed. The models in this group of inputs are useful for facilities that more complex electric power service such as:
+This group of input objects is related to electric power serving the facility. EnergyPlus has models for various types of electric generators and power conditioning devices that might be part of the electric power system serving the building being modeled. Buildings with simple utility electric power service will not necessarily need any of the models in this group. All EnergyPlus models that have any electric power consumption are assumed to have a straightforward connection to utility grid service and no extra input is needed. The models in this group of inputs are useful for facilities that more complex electric power service such as:
\begin{itemize}
\tightlist
@@ -228,7 +228,7 @@ \subsubsection{Inputs}\label{inputs-1-012}
\paragraph{Field: Generator List Name}\label{field-generator-list-name}
-This alpha field contains the identifying name for the list of generators in the set defined in an \hyperref[electricloadcentergenerators]{ElectricLoadCenter:Generators} object. All the generators connected to this load center need to be of the same type in terms of all AC or all DC. Currently the only DC generators are photovoltaic panels, the others are all AC. A facility with both AC and DC generators will need to use seperate ElectricLoadCenter:Distribution objects. The generator list named here can only be associated with one load center. This field can be left blank if there are no generators.
+This alpha field contains the identifying name for the list of generators in the set defined in an \hyperref[electricloadcentergenerators]{ElectricLoadCenter:Generators} object. All the generators connected to this load center need to be of the same type in terms of all AC or all DC. Currently the only DC generators are photovoltaic panels, the others are all AC. A facility with both AC and DC generators will need to use separate ElectricLoadCenter:Distribution objects. The generator list named here can only be associated with one load center. This field can be left blank if there are no generators.
\paragraph{Field: Generator Operation Scheme Type}\label{field-generator-operation-scheme-type}
diff --git a/doc/input-output-reference/src/overview/group-energy-management-system-ems.tex b/doc/input-output-reference/src/overview/group-energy-management-system-ems.tex
index 2abe6501c73..5032c5146a8 100644
--- a/doc/input-output-reference/src/overview/group-energy-management-system-ems.tex
+++ b/doc/input-output-reference/src/overview/group-energy-management-system-ems.tex
@@ -114,7 +114,7 @@ \subsubsection{Inputs}\label{inputs-2-012}
\item
BeginNewEnvironment. This calling point occurs near the beginning of each environment period. Environment periods include sizing periods such as design days and run periods. This calling point will not be useful for control actions but is useful for initialization of Erl program variables and other one-time set up actions for EMS.
\item
- BeginZoneTimestepBeforeSetCurrentWeather. This calling point occurs near the beginning of each timestep during weather data setup. It is called from ``ManageWeather'' before ``SetCurrentWeather'' which sets the environment variables for a given timstep. ``SetCurrentWeather'' is where the Weather Data actuators may override certain environment variables. Note that this calling point is not active during sizing.
+ BeginZoneTimestepBeforeSetCurrentWeather. This calling point occurs near the beginning of each timestep during weather data setup. It is called from ``ManageWeather'' before ``SetCurrentWeather'' which sets the environment variables for a given timestep. ``SetCurrentWeather'' is where the Weather Data actuators may override certain environment variables. Note that this calling point is not active during sizing.
\item
AfterNewEnvironmentWarmUpIsComplete. This calling point occurs at the beginning of each environment period but after warm up days are complete. Warm up days are used to condition the transient aspects of the model with the first day before proceeding. This calling point will not be useful for control actions but is useful for re-initializing Erl programs with fresh values after warm up is complete. Programs called from this point might be used to reset counters or summed variables that would change during warmup.
\item
@@ -130,7 +130,7 @@ \subsubsection{Inputs}\label{inputs-2-012}
\item
AfterPredictorAfterHVACManagers. This calling point happens each timestep after predictor executes and after the SetpointManager and AvailabilityManager models are called. This calling point is useful for a variety of control actions. However, if there are conflicts, SetpointManager or AvailabilityManager actions may be overwritten by EMS control actions.
\item
- InsideHVACSystemIterationLoop. This calling point happens each HVAC iteration. The HVAC systems solvers iterate to convergence within each timestep and this calling point is inside this iteration loop. This calling point is useful for a variety of control actions. Being inside the interation loop, this calling point has the advantage that input data need not necessarily be lagged from prior timestep results and can, in some cases, improve the accuracy of controls. The disadvantage is that programs may run an excessive number of times slowing down the execution of the program.
+ InsideHVACSystemIterationLoop. This calling point happens each HVAC iteration. The HVAC systems solvers iterate to convergence within each timestep and this calling point is inside this iteration loop. This calling point is useful for a variety of control actions. Being inside the iteration loop, this calling point has the advantage that input data need not necessarily be lagged from prior timestep results and can, in some cases, improve the accuracy of controls. The disadvantage is that programs may run an excessive number of times slowing down the execution of the program.
\item
EndOfZoneTimestepBeforeZoneReporting. This calling point happens each zone timestep just before the output reports are updated for zone-timestep variables and meters. This calling point is useful for custom output variables with Zone frequency because they will be in sync with the rest of the zone output variables.
\item
@@ -142,7 +142,7 @@ \subsubsection{Inputs}\label{inputs-2-012}
\item
EndOfZoneSizing. This calling point happens once during each simulation and only if the run is set to do zone sizing. The calling point occurs just after the native zone sizing calculations are completed but before the sizing results are finalized. This calling point is useful for taking the intermediate results of zone sizing calculations and modifying them based on custom calculations.
\item
- EndOfSystemSizing. This calling pont happens once during each simulation and only if the run is set to do system sizing. The calling point occurs just after the native air system sizing calculations are completed but before the sizing results are finalized. This calling point is useful for taking the intermediate results of zone and system sizing calculations and modifying them based on custom calculations.
+ EndOfSystemSizing. This calling point happens once during each simulation and only if the run is set to do system sizing. The calling point occurs just after the native air system sizing calculations are completed but before the sizing results are finalized. This calling point is useful for taking the intermediate results of zone and system sizing calculations and modifying them based on custom calculations.
\item
AfterComponentInputReadIn. This calling point occurs early in the simulation when HVAC component s input data has been processed but before any component-level calculations for automatic sizing. This calling point occurs once for each of the types of HVAC components that have EMS actuators for autosize overrides. This calling point is not directly useful for control actions but is useful for overriding the results of sizing at the component level.
\item
@@ -367,7 +367,7 @@ \subsubsection{Inputs}\label{inputs-6-008}
CWcoil1_tot_cool_Power, !- EMS Variable Name
Averaged, !- Type of Data in Variable
SystemTimestep, !- Update Frequency
- MainCWCoil1_ModelOuput, !- EMS Program or Subroutine Name
+ MainCWCoil1_Modeloutput, !- EMS Program or Subroutine Name
W; !- Units
\end{lstlisting}
@@ -504,7 +504,7 @@ \subsubsection{Field: Units}\label{field-units-1}
Zone 1 WinAC Electricity Consumption, !- Name
Zone1WinAC_ElectEnergy, !- EMS Variable Name
SystemTimestep, !- Update Frequency
- Zone1_WinAC_ModelOuput, !- EMS Program or Subroutine Name
+ Zone1_WinAC_Modeloutput, !- EMS Program or Subroutine Name
Electricity, !- Resource Type
HVAC, !- Group Type
Cooling, !- End-Use Category
@@ -562,7 +562,7 @@ \subsubsection{Inputs}\label{inputs-8-006}
\paragraph{Field: Internal Data Type}\label{field-internal-data-type}
-This field defines the type of internal data source that is to be mapped to the EMS variable. The types of internal source data that can be used as internal variables are listed in the EIO output file whan an input file has any EMS-related objects.
+This field defines the type of internal data source that is to be mapped to the EMS variable. The types of internal source data that can be used as internal variables are listed in the EIO output file when an input file has any EMS-related objects.
An example of this object follows.
diff --git a/doc/input-output-reference/src/overview/group-evaporative-coolers.tex b/doc/input-output-reference/src/overview/group-evaporative-coolers.tex
index 4d08872cc71..f2c497b7372 100644
--- a/doc/input-output-reference/src/overview/group-evaporative-coolers.tex
+++ b/doc/input-output-reference/src/overview/group-evaporative-coolers.tex
@@ -103,7 +103,7 @@ \subsubsection{Outputs}
\paragraph{Evaporative Cooler Wet Bulb Effectiveness}\label{evaporative-cooler-wet-bulb-effectiveness}
-The effectivenss, or saturation efficiency, is the temperature change of the supply air divided by the difference between the inlet air dry-bulb and wet-bulb temperatures. In other words, it is a measure of the approach to the inlet air wet-bulb temperature.
+The effectiveness, or saturation efficiency, is the temperature change of the supply air divided by the difference between the inlet air dry-bulb and wet-bulb temperatures. In other words, it is a measure of the approach to the inlet air wet-bulb temperature.
\paragraph{Evaporative Cooler Electricity Rate {[}W{]}}\label{evaporative-cooler-electric-powerw}
@@ -125,11 +125,11 @@ \subsubsection{Outputs}
\paragraph{Evaporative Cooler Starved Water Volume {[}m3{]}}\label{evaporative-cooler-starved-water-volume-m3}
-This is the water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\paragraph{Evaporative Cooler Starved Mains Water Volume {[}m3{]}}\label{evaporative-cooler-starved-mains-water-volume-m3}
-This is the source (mains) of water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the source (mains) of water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\subsection{EvaporativeCooler:Direct:ResearchSpecial}\label{evaporativecoolerdirectresearchspecial}
@@ -282,11 +282,11 @@ \subsubsection{Outputs}\label{outputs-1-009}
\paragraph{Evaporative Cooler Starved Water Volume {[}m3{]}}\label{evaporative-cooler-starved-water-volume-m3-1}
-This is the water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\paragraph{Evaporative Cooler Starved Mains Water Volume {[}m3{]}}\label{evaporative-cooler-starved-mains-water-volume-m3-1}
-This is the source (mains) of water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the source (mains) of water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\subsection{EvaporativeCooler:Indirect:CelDekPad}\label{evaporativecoolerindirectceldekpad}
@@ -440,11 +440,11 @@ \subsubsection{Outputs}\label{outputs-2-008}
\paragraph{Evaporative Cooler Starved Water Volume {[}m3{]}}\label{evaporative-cooler-starved-water-volume-m3-2}
-This is the water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\paragraph{Evaporative Cooler Starved Mains Water Volume {[}m3{]}}\label{evaporative-cooler-starved-mains-water-volume-m3-2}
-This is the source (mains) of water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the source (mains) of water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\subsection{EvaporativeCooler:Indirect:WetCoil}\label{evaporativecoolerindirectwetcoil}
@@ -587,11 +587,11 @@ \subsubsection{Outputs}\label{outputs-3-006}
\paragraph{Evaporative Cooler Starved Water Volume {[}m3{]}}\label{evaporative-cooler-starved-water-volume-m3-3}
-This is the water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\paragraph{Evaporative Cooler Starved Mains Water Volume {[}m3{]}}\label{evaporative-cooler-starved-mains-water-volume-m3-3}
-This is the source (mains) of water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the source (mains) of water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\subsection{EvaporativeCooler:Indirect:ResearchSpecial}\label{evaporativecoolerindirectresearchspecial}
@@ -619,7 +619,7 @@ \subsubsection{Inputs}\label{inputs-4-011}
\paragraph{Field: Cooler Drybulb Design Effectiveness}\label{field-cooler-drybulb-design-effectiveness}
-This numeric field is the dry bulb design effectiveness of the evaporative cooler. This is the nominal design dry blub effectiveness with respect to the dry bulb temperature difference, i.e., dry operation at design air flow rates, and no water evaporation or spraying on the secondary side.
+This numeric field is the dry bulb design effectiveness of the evaporative cooler. This is the nominal design dry bulb effectiveness with respect to the dry bulb temperature difference, i.e., dry operation at design air flow rates, and no water evaporation or spraying on the secondary side.
\paragraph{Field Drybulb Effectiveness Flow Ratio Modifier Curve Name}\label{field-drybulb-effectiveness-flow-ratio-modifier-curve-name}
@@ -756,7 +756,7 @@ \subsubsection{Outputs}\label{outputs-4-004}
\item
HVAC,Average,Evaporative Cooler Dewpoint Bound Status
\item
- HVAC,Average,Evaporative Cooler Operating Mode Satus {[]}
+ HVAC,Average,Evaporative Cooler Operating Mode Status {[]}
\item
HVAC,Sum,Evaporative Cooler Electricity Energy {[}J{]}
\item
@@ -771,7 +771,7 @@ \subsubsection{Outputs}\label{outputs-4-004}
\paragraph{Evaporative Cooler Total Stage Effectiveness {[]}}\label{evaporative-cooler-total-stage-effectiveness-2}
-The Total Stage Efficiency is defined as the temperature change of the supply air divided by the difference between the primary air entering dry-bulb temperature and the secondary air enterig wet-bulb temperature for wet operating mode or the the difference between the primary air entering dry-bulb temperature and the secondary air enterig dry-bulb temperature for dry operating mode, including the effect of the reduction in flow because of the secondary air stream. In other words, it is a measure of the approach to the secondary air wet-bulb temperature for wet operating mode, or it is a measure of the approach to the secondary air entering dry-bulb temperature for dry operating mode.
+The Total Stage Efficiency is defined as the temperature change of the supply air divided by the difference between the primary air entering dry-bulb temperature and the secondary air entering wet-bulb temperature for wet operating mode or the the difference between the primary air entering dry-bulb temperature and the secondary air entering dry-bulb temperature for dry operating mode, including the effect of the reduction in flow because of the secondary air stream. In other words, it is a measure of the approach to the secondary air wet-bulb temperature for wet operating mode, or it is a measure of the approach to the secondary air entering dry-bulb temperature for dry operating mode.
\paragraph{Evaporative Cooler Operating Mode Status {[]}}\label{evaporative-cooler-operating-mode-status}
@@ -783,7 +783,7 @@ \subsubsection{Outputs}\label{outputs-4-004}
\paragraph{Evaporative Cooler Dewpoint Bound Status {[]}}\label{evaporative-cooler-dewpoint-bound-status}
-This output variable is a flag that indicates if the modeling was based on dewpoint effectivenss rather than wetbulb effectiveness The ResearchSpecial model is usually based on wet-bulb approach, but since values in excess of 1.0 are allowed, there is a secondary constraint imposed by dewpoint. If the dewpoint effectiveness was applied, then this flag variable will have the value 1.0, otherwise it is 0.0.
+This output variable is a flag that indicates if the modeling was based on dewpoint effectiveness rather than wetbulb effectiveness The ResearchSpecial model is usually based on wet-bulb approach, but since values in excess of 1.0 are allowed, there is a secondary constraint imposed by dewpoint. If the dewpoint effectiveness was applied, then this flag variable will have the value 1.0, otherwise it is 0.0.
\paragraph{Evaporative Cooler Electricity Rate {[}W{]}}\label{evaporative-cooler-electric-power-w-1}
@@ -805,8 +805,8 @@ \subsubsection{Outputs}\label{outputs-4-004}
\paragraph{Evaporative Cooler Starved Water Volume {[}m3{]}}\label{evaporative-cooler-starved-water-volume-m3-4}
-This is the water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
\paragraph{Evaporative Cooler Starved Mains Water Volume {[}m3{]}}\label{evaporative-cooler-starved-mains-water-volume-m3-4}
-This is the source (mains) of water consumed by the evaporative cooler that could not accually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
+This is the source (mains) of water consumed by the evaporative cooler that could not actually be met by the storage tank. This output variable appears when storage tank water is supplied to the cooler.
diff --git a/doc/input-output-reference/src/overview/group-fans.tex b/doc/input-output-reference/src/overview/group-fans.tex
index 408c609e190..0403256412a 100644
--- a/doc/input-output-reference/src/overview/group-fans.tex
+++ b/doc/input-output-reference/src/overview/group-fans.tex
@@ -1,6 +1,6 @@
\section{Group -- Fans}\label{group-fans}
-As of version 8.7, a new simple "\hyperref[fansystemmodel]{Fan:SystemModel}" input object was added that can be substitued for \hyperref[fanconstantvolume]{Fan:ConstantVolume}, \hyperref[fanonoff]{Fan:OnOff}, \hyperref[fanvariablevolume]{Fan:VariableVolume}, and \hyperref[fanperformancenightventilation]{FanPerformance:NightVentilation}. Users are encouraged to migrate their models to use this new Fan in the air loop or zone equipment because the original fan objects may be deprecated and eventually removed in the future.
+As of version 8.7, a new simple "\hyperref[fansystemmodel]{Fan:SystemModel}" input object was added that can be substituted for \hyperref[fanconstantvolume]{Fan:ConstantVolume}, \hyperref[fanonoff]{Fan:OnOff}, \hyperref[fanvariablevolume]{Fan:VariableVolume}, and \hyperref[fanperformancenightventilation]{FanPerformance:NightVentilation}. Users are encouraged to migrate their models to use this new Fan in the air loop or zone equipment because the original fan objects may be deprecated and eventually removed in the future.
The following fans may be defined either in the air loop or as a zone equipment component: \hyperref[fanconstantvolume]{Fan:ConstantVolume}, \hyperref[fanonoff]{Fan:OnOff}, \hyperref[fanvariablevolume]{Fan:VariableVolume}, \hyperref[fanzoneexhaust]{Fan:ZoneExhaust}, and \hyperref[fanperformancenightventilation]{FanPerformance:NightVentilation}. The data that are common to these fan types include an identifying name, an availability schedule name, a total efficiency rating, a rated pressure rise, and inlet and outlet air node names. In the case of a variable volume fan, additional input includes parameters for modeling fan performance over a range of fan speeds. See the engineering documentation for the variable speed fan for a further description of what these coefficients represent. Commonly-used values for different variable volume systems are shown in the following table.
@@ -80,7 +80,7 @@ \subsubsection{Inputs}\label{inputs-fansysmodel}
When PowerPerFlow is selected, the value entered in the input field called Electric Power Per Unit Flow Rate is used to size the Design Electric Power Consumption. This method is useful during early-phase design modeling when little information is available for determining the Design Pressure Rise. Although the pressure rise is not used to size the Design Electric Power Consumption it is still used to determine the heat added to the air stream as a result of the work done by the fan.
When PowerPerFlowPerPressure is selected, the value entered in the input field called Electric Power Per Unit Flow Rate Per Unit Pressure is used to size the power. This method takes into account the Design Pressure Rise when sizing the Design Electric Power Consumption.
-When TotalEfficiencyAndPressure is selected, the values entered in the input fields called Fan Total Efficiency and Design Pressure Rise are used to size the power. This is the legacy method used by the older fan objects prior to verson 8.6.
+When TotalEfficiencyAndPressure is selected, the values entered in the input fields called Fan Total Efficiency and Design Pressure Rise are used to size the power. This is the legacy method used by the older fan objects prior to version 8.6.
\paragraph{Field: Electric Power Per Unit Flow Rate}\label{field-power-per-unit-flow-fansysmodel}
diff --git a/doc/input-output-reference/src/overview/group-heat-recovery.tex b/doc/input-output-reference/src/overview/group-heat-recovery.tex
index 448b0bff94a..e260ced39fa 100644
--- a/doc/input-output-reference/src/overview/group-heat-recovery.tex
+++ b/doc/input-output-reference/src/overview/group-heat-recovery.tex
@@ -177,7 +177,7 @@ \subsubsection{Outputs}\label{outputs-014}
\paragraph{Heat Exchanger Electricity Energy {[}J{]}}\label{heat-exchanger-electric-energy-j}
-This output is the electric consumption of the unit in Joules for the timestep being reported. This ouput is also added to a meter with ResourceType = Electricity, EndUseKey = HeatRecovery, GroupKey = System (ref. Output:Meter objects).
+This output is the electric consumption of the unit in Joules for the timestep being reported. This output is also added to a meter with ResourceType = Electricity, EndUseKey = HeatRecovery, GroupKey = System (ref. Output:Meter objects).
\subsection{HeatExchanger:AirToAir:SensibleAndLatent}\label{heatexchangerairtoairsensibleandlatent}
@@ -513,7 +513,7 @@ \subsubsection{Outputs}\label{outputs-1-012}
\paragraph{Heat Exchanger Electricity Energy {[}J{]}}\label{heat-exchanger-electric-energy-j-1}
-This output is the electric consumption of the unit in Joules for the timestep being reported. This ouput is also added to a meter with ResourceType = Electricity, EndUseKey = HeatRecovery, GroupKey = System (ref. Output:Meter objects).
+This output is the electric consumption of the unit in Joules for the timestep being reported. This output is also added to a meter with ResourceType = Electricity, EndUseKey = HeatRecovery, GroupKey = System (ref. Output:Meter objects).
\paragraph{Heat Exchanger Sensible Effectiveness {[]}}\label{heat-exchanger-sensible-effectiveness}
@@ -691,7 +691,7 @@ \subsubsection{Outputs}\label{outputs-2-010}
\paragraph{Heat Exchanger Electricity Energy {[}J{]}}\label{heat-exchanger-electric-energy-j-2}
-This output is the electric consumption of the unit in Joules for the timestep being reported. This ouput is also added to a meter with ResourceType = Electricity, EndUseKey = HeatRecovery, GroupKey = System (ref. Output:Meter objects).
+This output is the electric consumption of the unit in Joules for the timestep being reported. This output is also added to a meter with ResourceType = Electricity, EndUseKey = HeatRecovery, GroupKey = System (ref. Output:Meter objects).
\subsection{HeatExchanger:Desiccant:BalancedFlow:PerformanceDataType1}\label{heatexchangerdesiccantbalancedflowperformancedatatype1}
diff --git a/doc/input-output-reference/src/overview/group-heating-and-cooling-coils.tex b/doc/input-output-reference/src/overview/group-heating-and-cooling-coils.tex
index 2633c4b35da..118f4eac117 100644
--- a/doc/input-output-reference/src/overview/group-heating-and-cooling-coils.tex
+++ b/doc/input-output-reference/src/overview/group-heating-and-cooling-coils.tex
@@ -10,7 +10,7 @@ \section{Group Heating and Cooling Coils}\label{group-heating-and-cooling-coils}
\subsection{Coil:Cooling:Water}\label{coilcoolingwater}
-The water cooling coil (Coil:Cooling:Water) has the ability to give detailed output with simplified inputs, inputting complicated coil geometry is not required by the user for this model instead the coil is sized in terms of auto-sizeable thermodynamic inputs. The coil requires thermodynamic inputs such as temperatures, mass flow rates and humidity ratios.
+The water cooling coil (Coil:Cooling:Water) has the ability to give detailed output with simplified inputs, inputting complicated coil geometry is not required by the user for this model instead the coil is sized in terms of auto-sizable thermodynamic inputs. The coil requires thermodynamic inputs such as temperatures, mass flow rates and humidity ratios.
The coil is sized using auto-sized/user design input conditions and the UA values are calculated from the design conditions. A rough estimate of the coil area is provided along with percentage of surface wet and/or dry. This model uses the NTU-effectiveness approach to model heat transfer and has two types of flow arrangements cross-flow or counter-flow.
@@ -531,11 +531,11 @@ \subsubsection{Water Side Economizer Mode}\label{water-side-economizer-mode}
\subsubsection{Wrap Around Water Coil Heat Recovery Mode}\label{wrap-around-water-coil-heat-recovery-mode}
-This coil system may also be used to model a wrap-around water coil heat recovery system where a water coil system object is in one air stream (e.g., the outdoor air stream) while another cooling coil object is in a seperate air stream (e.g., exhaust air stream). The two water coils are connected in series on the demand side of a plant loop where the CoilSystem:Cooling:Water object is upstream of the Coil:Cooling:Water object. For wrap-around heat recovery coils, the supply side of the plant will typically have only a pump to circulate the water.\par
+This coil system may also be used to model a wrap-around water coil heat recovery system where a water coil system object is in one air stream (e.g., the outdoor air stream) while another cooling coil object is in a separate air stream (e.g., exhaust air stream). The two water coils are connected in series on the demand side of a plant loop where the CoilSystem:Cooling:Water object is upstream of the Coil:Cooling:Water object. For wrap-around heat recovery coils, the supply side of the plant will typically have only a pump to circulate the water.\par
The CoilSystemCooling:Water object is the main controller for the heat recovery loop. Neither this object or other coils in the heat recovery loop require an external controller (Ref: \hyperref[controllerwatercoil]{Controller:WaterCoil}). Do not specify a controller for this object or the associated water coil elsewhere in the input. This object checks that the water coil entering water (fluid) temperature to coil entering air temperature absolute difference is greater than the user specified temperature offset, otherwise the system is disabled. The water loop temperature entering the coil system's coil will be maintained between the entering air temperatures of the water coils (e.g., midway between the outdoor air temperature and exhaust air temperature if the coils are used in the outdoor air system). The coil system will be disabled if the plant loop water temperature falls below the minimum allowed heat recovery loop water temperature (Ref. field \hyperref[field-minimum-water-loop-temperature-for-heat-recovery]{Minimum Water Loop Temperature For Heat Recover}). Figure~\ref{fig:wrap-around-water-coil-heat-recovery-system-in-outdoor-air-system} shows a wrap-around heat recovery coil system in the outdoor air and relief air streams of the outdoor air system.
-\textbf{Note - although a \hyperref[plantloop]{PlantLoop} temperature setpoint node name and associated set point manager is required, that set point will not be used.}
+\textbf{Note - although a \hyperref[plantloop]{PlantLoop} temperature setpoint node name and associated set point manager is required, that set point will not be used.}
\begin{figure}[hbtp] % fig 143
\centering
@@ -639,7 +639,7 @@ \subsubsection{Inputs}\label{inputs}
Yes, !- Run on Sensible Load
Yes, !- Run on Latent Load
3.0; !- Minimum Air To Water Temperature Offset
-
+
\end{lstlisting}
@@ -2048,13 +2048,13 @@ \subsection{Coil:Cooling:DX:SingleSpeed}\label{coilcoolingdxsinglespeed}
\item
The total cooling capacity modifier curve (function of temperature) is a curve with two independent variables: wet-bulb temperature of the air entering the cooling coil, and dry-bulb temperature of the air entering the air-cooled condenser coil (wet-bulb temperature if modeling an evaporative-cooled condenser). The curve is normalized to 1 at 19.44$^\circ$C indoor wet-bulb temperature and 35$^\circ$C outdoor dry-bulb temperature. The output of this curve is multiplied by the gross rated total cooling capacity to give the gross total cooling capacity at specific temperature operating conditions (i.e., at temperatures different from the rating point temperatures). This curve is typically a biquadratic but any curve or table with two independent variables can be used.
\item
- The total cooling capacity modifier curve (function of flow fraction) is a curve or lookup table with the independent variable being the ratio of the actual air flow rate across the cooling coil to the rated air flow rate (i.e., fraction of full load flow). The curve is normalized to have the value of 1.0 when the actual air flow rate equals the rated air flow rate. The output of this curve is multiplied by the gross rated total cooling capacity and the total cooling capacity modifier curve (function of temperature) to give the gross total cooling capacity at the specific temperature and air flow conditions at which the coil is operating. This curve is typically a quadratic or cubic but any curve or table with one independent variablecan be used.
+ The total cooling capacity modifier curve (function of flow fraction) is a curve or lookup table with the independent variable being the ratio of the actual air flow rate across the cooling coil to the rated air flow rate (i.e., fraction of full load flow). The curve is normalized to have the value of 1.0 when the actual air flow rate equals the rated air flow rate. The output of this curve is multiplied by the gross rated total cooling capacity and the total cooling capacity modifier curve (function of temperature) to give the gross total cooling capacity at the specific temperature and air flow conditions at which the coil is operating. This curve is typically a quadratic or cubic but any curve or table with one independent variable can be used.
\item
The energy input ratio (EIR) modifier curve (function of temperature) is a curve with two independent variables: wet-bulb temperature of the air entering the cooling coil, and dry-bulb temperature of the air entering the air-cooled condenser coil (wet-bulb temperature if modeling an evaporative-cooled condenser). The curve is normalized to 1 at 19.44$^\circ$C indoor wet-bulb temperature and 35$^\circ$C outdoor dry-bulb temperature. The output of this curve is multiplied by the rated EIR (inverse of the rated COP) to give the EIR at specific temperature operating conditions (i.e., at temperatures different from the rating point temperatures). This curve is typically a biquadratic but any curve or table with two independent variables can be used.
\item
- The energy input ratio (EIR) modifier curve (function of flow fraction) is a curve or lookup table with the independent variable being the ratio of the actual air flow rate across the cooling coil to the rated air flow rate (i.e., fraction of full load flow). The curve is normalized to have the value of 1.0 when the actual air flow rate equals the rated air flow rate. The output of this curve is multiplied by the rated EIR (inverse of the rated COP) and the EIR modifier curve (function of temperature) to give the EIR at the specific temperature and air flow conditions at which the coil is operating. This curve is typically a quadratic or cubic but any curve or table with one independent variablecan be used.
+ The energy input ratio (EIR) modifier curve (function of flow fraction) is a curve or lookup table with the independent variable being the ratio of the actual air flow rate across the cooling coil to the rated air flow rate (i.e., fraction of full load flow). The curve is normalized to have the value of 1.0 when the actual air flow rate equals the rated air flow rate. The output of this curve is multiplied by the rated EIR (inverse of the rated COP) and the EIR modifier curve (function of temperature) to give the EIR at the specific temperature and air flow conditions at which the coil is operating. This curve is typically a quadratic or cubic but any curve or table with one independent variable can be used.
\item
- The part load fraction correlation (function of part load ratio) is a curve or a lookup table with the independent variable being part load ratio (sensible cooling load / steady-state sensible cooling capacity). The output of this curve is used in combination with the rated EIR and EIR modifier curves to give the effective EIR for a given simulation timestep. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. The curve should be normalized to a value of 1.0 when the part-load ratio equals 1.0 (i.e., the compressor(s) run continuously for the simulation timestep). This curve is typically a quadratic or cubic but any curve or table with one independent variablecan be used.
+ The part load fraction correlation (function of part load ratio) is a curve or a lookup table with the independent variable being part load ratio (sensible cooling load / steady-state sensible cooling capacity). The output of this curve is used in combination with the rated EIR and EIR modifier curves to give the effective EIR for a given simulation timestep. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. The curve should be normalized to a value of 1.0 when the part-load ratio equals 1.0 (i.e., the compressor(s) run continuously for the simulation timestep). This curve is typically a quadratic or cubic but any curve or table with one independent variable can be used.
\end{enumerate}
The curves are simply specified by name. Curve inputs are described in the curve manager section of this document (see Performance Curves in this document).
@@ -2095,7 +2095,7 @@ \subsubsection{Inputs}\label{inputs-13-004}
\paragraph{Field: 2017 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: Standard Ratings using this field will be reported in the "2017 Standard Ratings for DX Coils" table
Note 2: two values are calculated for SEER: 'SEER User' is calculated using user-input PLF curve and cooling coefficient of degradation; 'SEER Standard' is calculated using AHRI Std 210/240-2017 default PLF curve and cooling coefficient of degradation.
Note 3: SEER User, SEER Standard, EER, and IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 210-240 (2017).
@@ -2103,7 +2103,7 @@ \subsubsection{Inputs}\label{inputs-13-004}
\paragraph{Field: 2023 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: Standard Ratings using this field will be reported in the "2023 Standard Ratings for DX Coils" table
Note 2: two values are calculated for SEER2. 'SEER2 User' is calculated using user-input PLF curve and cooling coefficient of degradation. 'SEER2 Standard' is calculated using AHRI Std 210/240-2023 default PLF curve and cooling coefficient of degradation.
Note 3: SEER2 User, SEER2 Standard, EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr - will be calculated according to ANSI/AHRI standard 210-240 (2023).
@@ -2135,7 +2135,7 @@ \subsubsection{Inputs}\label{inputs-13-004}
\paragraph{Field: Part Load Fraction Correlation Curve Name}\label{field-part-load-fraction-correlation-curve-name-2}
-This alpha field defines the name of a performance curve (Ref: Performance Curves) that parameterizes the variation of electrical power input to the DX unit as a function of the part load ratio (PLR, sensible cooling load/steady-state sensible cooling capacity). The product of the rated EIR and EIR modifier curves is divided by the output of this curve to give the effective EIR for a given simulation timestep. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. This curve is typically a quadratic or cubic but any curve or table with one independent variablecan be used.
+This alpha field defines the name of a performance curve (Ref: Performance Curves) that parameterizes the variation of electrical power input to the DX unit as a function of the part load ratio (PLR, sensible cooling load/steady-state sensible cooling capacity). The product of the rated EIR and EIR modifier curves is divided by the output of this curve to give the effective EIR for a given simulation timestep. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. This curve is typically a quadratic or cubic but any curve or table with one independent variable can be used.
The part load fraction correlation should be normalized to a value of 1.0 when the part load ratio equals 1.0 (i.e., no efficiency losses when the compressor(s) run continuously for the simulation timestep). For PLR values between 0 and 1 (0 \textless{}= PLR \textless{} 1), the following rules apply:
@@ -2326,7 +2326,7 @@ \subsubsection{Inputs}\label{inputs-14-004}
\paragraph{Field: High Speed 2017 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: Standard Ratings using this field will be reported in the "2017 Standard Ratings for DX Coils" table
Note 2: two values are calculated for SEER: 'SEER User' is calculated using user-input PLF curve and cooling coefficient of degradation; 'SEER Standard' is calculated using AHRI Std 210/240-2017 default PLF curve and cooling coefficient of degradation.
Note 3: SEER User, SEER Standard, EER, and IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 210-240 (2017).
@@ -2334,7 +2334,7 @@ \subsubsection{Inputs}\label{inputs-14-004}
\paragraph{Field: High Speed 2023 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: Standard Ratings using this field will be reported in the "2023 Standard Ratings for DX Coils" table
Note 2: two values are calculated for SEER2. 'SEER2 User' is calculated using user-input PLF curve and cooling coefficient of degradation. 'SEER2 Standard' is calculated using AHRI Std 210/240-2023 default PLF curve and cooling coefficient of degradation.
Note 3: SEER2 User, SEER2 Standard, EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr - will be calculated according to ANSI/AHRI standard 210-240 (2023).
@@ -2411,7 +2411,7 @@ \subsubsection{Inputs}\label{inputs-14-004}
\paragraph{Field: Low Speed 2017 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Single Speed DX Cooling Coil, Standard Ratings) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER and Standard Rating Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Single Speed DX Cooling Coil, Standard Ratings) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER and Standard Rating Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: two values are calculated for SEER. 'SEER User' is calculated using user-input PLF curve and cooling coefficient of degradation. 'SEER Standard' is calculated using AHRI Std 210/240-2017 default PLF curve and cooling coefficient of degradation.
Note 2: SEER2 and Standard Rating (Net) Cooling Capacity -- will only be reported for coils with cooling capacity less than 65,000 Btu/hr - according to ANSI/AHRI standard 210-240 (2013).
Note 3: EER and IEER with cooling capacities less than 65,000 Btu/hr will be calculated according to ANSI/AHRI standard 210-240 (2017).
@@ -2419,7 +2419,7 @@ \subsubsection{Inputs}\label{inputs-14-004}
\paragraph{Field: Low Speed 2023 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Single Speed DX Cooling Coil, Standard Ratings) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER and Standard Rating Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Single Speed DX Cooling Coil, Standard Ratings) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER and Standard Rating Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: two values are calculated for SEER. 'SEER User' is calculated using user-input PLF curve and cooling coefficient of degradation. 'SEER Standard' is calculated using AHRI Std 210/240-2023 default PLF curve and cooling coefficient of degradation.
Note 2: SEER2 and Standard Rating (Net) Cooling Capacity -- will only be reported for coils with cooling capacity less than 65,000 Btu/hr - according to ANSI/AHRI standard 210-240 (2023).
Note 3: EER and IEER with cooling capacities less than 65,000 Btu/hr will be calculated according to ANSI/AHRI standard 210-240 (2023).
@@ -2858,7 +2858,7 @@ \subsubsection{Inputs}\label{inputs-16-003}
\paragraph{Field: Speed \textless{}X\textgreater{} 2017 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: Standard Ratings using this field will be reported in the "2017 Standard Ratings for DX Coils" table
Note 2: two values are calculated for SEER: 'SEER User' is calculated using user-input PLF curve and cooling coefficient of degradation; 'SEER Standard' is calculated using AHRI Std 210/240-2017 default PLF curve and cooling coefficient of degradation.
Note 3: SEER User, SEER Standard, EER, and IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 210-240 (2017).
@@ -2866,7 +2866,7 @@ \subsubsection{Inputs}\label{inputs-16-003}
\paragraph{Field: Speed \textless{}X\textgreater{} 2023 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: Standard Ratings using this field will be reported in the "2023 Standard Ratings for DX Coils" table
Note 2: two values are calculated for SEER2. 'SEER2 User' is calculated using user-input PLF curve and cooling coefficient of degradation. 'SEER2 Standard' is calculated using AHRI Std 210/240-2023 default PLF curve and cooling coefficient of degradation.
Note 3: SEER2 User, SEER2 Standard, EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr - will be calculated according to ANSI/AHRI standard 210-240 (2023).
@@ -3065,7 +3065,7 @@ \subsubsection{Inputs}\label{inputs-16-003}
HPACCOOLEIRFT Speed 4, !- Speed 4 Energy Input Ratio Modifier Curve (temperature)
HPACCOOLEIRFF Speed 4, !- Speed 4 Energy Input Ratio Modifier Curve (flow fraction)
HPACCOOLPLFFPLR Speed 1, !- Speed 4 Part Load Fraction Correlation (part load ratio)
- 1000.0, !- Speed 4 ominal Time for Condensate Removal to Begin {s}
+ 1000.0, !- Speed 4 Nominal Time for Condensate Removal to Begin {s}
1.5, !- Speed 4 Ratio of Initial Moisture Evaporation Rate and Steady-state Capacity {dimensionless}
3.0, !- Speed 4 Maximum ON/OFF Cycling Rate {cycles/hr}
45.0, !- Speed 4 Latent Capacity Time Constant {s}
@@ -3329,6 +3329,30 @@ \subsubsection{Inputs}\label{inputs-17-001}
This numeric field defines ratio of the initial moisture evaporation rate from the cooling coil (when the compressor first turns off, in Watts) and the coil's steady-state latent capacity (Watts) at rated airflow and temperature conditions. Suggested value is 1.5; zero value means the latent degradation model is disabled. The default value for this field is zero.
+\paragraph{Field: Maximum Cycling Rate}\label{field-maximum-cycling-rate-vs}
+
+This numeric field contains the maximum on-off cycling rate for the compressor, which occurs at 50\% run time fraction. Suggested values are shown in Figure~\ref{fig:suggested-values-for-maximum-cycling-rate-vs}. (Henderson et al. 1999):
+
+\begin{figure}[htbp]
+\centering
+\includegraphics{media/image295.png}
+\caption{Suggested values for maximum cycling rate \protect \label{fig:suggested-values-for-maximum-cycling-rate-vs}}
+\end{figure}
+
+\paragraph{Field: Latent Capacity Time Constant}\label{field-heat-pump-time-constant-vs}
+
+This numeric field contains the time constant for the cooling coil's capacity to reach steady state after startup. Suggested values are shown in Figure~\ref{fig:suggested-values-for-heat-pump-time-constant-vs}. (Henderson et al. 1999):
+
+\begin{figure}[htbp]
+\centering
+\includegraphics{media/image296.png}
+\caption{Suggested values for latent capacity time constant \protect \label{fig:suggested-values-for-heat-pump-time-constant-vs}}
+\end{figure}
+
+\paragraph{Field: Fan Delay Time}\label{field-heat-pump-fan-delay-time-vs}
+
+This numeric field contains the time delay for the heat pump supply air fan to shut off after the compressor cycles off in seconds. This value can be obtained from the manufacturer or the heat pump catalog. Enter a value of zero when the heat pump's fan operating mode is continuous. Suggested value is 60 seconds.
+
\paragraph{Field: Part Load Fraction Correlation Curve Name}\label{field-part-load-fraction-correlation-curve-name-4}
This alpha field defines the name of a quadratic or cubic performance curve (Ref: Performance Curves) that parameterizes the variation of electrical power input to the unit as a function of the part load ratio (PLR, sensible or latent load/steady-state sensible or latent cooling capacity for Speed 1), in the case that the unit operates under the lowest speed, i.e.~on/off. The product of the rated EIR and EIR modifier curves is divided by the output of this curve to give the effective EIR for a given simulation timestep for Speed 1. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. The part load fraction correlation should be normalized to a value of 1.0 when the part load ratio equals 1.0 (i.e., no efficiency losses when the compressor(s) run continuously for the simulation timestep).
@@ -3401,7 +3425,7 @@ \subsubsection{Inputs}\label{inputs-17-001}
\paragraph{Field: Speed \textless{}X\textgreater{} 2017 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: Standard Ratings using this field will be reported in the "2017 Standard Ratings for DX Coils" table
Note 2: two values are calculated for SEER: 'SEER User' is calculated using user-input PLF curve and cooling coefficient of degradation; 'SEER Standard' is calculated using AHRI Std 210/240-2017 default PLF curve and cooling coefficient of degradation.
Note 3: SEER User, SEER Standard, EER, and IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 210-240 (2017).
@@ -3409,7 +3433,7 @@ \subsubsection{Inputs}\label{inputs-17-001}
\paragraph{Field: Speed \textless{}X\textgreater{} 2023 Rated Evaporator Fan Power Per Volume Flow Rate}
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
+This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
Note 1: Standard Ratings using this field will be reported in the "2023 Standard Ratings for DX Coils" table
Note 2: two values are calculated for SEER2. 'SEER2 User' is calculated using user-input PLF curve and cooling coefficient of degradation. 'SEER2 Standard' is calculated using AHRI Std 210/240-2023 default PLF curve and cooling coefficient of degradation.
Note 3: SEER2 User, SEER2 Standard, EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr - will be calculated according to ANSI/AHRI standard 210-240 (2023).
@@ -3453,6 +3477,9 @@ \subsubsection{Inputs}\label{inputs-17-001}
1.7, !- Rated Air Flow Rate {m3/s}
0.0, !- Nominal Time for Condensate to Begin Leaving the Coil {s}
0.0, !- Initial Moisture Evaporation Rate Divided by Steady-State AC Latent Capacity {dimensionless}
+ , !- Maximum Cycling Rate {cylcles/hr}
+ , !- Latent Capacity Time Constant
+ , !- Fan Delay Time
HPACCOOLPLFFPLR, !- Part Load Fraction Correlation Curve Name
, ! - Condenser Air Inlet Node Name
AirCooled, ! - Condenser Type
@@ -4645,11 +4672,11 @@ \subsubsection{Outputs}\label{outputs-16}
\paragraph{Heating Coil Crankcase Heater Electricity Rate {[}W{]}}\label{heating-coil-crankcase-heater-electric-power-w-1}
-This is the average electricity consumption rate of the DX coil compressor's crankcase heater in Watts for the timestep being reported. When a companion cooling coil exits, the crankcase heater power of the companion cool coil is alos reported in this variable.
+This is the average electricity consumption rate of the DX coil compressor's crankcase heater in Watts for the timestep being reported. When a companion cooling coil exits, the crankcase heater power of the companion cool coil is also reported in this variable.
\paragraph{Heating Coil Crankcase Heater Electricity Energy {[}J{]}}\label{heating-coil-crankcase-heater-electric-energy-j-1}
-This is the electricity consumption of the DX coil compressor's crankcase heater in Joules for the timestep being reported. This output is also added to a meter with Resource Type = Electricity, End Use Key = Heating, Group Key = System (ref. Output:Meter objects). When a companion cooling coil exits, the crankcase heater power of the companion cool coil is alos reported in this variable.
+This is the electricity consumption of the DX coil compressor's crankcase heater in Joules for the timestep being reported. This output is also added to a meter with Resource Type = Electricity, End Use Key = Heating, Group Key = System (ref. Output:Meter objects). When a companion cooling coil exits, the crankcase heater power of the companion cool coil is also reported in this variable.
\paragraph{Heating Coil Runtime Fraction {[]}}
@@ -4782,7 +4809,7 @@ \subsubsection{Inputs}\label{inputs-21-001}
\paragraph{Field: Speed \textless{}x\textgreater{} Reference Unit Gross Rated Heating COP}\label{field-speed-x-reference-unit-gross-rated-heating-cop}
-This numeric field defines the coefficient of performance (COP = gross heating capacityin watts divided by electrical power input in watts) of the heating coil unit at rated conditions for Speed \textless{}x\textgreater{} operation. The value entered here must be greater than 0. The input power includes power for the compressor(s), the outdoor coil fan and accessories, but does not include the power consumption of the indoor supply air fan. The gross COP should NOT account for the supply air fan.
+This numeric field defines the coefficient of performance (COP = gross heating capacity in watts divided by electrical power input in watts) of the heating coil unit at rated conditions for Speed \textless{}x\textgreater{} operation. The value entered here must be greater than 0. The input power includes power for the compressor(s), the outdoor coil fan and accessories, but does not include the power consumption of the indoor supply air fan. The gross COP should NOT account for the supply air fan.
\paragraph{Field: Speed \textless{}x\textgreater{} Reference Unit Rated Air Flow Rate}\label{field-speed-x-reference-unit-rated-air-flow-rate-1}
@@ -5256,7 +5283,7 @@ \subsection{CoilSystem:Cooling:DX}\label{coilsystemcoolingdx}
The CoilSystem:Cooling:DX object is a virtual container component that consists of a DX cooling coil component and its associated controls, as shown in the Figure below. This control object supports several different types of DX cooling coils (see field Cooling Coil Object Type).
-This component may be used as a cooling coil in constant volume or variable volume systems, as blow through or draw through, with or without humidity controls. Unlike AirLoopHVAC:Unitary system types, this component controls only the DX coil, not the supply fan. CoilSystem:Cooling:DX is added to a system by placing it in an air loop branch (see Branch object) or in an \hyperref[airloophvacoutdoorairsystemequipmentlist]{AirLoopHVAC:OutdoorAirSystem:EquipmentList} or in a \hyperref[zonehvacoutdoorairunitequipmentlist]{ZoneHVAC:OutdoorAirUnit:EquipmentList} . It requires one or more setpoint manager (see SetpointManager:*) objects to specify temperature and/or humidity setpoints (unless it is used in a \hyperref[zonehvacoutdoorairunit]{ZoneHVAC:OutdoorAirUnit} which has its own temperature setpoints). This object is the one that is listed in the Branch or equipment list object rather than the coil itself. A constant volume or variable volume fan is modeled separately from this cooling system. These are the only fan types allowed for this system type (ref. \hyperref[fanconstantvolume]{Fan:ConstantVolume} and \hyperref[fanvariablevolume]{Fan:VariableVolume}). Cycling fan operation is not available with this model. The CoilSystem:Cooling:DX object can also be placed on dedicated outdoor air system (DOAS) airloop branches or in arloop branches where the air flow to capacity ratio range is between 100 300 cfm/ton. 100\% DOAS DX cooling coils operate in lower flow to capacity ratio range compared to regular DX cooling coils. The CoilSystem:Cooling:DX is selected to operate in DOAS application or in low flow to capacity ratio range by specifying YES to the input field Use Outdoor Air DX Cooling Coil . If this optional input field is left blank or specified as NO , then the coil is modeled as regular DX cooling coil. If the CoilSystem:Cooling:DX object is in an \hyperref[airloophvacoutdoorairsystemequipmentlist]{AirLoopHVAC:OutdoorAirSystem:EquipmentList} or in a \hyperref[zonehvacoutdoorairunitequipmentlist]{ZoneHVAC:OutdoorAirUnit:EquipmentList} then it is treated as 100\% DOAS DX cooling coil only if the choice input field Use Outdoor Air DX Cooling Coil is set too YES . All the control options of the regular DX cooling coils are available to DOAS DX coils as well. Heating DX coils in DOAS airloop operate at the same flow to capacity ratio limits as the DOAS DX cooling coils.
+This component may be used as a cooling coil in constant volume or variable volume systems, as blow through or draw through, with or without humidity controls. Unlike AirLoopHVAC:Unitary system types, this component controls only the DX coil, not the supply fan. CoilSystem:Cooling:DX is added to a system by placing it in an air loop branch (see Branch object) or in an \hyperref[airloophvacoutdoorairsystemequipmentlist]{AirLoopHVAC:OutdoorAirSystem:EquipmentList} or in a \hyperref[zonehvacoutdoorairunitequipmentlist]{ZoneHVAC:OutdoorAirUnit:EquipmentList} . It requires one or more setpoint manager (see SetpointManager:*) objects to specify temperature and/or humidity setpoints (unless it is used in a \hyperref[zonehvacoutdoorairunit]{ZoneHVAC:OutdoorAirUnit} which has its own temperature setpoints). This object is the one that is listed in the Branch or equipment list object rather than the coil itself. A constant volume or variable volume fan is modeled separately from this cooling system. These are the only fan types allowed for this system type (ref. \hyperref[fanconstantvolume]{Fan:ConstantVolume} and \hyperref[fanvariablevolume]{Fan:VariableVolume}). Cycling fan operation is not available with this model. The CoilSystem:Cooling:DX object can also be placed on dedicated outdoor air system (DOAS) airloop branches or in airloop branches where the air flow to capacity ratio range is between 100 300 cfm/ton. 100\% DOAS DX cooling coils operate in lower flow to capacity ratio range compared to regular DX cooling coils. The CoilSystem:Cooling:DX is selected to operate in DOAS application or in low flow to capacity ratio range by specifying YES to the input field Use Outdoor Air DX Cooling Coil . If this optional input field is left blank or specified as NO , then the coil is modeled as regular DX cooling coil. If the CoilSystem:Cooling:DX object is in an \hyperref[airloophvacoutdoorairsystemequipmentlist]{AirLoopHVAC:OutdoorAirSystem:EquipmentList} or in a \hyperref[zonehvacoutdoorairunitequipmentlist]{ZoneHVAC:OutdoorAirUnit:EquipmentList} then it is treated as 100\% DOAS DX cooling coil only if the choice input field Use Outdoor Air DX Cooling Coil is set too YES . All the control options of the regular DX cooling coils are available to DOAS DX coils as well. Heating DX coils in DOAS airloop operate at the same flow to capacity ratio limits as the DOAS DX cooling coils.
\begin{figure}[hbtp] % fig 138
\centering
@@ -5687,7 +5714,7 @@ \subsubsection{Inputs}\label{inputs-ASIHP}
This alpha field defines the water heating operation in the combined space heating and water heating with desuperheating (SCDWH) mode in an ASIHP, which must be given. The power values and curves in the Coil:WaterHeating:AirToWaterHeatPump:VariableSpeed are not used. That means the power consumption at each speed level of the SHDWH mode is accounted for by the heating coil part.
-\paragraph{Field: SCWH Mode Minimum Indoor Temperature to Allow Overcooling}\label{Field-SCWH-Minimum-In-Overcooling-ASIHP}
+\paragraph{Field: SCWH Mode Minimum Indoor Temperature to Allow Overcooling}\label{Field-SCWH-Minimum-In-Overcooling-ASIHP}
This numeric field defines an indoor air temperature [C] above which indoor overcooling is allowed in the cooling operation, i.e., allowing running the SCWH mode to cool down the indoor air below the thermostat setting temperature, and iterate the compressor speed to match the water heating load. It has to be noted that both the indoor temperature and ambient temperature lower bound settings have to be satisfied when allowing indoor overcooling by running the SCWH mode.
@@ -6852,7 +6879,7 @@ \subsubsection{Outputs}\label{vshpwhheating-outputs}
This output variable is the ratio of the part-load capacity to the steady state capacity of the DX coil.
\paragraph{HVAC,Average,Cooling Coil Air Mass Flow Rate {[}kg/s{]}}\label{vshpwhheating-output-cooling-coil-air-mass-flow-rate}
-The output variable is the average air mass flow rate going through the evporator over the timestep being reported.
+The output variable is the average air mass flow rate going through the evaporator over the timestep being reported.
\paragraph{HVAC,Average,Cooling Coil Air Inlet Temperature {[}C{]}}\label{vshpwhheating-output-cooling-coil-air-inlet-temperature}
The output variable is the average entering air dry-bulb temperature over the timestep being reported.
@@ -6976,7 +7003,7 @@ \subsubsection{Inputs}\label{inputs-29}
This numeric field defines the estimated parameter of the \textbf{compressor's efficiency}. The compressor efficiency is formulated as the equation below:
\begin{equation}
-\eta = \frac{{{{\dot W}_{Theoritical}}}}{{{{\dot W}_{CompInput}} - {{\dot W}_{Loss}}}}
+\eta = \frac{{{{\dot W}_{Theoretical}}}}{{{{\dot W}_{CompInput}} - {{\dot W}_{Loss}}}}
\end{equation}
This field was previously know as Parameter 5.
@@ -7017,6 +7044,34 @@ \subsubsection{Inputs}\label{inputs-29}
This numeric field defines the estimated parameter \textbf{source side heat transfer resistance} 2. Unit is W/K. This field was previously known as Parameter 10. It should only be used when the Source Side Fluid Name is an antifreeze.
+\paragraph{Field: Part Load Fraction Correlation Curve Name}\label{field-part-load-fraction-correlation-curve-name-pe}
+
+This alpha field defines the name of a quadratic or cubic performance curve (Ref: Performance Curves) that parameterizes the variation of electrical power input to the unit as a function of the part load ratio (PLR). The product of the rated EIR and EIR modifier curves is divided by the output of this curve to give the effective EIR for a given simulation timestep. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. The part load fraction correlation should be normalized to a value of 1.0 when the part load ratio equals 1.0 (i.e., no efficiency losses when the compressor(s) run continuously for the simulation timestep).
+
+\paragraph{Field: Maximum Cycling Rate}\label{field-maximum-cycling-rate-pe}
+
+This numeric field contains the maximum on-off cycling rate for the compressor, which occurs at 50\% run time fraction. Suggested values are shown in Figure~\ref{fig:suggested-values-for-maximum-cycling-rate-pe}. (Henderson et al. 1999):
+
+\begin{figure}[htbp]
+\centering
+\includegraphics{media/image295.png}
+\caption{Suggested values for maximum cycling rate \protect \label{fig:suggested-values-for-maximum-cycling-rate-pe}}
+\end{figure}
+
+\paragraph{Field: Latent Capacity Time Constant}\label{field-heat-pump-time-constant-pe}
+
+This numeric field contains the time constant for the cooling coil's capacity to reach steady state after startup. Suggested values are shown in Figure~\ref{fig:suggested-values-for-heat-pump-time-constant-pe}. (Henderson et al. 1999):
+
+\begin{figure}[htbp]
+\centering
+\includegraphics{media/image296.png}
+\caption{Suggested values for latent capacity time constant \protect \label{fig:suggested-values-for-heat-pump-time-constant-pe}}
+\end{figure}
+
+\paragraph{Field: Fan Delay Time}\label{field-heat-pump-fan-delay-time-pe}
+
+This numeric field contains the time delay for the heat pump supply air fan to shut off after the compressor cycles off in seconds. This value can be obtained from the manufacturer or the heat pump catalog. Enter a value of zero when the heat pump's fan operating mode is continuous. Suggested value is 60 seconds.
+
Following is an example for COIL:WaterToAirHP:ParameterEstimation:Cooling coil input
\begin{lstlisting}
@@ -7048,7 +7103,9 @@ \subsubsection{Inputs}\label{inputs-29}
2.06530E-02, !-Leak Rate Coefficient
1.92757E+03, !- Source Side Heat Transfer Coefficient {W/K}
, !- Source Side Heat Transfer Resistance1 {dimensionless}
- ; !- Source Side Heat Transfer Resistance2 {W/K}
+ , !- Source Side Heat Transfer Resistance2 {W/K}
+ HPACCOOLPLFFPLR; !- Part Load Fraction Correlation Curve Name
+
\end{lstlisting}
\subsection{Coil:Cooling:WaterToAirHeatPump:EquationFit}\label{coilcoolingwatertoairheatpumpequationfit}
@@ -7083,22 +7140,6 @@ \subsubsection{Inputs}\label{inputs-30}
This numeric field contains the rated volumetric air flow rate on the load side of the heat pump in m3/s. This field is autosizable.
-\paragraph{Field: 2017 Rated Evaporator Fan Power Per Volume Flow Rate}
-
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
-Note 1: Standard Ratings using this field will be reported in the "2017 Standard Ratings for DX Coils" table
-Note 2: two values are calculated for SEER: 'SEER User' is calculated using user-input PLF curve and cooling coefficient of degradation; 'SEER Standard' is calculated using AHRI Std 210/240-2017 default PLF curve and cooling coefficient of degradation.
-Note 3: SEER User, SEER Standard, EER, and IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 210-240 (2017).
-Note 4: EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity between 65,000 and 135,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 340-360 (2013).
-
-\paragraph{Field: 2023 Rated Evaporator Fan Power Per Volume Flow Rate}
-
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
-Note 1: Standard Ratings using this field will be reported in the "2023 Standard Ratings for DX Coils" table
-Note 2: two values are calculated for SEER2. 'SEER2 User' is calculated using user-input PLF curve and cooling coefficient of degradation. 'SEER2 Standard' is calculated using AHRI Std 210/240-2023 default PLF curve and cooling coefficient of degradation.
-Note 3: SEER2 User, SEER2 Standard, EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr - will be calculated according to ANSI/AHRI standard 210-240 (2023).
-Note 4: EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacities between 65,000 and 135,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 340-360 (2022).
-
\paragraph{Field: Rated Water Flow Rate}\label{field-rated-water-flow-rate}
This numeric field contains the rated volumetric water flow rate on the source side of the heat pump in m3/s. This field is autosizable.
@@ -7109,7 +7150,7 @@ \subsubsection{Inputs}\label{inputs-30}
\paragraph{Field: Gross Rated Sensible Cooling Capacity}\label{field-gross-rated-sensible-cooling-capacity}
-This numeric field contains the gross rated sensible capacity of the heat pump in W. This field is autosizable. The gross rated sensible cooling capacity shouldnot account for the effect of supply air fan heat.
+This numeric field contains the gross rated sensible capacity of the heat pump in W. This field is autosizable. The gross rated sensible cooling capacity should not account for the effect of supply air fan heat.
\paragraph{Field: Rated Cooling Coefficient of Performance}\label{field-rated-cooling-coefficient-of-performance}
@@ -7139,6 +7180,10 @@ \subsubsection{Inputs}\label{inputs-30}
This alpha field specifies the name of a \textbf{quadlinear} performance curve object (ref: Performance Curves) for the heat pump power consumption. The Single Speed Equation-Fit Model for Unitary Water-To-Air Heat Pump under the Air System Compound Component Groups in the Engineering Reference document contains more explanation regarding this.
+\paragraph{Field: Part Load Fraction Correlation Curve Name}\label{field-part-load-fraction-correlation-curve-name-efc}
+
+This alpha field defines the name of a quadratic or cubic performance curve (Ref: Performance Curves) that parameterizes the variation of electrical power input to the unit as a function of the part load ratio (PLR). The product of the rated EIR and EIR modifier curves is divided by the output of this curve to give the effective EIR for a given simulation timestep. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. The part load fraction correlation should be normalized to a value of 1.0 when the part load ratio equals 1.0 (i.e., no efficiency losses when the compressor(s) run continuously for the simulation timestep).
+
\paragraph{Field: Nominal Time for Condensate Removal to Begin}\label{field-nominal-time-for-condensate-removal-to-begin-4}
This numeric field defines the nominal time (in seconds) after startup for condensate to begin leaving the coil's condensate drain line at the coil's rated airflow and temperature conditions, starting with a dry coil. Nominal time is equal to the ratio of the energy of the coil's maximum condensate holding capacity (J) to the coil's steady-state latent capacity (W). Suggested value is 1000; zero value means the latent degradation model is disabled. The default value for this field is zero.
@@ -7147,6 +7192,30 @@ \subsubsection{Inputs}\label{inputs-30}
This numeric field defines ratio of the initial moisture evaporation rate from the cooling coil (when the compressor first turns off, in Watts) and the coil's steady-state latent capacity (Watts) at rated airflow and temperature conditions. Suggested value is 1.5; zero value means the latent degradation model is disabled. The default value for this field is zero.
+\paragraph{Field: Maximum Cycling Rate}\label{field-maximum-cycling-rate-efc}
+
+This numeric field contains the maximum on-off cycling rate for the compressor, which occurs at 50\% run time fraction. Suggested values are shown in Figure~\ref{fig:suggested-values-for-maximum-cycling-rate-efc}. (Henderson et al. 1999):
+
+\begin{figure}[htbp]
+\centering
+\includegraphics{media/image295.png}
+\caption{Suggested values for maximum cycling rate \protect \label{fig:suggested-values-for-maximum-cycling-rate-efc}}
+\end{figure}
+
+\paragraph{Field: Latent Capacity Time Constant}\label{field-heat-pump-time-constant-efc}
+
+This numeric field contains the time constant for the cooling coil's capacity to reach steady state after startup. Suggested values are shown in Figure~\ref{fig:suggested-values-for-heat-pump-time-constant-efc}. (Henderson et al. 1999):
+
+\begin{figure}[htbp]
+\centering
+\includegraphics{media/image296.png}
+\caption{Suggested values for latent capacity time constant \protect \label{fig:suggested-values-for-heat-pump-time-constant-efc}}
+\end{figure}
+
+\paragraph{Field: Fan Delay Time}\label{field-heat-pump-fan-delay-time-efc}
+
+This numeric field contains the time delay for the heat pump supply air fan to shut off after the compressor cycles off in seconds. This value can be obtained from the manufacturer or the heat pump catalog. Enter a value of zero when the heat pump's fan operating mode is continuous. Suggested value is 60 seconds.
+
Following is an example of the input for Coil:WaterToAirHP:EquationFit:Cooling coil
\begin{lstlisting}
@@ -7165,9 +7234,10 @@ \subsubsection{Inputs}\label{inputs-30}
TotCoolCapCurve, !- Total Cooling Capacity Curve Name
CoolSensCapCurve, !- Sensible Cooling Capacity Curve Name
CoolPowCurve, !- Cooling Power Consumption Curve Name
+ HPACCOOLPLFFPLR, !- Part Load Fraction Correlation Curve Name
0, !- Nominal Time for Condensate Removal to Begin
0; !- Ratio of Initial Moisture Evaporation Rate and Steady-state Latent Capacity
-
+
Curve:QuadLinear,
TotCoolCapCurve, ! Curve Name
-0.68126221, ! CoefficientC1
@@ -7463,6 +7533,30 @@ \subsubsection{Inputs}\label{inputs-31}
This numeric field defines ratio of the initial moisture evaporation rate from the cooling coil (when the compressor first turns off, in Watts) and the coil's steady-state latent capacity (Watts) at rated airflow and temperature conditions. Suggested value is 1.5; zero value means the latent degradation model is disabled. The default value for this field is zero.
+\paragraph{Field: Maximum Cycling Rate}\label{field-maximum-cycling-rate-vsefc}
+
+This numeric field contains the maximum on-off cycling rate for the compressor, which occurs at 50\% run time fraction. Suggested values are shown in Figure~\ref{fig:suggested-values-for-maximum-cycling-rate-vsefc}. (Henderson et al. 1999):
+
+\begin{figure}[htbp]
+\centering
+\includegraphics{media/image295.png}
+\caption{Suggested values for maximum cycling rate \protect \label{fig:suggested-values-for-maximum-cycling-rate-vsefc}}
+\end{figure}
+
+\paragraph{Field: Latent Capacity Time Constant}\label{field-heat-pump-time-constant-vsefc}
+
+This numeric field contains the time constant for the cooling coil's capacity to reach steady state after startup. Suggested values are shown in Figure~\ref{fig:suggested-values-for-heat-pump-time-constant-vsefc}. (Henderson et al. 1999):
+
+\begin{figure}[htbp]
+\centering
+\includegraphics{media/image296.png}
+\caption{Suggested values for latent capacity time constant \protect \label{fig:suggested-values-for-heat-pump-time-constant-vsefc}}
+\end{figure}
+
+\paragraph{Field: Fan Delay Time}\label{field-heat-pump-fan-delay-time-vsefc}
+
+This numeric field contains the time delay for the heat pump supply air fan to shut off after the compressor cycles off in seconds. This value can be obtained from the manufacturer or the heat pump catalog. Enter a value of zero when the heat pump's fan operating mode is continuous. Suggested value is 60 seconds.
+
\paragraph{Field: Flag for Using Hot Gas Reheat, 0 or 1}\label{field-flag-for-using-hot-gas-reheat-0-or-1}
This numeric field dictates whether to use the recoverable waste heat for reheating the supply air, downstream of the coil. The value 1 means using the hot gas reheating, and 0 means not using. If the hot gas reheating is turned on, the recoverable waste heat is subtracted from both the total cooling capacity and the sensible cooling capacity. The default value for this field is zero.
@@ -7505,22 +7599,6 @@ \subsubsection{Inputs}\label{inputs-31}
This numeric field defines the volumetric air flow rate, in \si{\volumeFlowRate}, across the cooling coil at rated conditions for Speed \textless{}x\textgreater{} operation. The value entered here should be directly from the Reference Unit data, corresponding to the given gross rated total cooling capacity and gross rated cooling COP at the speed, as above.
-\paragraph{Field: Speed \textless{}X\textgreater{} 2017 Rated Evaporator Fan Power Per Volume Flow Rate}
-
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 773.3 W/(m\(^{3}\)/s) (365 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1250 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2017 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, 15.2 Coils) and also in the predefined tabular output reports (Output:Table:SummaryReports object, Equipment Summary). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
-Note 1: Standard Ratings using this field will be reported in the "2017 Standard Ratings for DX Coils" table
-Note 2: two values are calculated for SEER: 'SEER User' is calculated using user-input PLF curve and cooling coefficient of degradation; 'SEER Standard' is calculated using AHRI Std 210/240-2017 default PLF curve and cooling coefficient of degradation.
-Note 3: SEER User, SEER Standard, EER, and IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 210-240 (2017).
-Note 4: EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity between 65,000 and 135,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 340-360 (2013).
-
-\paragraph{Field: Speed \textless{}X\textgreater{} 2023 Rated Evaporator Fan Power Per Volume Flow Rate}
-
-This field is the electric power for the evaporator (cooling coil) fan per air volume flow rate through the coil at the rated conditions for Speed in W/(m\(^{3}\)/s). The default value is 934.4 W/(m3/s) (441 W/1000 cfm) if this field is left blank. If a value is entered, it must be \textgreater{}= 0.0 and \textless{}= 1505 W/(m\(^{3}\)/s). This value is only used to calculate the following metrics according to the 2023 version of the ANSI/AHRI 210-240 standard: Seasonal Energy Efficiency Ratio (SEER2), Energy Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER) and the Standard Rating (Net) Cooling Capacity. These metrics will be outputs in the EnergyPlus eio file (ref. EnergyPlus Engineering Reference, Section 15.2 Coils). This value is not used for modeling the evaporator (cooling coil) fan during simulations; instead, it is used for calculating SEER2, EER, IEER, and Standard Rating (Net) Cooling Capacity to assist the user in verifying their inputs for modeling this type of equipment.
-Note 1: Standard Ratings using this field will be reported in the "2023 Standard Ratings for DX Coils" table
-Note 2: two values are calculated for SEER2. 'SEER2 User' is calculated using user-input PLF curve and cooling coefficient of degradation. 'SEER2 Standard' is calculated using AHRI Std 210/240-2023 default PLF curve and cooling coefficient of degradation.
-Note 3: SEER2 User, SEER2 Standard, EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacity less than 65,000 Btu/hr - will be calculated according to ANSI/AHRI standard 210-240 (2023).
-Note 4: EER, IEER, and Standard Rating (Net) Cooling Capacity -- with cooling capacities between 65,000 and 135,000 Btu/hr -- will be calculated according to ANSI/AHRI standard 340-360 (2022).
-
\paragraph{Field: Speed \textless{}x\textgreater{} Reference Unit Rated Water Flow Rate}\label{field-speed-x-reference-unit-rated-water-flow-rate}
This numeric field defines the volumetric water flow rate, in \si{\volumeFlowRate}, flowing at the source side of the cooling coil at rated conditions for Speed \textless{}x\textgreater{} operation. The value entered here should be directly from the Reference Unit data, corresponding to the given gross rated total cooling capacity and gross rated cooling COP at the speed, as above.
@@ -7615,6 +7693,9 @@ \subsubsection{Inputs}\label{inputs-31}
Autosize, !- Rated Water Flow Rate {m3/s}
0.0, !- Nominal time for Condensate to Begin Leaving the Coil
0.0, !- Initial Moisture Evaporation Rate Divided by Steady-State AC Latent Capacity
+ , !- Maximum Cycling Rate {cylcles/hr}
+ , !- Latent Capacity Time Constant
+ , !- Fan Delay Time
1, !- Flag for Using Hot Gas Reheat or Not, 0 = false; 1 = true
VS Energy Part Load Fraction 1, !- Energy Part Load Fraction Curve
1524.1, !- Speed 1 Reference Unit Gross Rated Total Cooling Capacity
@@ -7961,7 +8042,7 @@ \subsubsection{Inputs}\label{inputs-32}
This numeric field defines the estimated parameter of the \textbf{compressor's efficiency}. The compressor efficiency is formulated as the equation below:
\begin{equation}
-\eta = \frac{{{{\dot W}_{Theoritical}}}}{{{{\dot W}_{CompInput}} - {{\dot W}_{Loss}}}}
+\eta = \frac{{{{\dot W}_{Theoretical}}}}{{{{\dot W}_{CompInput}} - {{\dot W}_{Loss}}}}
\end{equation}
This field was previously know as Parameter 4.
@@ -8002,6 +8083,10 @@ \subsubsection{Inputs}\label{inputs-32}
This numeric field defines the estimated \textbf{parameter source side heat transfer resistance 2}. Unit is W/K. This field was previously known as Parameter 9. It should only be used when the Source Side Fluid Name is an antifreeze.
+\paragraph{Field: Part Load Fraction Correlation Curve Name}\label{field-part-load-fraction-correlation-curve-name-peh}
+
+This alpha field defines the name of a quadratic or cubic performance curve (Ref: Performance Curves) that parameterizes the variation of electrical power input to the unit as a function of the part load ratio (PLR). The product of the rated EIR and EIR modifier curves is divided by the output of this curve to give the effective EIR for a given simulation timestep. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. The part load fraction correlation should be normalized to a value of 1.0 when the part load ratio equals 1.0 (i.e., no efficiency losses when the compressor(s) run continuously for the simulation timestep).
+
Following is an example input for Coil:WatertoAirHP:ParameterEstimation:Heating
\begin{lstlisting}
@@ -8031,6 +8116,7 @@ \subsubsection{Inputs}\label{inputs-32}
4.00322E+03, !- Source Side Heat Transfer Coefficient {W/K}
, !- Source Side Heat Transfer Resistance1 {dimensionless}
; !- Source Side Heat Transfer Resistance2 {W/K}
+ HPACHEATPLFFPLR; !- Part Load Fraction Correlation Curve Name
\end{lstlisting}
\subsection{Coil:Heating:WaterToAirHeatPump:EquationFit}\label{coilheatingwatertoairheatpumpequationfit}
@@ -8095,6 +8181,10 @@ \subsubsection{Inputs}\label{inputs-33}
This alpha field specifies the name of a \textbf{quadlinear} performance curve object (ref: Performance Curves) for the heat pump power consumption. The Single Speed Equation-Fit Model for Unitary Water-To-Air Heat Pump under the Air System Compound Component Groups in the Engineering Reference document contains more explanation regarding this.
+\paragraph{Field: Part Load Fraction Correlation Curve Name}\label{field-part-load-fraction-correlation-curve-name-efh}
+
+This alpha field defines the name of a quadratic or cubic performance curve (Ref: Performance Curves) that parameterizes the variation of electrical power input to the unit as a function of the part load ratio (PLR). The product of the rated EIR and EIR modifier curves is divided by the output of this curve to give the effective EIR for a given simulation timestep. The part load fraction (PLF) correlation accounts for efficiency losses due to compressor cycling. The part load fraction correlation should be normalized to a value of 1.0 when the part load ratio equals 1.0 (i.e., no efficiency losses when the compressor(s) run continuously for the simulation timestep).
+
\subsubsection{Outputs}\label{outputs-27}
Coil:Heating:WaterToAirHeatPump:ParameterEstimation and Coil:Heating:WaterToAirHeatPump:EquationFit have the same output variables listed as follows;
@@ -9103,7 +9193,7 @@ \subsubsection{Inputs}\label{inputs-35}
This field is the rate of air flow through the condenser section, in m\(^{3}\)/s. The model assumes constant, single-speed condenser fans. The flow rate is not used to determine coil operation but is used to determine the conditions leaving the condenser section. This field is required, for both air-cooled and evaporatively-cooled condenser types.
-This field is autocalulatable. When autocalculated, the design flow rate is determined using the sizing factor in the following input field.
+This field is autocalculatable. When autocalculated, the design flow rate is determined using the sizing factor in the following input field.
\paragraph{Field: Condenser Air Flow Sizing Factor}\label{field-condenser-air-flow-sizing-factor}
diff --git a/doc/input-output-reference/src/overview/group-humidifiers-and-dehumidifiers.tex b/doc/input-output-reference/src/overview/group-humidifiers-and-dehumidifiers.tex
index 2f7d6dc2d12..512b5c8e245 100644
--- a/doc/input-output-reference/src/overview/group-humidifiers-and-dehumidifiers.tex
+++ b/doc/input-output-reference/src/overview/group-humidifiers-and-dehumidifiers.tex
@@ -94,7 +94,7 @@ \subsubsection{Outputs}\label{outputs-016}
\paragraph{Humidifier Water Volume{[}m3{]}}\label{humidifier-water-volumem3}
-This ouput is the cubic meters of water consumed by the steam humidifier over the timestep being reported.
+This output is the cubic meters of water consumed by the steam humidifier over the timestep being reported.
\paragraph{Humidifier Electricity Rate {[}W{]}}\label{humidifier-electric-powerw}
@@ -130,7 +130,7 @@ \subsubsection{Outputs}\label{outputs-016}
\subsection{Humidifier:Steam:Gas}\label{humidifiersteamgas}
-The gas fired steam humidifier is a component that represents a gas fired self-contained steam humidifier. The component uses gas fired energy to convert ordinary tap water to steam which it then blows or injects into the supply air stream. Blower fan may not be required depending on how the dry steam is delivered into the supply air stream. The humidifier model includes local control of the humidifier unit to meet a humidity ratio setpoint on its air outlet node of the unit. A humidity set point manager is needed to put a setpoint on the outlet node but no other local controllers are needed. The humidifier either blows or injects dry steam to meet the humidity ratio setpoint requirement. If the Rated Gas Use Rate input field is not autosized, the thermal efficiency input specified will be ignored and ovverriden by a thermal efficiency value determined from user specified Rated Gas Use Rate, rated capacity (m3/s) and design conditions for sizing calculation.
+The gas fired steam humidifier is a component that represents a gas fired self-contained steam humidifier. The component uses gas fired energy to convert ordinary tap water to steam which it then blows or injects into the supply air stream. Blower fan may not be required depending on how the dry steam is delivered into the supply air stream. The humidifier model includes local control of the humidifier unit to meet a humidity ratio setpoint on its air outlet node of the unit. A humidity set point manager is needed to put a setpoint on the outlet node but no other local controllers are needed. The humidifier either blows or injects dry steam to meet the humidity ratio setpoint requirement. If the Rated Gas Use Rate input field is not autosized, the thermal efficiency input specified will be ignored and overridden by a thermal efficiency value determined from user specified Rated Gas Use Rate, rated capacity (m3/s) and design conditions for sizing calculation.
\subsubsection{Inputs}\label{inputs-1-021}
@@ -338,7 +338,7 @@ \subsubsection{Inputs}\label{inputs-011}
\hyperref[setpointmanagermultizonehumiditymaximum]{SetpointManager:MultiZone:Humidity:Maximum}
\end{itemize}
-This will also require the use of a \textbf{\hyperref[zonecontrolhumidistat]{ZoneControl:Humidistat}} object. If the dehumidifer is located in the outdoor air stream, it may also be necessary to use \textbf{\hyperref[setpointmanageroutdoorairpretreat]{SetpointManager:OutdoorAirPretreat}}.
+This will also require the use of a \textbf{\hyperref[zonecontrolhumidistat]{ZoneControl:Humidistat}} object. If the dehumidifier is located in the outdoor air stream, it may also be necessary to use \textbf{\hyperref[setpointmanageroutdoorairpretreat]{SetpointManager:OutdoorAirPretreat}}.
\paragraph{Field: Leaving Maximum Humidity Ratio Setpoint}\label{field-leaving-maximum-humidity-ratio-setpoint}
diff --git a/doc/input-output-reference/src/overview/group-hybrid-model.tex b/doc/input-output-reference/src/overview/group-hybrid-model.tex
index fb3d051cc82..c60768c32d6 100644
--- a/doc/input-output-reference/src/overview/group-hybrid-model.tex
+++ b/doc/input-output-reference/src/overview/group-hybrid-model.tex
@@ -14,7 +14,7 @@ \subsubsection{Inputs}\label{inputs-hybridzone}
This field is the name of the thermal zone (ref: Zone) and attaches a particular hybrid model input to a thermal zone in the building.
-\paragraph{Field: Calculate Zone Internal Thermal Mass}\label{field-calculate-zon-internal-thermal-mass-hm}
+\paragraph{Field: Calculate Zone Internal Thermal Mass}\label{field-calculate-zone-internal-thermal-mass-hm}
This field is used to provide an option to calculate the temperature capacity multiplier (Ref: ZoneCapacitanceMultiplier:ResearchSpecial). The temperature capacity multiplier is represented as internal thermal mass multiplier in the hybrid model.
When YES is selected, the hybrid model calculates the multiplier based on the inverse heat balance algorithm using the measured zone air temperature.
@@ -59,15 +59,15 @@ \subsubsection{Inputs}\label{inputs-hybridzone}
\paragraph{Field: Zone Measured Air Temperature Schedule Name}\label{field-zone-measured-air-temperature-schedule-name-hm}
-This field is the name of the schedule object which contains the zone air temperature measurement data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputing the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
+This field is the name of the schedule object which contains the zone air temperature measurement data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputting the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
\paragraph{Field: Zone Measured Air Humidity Ratio Schedule Name}\label{field-zone-measured-air-humidity-ratio-schedule-name-hm}
-This field is the name of the schedule object which contains the zone air humidity ration measurement data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputing the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
+This field is the name of the schedule object which contains the zone air humidity ration measurement data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputting the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
\paragraph{Field: Zone Measured Air CO$_2$ concentration Schedule Name}\label{field-zone-measured-air-co2-concentration-schedule-name-hm}
-This field is the name of the schedule object which contains the zone air CO$_2$ concentration measurement data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputing the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
+This field is the name of the schedule object which contains the zone air CO$_2$ concentration measurement data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputting the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
\paragraph{Field: Zone Input People Activity Level Schedule Name}\label{field-zone-input-people-activity-schedule-name-hm}
@@ -87,19 +87,19 @@ \subsubsection{Inputs}\label{inputs-hybridzone}
\paragraph{Field: Zone Input Supply Air Temperature Schedule Name}\label{field-zone-input-supply-air-temperature-schedule-name-hm}
-This field is the name of the schedule object which contains the measured supply air temperature data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputing the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
+This field is the name of the schedule object which contains the measured supply air temperature data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputting the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
\paragraph{Field: Zone Input Supply Air Mass Flow Rate Schedule Name}\label{field-zone-input-supply-air-mass-flow-rate-schedule-name-hm}
-This field is the name of the schedule object which contains the measured supply air mass flow rate data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputing the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
+This field is the name of the schedule object which contains the measured supply air mass flow rate data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputting the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
\paragraph{Field: Zone Input Supply Air Humidity Ratio Schedule Name}\label{field-zone-input-supply-air-humidity-ratio-schedule-name-hm}
-This field is the name of the schedule object which contains the measured supply air humidity ratio data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputing the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
+This field is the name of the schedule object which contains the measured supply air humidity ratio data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputting the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
\paragraph{Field: Zone Input Supply Air CO$_2$ Concentration Schedule Name}\label{field-zone-input-supply-air-co2-concentration-schedule-name-hm}
-This field is the name of the schedule object which contains the measured supply air CO$_2$ concentration data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputing the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
+This field is the name of the schedule object which contains the measured supply air CO$_2$ concentration data. The date range of the schedule should cover the start and end date of the HybridModel. A Schedule:File object is recommended for inputting the time-series measurements. When a schedule:file object is provided, all the rows for a whole year should be in the file, the rows outside of the start and end date range of the HybridModel should be zeros.
\paragraph{Field: Begin Month}\label{field-begin-month-hm}
diff --git a/doc/input-output-reference/src/overview/group-internal-gains-people-lights-other.tex b/doc/input-output-reference/src/overview/group-internal-gains-people-lights-other.tex
index 53a5cfa9fe3..48b9407966a 100644
--- a/doc/input-output-reference/src/overview/group-internal-gains-people-lights-other.tex
+++ b/doc/input-output-reference/src/overview/group-internal-gains-people-lights-other.tex
@@ -689,7 +689,7 @@ \subsubsection{Outputs}\label{outputs-017}
\paragraph{Zone Thermal Comfort ASHRAE 55 Ankle Draft PPD}\label{zone-thermal-comfort-ashrae55-ankle-draft-ppd}
-This field is the ``ppredicted percentage of dissatisfied'' (PPD) on draft at ankle level. It is used as the metric to evaluate the ankle draft risk as a function of PMV and air speed at the ankle level (0.1 m).
+This field is the ``predicted percentage of dissatisfied'' (PPD) on draft at ankle level. It is used as the metric to evaluate the ankle draft risk as a function of PMV and air speed at the ankle level (0.1 m).
\subsubsection{Outputs}\label{outputs-1-014}
@@ -1555,7 +1555,7 @@ \subsubsection{Inputs}\label{inputs-5-015}
\paragraph{Field: End-Use Subcategory}\label{field-end-use-subcategory-3-000}
-Allows you to specify a user-defined end-use subcategory, e.g., ``Cooking'', ``Clothes Drying'', etc. A new meter for reporting is created for each unique subcategory~ (ref: \hyperref[outputmeter-and-outputmetermeterfileonly]{Output:Meter} obejct). Subcategories are also reported in the ABUPS table. If this field is omitted or blank, the equipment will be assigned to the ``General'' end-use subcategory. Any text may be used here to categorize the end-uses in the ABUPS End Uses by Subcategory table and the LEED Summary table EAp2-4/5 Performance Rating Method Compliance.
+Allows you to specify a user-defined end-use subcategory, e.g., ``Cooking'', ``Clothes Drying'', etc. A new meter for reporting is created for each unique subcategory~ (ref: \hyperref[outputmeter-and-outputmetermeterfileonly]{Output:Meter} object). Subcategories are also reported in the ABUPS table. If this field is omitted or blank, the equipment will be assigned to the ``General'' end-use subcategory. Any text may be used here to categorize the end-uses in the ABUPS End Uses by Subcategory table and the LEED Summary table EAp2-4/5 Performance Rating Method Compliance.
IDF Examples:
@@ -3775,7 +3775,7 @@ \subsubsection{Outputs}\label{outputs-10-003}
\paragraph{Generic Air Contaminant Decay Model Generation Emission Start Elapsed Time {[}s{]}}\label{generic-air-contaminant-decay-model-generation-emission-start-elapsed-time-s}
-This output is the decay time since the start of emission. The start time is either at the beginning of each run period, including design day simulations, or the time when the egenration schedule value is zero.
+This output is the decay time since the start of emission. The start time is either at the beginning of each run period, including design day simulations, or the time when the generation schedule value is zero.
\subsection{Surface\-Contaminant\-Source\-And\-Sink:\-Generic:\-Boundary\-Layer\-Diffusion}\label{surfacecontaminantsourceandsinkgenericboundarylayerdiffusion}
diff --git a/doc/input-output-reference/src/overview/group-location-climate-weather-file-access.tex b/doc/input-output-reference/src/overview/group-location-climate-weather-file-access.tex
index eccf3f834b8..644d019d65b 100644
--- a/doc/input-output-reference/src/overview/group-location-climate-weather-file-access.tex
+++ b/doc/input-output-reference/src/overview/group-location-climate-weather-file-access.tex
@@ -53,7 +53,7 @@ \subsection{Site:VariableLocation}\label{sitevariablelocation}
\begin{itemize}
\item a vehicle driving along the road,
\item a rotating building, such as for experimental testing at different orientations, or
- \item if combind with a ``\hyperref[surfacepropertyunderwater]{SurfaceProperty:Underwater}'' boundary condition, it could apply to ships and vessels.
+ \item if combined with a ``\hyperref[surfacepropertyunderwater]{SurfaceProperty:Underwater}'' boundary condition, it could apply to ships and vessels.
\end{itemize}
The latitude, longitude, and orientation are all defined according to the same conventions as in the regular ``\hyperref[sitelocation]{Site:Location}'' object.
@@ -315,7 +315,7 @@ \subsubsection{Inputs}\label{inputs-1-024}
\paragraph{Field: Begin Environment Reset Mode}\label{field-beg-env-reset-mode}
-Optional choice field to control if zone heat balance history terms should be reset when beginning to run this sizing period. This can reduce the number of warmup days needed to reach zone convergence. The options are \textbf{FullResetAtBeginEnvironment} or \textbf{SuppressThermalResetAtBeginEnvironment}. \textbf{FullResetAtBeginEnvironment} means that at the beginning of the design day warmup the building model's surfaces are set to 23 degrees C, which is the usual starting point for each environment. \textbf{SuppressThermalResetAtBeginEnvironment} means that at the beginning of the design day warmup the building model's surfaces are not reset and will just retain whatever thermal history results they had at the end of the previous design day. The warmup days still proceed as usual but because the initial condition is closer it needs fewer warmup days to reach convergence. This is available to reduce simulation run time when using many design days that are similiar to each other.
+Optional choice field to control if zone heat balance history terms should be reset when beginning to run this sizing period. This can reduce the number of warmup days needed to reach zone convergence. The options are \textbf{FullResetAtBeginEnvironment} or \textbf{SuppressThermalResetAtBeginEnvironment}. \textbf{FullResetAtBeginEnvironment} means that at the beginning of the design day warmup the building model's surfaces are set to 23 degrees C, which is the usual starting point for each environment. \textbf{SuppressThermalResetAtBeginEnvironment} means that at the beginning of the design day warmup the building model's surfaces are not reset and will just retain whatever thermal history results they had at the end of the previous design day. The warmup days still proceed as usual but because the initial condition is closer it needs fewer warmup days to reach convergence. This is available to reduce simulation run time when using many design days that are similar to each other.
IDF Examples:
@@ -966,7 +966,7 @@ \subsection{Site:WeatherStation}\label{siteweatherstation}
\caption[]{Wind Speed Profile Coefficients (ASHRAE Fundamentals 2005).} \tabularnewline
\toprule
-Terrain Description & Exponent & Bounhary Layer Thickness (m) \tabularnewline
+Terrain Description & Exponent & Boundary Layer Thickness (m) \tabularnewline
\midrule
\endhead
@@ -1263,7 +1263,7 @@ \subsubsection{Inputs}\label{inputs-15-007}
1.08, !- Soil Thermal Conductivity {W/m-K}
962, !- Soil Density {kg/m3}
2576, !- Soil Specific Heat {J/kg-K}
- 11.1, !- Average Soil Surface Tempeature {C}
+ 11.1, !- Average Soil Surface Temperature {C}
13.4, !- Soil Surface Temperature Amplitude 1 {deltaC}
0.7, !- Soil Surface Temperature Amplitude 2 {deltaC}
25, !- Phase Shift of Temperature Amplitude 1 {days}
@@ -1737,7 +1737,7 @@ \subsection{Site:WaterMainsTemperature}\label{sitewatermainstemperature}
maximum difference in monthly average outdoor air temperatures
\end{itemize}
-These values can be calculated from annual weather data using the auxillary program CalcSoilSurfTemp preprocessor. For more information on the water mains temperatures correlation, see the \emph{EnergyPlus Engineering Document}.
+These values can be calculated from annual weather data using the auxiliary program CalcSoilSurfTemp preprocessor. For more information on the water mains temperatures correlation, see the \emph{EnergyPlus Engineering Document}.
Alternatively, the Site:WaterMainsTemperature object can read values from a schedule. This is useful for measured data or when water comes from a source other than buried pipes, e.g., a river or lake.
diff --git a/doc/input-output-reference/src/overview/group-node-branch-management.tex b/doc/input-output-reference/src/overview/group-node-branch-management.tex
index e16a3e983a4..3f6d6caf8fe 100644
--- a/doc/input-output-reference/src/overview/group-node-branch-management.tex
+++ b/doc/input-output-reference/src/overview/group-node-branch-management.tex
@@ -114,7 +114,7 @@ \subsubsection{Outputs}\label{outputs-019}
\item
HVAC,Average,System Node Maximum Available Mass Flow Rate {[}kg/s{]}
\item
- HVAC,Averge,System Node Requested Mass Flow Rate {[}kg/s{]}
+ HVAC,Average,System Node Requested Mass Flow Rate {[}kg/s{]}
\item
HVAC,Average,System Node Setpoint Mass Flow Rate {[}kg/s{]}
\end{itemize}
diff --git a/doc/input-output-reference/src/overview/group-non-zone-equipment.tex b/doc/input-output-reference/src/overview/group-non-zone-equipment.tex
index 64ffe68d32e..5d35dff1057 100644
--- a/doc/input-output-reference/src/overview/group-non-zone-equipment.tex
+++ b/doc/input-output-reference/src/overview/group-non-zone-equipment.tex
@@ -28,7 +28,7 @@ \subsubsection{Inputs}\label{inputs-028}
\paragraph{Field: Load Schedule Name}\label{field-load-schedule-name}
-Reference to the schedule object specifying the load profile {[}W{]}. The value of load can be positive or negative. Negative values here are for imposing a cooling load on the loop (with a chiller on the supply side, e.g.), while psoitive values are impose a heating load (with a boiler on the supply side).
+Reference to the schedule object specifying the load profile {[}W{]}. The value of load can be positive or negative. Negative values here are for imposing a cooling load on the loop (with a chiller on the supply side, e.g.), while positive values are impose a heating load (with a boiler on the supply side).
\paragraph{Field: Peak Flow Rate}\label{field-peak-flow-rate}
diff --git a/doc/input-output-reference/src/overview/group-operational-faults.tex b/doc/input-output-reference/src/overview/group-operational-faults.tex
index 94297b312d9..dc4abfd446b 100644
--- a/doc/input-output-reference/src/overview/group-operational-faults.tex
+++ b/doc/input-output-reference/src/overview/group-operational-faults.tex
@@ -429,7 +429,7 @@ \subsubsection{Inputs}\label{inputs-8-013}
\paragraph{Field: Fan Curve Name}\label{field-fan-curve-name}
-This field provides the name of a fan curve for the fan associated with the fault. The curve describes the relationship between the fan pressure rise and air flow rate. This is used to estimate the variations of the fan air flow rate in the faulty cases, given the Pressure Rise Variation Schedule. For variable speed fans, the curve should be the one corresponding to the maximum fan speed. The fan curve should cover the design operational point specified in the corresponding fan object. It is also required that the faulty fan operatinal state point falls within the fan selection range that is monotonically decreasing.
+This field provides the name of a fan curve for the fan associated with the fault. The curve describes the relationship between the fan pressure rise and air flow rate. This is used to estimate the variations of the fan air flow rate in the faulty cases, given the Pressure Rise Variation Schedule. For variable speed fans, the curve should be the one corresponding to the maximum fan speed. The fan curve should cover the design operational point specified in the corresponding fan object. It is also required that the faulty fan operational state point falls within the fan selection range that is monotonically decreasing.
\paragraph{IDF Examples}\label{an-example-of-idf-codes-for-the-fouling-air-filter-fault-models}
diff --git a/doc/input-output-reference/src/overview/group-performance-curves.tex b/doc/input-output-reference/src/overview/group-performance-curves.tex
index d93add8b1f4..0675def13f5 100644
--- a/doc/input-output-reference/src/overview/group-performance-curves.tex
+++ b/doc/input-output-reference/src/overview/group-performance-curves.tex
@@ -1,6 +1,6 @@
\section{Group - Performance Curves}\label{group---performance-curves}
-This group of objects primarily consists of polynomial curves that are used to characterize the performance of HVAC equipment. Several other non-polynomial curves are also included to characterize the performance of pumps and fans. All of the curves are input, stored, and evaluated entirely within the Curve module. The curves are usually derived from fits or regressions to data covering a limited range. Results for independent variable values outside this range are likely to be invalid, so curve input always contains a range of validity (maximum and minimum permitted values) for each independent variable and can optionally have limits on the curve ouput. No error or warning message is issued if an independent variable is outside the range. Instead, the curve manager uses the minimum value if an independent variable is less than the minimum, and the maximum if a variable exceeds the maximum. Similarly, no error or warning message is issued if the curve output is outside the range of the optional minimum and maximum curve output limits. Instead, the curve manager uses the minimum and maximum curve limits to cap the output of the performance curve.
+This group of objects primarily consists of polynomial curves that are used to characterize the performance of HVAC equipment. Several other non-polynomial curves are also included to characterize the performance of pumps and fans. All of the curves are input, stored, and evaluated entirely within the Curve module. The curves are usually derived from fits or regressions to data covering a limited range. Results for independent variable values outside this range are likely to be invalid, so curve input always contains a range of validity (maximum and minimum permitted values) for each independent variable and can optionally have limits on the curve output. No error or warning message is issued if an independent variable is outside the range. Instead, the curve manager uses the minimum value if an independent variable is less than the minimum, and the maximum if a variable exceeds the maximum. Similarly, no error or warning message is issued if the curve output is outside the range of the optional minimum and maximum curve output limits. Instead, the curve manager uses the minimum and maximum curve limits to cap the output of the performance curve.
Curve names must be unique across all curve types.
@@ -93,7 +93,7 @@ \subsubsection{Inputs}\label{inputs-031}
Curve:Linear,
DiagnosticSPR, ! Curve Name f = C1 + C2\*x
248.84, ! Coefficient1 Constant [Pa]
- 0., ! Coefficent 2 Press/Flow [Pa-s/m3]
+ 0., ! Coefficient 2 Press/Flow [Pa-s/m3]
0., ! Minimum Value of x (Qfan) [m3/s]
100., ! Maximum Value of x (Qfan) [m3/s]
62.5, ! Minimum Curve Output [Pa]
@@ -2374,7 +2374,7 @@ \subsubsection{Inputs}\label{inputs-18-005}
\paragraph{Field: Output Unit Type}\label{field-output-unit-type-16}
-The optional field is provided for future purposes so that the IDF Editor could display the appropriate SI or IP units for the Minimum and Maximum Curve Ouput. Currently, only Dimensionless option is provided so that no unit conversion is used for this curve.
+The optional field is provided for future purposes so that the IDF Editor could display the appropriate SI or IP units for the Minimum and Maximum Curve output. Currently, only Dimensionless option is provided so that no unit conversion is used for this curve.
An example input of the Curve:DoubleExponentialDecay input is:
@@ -2395,7 +2395,7 @@ \subsubsection{Outputs}\label{outputs-021}
\paragraph{Performance Curve Output Value}\label{performance-curve-output-value}
-The current value of the performance curve. This value is averaged over the time step being reported. Inactive or unused performance curves will show a value of -999 (e.g., equipment is off, a specific performance curve is not required for this aspect of the equipment model at this time step, etc.). This value means that the performance curve was not called during the simulation and, therefore, not evaluated. This inactive state value is only set at the beginning of each environment. When averaging over long periods of time, this inactive state value may skew results. In this case, use a detaled reporting frequency (ref. Output:Variable object) to view results at each HVAC time step.
+The current value of the performance curve. This value is averaged over the time step being reported. Inactive or unused performance curves will show a value of -999 (e.g., equipment is off, a specific performance curve is not required for this aspect of the equipment model at this time step, etc.). This value means that the performance curve was not called during the simulation and, therefore, not evaluated. This inactive state value is only set at the beginning of each environment. When averaging over long periods of time, this inactive state value may skew results. In this case, use a detailed reporting frequency (ref. Output:Variable object) to view results at each HVAC time step.
\paragraph{Performance Curve Input Variable 1(-N) Value {[]}}\label{performance-curve-input-variable-1-n-value}
diff --git a/doc/input-output-reference/src/overview/group-plant-condenser-control.tex b/doc/input-output-reference/src/overview/group-plant-condenser-control.tex
index 042156a68e2..dd96c674806 100644
--- a/doc/input-output-reference/src/overview/group-plant-condenser-control.tex
+++ b/doc/input-output-reference/src/overview/group-plant-condenser-control.tex
@@ -261,7 +261,7 @@ \subsubsection{Inputs}\label{inputs-8-015}
\paragraph{Field Set: (Lower limit, Upper Limit, Equip List name) up to 10}\label{field-set-lower-limit-upper-limit-equip-list-name-up-to-10-1}
-\paragraph{Field: \textless{}specfic type\textgreater{} Range \textless{}\#\textgreater{} Lower Limit}\label{field-specfic-type-range-lower-limit}
+\paragraph{Field: \textless{}specific type\textgreater{} Range \textless{}\#\textgreater{} Lower Limit}\label{field-specific-type-range-lower-limit}
This numeric field contains the lower limit (C for temperature operations, Percent for relative humidity operations) for the equipment list. If specific value is below this value, then this equipment list will not turn on to meet the demand.
@@ -297,11 +297,11 @@ \subsubsection{Inputs}\label{inputs-11-011}
\paragraph{Field Set: (Lower limit, Upper limit, Equipment List)}\label{field-set-lower-limit-upper-limit-equipment-list}
-\paragraph{Field: \textless{}specfic type\textgreater{} Range \textless{}\#\textgreater{} Lower Limit}\label{field-specfic-type-range-lower-limit-1}
+\paragraph{Field: \textless{}specific type\textgreater{} Range \textless{}\#\textgreater{} Lower Limit}\label{field-specific-type-range-lower-limit-1}
This numeric field specifies the minimum temperature difference required for the equipment specified in the equipment list to operate.
-\paragraph{Field: \textless{}specfic type\textgreater{} Range \textless{}\#\textgreater{} Upper Limit}\label{field-specfic-type-range-upper-limit}
+\paragraph{Field: \textless{}specific type\textgreater{} Range \textless{}\#\textgreater{} Upper Limit}\label{field-specific-type-range-upper-limit}
This numeric field specifies the maximum temperature difference below which the equipment specified in the equipment list is available.
diff --git a/doc/input-output-reference/src/overview/group-plant-equipment.tex b/doc/input-output-reference/src/overview/group-plant-equipment.tex
index 3d051381fa2..4b141538e3d 100644
--- a/doc/input-output-reference/src/overview/group-plant-equipment.tex
+++ b/doc/input-output-reference/src/overview/group-plant-equipment.tex
@@ -193,7 +193,7 @@ \subsubsection{Chiller Electricity Rate {[}W{]}}\label{chiller-electric-power-w}
\subsubsection{Chiller Electricity Energy {[}J{]}}\label{chiller-electric-energy-j}
-These outputs are the electric power input to the chiller. In the case of steam or fuel-powered chillers, this repesents the internal chiller pumps and other electric power consumption. Consumption is metered on Cooling:Electricity, Electricity:Plant, and Electricity:Facility.
+These outputs are the electric power input to the chiller. In the case of steam or fuel-powered chillers, this represents the internal chiller pumps and other electric power consumption. Consumption is metered on Cooling:Electricity, Electricity:Plant, and Electricity:Facility.
\subsubsection{Chiller Evaporator Cooling Rate {[}W{]}}\label{chiller-evaporator-cooling-rate-w}
@@ -605,11 +605,11 @@ \subsubsection{Inputs}\label{inputs-1-033}
\paragraph{Field: Generator Heat Input Function of Part Load Ratio Curve Name}\label{field-generator-heat-input-function-of-part-load-ratio-curve-name}
-This required alpha field specifies the name of the curve used to determine the heat input to the chiller. The curve is a quadratic or cubic curve which characterizes the heat input as a function of chiller part-load ratio. The curve output is multiplied by the chiller's nominal capacity and operating part-load ratio or minimum part-load ratio, whichever is greater, to determine the amount of heat input required for the given operating conditons.
+This required alpha field specifies the name of the curve used to determine the heat input to the chiller. The curve is a quadratic or cubic curve which characterizes the heat input as a function of chiller part-load ratio. The curve output is multiplied by the chiller's nominal capacity and operating part-load ratio or minimum part-load ratio, whichever is greater, to determine the amount of heat input required for the given operating conditions.
\paragraph{Field: Pump Electric Input Function of Part Load Ratio Curve Name}\label{field-pump-electric-input-function-of-part-load-ratio-curve-name}
-This alpha field specifies the name of the curve used to determine the pump electrical input to the chiller. The curve is a quadratic or cubic curve which characterizes the pump electrical power as a function of chiller part-load ratio. The curve output is multiplied by the chiller's nominal pumping power and operating part-load ratio or minimum part-load ratio, whichever is greater, to determine the amount of pumping power required for the given operating conditons.
+This alpha field specifies the name of the curve used to determine the pump electrical input to the chiller. The curve is a quadratic or cubic curve which characterizes the pump electrical power as a function of chiller part-load ratio. The curve output is multiplied by the chiller's nominal pumping power and operating part-load ratio or minimum part-load ratio, whichever is greater, to determine the amount of pumping power required for the given operating conditions.
\paragraph{Field: Generator Inlet Node Name}\label{field-generator-inlet-node-name-1}
@@ -649,7 +649,7 @@ \subsubsection{Inputs}\label{inputs-1-033}
\paragraph{Field: Temperature Lower Limit Generator Inlet}\label{field-temperature-lower-limit-generator-inlet}
-This numeric field specifies the lower limit of the generator's entering water temperature. This field is not used iif the Generator Fluid Type is specified as steam.
+This numeric field specifies the lower limit of the generator's entering water temperature. This field is not used if the Generator Fluid Type is specified as steam.
\paragraph{Field: Degree of Subcooling in Steam Generator}\label{field-degree-of-subcooling-in-steam-generator-1}
@@ -1567,7 +1567,7 @@ \subsubsection{Outputs}
\paragraph{Minimum Part Load Ratio {[]}}\label{chiller205-minimum-plr}
-This is the raio of minimum capacity to maximum capacity, under which the chiller cycling (where the amount of power remains constant to produce smaller loads than this fraction) occurs.
+This is the ratio of minimum capacity to maximum capacity, under which the chiller cycling (where the amount of power remains constant to produce smaller loads than this fraction) occurs.
\paragraph{Chiller Condenser Inlet Temperature ~{[}C{]}}\label{chiller205-condenser-inlet-temperature-c}
@@ -1685,7 +1685,7 @@ \subsubsection{Inputs}\label{inputs-4-023}
\paragraph{Field: Condenser Fan Power Ratio}\label{field-condenser-fan-power-ratio}
-This field is used to model condenser fan power associated with air-cooled or evaporatively-cooled condensers (for cooling towers, refer to Group - Condenser Equipment). Enter the ratio of the condenser fan power to the reference chiller cooling capacity in W/W. If this input is greater than 0, the condenser fan power is modeled seperatly from compressor power. In addition, if condenser fan power is modeled using this input, the reference COP and ``Electric Input to Cooling Output Ratio Function of'' performance curves should not include condenser fan power.
+This field is used to model condenser fan power associated with air-cooled or evaporatively-cooled condensers (for cooling towers, refer to Group - Condenser Equipment). Enter the ratio of the condenser fan power to the reference chiller cooling capacity in W/W. If this input is greater than 0, the condenser fan power is modeled separately from compressor power. In addition, if condenser fan power is modeled using this input, the reference COP and ``Electric Input to Cooling Output Ratio Function of'' performance curves should not include condenser fan power.
\paragraph{Field: Fraction of Compressor Electric Power Rejected by Condenser}\label{field-fraction-of-compressor-electric-power-rejected-by-condenser}
@@ -1737,7 +1737,7 @@ \subsubsection{Inputs}\label{inputs-4-023}
\paragraph{Field: Heat Recovery Leaving Temperature Setpoint Node Name}\label{field-heat-recovery-leaving-temperature-setpoint-node-name-1}
-This field is optional.~ It can be used to refine the model and controls for heat recovery operation of the chiller.~ The node named here should have a setpoint placed on it by a setpoint manager.~ If the plant loop's demand calculation scheme is set to SingleSetpoint, then a single setpoint manager should be used.~ If the plant loop's demand calculation is set to DualSetpointDeadband then a dual setpoint manager should be used and the upper setpoint is used for control.~ When this field is used, a different model is used for determining the distribution of rejected heat between the two bundles that is more appropriate for series bundle arrangements and for chiller's that are able to produce relatively higher temperature heated fluilds.
+This field is optional.~ It can be used to refine the model and controls for heat recovery operation of the chiller.~ The node named here should have a setpoint placed on it by a setpoint manager.~ If the plant loop's demand calculation scheme is set to SingleSetpoint, then a single setpoint manager should be used.~ If the plant loop's demand calculation is set to DualSetpointDeadband then a dual setpoint manager should be used and the upper setpoint is used for control.~ When this field is used, a different model is used for determining the distribution of rejected heat between the two bundles that is more appropriate for series bundle arrangements and for chiller's that are able to produce relatively higher temperature heated fluids.
\paragraph{Field: End-Use Subcategory}
@@ -2125,7 +2125,7 @@ \subsubsection{Inputs}\label{inputs-5-021}
\paragraph{Field: Heat Recovery Leaving Temperature Setpoint Node Name}\label{field-heat-recovery-leaving-temperature-setpoint-node-name-2}
-This field is optional.~ It can be used to refine the model and controls for heat recovery operation of the chiller.~ The node named here should have a setpoint placed on it by a setpoint manager.~ If the plant loop's demand calculation scheme is set to SingleSetpoint, then a single setpoint manager should be used.~ If the plant loop's demand calculation is set to DualSetpointDeadband then a dual setpoint manager should be used and the upper setpoint is used for control.~ When this field is used, a different model is used for determining the distribution of rejected heat between the two bundles that is more appropriate for series bundle arrangements and for chiller's that are able to produce relatively higher temperature heated fluilds.
+This field is optional.~ It can be used to refine the model and controls for heat recovery operation of the chiller.~ The node named here should have a setpoint placed on it by a setpoint manager.~ If the plant loop's demand calculation scheme is set to SingleSetpoint, then a single setpoint manager should be used.~ If the plant loop's demand calculation is set to DualSetpointDeadband then a dual setpoint manager should be used and the upper setpoint is used for control.~ When this field is used, a different model is used for determining the distribution of rejected heat between the two bundles that is more appropriate for series bundle arrangements and for chiller's that are able to produce relatively higher temperature heated fluids.
\paragraph{Field: End-Use Subcategory}\label{end-use-subcategory-12}
@@ -3004,7 +3004,7 @@ \subsubsection{Inputs}\label{inputs-7-018}
\paragraph{Field: Gas Turbine Engine Capacity}\label{field-gas-turbine-engine-capacity}
-This numeric field contains the capacity of the gas turbine engine in watts. This field is autosizable. When autosized the field below called Turbine Engine Effciency can be used to scale the resulting size.
+This numeric field contains the capacity of the gas turbine engine in watts. This field is autosizable. When autosized the field below called Turbine Engine Efficiency can be used to scale the resulting size.
\paragraph{Field: Maximum Exhaust Flow per Unit of Power Output}\label{field-maximum-exhaust-flow-per-unit-of-power-output-1-000}
@@ -3256,7 +3256,7 @@ \subsubsection{Inputs}\label{inputs-8-016}
\paragraph{Field: Electric Input to Heating Output Ratio}\label{field-electric-input-to-heating-output-ratio}
-A positive fraction that represents the ratio of the instantaneous electricity used divided by the nominal heating capacity. If the chiller is both heating and cooling, the greater of the cooling electricity and heating eletricity is used. The default is 0.0.
+A positive fraction that represents the ratio of the instantaneous electricity used divided by the nominal heating capacity. If the chiller is both heating and cooling, the greater of the cooling electricity and heating electricity is used. The default is 0.0.
\paragraph{Field: Chilled Water Inlet Node Name}\label{field-chilled-water-inlet-node-name-7}
@@ -3354,7 +3354,7 @@ \subsubsection{Inputs}\label{inputs-8-016}
\paragraph{Field: Heating Capacity Function of Cooling Capacity Curve Name}\label{field-heating-capacity-function-of-cooling-capacity-curve-name}
-The HeatCapFCool curve represents how the heating capacity of the chiller varies with cooling capacity when the chiller is simultaeous heating and cooling. The curve is normalized so an input of 1.0 represents the nominal cooling capacity and an output of 1.0 represents the full heating capacity (see the Heating to Cooling Capacity Ratio input)~ The curve is usually linear or quadratic. The available heating capacity is computed as follows:
+The HeatCapFCool curve represents how the heating capacity of the chiller varies with cooling capacity when the chiller is simultaneous heating and cooling. The curve is normalized so an input of 1.0 represents the nominal cooling capacity and an output of 1.0 represents the full heating capacity (see the Heating to Cooling Capacity Ratio input)~ The curve is usually linear or quadratic. The available heating capacity is computed as follows:
\begin{equation}
HeatFuelInput = AvailHeatCap \cdot HFIR \cdot HFIRfHPLR(HPLR)
@@ -3655,7 +3655,7 @@ \subsubsection{Inputs}\label{inputs-9-014}
\paragraph{Field: Electric Input to Heating Output Ratio}\label{field-electric-input-to-heating-output-ratio-1}
-A positive fraction that represents the ratio of the instantaneous electricity used divided by the nominal heating capacity. If the chiller is both heating and cooling, the greater of the cooling electricity and heating eletricity is used. The default is 0.0.
+A positive fraction that represents the ratio of the instantaneous electricity used divided by the nominal heating capacity. If the chiller is both heating and cooling, the greater of the cooling electricity and heating electricity is used. The default is 0.0.
\paragraph{Field: Chilled Water Inlet Node Name}\label{field-chilled-water-inlet-node-name-8}
@@ -4059,7 +4059,7 @@ \subsubsection{Outputs}\label{outputs-9-005}
\subsection{Boiler:HotWater}\label{boilerhotwater}
-The boiler model calculates the performance of fuel oil, gas and electric boilers. Boiler performance is based on nominal thermal efficiency. A normailized efficiency performance curve may be used to more accurately represent the performance of non-electric boilers but is not considered a required input. When using the normalized efficiency performance curve, if all coefficients are not required simply set the unused coefficients to 0. For example, an electric boiler could be modeled by setting the nominal thermal efficiency to a value in the range of 0.96 to 1.0. Coefficient A0 in the normalized efficiency performance curve would equal 1 and all other coefficients would be set to 0. Coefficients for other types of non-electric boilers would set a combination of the available coefficents to non-zero values.
+The boiler model calculates the performance of fuel oil, gas and electric boilers. Boiler performance is based on nominal thermal efficiency. A normalized efficiency performance curve may be used to more accurately represent the performance of non-electric boilers but is not considered a required input. When using the normalized efficiency performance curve, if all coefficients are not required simply set the unused coefficients to 0. For example, an electric boiler could be modeled by setting the nominal thermal efficiency to a value in the range of 0.96 to 1.0. Coefficient A0 in the normalized efficiency performance curve would equal 1 and all other coefficients would be set to 0. Coefficients for other types of non-electric boilers would set a combination of the available coefficients to non-zero values.
\subsubsection{Inputs}\label{inputs-10-013}
@@ -4089,7 +4089,7 @@ \subsubsection{Inputs}\label{inputs-10-013}
\paragraph{Field: Nominal Thermal Efficiency}\label{field-nominal-thermal-efficiency}
-This required numeric field contains the heating efficiency (as a fraction between 0 and 1) of the boiler's burner.~ This is the efficiency relative to the higher heating value (HHV) of fuel at a part load ratio of 1.0. Manufacturers typically specify the efficiency of a boiler using the higher heating value of the fuel. For the rare occurences when a manufacturers (or particular data set) thermal efficiency is based on the lower heating value (LHV) of the fuel, multiply the thermal efficiency by the lower-to-higher heating value ratio. For example, assume a fuel's lower and higher heating values are approximately 45,450 and 50,000 kJ/kg, respectively. For a manuracturers thermal effiency rating of 0.90 (based on the LHV), the nominal thermal efficiency entered here is 0.82 (i.e.~0.9 multiplied by 45,450/50,000).
+This required numeric field contains the heating efficiency (as a fraction between 0 and 1) of the boiler's burner.~ This is the efficiency relative to the higher heating value (HHV) of fuel at a part load ratio of 1.0. Manufacturers typically specify the efficiency of a boiler using the higher heating value of the fuel. For the rare occurrences when a manufacturers (or particular data set) thermal efficiency is based on the lower heating value (LHV) of the fuel, multiply the thermal efficiency by the lower-to-higher heating value ratio. For example, assume a fuel's lower and higher heating values are approximately 45,450 and 50,000 kJ/kg, respectively. For a manufacturers thermal efficiency rating of 0.90 (based on the LHV), the nominal thermal efficiency entered here is 0.82 (i.e.~0.9 multiplied by 45,450/50,000).
\paragraph{Field: Efficiency Curve Temperature Evaluation Variable}\label{field-efficiency-curve-temperature-evaluation-variable}
@@ -4710,7 +4710,7 @@ \subsubsection{Inputs}\label{inputs-12-012}
\paragraph{Field: Reference Cooling Power Consumption}\label{field-rated-cooling-power-consumption}
-This numeric field is the design electric power consumption for cooling, in W. This corresponds to the electic power use at the Reference Cooling Capacity. This field is autosizable. When autosized, the field called Reference Coefficient of Performance must be used.
+This numeric field is the design electric power consumption for cooling, in W. This corresponds to the electric power use at the Reference Cooling Capacity. This field is autosizable. When autosized, the field called Reference Coefficient of Performance must be used.
\paragraph{Fields: Cooling Capacity Curve Name}\label{fields-cooling-capacity-curve-name}
@@ -4910,7 +4910,7 @@ \subsubsection{Inputs}\label{inputs-13-010}
\paragraph{Field: Reference Heating Power Consumption}\label{field-rated-heating-power-consumption}
-This numeric field contains the design electric power consumption for heating, in W. This corresponds to the electic power use at the Reference Heating Capacity. This field is autosizable. When autosized, the field called Reference Coefficient of Performance must be used.
+This numeric field contains the design electric power consumption for heating, in W. This corresponds to the electric power use at the Reference Heating Capacity. This field is autosizable. When autosized, the field called Reference Coefficient of Performance must be used.
\paragraph{Fields: Heating Capacity Curve Name}\label{fields-heating-capacity-curve-name}
@@ -5230,7 +5230,7 @@ \subsubsection{Inputs}\label{inputs-15-010}
3998, !- Source Side Heat Transfer Coefficient {W/K}
.012544, !- Piston Displacement {m3/s}
.05469, !- Compressor Clearance Factor %
- 92156.2, !- Compressor Suction And Dischrage Pressure Drop {Pa}
+ 92156.2, !- Compressor Suction And Discharge Pressure Drop {Pa}
4.8907, !- Superheating {C}
2803.9, !- Constant Part Of Electro Mechanical Power Losses {W}
.699, !- Loss Factor
@@ -5420,7 +5420,7 @@ \subsubsection{Inputs}\label{plhp_eir_inputs}
EIRCurveFuncPLR2; !- Electric Input to Heating Output Ratio Modifier Function of Part Load Ratio Curve Name
\end{lstlisting}
-An idf example for an air-source applicaiton:
+An idf example for an air-source application:
\begin{lstlisting}
HeatPump:PlantLoop:EIR:Heating,
@@ -5581,9 +5581,9 @@ \subsubsection{Inputs}
\paragraph{Field: Nominal COP}
-The nominal COP (Coefficient of Performance) in [W/W], which is the fuel based COP of the heat pump in the rating conditions. This is a require-field. The default value is set to 1.0 in case the input filed is accidently left blank.
+The nominal COP (Coefficient of Performance) in [W/W], which is the fuel based COP of the heat pump in the rating conditions. This is a require-field. The default value is set to 1.0 in case the input filed is accidentally left blank.
-For the HeatPump:AirToWater:FuelFired:Heating object, this is the fuel based nominal heatinging COP; and for the HeatPump:AirToWater:FuelFired:Cooling object, this is the fuel based nominal cooling COP.
+For the HeatPump:AirToWater:FuelFired:Heating object, this is the fuel based nominal heating COP; and for the HeatPump:AirToWater:FuelFired:Cooling object, this is the fuel based nominal cooling COP.
\paragraph{Field: Design Flow Rate}
@@ -5617,7 +5617,7 @@ \subsubsection{Inputs}
\paragraph{Field: Normalized Capacity Function of Temperature Curve Name}
-This field is the curve name of the normalized capacity function of the two independent temperature variables. The maximum capacity is adjusted from the rated conditions, and represents what the actual capacity the heat pump can achieve under the outdoor air temperature (either drybulb or wetbuld depending on the previous input field choice), and the water temperature (either leaving condenser/evaporator or entering condenser/evaporator depending on the previous input field choice).
+This field is the curve name of the normalized capacity function of the two independent temperature variables. The maximum capacity is adjusted from the rated conditions, and represents what the actual capacity the heat pump can achieve under the outdoor air temperature (either drybulb or wetbulb depending on the previous input field choice), and the water temperature (either leaving condenser/evaporator or entering condenser/evaporator depending on the previous input field choice).
\paragraph{Field: Fuel Energy Input Ratio Function of Temperature Curve name}
@@ -5736,7 +5736,7 @@ \subsubsection{Outputs}
This is the load side heat transfer rate for the fuel-fired absorption heat pump. The value will be positive for the heating mode, and negative for the cooling mode.
\paragraph{Fuel-fired Absorption HeatPump Load Side Heating Transfer Energy [J]}
-This is the accumulated value fo the load side heat transfer energy for the fuel-fired absorption heat pump. The value will be positive for the heating mode, and negative for the cooling mode.
+This is the accumulated value of the load side heat transfer energy for the fuel-fired absorption heat pump. The value will be positive for the heating mode, and negative for the cooling mode.
\paragraph{Fuel-fired Absorption HeatPump Fuel Rate [W]}
This is the fuel consumption rate in [W] of the fuel-fired absorption heat pump.
@@ -6353,7 +6353,7 @@ \subsubsection{Field: Reference Heating Mode Cooling Power Ratio}\label{field-re
Ratio = \frac{{Powe{r_{@Tchw,l = 6.67C,Tcond,l = 51.67C}}}}{{Powe{r_{@Tchw,l = 6.67C,Tcond,l = 35.0C}}}}
\end{equation}
-The default value is 1.5. This field is used to determine full load compressor power at the simultaneous cooling-heating mode's reference chilled water leaving and condenser water leaving temperatures. Note: In heating-only mode, the chilled water leaving temperature floats so the EIRFT curve is used to modify the simultaneouos cooling-heating full load compressor power value.
+The default value is 1.5. This field is used to determine full load compressor power at the simultaneous cooling-heating mode's reference chilled water leaving and condenser water leaving temperatures. Note: In heating-only mode, the chilled water leaving temperature floats so the EIRFT curve is used to modify the simultaneous cooling-heating full load compressor power value.
\subsubsection{Field: Reference Heating Mode Leaving Chilled Water Temperature}\label{field-reference-heating-mode-leaving-chilled-water-temperature}
diff --git a/doc/input-output-reference/src/overview/group-python-plugins.tex b/doc/input-output-reference/src/overview/group-python-plugins.tex
index 2deddf79866..935ca3a2f78 100644
--- a/doc/input-output-reference/src/overview/group-python-plugins.tex
+++ b/doc/input-output-reference/src/overview/group-python-plugins.tex
@@ -98,7 +98,7 @@ \subsection{Python Plugin}
Note: a single class can override multiple functions, so that the same class instance is called at multiple points in a simulation.
Once this plugin is created, it can be placed in a number of locations on the filesystem, as described in the PythonPlugin:SearchPaths section~\ref{subsec:plugin-search-paths}.
-The plugin instance, along with any other plugin related obejcts are declared in the input file, and then EnergyPlus is executed.
+The plugin instance, along with any other plugin related objects are declared in the input file, and then EnergyPlus is executed.
More data is provided in each of the specific object sections below.
\subsection{PythonPlugin:SearchPaths}\label{subsec:plugin-search-paths}
diff --git a/doc/input-output-reference/src/overview/group-radiative-convective-units.tex b/doc/input-output-reference/src/overview/group-radiative-convective-units.tex
index 4a77cffbb89..d5e1bf9ea67 100644
--- a/doc/input-output-reference/src/overview/group-radiative-convective-units.tex
+++ b/doc/input-output-reference/src/overview/group-radiative-convective-units.tex
@@ -152,7 +152,7 @@ \subsubsection{ZoneHVAC:Baseboard:RadiantConvective:Water:Design}\label{ZoneHVAC
\paragraph{Field: Fraction of Radiant Energy Incident on People}\label{field-fraction-of-radiant-energy-incident-on-people}
-This field specifies the fraction of radiant portion of heat transfer to the zone from the baseboard heater that is incident directly on people within the space. This has an impact on the predicted thermal comfort of the zone occupants. Note that although this energy is ``radiant'' it is actually modeled in the zone heat balance as convective energy (like an internal gain). The basic assumption here is that most radiant energy falling on people will most likely be rereleased to the zone air by convection. This is a simplification of reality, but it maintains the overall energy balance.
+This field specifies the fraction of radiant portion of heat transfer to the zone from the baseboard heater that is incident directly on people within the space. This has an impact on the predicted thermal comfort of the zone occupants. Note that although this energy is ``radiant'' it is actually modeled in the zone heat balance as convective energy (like an internal gain). The basic assumption here is that most radiant energy falling on people will most likely be re-released to the zone air by convection. This is a simplification of reality, but it maintains the overall energy balance.
An example IDF for the water baseboard design object is shown below.
@@ -356,7 +356,7 @@ \subsubsection{ZoneHVAC:Baseboard:RadiantConvective:Steam:Design}\label{ZoneHVAC
\paragraph{Field: Fraction of Radiant Energy Incident on People}\label{field-fraction-of-radiant-energy-incident-on-people-1}
-This field specifies the fraction of radiant portion of heat transfer to the zone from the baseboard heater that is incident directly on people within the space. This has an impact on the predicted thermal comfort of the zone occupants. Note that although this energy is ``radiant'' it is actually modeled in the zone heat balance as convective energy (like an internal gain). The basic assumption here is that most radiant energy falling on people will most likely be rereleased to the zone air by convection. This is a simplification of reality, but it maintains the overall energy balance.
+This field specifies the fraction of radiant portion of heat transfer to the zone from the baseboard heater that is incident directly on people within the space. This has an impact on the predicted thermal comfort of the zone occupants. Note that although this energy is ``radiant'' it is actually modeled in the zone heat balance as convective energy (like an internal gain). The basic assumption here is that most radiant energy falling on people will most likely be re-released to the zone air by convection. This is a simplification of reality, but it maintains the overall energy balance.
An example IDF for the steam baseboard design object is shown below.
@@ -479,7 +479,7 @@ \subsubsection{Inputs}\label{inputs-2-032}
\paragraph{Field: Fraction of Radiant Energy Incident on People}\label{field-fraction-of-radiant-energy-incident-on-people-2}
-This field specifies the fraction of the radiant portion of heat transfer to the zone from the baseboard heater that is incident directly on people within the space. This has an impact on the predicted thermal comfort of the zone occupants. Note that although this energy is ``radiant'' it is actually modeled in the zone heat balance as a convective energy (like an internal gain). The basic assumption here is that radiant energy falling on people will most likely be rereleased to the zone air by convection. This is a simplification of reality, but it maintains the overall energy balance.
+This field specifies the fraction of the radiant portion of heat transfer to the zone from the baseboard heater that is incident directly on people within the space. This has an impact on the predicted thermal comfort of the zone occupants. Note that although this energy is ``radiant'' it is actually modeled in the zone heat balance as a convective energy (like an internal gain). The basic assumption here is that radiant energy falling on people will most likely be re-released to the zone air by convection. This is a simplification of reality, but it maintains the overall energy balance.
\paragraph{Field Set: Surface Name, Fraction of Radiant Energy to Surface}\label{field-set-surface-name-fraction-of-radiant-energy-to-surface-2}
@@ -1289,7 +1289,7 @@ \subsubsection{Inputs}
\paragraph{Field: Heating Control Throttling Range}\label{field-heating-control-throttling-range}
-This field specifies the range of temperature in degrees Celsuis over which the radiant system throttles from zero flow rate up to the maximum defined by the maximum hot water flow rate field described above. The throttling range parameter is used in conjunction with the control temperature and the setpoint type to define the response of the system to various conditions. The Heating Control Temperature Schedule specifies the ``setpoint'' temperature that is to be met. This is used in conjunction with the Setpoint Type which defines whether the flow rate of the system is at zero flow or half flow when the parameter defined by the Temperature Control Type is equal to the setpoint temperature defined by the Heating Control Temperature Schedule. See these other input parameters of this radiant system for more information on these different parameters. Note that when the throttling range is set to zero that this approximates an on-off system that is either fully on or totally off.
+This field specifies the range of temperature in degrees Celsius over which the radiant system throttles from zero flow rate up to the maximum defined by the maximum hot water flow rate field described above. The throttling range parameter is used in conjunction with the control temperature and the setpoint type to define the response of the system to various conditions. The Heating Control Temperature Schedule specifies the ``setpoint'' temperature that is to be met. This is used in conjunction with the Setpoint Type which defines whether the flow rate of the system is at zero flow or half flow when the parameter defined by the Temperature Control Type is equal to the setpoint temperature defined by the Heating Control Temperature Schedule. See these other input parameters of this radiant system for more information on these different parameters. Note that when the throttling range is set to zero that this approximates an on-off system that is either fully on or totally off.
For clarity, here is an example of how the flow rate to the system will be set. In this example, it is assumed that heating control temperature setpoint is currently 15$^\circ$C, the heating throttling range is 2$^\circ$C, and that the setpoint type is HalfFlowPower. The water flow rate to the radiant system will be zero when the controlling temperature (MAT, MRT, Operative Temperature, etc.; see control type field above) is at or above 16$^\circ$C and the maximum flow rate when the controlling temperature is at or below 14$^\circ$C. This represents a throttling range of 2$^\circ$C around the setpoint of 15$^\circ$C. In between 14$^\circ$C and 16$^\circ$C, the flow rate to the radiant system is varied linearly from full flow at a control temperature of 14$^\circ$C to half flow at 15$^\circ$C to zero flow at 16$^\circ$C. If the throttling range is changed to 0$^\circ$C or on-off control, then the system will be off above 15$^\circ$C and on below 15$^\circ$C. However, if the throttling range is kept at 2$^\circ$C and the setpoint type is changed to ZeroFlowPower, then the system will vary the flow linearly between zero for when the control temperature is at 15$^\circ$C to full flow at 13$^\circ$C.
@@ -1311,7 +1311,7 @@ \subsubsection{Inputs}
\paragraph{Field: Cooling Control Throttling Range}\label{field-cooling-control-throttling-range}
-This field specifies the range of temperature in degrees Celsuis over which the radiant system throttles from zero flow rate up to the maximum defined by the maximum cold water flow rate field described above. The throttling range parameter is used in conjunction with the control temperature and the setpoint type to define the response of the system to various conditions. The Cooling Control Temperature Schedule specifies the ``setpoint'' temperature that is to be met. This is used in conjunction with the Setpoint Type which defines whether the flow rate of the system is at zero flow or half flow when the parameter defined by the Temperature Control Type is equal to the setpoint temperature defined by the Cooling Control Temperature Schedule. See these other input parameters of this radiant system for more information on these different parameters. Note that when the throttling range is set to zero that this approximates an on-off system that is either fully on or totally off.
+This field specifies the range of temperature in degrees Celsius over which the radiant system throttles from zero flow rate up to the maximum defined by the maximum cold water flow rate field described above. The throttling range parameter is used in conjunction with the control temperature and the setpoint type to define the response of the system to various conditions. The Cooling Control Temperature Schedule specifies the ``setpoint'' temperature that is to be met. This is used in conjunction with the Setpoint Type which defines whether the flow rate of the system is at zero flow or half flow when the parameter defined by the Temperature Control Type is equal to the setpoint temperature defined by the Cooling Control Temperature Schedule. See these other input parameters of this radiant system for more information on these different parameters. Note that when the throttling range is set to zero that this approximates an on-off system that is either fully on or totally off.
For clarity, here is an example of how the flow rate to the system will be set. In this example, it is assumed that cooling control temperature setpoint is currently 25$^\circ$C, the cooling throttling range is 2$^\circ$C, and that the setpoint type is HalfFlowPower. The water flow rate to the radiant system will be zero when the controlling temperature (MAT, MRT, Operative Temperature, etc.; see control type field above) is at or below 24$^\circ$C and the maximum flow rate when the controlling temperature is at or above 26$^\circ$C. This represents a throttling range of 2$^\circ$C around the setpoint of 25$^\circ$C. In between 24$^\circ$C and 26$^\circ$C, the flow rate to the radiant system is varied linearly from zero flow at a control temperature of 24$^\circ$C to half flow at 15$^\circ$C to full flow at w6$^\circ$C. If the throttling range is changed to 0$^\circ$C or on-off control, then the system will be on above 25$^\circ$C and off below 25$^\circ$C. However, if the throttling range is kept at 2$^\circ$C and the setpoint type is changed to ZeroFlowPower, then the system will vary the flow linearly between zero for when the control temperature is at 25$^\circ$C to full flow at 27$^\circ$C.
@@ -1846,7 +1846,7 @@ \subsubsection{Inputs}\label{inputs-7-019}
\paragraph{Field: Heating Throttling Range}\label{field-heating-throttling-range}
-This field specifies the range of temperature in degrees Celsuis over which the radiant system throttles from zero flow heat input via the electric resistance wires up to the maximum defined by the maximum electrical power field described above. The throttling range parameter is used in conjunction with the control temperature and the setpoint type to define the response of the system to various conditions. The Heating Setpoint Temperature Schedule specifies the ``setpoint'' temperature that is to be met. This is used in conjunction with the Setpoint Type which defines whether the flow rate of the system is at zero heat input or half heat input when the parameter defined by the Temperature Control Type is equal to the setpoint temperature defined by the Heating Control Temperature Schedule. See these other input parameters of this radiant system for more information on these different parameters. Note that when the throttling range is set to zero that this approximates an on-off system that is either fully on or totally off.
+This field specifies the range of temperature in degrees Celsius over which the radiant system throttles from zero flow heat input via the electric resistance wires up to the maximum defined by the maximum electrical power field described above. The throttling range parameter is used in conjunction with the control temperature and the setpoint type to define the response of the system to various conditions. The Heating Setpoint Temperature Schedule specifies the ``setpoint'' temperature that is to be met. This is used in conjunction with the Setpoint Type which defines whether the flow rate of the system is at zero heat input or half heat input when the parameter defined by the Temperature Control Type is equal to the setpoint temperature defined by the Heating Control Temperature Schedule. See these other input parameters of this radiant system for more information on these different parameters. Note that when the throttling range is set to zero that this approximates an on-off system that is either fully on or totally off.
For clarity, here is an example of how the heat input fraction (of the unit capacity) to the system will be set. In this example, it is assumed that heating control temperature setpoint is currently 15$^\circ$C, the heating throttling range is 2$^\circ$C, and that the setpoint type is HalfFlowPower. The heat input rate to the radiant system will be zero when the controlling temperature (MAT, MRT, Operative Temperature, etc.; see control type field above) is at or above 16$^\circ$C and the maximum heat input when the controlling temperature is at or below 14$^\circ$C. This represents a throttling range of 2$^\circ$C around the setpoint of 15$^\circ$C. In between 14$^\circ$C and 16$^\circ$C, the heat input rate to the radiant system is varied linearly from full heat input at a control temperature of 14$^\circ$C to half heat input at 15$^\circ$C to zero heat input at 16$^\circ$C. If the throttling range is changed to 0$^\circ$C or on-off control, then the system will be off above 15$^\circ$C and on below 15$^\circ$C. However, if the throttling range is kept at 2$^\circ$C and the setpoint type is changed to ZeroFlowPower, then the system will vary the heat input linearly between zero for when the control temperature is at 15$^\circ$C to full heat input at 13$^\circ$C.
@@ -2013,7 +2013,7 @@ \subsubsection{Inputs}\label{inputs-9-015}
\paragraph{Field: Heating Throttling Range}\label{field-heating-throttling-range-1}
-This field specifies the range of temperature in degrees Celsuis over which the radiant system throttles from zero heat input via the electric resistance wires up to the maximum defined by the maximum electrical power field described above. The throttling range parameter is used in conjunction with the control temperature (see below) to define the response of the system to various zone conditions. The heating control temperature schedule specifies the ``setpoint'' temperature where the power input to the system is at half of the maximum power input. For example, if the heating control temperature setpoint is currently 15$^\circ$C and the heating throttling range is 2$^\circ$C, the electrical power supplied to the radiant system will be zero when the controlling temperature (Mean Air Temperature, Mean Radiant Temperature, and Operative Temperature; see control type field above) is at or above 16$^\circ$C and the maximum power input when the controlling temperature is at or below 14$^\circ$C. This represents a throttling range of 2$^\circ$C around the setpoint of 15$^\circ$C. In between 14$^\circ$C and 16$^\circ$C, the power input to the radiant system is varied linearly.
+This field specifies the range of temperature in degrees Celsius over which the radiant system throttles from zero heat input via the electric resistance wires up to the maximum defined by the maximum electrical power field described above. The throttling range parameter is used in conjunction with the control temperature (see below) to define the response of the system to various zone conditions. The heating control temperature schedule specifies the ``setpoint'' temperature where the power input to the system is at half of the maximum power input. For example, if the heating control temperature setpoint is currently 15$^\circ$C and the heating throttling range is 2$^\circ$C, the electrical power supplied to the radiant system will be zero when the controlling temperature (Mean Air Temperature, Mean Radiant Temperature, and Operative Temperature; see control type field above) is at or above 16$^\circ$C and the maximum power input when the controlling temperature is at or below 14$^\circ$C. This represents a throttling range of 2$^\circ$C around the setpoint of 15$^\circ$C. In between 14$^\circ$C and 16$^\circ$C, the power input to the radiant system is varied linearly.
\paragraph{Field: Heating Setpoint Temperature Schedule Name}\label{field-heating-setpoint-temperature-schedule-name-1}
@@ -2154,7 +2154,7 @@ \subsubsection{Inputs}\label{inputs-10-014}
\paragraph{Field: Maximum Outdoor Air Flow Rate}\label{field-maximum-outdoor-air-flow-rate-001}
-This field allows the user to enter the maximum volumetric flow rate of outdoor air that can be brought into the ventilated slab in m\(^{3}\)/sec.~ This parameter should be some real number greater than zero.~ Note that the value for this parameter may be less than the maximum air flow rate of the ventilated slab and this may affect the maximum fraction of outdoor air within the control strategy defined above. This parameter is an absolute maximum and will supercede any scheduled fraction of the ventilated slab maximum airflow rate. If ``FixedAmount'' type is selected as the outdoor air control strategy, this field will be ignored and be automatically set to be equal to the minimum outdoor air flow rate specified in the field above.
+This field allows the user to enter the maximum volumetric flow rate of outdoor air that can be brought into the ventilated slab in m\(^{3}\)/sec.~ This parameter should be some real number greater than zero.~ Note that the value for this parameter may be less than the maximum air flow rate of the ventilated slab and this may affect the maximum fraction of outdoor air within the control strategy defined above. This parameter is an absolute maximum and will supersede any scheduled fraction of the ventilated slab maximum airflow rate. If ``FixedAmount'' type is selected as the outdoor air control strategy, this field will be ignored and be automatically set to be equal to the minimum outdoor air flow rate specified in the field above.
\paragraph{Field: Maximum Outdoor Air Fraction or Temperature Schedule Name}\label{field-maximum-outdoor-air-fraction-or-temperature-schedule-name}
@@ -2321,7 +2321,7 @@ \subsubsection{Inputs}\label{inputs-10-014}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Air Flow Rate in this Ventilated Slab zone HVAC object. The scaled Maximum Air Flow Rate in turn is used to size cooling and heating capacity of the coils.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Air Flow Rate in this Ventilated Slab zone HVAC object. The scaled Maximum Air Flow Rate in turn is used to size cooling and heating capacity of the coils.
An example IDF with a ventilated slab is shown below.
@@ -2453,7 +2453,7 @@ \subsubsection{Outputs}\label{outputs-9-006}
\paragraph{Zone Ventilated Slab Coil Sensible Cooling Energy {[}J{]}}\label{zone-ventilated-slab-coil-sensible-cooling-energy-j}
-This field is the sensible cooling output of the cooling coli of the ventilated slab system to the zone it is serving in Joules over the timestep being reported.~ This is determined by outlet and zone air conditions, the mass flow rate through the ventilation slab system, and the timestep.
+This field is the sensible cooling output of the cooling coil of the ventilated slab system to the zone it is serving in Joules over the timestep being reported.~ This is determined by outlet and zone air conditions, the mass flow rate through the ventilation slab system, and the timestep.
\paragraph{Zone Ventilated Slab Coil Latent Cooling Rate {[}W{]}}\label{zone-ventilated-slab-coil-latent-cooling-rate-w}
@@ -2461,7 +2461,7 @@ \subsubsection{Outputs}\label{outputs-9-006}
\paragraph{Zone Ventilated Slab Coil Latent Cooling Energy {[}J{]}}\label{zone-ventilated-slab-coil-latent-cooling-energy-j}
-This field is the latent cooling output of the cooling coli of the ventilated slab system to the zone it is serving in Joules over the timestep being reported.~ This is determined by outlet and zone air conditions, the mass flow rate through the ventilation slab system, and the timestep.
+This field is the latent cooling output of the cooling coil of the ventilated slab system to the zone it is serving in Joules over the timestep being reported.~ This is determined by outlet and zone air conditions, the mass flow rate through the ventilation slab system, and the timestep.
\paragraph{Zone Ventilated Slab Air Mass Flow Rate {[}kg/s{]}}\label{zone-ventilated-slab-air-mass-flow-rate-kgs}
diff --git a/doc/input-output-reference/src/overview/group-refrigeration.tex b/doc/input-output-reference/src/overview/group-refrigeration.tex
index 1ad530f9f93..9592a0ecfa8 100644
--- a/doc/input-output-reference/src/overview/group-refrigeration.tex
+++ b/doc/input-output-reference/src/overview/group-refrigeration.tex
@@ -548,7 +548,7 @@ \subsubsection{Inputs}\label{inputs-1-036}
CaseTemperatureMethod
\end{itemize}
-This method defines the variation in latent case credits as a cubic function of Case Operating Temperature. The result from the cubic curve is multiplied by the difference between the rated ambient relative humidity and the actual zone relative humidity, and one minus this value is multiplied by the Rated LHR to give the operating LHR at the actual zone humidity condition. (Representative cooefficient values for single-shelf horizontal and multi-shelf vertical display cases are given in the EnergyPlus Engineering Reference.)
+This method defines the variation in latent case credits as a cubic function of Case Operating Temperature. The result from the cubic curve is multiplied by the difference between the rated ambient relative humidity and the actual zone relative humidity, and one minus this value is multiplied by the Rated LHR to give the operating LHR at the actual zone humidity condition. (Representative coefficient values for single-shelf horizontal and multi-shelf vertical display cases are given in the EnergyPlus Engineering Reference.)
\begin{itemize}
\tightlist
@@ -656,7 +656,7 @@ \subsubsection{Inputs}\label{inputs-1-036}
CaseTemperatureMethod
\end{itemize}
-This method defines the variation in defrost energy as a cubic function of Case Operating Temperature. The result from the cubic curve is multiplied by the difference between the rated ambient relative humidity and the actual zone relative humidity, and one minus this value is multiplied by the Case Defrost Power to give the (average) operating defrost power at the actual zone humidity condition. (Representative cooefficient values for single-shelf horizontal and multi-shelf vertical display cases are given in the EnergyPlus Engineering Reference.)
+This method defines the variation in defrost energy as a cubic function of Case Operating Temperature. The result from the cubic curve is multiplied by the difference between the rated ambient relative humidity and the actual zone relative humidity, and one minus this value is multiplied by the Case Defrost Power to give the (average) operating defrost power at the actual zone humidity condition. (Representative coefficient values for single-shelf horizontal and multi-shelf vertical display cases are given in the EnergyPlus Engineering Reference.)
\begin{itemize}
\tightlist
@@ -935,7 +935,7 @@ \subsubsection{Outputs}\label{outputs-1-022}
\subsection{Refrigeration:CaseAndWalkInList}\label{refrigerationcaseandwalkinlist}
-This object provides a list of all the refrigerated cases and/or walk in coolers cooled by a single refrigeration system (ref: Refrigeraion:CompressorRack and \hyperref[refrigerationsystem]{Refrigeration:System}). This list is extensible. Note that the names of all cases, walk-ins,air chillers, and caseandwalkinlists must be unique.~ That is, you cannot give a list the same name as one of the cases.~ Similarly, a walkin cannot have the same name as a case.This list may contain a combination of case and walk-in names OR a list of air chiller names.~ Air chillers may not be included in any list that also includes cases or walk-ins.
+This object provides a list of all the refrigerated cases and/or walk in coolers cooled by a single refrigeration system (ref: Refrigeration:CompressorRack and \hyperref[refrigerationsystem]{Refrigeration:System}). This list is extensible. Note that the names of all cases, walk-ins,air chillers, and caseandwalkinlists must be unique.~ That is, you cannot give a list the same name as one of the cases.~ Similarly, a walkin cannot have the same name as a case.This list may contain a combination of case and walk-in names OR a list of air chiller names.~ Air chillers may not be included in any list that also includes cases or walk-ins.
\subsubsection{Inputs}\label{inputs-2-033}
@@ -1053,7 +1053,7 @@ \subsubsection{Field: Insulated Floor Surface Area}\label{field-insulated-floor-
\subsubsection{Field: Insulated Floor U-Value}\label{field-insulated-floor-u-value}
-The floor themal transmittance (in W/m\(^{2}\)-K). This value has a default value of 0.3154. (This corresponds to R18 in Archaic American Insulation Units.~ To convert other R-values to thermal transmittance, divide 5.678 by the R-value.~ For example, R15 is 0.3785 W/m\(^{2}\)-K and R5 is 1.136 W/m\(^{2}\)-K.)
+The floor thermal transmittance (in W/m\(^{2}\)-K). This value has a default value of 0.3154. (This corresponds to R18 in Archaic American Insulation Units.~ To convert other R-values to thermal transmittance, divide 5.678 by the R-value.~ For example, R15 is 0.3785 W/m\(^{2}\)-K and R5 is 1.136 W/m\(^{2}\)-K.)
\textbf{\emph{THE REMAINING 12 FIELDS FOR THE WALK-IN COOLER MUST BE REPEATED FOR EACH ZONE WHICH IS IN CONTACT WITH A WALK-IN WALL, CEILING, OR DOOR. This object is extensible, so additional fields of this type can be added to the end of this object by repeating the last 12 fields in the object.}}
@@ -1067,7 +1067,7 @@ \subsubsection{Field: Total Insulated Surface Area Facing~ Zone \textless{}x\tex
\subsubsection{Field: Insulated Surface U-Value Facing Zone \textless{}x\textgreater{}}\label{field-insulated-surface-u-value-facing-zone-x}
-The surface (walls and ceilings) themal transmittance (in W/m\(^{2}\)-K). This value has a default value of 0.3154. (This corresponds to R18 in Archaic American Insulation Units.~ To convert other R-values to thermal transmittance, divide 5.678 by the R-value.~ For example, R15 is 0.3785 W/m\(^{2}\)-K and R5 is 1.136 W/m\(^{2}\)-K.)
+The surface (walls and ceilings) thermal transmittance (in W/m\(^{2}\)-K). This value has a default value of 0.3154. (This corresponds to R18 in Archaic American Insulation Units.~ To convert other R-values to thermal transmittance, divide 5.678 by the R-value.~ For example, R15 is 0.3785 W/m\(^{2}\)-K and R5 is 1.136 W/m\(^{2}\)-K.)
\subsubsection{Field: Area of Glass Reach In Doors Facing Zone \textless{}x\textgreater{}}\label{field-area-of-glass-reach-in-doors-facing-zone-x}
@@ -1079,7 +1079,7 @@ \subsubsection{Field: Height of Glass Reach In Doors Facing Zone \textless{}x\te
\subsubsection{Field: Glass Reach In Door U-Value Facing Zone \textless{}x\textgreater{}}\label{field-glass-reach-in-door-u-value-facing-zone-x}
-The glass door themal transmittance (in W/m\(^{2}\)-K). This field has a default value of 1.136. (This corresponds to R5 in Archaic American Insulation Units.)
+The glass door thermal transmittance (in W/m\(^{2}\)-K). This field has a default value of 1.136. (This corresponds to R5 in Archaic American Insulation Units.)
\subsubsection{Field: Glass Reach In Door Opening Schedule Name Facing Zone \textless{}x\textgreater{}}\label{field-glass-reach-in-door-opening-schedule-name-facing-zone-x}
@@ -1095,7 +1095,7 @@ \subsubsection{Field: Height of Stocking Doors Facing Zone \textless{}x\textgrea
\subsubsection{Field: Stocking Door U-Value Facing Zone \textless{}x\textgreater{}}\label{field-stocking-door-u-value-facing-zone-x}
-The stocking door themal transmittance (in W/m\(^{2}\)-K). This value has a default value of 0.3785. (This corresponds to R15 in Archaic American Insulation Units.)
+The stocking door thermal transmittance (in W/m\(^{2}\)-K). This value has a default value of 0.3785. (This corresponds to R15 in Archaic American Insulation Units.)
\subsubsection{Field: Stocking Door Opening Schedule Name Facing Zone \textless{}x\textgreater{}}\label{field-stocking-door-opening-schedule-name-facing-zone-x}
@@ -1390,7 +1390,7 @@ \subsubsection{Inputs}\label{inputs-3-029}
, !- Refrigeration Transfer Load or TransferLoad List Name
AirCooledCondenserA, !- Refrigeration Condenser Name
MediumTempCompressorlist, !- Refrigeration Compressor or CompressorList Name
- 25.0, !- Minimum Condensing Temperture {C}
+ 25.0, !- Minimum Condensing Temperature {C}
R134a, !- Refrigeration System Working Fluid
ConstantSuctionTemperature, !- Suction Temperature Control Type
, !- Optional mechanical subcooler name
@@ -1410,7 +1410,7 @@ \subsubsection{Inputs}\label{inputs-3-029}
, !- Refrigeration Transfer Load or TransferLoad List Name
AirCooledCondenserB, !- Refrigeration Condenser Name
LowStageCompressorList, !- Refrigeration Compressor or CompressorList Name
- 25.0, !- Minimum Condensing Temperture {C}
+ 25.0, !- Minimum Condensing Temperature {C}
R404A, !- Refrigeration System Working Fluid
ConstantSuctionTemperature, !- Suction Temperature Control
, !- Optional mechanical subcooler name
@@ -1634,7 +1634,7 @@ \subsubsection{Outputs}\label{outputs-2-018}
\paragraph{Refrigeration System Total Cases and Walk Ins Heat Transfer Energy {[}J{]}}\label{refrigeration-system-total-cases-and-walk-ins-heat-transfer-energy-j}
-This output is the total heat transfer energy from the refrigerated cases and walk-ins served directly by this system in Joules. It is the sum of all of the heat transfered for the refrigerated cases and walk-ins that are connected directly to this system. This value does not include compressor or condenser fan heat or the heat transfer for cases and walk-ins served by any connected secondary systems.
+This output is the total heat transfer energy from the refrigerated cases and walk-ins served directly by this system in Joules. It is the sum of all of the heat transferred for the refrigerated cases and walk-ins that are connected directly to this system. This value does not include compressor or condenser fan heat or the heat transfer for cases and walk-ins served by any connected secondary systems.
\paragraph{Refrigeration System Total Transferred Load Heat Transfer Rate {[}W{]}}\label{refrigeration-system-total-transferred-load-heat-transfer-rate-w}
@@ -1642,7 +1642,7 @@ \subsubsection{Outputs}\label{outputs-2-018}
\paragraph{Refrigeration System Total Transferred Load Heat Transfer Energy {[}J{]}}\label{refrigeration-system-total-transferred-load-heat-transfer-energy-j}
-This output is the sum of the heat transfered for any secondary loops, cascade condensers, and mechanical subcoolers cooled by this system, minus the benefit of any mechanical subcooler providing cooling to this system in Joules. Therefore, if the only transfer load between two systems is a mechanical subcooler, the same amount will show as a negative value for the system receiving the cooling effect and as a positive number for the system serving that cooling load. It also includes the pump energy for any secondary loops and the compressor energy for any cascade condenser systems that are cooled by this system. (See the Engineering Reference for more details about the loads placed by secondary systems upon the primary system.)
+This output is the sum of the heat transferred for any secondary loops, cascade condensers, and mechanical subcoolers cooled by this system, minus the benefit of any mechanical subcooler providing cooling to this system in Joules. Therefore, if the only transfer load between two systems is a mechanical subcooler, the same amount will show as a negative value for the system receiving the cooling effect and as a positive number for the system serving that cooling load. It also includes the pump energy for any secondary loops and the compressor energy for any cascade condenser systems that are cooled by this system. (See the Engineering Reference for more details about the loads placed by secondary systems upon the primary system.)
\paragraph{Refrigeration System Total Suction Pipe Heat Gain Rate {[}W{]}}\label{refrigeration-system-total-suction-pipe-heat-gain-rate-w}
@@ -1772,7 +1772,7 @@ \subsubsection{Outputs}\label{outputs-2-018}
\paragraph{Refrigeration Air Chiller System Total Case and Walk In Heat Transfer Energy {[}J{]}}\label{refrigeration-air-chiller-system-total-case-and-walk-in-heat-transfer-energy-j}
-This output is the total heat transfer energy from the refrigerated cases and walk-ins served directly by this system in Joules. It is the sum of all of the heat transfered for the refrigerated cases and walk-ins that are connected directly to this system. This value does not include compressor or condenser fan heat or the heat transfer for cases and walk-ins served by any connected secondary systems.
+This output is the total heat transfer energy from the refrigerated cases and walk-ins served directly by this system in Joules. It is the sum of all of the heat transferred for the refrigerated cases and walk-ins that are connected directly to this system. This value does not include compressor or condenser fan heat or the heat transfer for cases and walk-ins served by any connected secondary systems.
\paragraph{Refrigeration Air Chiller System Total Transferred Load Heat Transfer Rate {[}W{]}}\label{refrigeration-air-chiller-system-total-transferred-load-heat-transfer-rate-w}
@@ -1780,7 +1780,7 @@ \subsubsection{Outputs}\label{outputs-2-018}
\paragraph{Refrigeration Air Chiller System Total Transferred Load Heat Transfer Energy {[}J{]}}\label{refrigeration-air-chiller-system-total-transferred-load-heat-transfer-energy-j}
-This output is the sum of the heat transfered for any secondary loops, cascade condensers, and mechanical subcoolers cooled by this system, minus the benefit of any mechanical subcooler providing cooling to this system in Joules. Therefore, if the only transfer load between two systems is a mechanical subcooler, the same amount will show as a negative value for the system receiving the cooling effect and as a positive number for the system serving that cooling load. It also includes the pump energy for any secondary loops and the compressor energy for any cascade condenser systems that are cooled by this system. (See the Engineering Reference for more details about the loads placed by secondary systems upon the primary system.)
+This output is the sum of the heat transferred for any secondary loops, cascade condensers, and mechanical subcoolers cooled by this system, minus the benefit of any mechanical subcooler providing cooling to this system in Joules. Therefore, if the only transfer load between two systems is a mechanical subcooler, the same amount will show as a negative value for the system receiving the cooling effect and as a positive number for the system serving that cooling load. It also includes the pump energy for any secondary loops and the compressor energy for any cascade condenser systems that are cooled by this system. (See the Engineering Reference for more details about the loads placed by secondary systems upon the primary system.)
\paragraph{Refrigeration Air Chiller System Total Suction Pipe Heat Gain Rate {[}W{]}}\label{refrigeration-air-chiller-system-total-suction-pipe-heat-gain-rate-w}
@@ -2795,7 +2795,7 @@ \subsubsection{Inputs}\label{inputs-9-016}
746., !- Rated Condenser Fan Power
0.25, !- Minimum air flow fraction through condenser fan {dimensionless}
6.63 , !- Evaporative Condenser Approach Temp Const, {C}
- 0.468 , !- Evaporative Condenser Approach Temp HRCF Cooefficient
+ 0.468 , !- Evaporative Condenser Approach Temp HRCF Coefficient
17.93 , !- Evaporative Condenser Approach Temp 1/hrcf coefficient
-0.322, !- Evaporative Condenser Approach Temp Twb coefficient {1/C}
0.6 , !- Minimum Condenser Capacity Factor
@@ -3524,7 +3524,7 @@ \subsubsection{Inputs}\label{inputs-14-011}
For ``FluidAlwaysLiquid'', this name must correspond to either an ethylene or propylene glycol (ref: \hyperref[fluidpropertiesglycolconcentration]{FluidProperties:GlycolConcentration}) or to a user-defined glycol (ref: \hyperref[fluidpropertiesname]{FluidProperties:Name} and FluidProperties: GlycolConcentration) in the input file. Note that the corresponding property data, including \hyperref[fluidpropertiesconcentration]{FluidProperties:Concentration}, \hyperref[fluidpropertiestemperatures]{FluidProperties:Temperatures}, and \hyperref[fluidpropertiesglycolconcentration]{FluidProperties:GlycolConcentration} must also be included in the input file and are provided in GlycolPropertiesRefData.idf for typical ethylene and propylene glycols.
-For ``FluidPhaseChange'', the refrigerant used by the secondary system must be listed in the \hyperref[fluidpropertiesname]{FluidProperties:Name} object.~ The corresponding property data must also be supplied in the input file. Property data for many refrigererants, including R11, R123, R134A, R12, R22, R404A, R507A, R410A, and R744, are available in FluidPropertiesRefData.idf.
+For ``FluidPhaseChange'', the refrigerant used by the secondary system must be listed in the \hyperref[fluidpropertiesname]{FluidProperties:Name} object.~ The corresponding property data must also be supplied in the input file. Property data for many refrigerants, including R11, R123, R134A, R12, R22, R404A, R507A, R410A, and R744, are available in FluidPropertiesRefData.idf.
\paragraph{Field: Evaporator Capacity}\label{field-evaporator-capacity}
@@ -3536,7 +3536,7 @@ \subsubsection{Inputs}\label{inputs-14-011}
For ``FluidAlwaysLiquid'' systems, this is the rated evaporator secondary fluid flow rate in m\(^{3}\)/s.~ If this variable is specified and the rated evaporator capacity in watts is not, then the rated capacity will be calculated. At least one of these two input variables is required.
-For ``FluidPhaseChange'', this field is not used (see ``Phase Cange Circulating Rate'').
+For ``FluidPhaseChange'', this field is not used (see ``Phase Change Circulating Rate'').
\paragraph{Field:Evaporator Evaporating Temperature}\label{fieldevaporator-evaporating-temperature}
@@ -3596,7 +3596,7 @@ \subsubsection{Inputs}\label{inputs-14-011}
\paragraph{Field: Sum UA Receiver/Separator Shell}\label{field-sum-ua-receiverseparator-shell}
-This optional field is typically used when trying to compare the impact of refrigeration component heat gains on system performance, particularly in comparing a conventional primary DX system to a secondary system. Enter the value for receiver/separator heat gain (in W/C).~ That is, sum up the product of the tank insulaton conductance times the outer tank insulation surface area. Please see the Engineering Reference for guidance in calculating this value.
+This optional field is typically used when trying to compare the impact of refrigeration component heat gains on system performance, particularly in comparing a conventional primary DX system to a secondary system. Enter the value for receiver/separator heat gain (in W/C).~ That is, sum up the product of the tank insulation conductance times the outer tank insulation surface area. Please see the Engineering Reference for guidance in calculating this value.
\paragraph{Field: Receiver/Separator Zone Name}\label{field-receiverseparator-zone-name}
diff --git a/doc/input-output-reference/src/overview/group-room-air-models.tex b/doc/input-output-reference/src/overview/group-room-air-models.tex
index 1db9af4809f..84071d2a658 100644
--- a/doc/input-output-reference/src/overview/group-room-air-models.tex
+++ b/doc/input-output-reference/src/overview/group-room-air-models.tex
@@ -790,7 +790,7 @@ \subsubsection{Inputs}\label{inputs-2016-06-17-0938}
\paragraph{Field: Diffuser Type}\label{field-diffuser-type}
-The choices for this alpha field are \textbf{Swirl} \textbar{} \textbf{VariableArea} \textbar{} \textbf{HorizontalSwirl \textbar{} LinearBarGrille \textbar{} Custom.} The swirl and displacement diffusers are fixed area diffusers. The variable area diffusers maintain an approximately constant exit velocity. Linear bar grilles are normally used in exterior zonesand are fixed area diffusers. Custom is used to signify that the user intends to input the coefficients A -- E (see below) rather than let the program set the coefficients based on diffuser type. The default is \emph{Swirl}.
+The choices for this alpha field are \textbf{Swirl} \textbar{} \textbf{VariableArea} \textbar{} \textbf{HorizontalSwirl \textbar{} LinearBarGrille \textbar{} Custom.} The swirl and displacement diffusers are fixed area diffusers. The variable area diffusers maintain an approximately constant exit velocity. Linear bar grilles are normally used in exterior zones and are fixed area diffusers. Custom is used to signify that the user intends to input the coefficients A -- E (see below) rather than let the program set the coefficients based on diffuser type. The default is \emph{Swirl}.
\paragraph{Field: Transition Height}\label{field-transition-height}
@@ -966,7 +966,7 @@ \subsubsection{Inputs}\label{inputs-11-016}
\paragraph{Field: Diffuser Type}\label{field-diffuser-type-1}
-The choices for this alpha field are \textbf{Swirl} \textbar{} \textbf{VariableArea} \textbar{} \textbf{HorizontalSwirl \textbar{} LinearBarGrille \textbar{} Custom.} The swirl and displacement diffusers are fixed area diffusers. The variable area diffusers maintain an approximately constant exit velocity. Linear bar grilles are normally used in exterior zonesand are fixed area diffusers. Custom is used to signify that the user intends to input the coefficients A -- E (see below) rather than let the program set the coefficients based on diffuser type. The default is \emph{Swirl}.
+The choices for this alpha field are \textbf{Swirl} \textbar{} \textbf{VariableArea} \textbar{} \textbf{HorizontalSwirl \textbar{} LinearBarGrille \textbar{} Custom.} The swirl and displacement diffusers are fixed area diffusers. The variable area diffusers maintain an approximately constant exit velocity. Linear bar grilles are normally used in exterior zones and are fixed area diffusers. Custom is used to signify that the user intends to input the coefficients A -- E (see below) rather than let the program set the coefficients based on diffuser type. The default is \emph{Swirl}.
\paragraph{Field: Transition Height}\label{field-transition-height-1}
diff --git a/doc/input-output-reference/src/overview/group-setpoint-managers.tex b/doc/input-output-reference/src/overview/group-setpoint-managers.tex
index 15185582eb3..5f0ffdb8a6b 100644
--- a/doc/input-output-reference/src/overview/group-setpoint-managers.tex
+++ b/doc/input-output-reference/src/overview/group-setpoint-managers.tex
@@ -107,7 +107,7 @@ \subsubsection{Inputs}\label{inputs-043}
\begin{itemize}
\item
- Temperature Temperture of fluid at node ( °C)
+ Temperature Temperature of fluid at node ( °C)
\item
MaximumTemperature Maximum temperature of fluid at node ( °C)
\item
@@ -329,7 +329,7 @@ \subsubsection{Inputs}\label{inputs-3-033}
\subsection{SetpointManager:SingleZone:Heating}\label{setpointmanagersinglezoneheating}
-The Single Zone Heating Setpoint Manager allows a component to be controlled based on the load required to meet the zone heating setpoint. Ths setpoint manager detects the control zone load to meet the current heating setpoint, zone inlet node flow rate, and zone node temperature, and calculates a setpoint temperature for the supply air that will satisfy the zone heating load for the control zone. This setpoint manager creates a variable temperature system. The input consists of the setpoint manager name, the controlled variable type, the minimum and maximum supply air temperatures, the name of the control zone, the name of the control zone node, the name of the control zone inlet node, and the name of a node or node list containing the nodes whose setpoint temperatures are to be set by this manager.
+The Single Zone Heating Setpoint Manager allows a component to be controlled based on the load required to meet the zone heating setpoint. The setpoint manager detects the control zone load to meet the current heating setpoint, zone inlet node flow rate, and zone node temperature, and calculates a setpoint temperature for the supply air that will satisfy the zone heating load for the control zone. This setpoint manager creates a variable temperature system. The input consists of the setpoint manager name, the controlled variable type, the minimum and maximum supply air temperatures, the name of the control zone, the name of the control zone node, the name of the control zone inlet node, and the name of a node or node list containing the nodes whose setpoint temperatures are to be set by this manager.
\subsubsection{Inputs}\label{inputs-4-030}
@@ -515,7 +515,7 @@ \subsubsection{Inputs}\label{inputs-7-024}
Controller:WaterCoil,
- Central Cooling Coil Contoller 1, !- Name
+ Central Cooling Coil Controller 1, !- Name
TEMPandHUMRAT, !- Control Variable
Reverse, !- Action
FLOW, !- Actuator Variable
@@ -1535,7 +1535,7 @@ \subsubsection{Inputs}\label{inputs-25-002}
\paragraph{Field: Setpoint Node or NodeList Name}\label{field-setpoint-node-or-nodelist-name-20}
-This alpha field is the name of a \hyperref[nodelist]{NodeList} objet containing the names of the HVAC system nodes, or the name of a system node, for which temperature setpoints will be established by this setpoint manager.
+This alpha field is the name of a \hyperref[nodelist]{NodeList} object containing the names of the HVAC system nodes, or the name of a system node, for which temperature setpoints will be established by this setpoint manager.
An example input follows.
@@ -1573,7 +1573,7 @@ \subsubsection{Field: Control Zone Name}\label{field-control-zone-name-4}
\subsubsection{Field: Setpoint Node or NodeList Name}\label{field-setpoint-node-or-nodelist-name-21}
-This alpha field is the name of a \hyperref[nodelist]{NodeList} objet containing the names of the HVAC system nodes, or the name of a system node, for which temperature setpoints will be established by this setpoint manager.
+This alpha field is the name of a \hyperref[nodelist]{NodeList} object containing the names of the HVAC system nodes, or the name of a system node, for which temperature setpoints will be established by this setpoint manager.
An example input follows.
@@ -1849,7 +1849,7 @@ \subsubsection{Inputs}
MaximumHumidityRatio, !- Control Variable
0.00924, !- Setpoint at Low Reference Humidity Ratio (kgWater/kgDryAir)
0.00600, !- Setpoint at High Reference Humidity Ratio (kgWater/kgDryAir)
- 0.00850, !- Low Reference Humdity Ratio (kgWater/kgDryAir)
+ 0.00850, !- Low Reference Humidity Ratio (kgWater/kgDryAir)
0.01000, !- High Reference Humidity Ratio (kgWater/kgDryAir)
Plenum-1 Out Node, !- Reference Node Name
DOAS Cooling Coil Outlet; !- Setpoint Node or NodeList Name
diff --git a/doc/input-output-reference/src/overview/group-simulation-parameters.tex b/doc/input-output-reference/src/overview/group-simulation-parameters.tex
index 2143569dc80..52dd4670c0d 100644
--- a/doc/input-output-reference/src/overview/group-simulation-parameters.tex
+++ b/doc/input-output-reference/src/overview/group-simulation-parameters.tex
@@ -154,7 +154,7 @@ \subsubsection{Inputs}\label{inputs-3-034}
\paragraph{Warmup Convergence}\label{warmup-convergence}
-The following two fields along with the minimum and maximum number of warmup days (also in this object) define the user specified criteria for when EnergyPlus will ``converge'' at each environment (each sizing period or run period set as Yes in the \hyperref[simulationcontrol]{SimulationControl} object). At the beginning of a new enviroment the building model is reinitialized so that temperatures are initialized to 23C and zone humidity ratios are initialized to the outdoor humidity ratio (unless this initialization is suppressed using the input field called Begin Environment Reset Mode in the \hyperref[sizingperioddesignday]{SizingPerod:DesignDay} object). EnergyPlus repeatedly ``runs'' the first day of the environment or until it reaches ``maximum number of warmup days'' or the convergence criteria are met. Note that setting the convergence tolerance values too loose will cause the program to be satisfied too early and you may not get the results you expect from the actual simulation. However too tight of a value and the program will repeat the first day too many times leading to excessive simulation run time.
+The following two fields along with the minimum and maximum number of warmup days (also in this object) define the user specified criteria for when EnergyPlus will ``converge'' at each environment (each sizing period or run period set as Yes in the \hyperref[simulationcontrol]{SimulationControl} object). At the beginning of a new environment the building model is reinitialized so that temperatures are initialized to 23C and zone humidity ratios are initialized to the outdoor humidity ratio (unless this initialization is suppressed using the input field called Begin Environment Reset Mode in the \hyperref[sizingperioddesignday]{SizingPerod:DesignDay} object). EnergyPlus repeatedly ``runs'' the first day of the environment or until it reaches ``maximum number of warmup days'' or the convergence criteria are met. Note that setting the convergence tolerance values too loose will cause the program to be satisfied too early and you may not get the results you expect from the actual simulation. However too tight of a value and the program will repeat the first day too many times leading to excessive simulation run time.
\paragraph{Field: Loads Convergence Tolerance Value}\label{field-loads-convergence-tolerance-value}
@@ -254,7 +254,7 @@ \subsubsection{Inputs}\label{inputs-3-034}
You may be able to increase the Maximum Number of Warmup Days and get convergence, but some anomalous buildings may still not converge. Simulation proceeds for x warmup days until ``convergence'' is reached (see the discussion under the Temperature Convergence Tolerance Value field in this object, just above).
-The value in this field is an overall parameter for all types of environments in the simulation. The maximum nmber of warmup days can also be controlled separately for individual designgdays using the input field Maximum Number Warmup Days in the \hyperref[sizingperioddesignday]{SizingPerod:DesignDay} object.
+The value in this field is an overall parameter for all types of environments in the simulation. The maximum number of warmup days can also be controlled separately for individual design days using the input field Maximum Number Warmup Days in the \hyperref[sizingperioddesignday]{SizingPerod:DesignDay} object.
\paragraph{Field: Minimum Number of Warmup Days}\label{field-minimum-number-of-warmup-days}
diff --git a/doc/input-output-reference/src/overview/group-solar-collectors.tex b/doc/input-output-reference/src/overview/group-solar-collectors.tex
index ecab2c63e9f..fe8fd6b1b72 100644
--- a/doc/input-output-reference/src/overview/group-solar-collectors.tex
+++ b/doc/input-output-reference/src/overview/group-solar-collectors.tex
@@ -4,7 +4,7 @@ \section{Group Solar Collectors}\label{group-solar-collectors}
In EnergyPlus solar collectors are components that are connected to the plant loop. A solar heating system can be constructed with a combination of solar collectors, pumps, and hot water tanks.
-Flate plate solar collectors are defined using two objects: \hyperref[solarcollectorflatplatewater]{SolarCollector:FlatPlate:Water} and \hyperref[solarcollectorperformanceflatplate]{SolarCollectorPerformance:FlatPlate}. Similarly, Integral-Collector-Storage (ICS) solar collectors are defined using two objects: \hyperref[solarcollectorintegralcollectorstorage]{SolarCollector:IntegralCollectorStorage}, and \hyperref[solarcollectorperformanceintegralcollectorstorage]{SolarCollectorPerformance:IntegralCollectorStorage}. The \hyperref[solarcollectorflatplatewater]{SolarCollector:FlatPlate:Water} and \hyperref[solarcollectorintegralcollectorstorage]{SolarCollector:IntegralCollectorStorage} objects describe the plant component connections. These object also reference \hyperref[solarcollectorperformanceflatplate]{SolarCollectorPerformance:FlatPlate} and \hyperref[solarcollectorperformanceintegralcollectorstorage]{SolarCollectorPerformance:IntegralCollectorStorage} performance objects which contains the thermal and optical performance test data for a specific make and model of collector. Parameters are defined separately so that these values can be organized into a reference data set and need only be entered once if for an array of the same type of collectors.
+Flat plate solar collectors are defined using two objects: \hyperref[solarcollectorflatplatewater]{SolarCollector:FlatPlate:Water} and \hyperref[solarcollectorperformanceflatplate]{SolarCollectorPerformance:FlatPlate}. Similarly, Integral-Collector-Storage (ICS) solar collectors are defined using two objects: \hyperref[solarcollectorintegralcollectorstorage]{SolarCollector:IntegralCollectorStorage}, and \hyperref[solarcollectorperformanceintegralcollectorstorage]{SolarCollectorPerformance:IntegralCollectorStorage}. The \hyperref[solarcollectorflatplatewater]{SolarCollector:FlatPlate:Water} and \hyperref[solarcollectorintegralcollectorstorage]{SolarCollector:IntegralCollectorStorage} objects describe the plant component connections. These object also reference \hyperref[solarcollectorperformanceflatplate]{SolarCollectorPerformance:FlatPlate} and \hyperref[solarcollectorperformanceintegralcollectorstorage]{SolarCollectorPerformance:IntegralCollectorStorage} performance objects which contains the thermal and optical performance test data for a specific make and model of collector. Parameters are defined separately so that these values can be organized into a reference data set and need only be entered once if for an array of the same type of collectors.
\subsection{SolarCollector:FlatPlate:Water}\label{solarcollectorflatplatewater}
@@ -453,7 +453,7 @@ \subsubsection{Inputs}\label{inputs-4-032}
\paragraph{Field: Water Outlet Node Name}\label{field-water-outlet-node-name-002}
-This field is the name of a plant loop node that seves as the outlet from the PVT collector. This field is only used if the Thermal Working Fluid Type is set to Plant/Water.
+This field is the name of a plant loop node that serves as the outlet from the PVT collector. This field is only used if the Thermal Working Fluid Type is set to Plant/Water.
\paragraph{Field: Air Inlet Node Name}\label{field-air-inlet-node-name-006}
diff --git a/doc/input-output-reference/src/overview/group-surface-construction-elements.tex b/doc/input-output-reference/src/overview/group-surface-construction-elements.tex
index 2c95cba0363..6d45b41541f 100644
--- a/doc/input-output-reference/src/overview/group-surface-construction-elements.tex
+++ b/doc/input-output-reference/src/overview/group-surface-construction-elements.tex
@@ -301,7 +301,7 @@ \subsubsection{Inputs}\label{empd-inputs}
\(\rho_{material}\) = dry density of material, kg/m$^3$;
-\(\frac{du}{d\phi}\) = slope of moisture soprtion curve, \(a b \phi^{b-1} + c d \phi^{d-1}\).
+\(\frac{du}{d\phi}\) = slope of moisture sorption curve, \(a b \phi^{b-1} + c d \phi^{d-1}\).
If this field is left blank or set to \texttt{autocalculate}, the above equation will be used to calculate the surface layer penetration depth assuming a $\tau_{surf}$ of 24 hours.
@@ -1917,7 +1917,7 @@ \subsubsection{Inputs}\label{inputs-16-011}
\paragraph{Field: Specific Heat Ratio}\label{field-specific-heat-ratio-1}
-The specific heat ratio for gas.~ The specific heat ratio of a gas is the ratio of the specific heat at contant pressure, to the specific heat at constant volume.~ Used only if Gas Type = Custom.
+The specific heat ratio for gas.~ The specific heat ratio of a gas is the ratio of the specific heat at constant pressure, to the specific heat at constant volume.~ Used only if Gas Type = Custom.
An IDF example:
@@ -2919,17 +2919,17 @@ \subsubsection{Inputs}\label{inputs-25-003}
\subsection{WindowMaterial:Shade:EquivalentLayer}\label{windowmaterialshadeequivalentlayer}
-This object specifies the properties of Equivalent Layer window shade (roller blind) materials. Shades are considered to be thin, flat and perfect diffusers (all transmitted and reflected radiation is hemispherically-diffuse). However, shades can have beam-beam transmittance by virtue of their material openness.~ The beam-beam transmittence is assumed to be the same for both sides of the shade and is the same as the openness area fraction. Beam-diffuse transmittance and reflectance, and emissivity properties can be different for front and back side of the shade.Window shades can be placed on the inside of the window, on the outside of the window, or between glass layers. WindowMaterial:Shade:EquivalentLayer is used for roller blinds. The off-normal solar property calculation of shades (roller blind) is based on a set of correlations developed from measurement of samples of commercially produced roller blind material with openness fraction less than 0.14. The model is not intended for materials with unusually high values of openness and should be limited to a maximum openness fraction of 0.20. The visible spectrum solar properties input fields are not used currently hence can be left blank. The equivalent layer window shade model does not support \hyperref[windowpropertyshadingcontrol]{WindowShadingControl}.
+This object specifies the properties of Equivalent Layer window shade (roller blind) materials. Shades are considered to be thin, flat and perfect diffusers (all transmitted and reflected radiation is hemispherically-diffuse). However, shades can have beam-beam transmittance by virtue of their material openness.~ The beam-beam transmittance is assumed to be the same for both sides of the shade and is the same as the openness area fraction. Beam-diffuse transmittance and reflectance, and emissivity properties can be different for front and back side of the shade.Window shades can be placed on the inside of the window, on the outside of the window, or between glass layers. WindowMaterial:Shade:EquivalentLayer is used for roller blinds. The off-normal solar property calculation of shades (roller blind) is based on a set of correlations developed from measurement of samples of commercially produced roller blind material with openness fraction less than 0.14. The model is not intended for materials with unusually high values of openness and should be limited to a maximum openness fraction of 0.20. The visible spectrum solar properties input fields are not used currently hence can be left blank. The equivalent layer window shade model does not support \hyperref[windowpropertyshadingcontrol]{WindowShadingControl}.
\subsubsection{Inputs}\label{inputs-26-002}
\paragraph{Field: Name}\label{field-name-20-003}
-Name of the shade. It is referenced as an inside, inbetween or outside layer in an equivalent layer~ window construction.
+Name of the shade. It is referenced as an inside, in-between or outside layer in an equivalent layer~ window construction.
\paragraph{Field: Shade Beam-Beam Solar Transmittance}\label{field-shade-beam-beam-solar-transmittance}
-This value is the beam-beam transmittance of the shade at normal incidence and it is the same as the openness area fraction of the shade material. Assumed to be the same for front and back sides of the roller blinds.~ The minimum value is 0.0 and maximum value is less than 1.0.~ The default value is 0.0. For most common shade materials (e.g.~Roller Blinds) the material oppeness fraction doesn't exceed 0.20.
+This value is the beam-beam transmittance of the shade at normal incidence and it is the same as the openness area fraction of the shade material. Assumed to be the same for front and back sides of the roller blinds.~ The minimum value is 0.0 and maximum value is less than 1.0.~ The default value is 0.0. For most common shade materials (e.g.~Roller Blinds) the material openness fraction doesn't exceed 0.20.
\paragraph{Field: Front Side Shade Beam-Diffuse Solar Transmittance}\label{field-front-side-shade-beam-diffuse-solar-transmittance}
@@ -2994,7 +2994,7 @@ \subsection{WindowMaterial:Drape:EquivalentLayer}\label{windowmaterialdrapeequiv
Specifies the optical and thermal properties of equivalent layer window drape fabric materials.
-Drapery fabric shades are commonly placed on the the inside of the window. The long-wave (Thermal) properties for commonly used drapery fabrics are assumed to be the same on both sides but different values can be specified when required. Drape fabric shade layers are considered to be perfect diffusers (reflected radiation is hemispherically-diffuse independent of angle of incidence). Unpleated drape fabric is treated as thin and flat layer.The off-normal optical properties of drapery fabric is determined from user specified optical properties at normal incidence using empirical correlations. Pleated drape fabric requires entering the pleated section average width and length as shown in Figure~\ref{fig:geometry-used-for-pleated-drape-analysis}. For pleated drapes the effective beam-beam and beam-diffuse solar properties are determined by tracking both radiation components, for a given incident angle solar radiation, through various interactions with a fabric pleated in a rectangular geometry shown in Figure~\ref{fig:geometry-used-for-pleated-drape-analysis}.~ The solar properties of the two different pleat facets are evaluated on the basis of the local solar incidence angle.~ Therefore, the effective layer properties are influenced not just by horizontal solar profile angle, but also by incidence angle. The correlations used for drape fabrics optical property calculations reqiure that the solar absorptance of the fabric, at normal incidence, is not less than 1\%. The equivalent layer window drapery fabric shade model does not support \hyperref[windowpropertyshadingcontrol]{WindowShadingControl}.
+Drapery fabric shades are commonly placed on the the inside of the window. The long-wave (Thermal) properties for commonly used drapery fabrics are assumed to be the same on both sides but different values can be specified when required. Drape fabric shade layers are considered to be perfect diffusers (reflected radiation is hemispherically-diffuse independent of angle of incidence). Unpleated drape fabric is treated as thin and flat layer.The off-normal optical properties of drapery fabric is determined from user specified optical properties at normal incidence using empirical correlations. Pleated drape fabric requires entering the pleated section average width and length as shown in Figure~\ref{fig:geometry-used-for-pleated-drape-analysis}. For pleated drapes the effective beam-beam and beam-diffuse solar properties are determined by tracking both radiation components, for a given incident angle solar radiation, through various interactions with a fabric pleated in a rectangular geometry shown in Figure~\ref{fig:geometry-used-for-pleated-drape-analysis}.~ The solar properties of the two different pleat facets are evaluated on the basis of the local solar incidence angle.~ Therefore, the effective layer properties are influenced not just by horizontal solar profile angle, but also by incidence angle. The correlations used for drape fabrics optical property calculations require that the solar absorptance of the fabric, at normal incidence, is not less than 1\%. The equivalent layer window drapery fabric shade model does not support \hyperref[windowpropertyshadingcontrol]{WindowShadingControl}.
\begin{figure}[hbtp] % fig 21
\centering
@@ -3189,7 +3189,7 @@ \subsubsection{Inputs}\label{inputs-28-001}
\paragraph{Field: Slat Angle Control}\label{field-slat-angle-control}
-This input field is used only if slat angle control is desired.~ The three key choice inputs allowed are ``FixedSlatAngle'', ``MaximizeSolar'', and ``BlockBeamSolar''.~ The default value is ``FixedSlatAngle''.If Type of Slat Angle Control for Blinds = MaximizeSolar the slat angle is adjusted to maximize solar gain.~If Type of Slat Angle Control for Blinds = BlockBeamSolar, the slat angle is adjusted to maximize visibiity while eliminating beam solar radiation.~If Type of Slat Angle Control for Blinds = FixedSlatAngle, then the model uses a fixed slat angle specified above.
+This input field is used only if slat angle control is desired.~ The three key choice inputs allowed are ``FixedSlatAngle'', ``MaximizeSolar'', and ``BlockBeamSolar''.~ The default value is ``FixedSlatAngle''.If Type of Slat Angle Control for Blinds = MaximizeSolar the slat angle is adjusted to maximize solar gain.~If Type of Slat Angle Control for Blinds = BlockBeamSolar, the slat angle is adjusted to maximize visibility while eliminating beam solar radiation.~If Type of Slat Angle Control for Blinds = FixedSlatAngle, then the model uses a fixed slat angle specified above.
An IDF example for this object, is shown below:
@@ -4066,7 +4066,7 @@ \subsubsection{Inputs}\label{inputs-38}
\paragraph{Field: Source Present After Layer Number}\label{field-source-present-after-layer-number}
-This field is an integer that relates the location of the heat source or sink. The integer refers to the list of material layers that follow later in the syntax and determines the layer after which the source is present. If a source is embedded within a single homogenous layer (such as concrete), that layer should be split into two layers and the source added between them. For example, a value of ``2'' in this field tells EnergyPlus that the source is located between the second and third material layers listed later in the construction description (see layer fields below). This field must be between 1 and the number of material layers in the construction (maximum of 10 layers).
+This field is an integer that relates the location of the heat source or sink. The integer refers to the list of material layers that follow later in the syntax and determines the layer after which the source is present. If a source is embedded within a single homogeneous layer (such as concrete), that layer should be split into two layers and the source added between them. For example, a value of ``2'' in this field tells EnergyPlus that the source is located between the second and third material layers listed later in the construction description (see layer fields below). This field must be between 1 and the number of material layers in the construction (maximum of 10 layers).
\paragraph{Field: Temperature Calculation Requested After Layer Number}\label{field-temperature-calculation-requested-after-layer-number}
diff --git a/doc/input-output-reference/src/overview/group-system-availability-managers.tex b/doc/input-output-reference/src/overview/group-system-availability-managers.tex
index d7d9bf7ed2c..6213db169d9 100644
--- a/doc/input-output-reference/src/overview/group-system-availability-managers.tex
+++ b/doc/input-output-reference/src/overview/group-system-availability-managers.tex
@@ -24,7 +24,7 @@ \subsubsection{Inputs}\label{inputs-047}
\paragraph{Field: Schedule Name}\label{field-schedule-name-006}
-The name of a schedule defined elsewhere in the input. Schedule values greater than zero (usually 1 is used) indicate that the system is on. Schedule values less than or equal to zero (usually 0 is used) denote that the system is off. This schedule overides the central fan schedule for determining whether the fan is on.
+The name of a schedule defined elsewhere in the input. Schedule values greater than zero (usually 1 is used) indicate that the system is on. Schedule values less than or equal to zero (usually 0 is used) denote that the system is off. This schedule overrides the central fan schedule for determining whether the fan is on.
An example of this statement in an IDF is:
@@ -61,7 +61,7 @@ \subsubsection{Inputs}\label{inputs-1-044}
\paragraph{Field: Schedule Name}\label{field-schedule-name-1-003}
-The name of a schedule defined elsewhere in the input. Schedule values greater than zero (usually 1 is used) indicate that the system is on. Schedule values less than or equal to zero (usually 0 is used) denote that \emph{NoAction} is desired. This schedule overides the central fan schedule for determining whether the fan is on.
+The name of a schedule defined elsewhere in the input. Schedule values greater than zero (usually 1 is used) indicate that the system is on. Schedule values less than or equal to zero (usually 0 is used) denote that \emph{NoAction} is desired. This schedule overrides the central fan schedule for determining whether the fan is on.
An example of this statement in an IDF is:
@@ -88,7 +88,7 @@ \subsubsection{Outputs}\label{outputs-036}
\subsection{AvailabilityManager:ScheduledOff}\label{availabilitymanagerscheduledoff}
-The Schedule Off Availability Manager is used when equipment must be turned off during a given time period. This availability manager will not turn the equipment on, a separate availability manager must be used to enable the equipment as necessary. The scheduled off availability is determined by an off schedule. Schedule values equal to 0 set a \emph{ForceOff} availability status. Schedule values other than 0 (usually a 1 is used) set a \emph{NoAction} availability status. The syntax for mplementing such an availability manager is shown below. The identifying name refers back to the name recorded in the \hyperref[availabilitymanagerassignmentlist]{AvailabilityManagerAssignmentList} statement described in the \textbf{Group Air Distribution} section. The schedule must be the name of a schedule defined elsewhere in the input.
+The Schedule Off Availability Manager is used when equipment must be turned off during a given time period. This availability manager will not turn the equipment on, a separate availability manager must be used to enable the equipment as necessary. The scheduled off availability is determined by an off schedule. Schedule values equal to 0 set a \emph{ForceOff} availability status. Schedule values other than 0 (usually a 1 is used) set a \emph{NoAction} availability status. The syntax for implementing such an availability manager is shown below. The identifying name refers back to the name recorded in the \hyperref[availabilitymanagerassignmentlist]{AvailabilityManagerAssignmentList} statement described in the \textbf{Group Air Distribution} section. The schedule must be the name of a schedule defined elsewhere in the input.
\subsubsection{Inputs}\label{inputs-2-041}
diff --git a/doc/input-output-reference/src/overview/group-thermal-zone-description-geometry.tex b/doc/input-output-reference/src/overview/group-thermal-zone-description-geometry.tex
index 9dd0fac5a84..b97a989a838 100644
--- a/doc/input-output-reference/src/overview/group-thermal-zone-description-geometry.tex
+++ b/doc/input-output-reference/src/overview/group-thermal-zone-description-geometry.tex
@@ -13,7 +13,7 @@ \subsection{Space}\label{space}
Input references to Space Names must have a matching Space object.
Default space names may not be referenced in the input except for \hyperref[outputvariable]{Output:Variable} keys).
-Space geometry is specified by attaching surfaces to a space using the ``Space Name'' field. If a Space has only floor surface(s) and internal mass assigned to it, the Space is assumed to share the same enclosure with other such Spaces in the same Zone (and with any surfaces that are not explicitly assinged to a space). If a Space also has other types of surfaces (e.g. wall, ceiling, or roof) then the Space forms its own enclosure unless it is connected to other spaces with air boundaries (see \hyperref[constructionairboundary]{Construction:AirBoundary}).
+Space geometry is specified by attaching surfaces to a space using the ``Space Name'' field. If a Space has only floor surface(s) and internal mass assigned to it, the Space is assumed to share the same enclosure with other such Spaces in the same Zone (and with any surfaces that are not explicitly assigned to a space). If a Space also has other types of surfaces (e.g. wall, ceiling, or roof) then the Space forms its own enclosure unless it is connected to other spaces with air boundaries (see \hyperref[constructionairboundary]{Construction:AirBoundary}).
\subsubsection{Inputs}\label{space-inputs-048}
@@ -31,7 +31,7 @@ \subsubsection{Inputs}\label{space-inputs-048}
Note that the Ceiling Height is the distance from the Floor to the Ceiling in the Space, not an absolute height from the ground.
-NOTE: At the moment, the autocalcuted Space ceiling height is set to the Zone ceiling height.
+NOTE: At the moment, the autocalculated Space ceiling height is set to the Zone ceiling height.
\paragraph{Field: Volume}\label{field-space-volume}
@@ -106,7 +106,7 @@ \subsubsection{Inputs}\label{inputs-048}
\paragraph{Field(s): (X,Y,Z) Origin}\label{fields-xyz-origin}
-The X,Y,Z coordinates of a zone origin can be specified, for convenience in vertice entry. Depending on the values in ``\hyperref[globalgeometryrules]{GlobalGeometryRules}'' (see description later in this section), these will be used to completely specify the building coordinates in ``world coordinate'' or not. Zone Origin coordinates are specified \textbf{relative to the Building Origin (which always 0,0,0)}. The following figure illustrates the use of Zone North Axis as well as Zone Origin values.
+The X,Y,Z coordinates of a zone origin can be specified, for convenience in vertices entry. Depending on the values in ``\hyperref[globalgeometryrules]{GlobalGeometryRules}'' (see description later in this section), these will be used to completely specify the building coordinates in ``world coordinate'' or not. Zone Origin coordinates are specified \textbf{relative to the Building Origin (which always 0,0,0)}. The following figure illustrates the use of Zone North Axis as well as Zone Origin values.
\begin{figure}[hbtp] % fig 27
\centering
@@ -2826,12 +2826,14 @@ \subsection{Surface Output Variables/Reports}\label{surface-output-variablesrepo
Zone,Average,Surface Outside Face Thermal Radiation to Air Heat Transfer Coefficient [W/m2-K]
Zone,Average,Surface Outside Face Thermal Radiation to Sky Heat Transfer Coefficient [W/m2-K]
Zone,Average,Surface Outside Face Thermal Radiation to Ground Heat Transfer Coefficient [W/m2-K]
+Zone,Average,Surface Outside Face Thermal Radiation to Surrounding Surfaces Heat Transfer Coefficient [W/m2-K]
+Zone,Average,Surface Outside Face Surrounding Surfaces Average Temperature [C]
Zone,Average,Surface Inside Face Exterior Windows Incident Beam Solar Radiation Rate [W]
Zone,Sum,Surface Inside Face Exterior Windows Incident Beam Solar Radiation Energy [J]
Zone,Average,Surface Inside Face Exterior Windows Incident Beam Solar Radiation Rate per Area[W/m2]
Zone,Average,Surface Inside Face Interior Windows Incident Beam Solar Radiation Rate [W]
Zone,Average,Surface Inside Face Interior Windows Incident Beam Solar Radiation Rate per Area[W/m2]
-Zone, Sum,Surface Inside Face Interior Windows Incident Beam Solar Radiation Energy [J]
+Zone,Sum,Surface Inside Face Interior Windows Incident Beam Solar Radiation Energy [J]
Zone,Average,Surface Inside Face Initial Transmitted Diffuse Absorbed Solar Radiation Rate [W]
Zone,Average,Surface Inside Face Initial Transmitted Diffuse Transmitted Out Window Solar Radiation Rate [W]
Zone,Average,Surface Inside Face Absorbed Shortwave Radiation Rate [W]
@@ -3242,6 +3244,14 @@ \subsubsection{Surface Outside Face Heat Emission to Air Rate {[}W{]}}\label{sur
This is total heat transfer rate between the outside face and the air mass surrounding the surface by convection and thermal radiation.
+\subsubsection{Surface Outside Face Thermal Radiation to Surrounding Surfaces Heat Transfer Coefficient {[}W/m2-K{]}}\label{surface-outside-face-thermal-radiation-to-surrounding-surfaces-heat-transfer-coefficient-wm2-k}
+
+This is the coefficient that describes thermal radiation heat transfer between the outside face of an exterior surface and the surrounding surfaces it views. It is the value of ``Hr'' in the classic linearized model for thermal radiation exchange Q = Hr * A * (T\_surf -- T\_srdsurfs) when applied to the surrounding surfaces. Where T\_surf = Surface Outside Face Temperature, and T\_srdsurf = Average temperature of the surrounding surfaces viewed by an exterior surface.
+
+\subsubsection{Surface Outside Face Surrounding Surfaces Average Temperature {[}C{]}}\label{surface-outside-face-surrounding-surfaces-average-temperature-C}
+
+This is the average surface temperature of the surrounding surfaces viewed by an exterior surface, in degrees Celsius. The surrounding surfaces average temperature is a view factor weighed surface temperature of multiple surrounding surfaces seen by an exterior surface. If an exterior surface views a single surrounding surface then the average temperature is the same as the user specified surrounding surface temperature.
+
\subsubsection{Surface Outside Face Solar Radiation Heat Gain Rate {[}W{]}}\label{surface-outside-face-solar-radiation-heat-gain-rate-w}
\subsubsection{Surface Outside Face Solar Radiation Heat Gain Rate per Area {[}W/m2{]}}\label{surface-outside-face-solar-radiation-heat-gain-rate-per-area-wm2}
@@ -4479,7 +4489,7 @@ \subsection{WindowShadingControl}\label{windowpropertyshadingcontrol}
With WindowShadingControl you specify the type, location, and timing of the shading device, what variable or combination of variables controls deployment of the shading device, and what the control setpoint is. If the shading device is a blind, you also specify how the slat angle is controlled. Each WindowShadingControl object is associated with a zone and has a list of one or more windows and glass doors to which the shading control is applied (ref: \hyperref[fenestrationsurfacedetailed]{FenestrationSurface:Detailed} with Type = Window or GlassDoor, Window, and \hyperref[glazeddoor]{GlazedDoor}).
-NOTE: WindowShadingControl does not work with complex fenestration systems. Controlled complex fenestration systems can be made only with Energy Management Systems objects. Refrencing a \hyperref[fenestrationsurfacedetailed]{FenestrationSurface:Detailed} in a WindowShadingControl while using complex fenestration systems will be ignored by program.
+NOTE: WindowShadingControl does not work with complex fenestration systems. Controlled complex fenestration systems can be made only with Energy Management Systems objects. Referencing a \hyperref[fenestrationsurfacedetailed]{FenestrationSurface:Detailed} in a WindowShadingControl while using complex fenestration systems will be ignored by program.
As shown in Figure~\ref{fig:allowed-locations-of-a-window-shading-device.}, a shading device can be inside the window (Shading Type = InteriorShade or InteriorBlind), outside the window (Shading Type = ExteriorShade or ExteriorBlind), or between panes of glass (Shading Type = BetweenGlassShade or BetweenGlassBlind). The exception is window screens which can only be outside the window (Shading Type = ExteriorScreen).
diff --git a/doc/input-output-reference/src/overview/group-unitary-equipment.tex b/doc/input-output-reference/src/overview/group-unitary-equipment.tex
index a470115ce85..51af0aa3017 100644
--- a/doc/input-output-reference/src/overview/group-unitary-equipment.tex
+++ b/doc/input-output-reference/src/overview/group-unitary-equipment.tex
@@ -308,40 +308,6 @@ \subsubsection{Inputs}\label{inputs-049}
This alpha field specifies the name of the outdoor node which controls the operation of the supplemental heating coil. If this field is left blank, the outdoor temperature is based solely on the weather data. If this field is not blank, the node name specified must also be listed in an \hyperref[outdoorairnode]{OutdoorAir:Node} object where the height of the node is taken into consideration when calculating outdoor temperature from the weather data. Alternately, the node name must be specified in an \hyperref[outdoorairnodelist]{OutdoorAir:NodeList} object where the outdoor temperature is taken directly from the weather data.
-\paragraph{Field: Maximum Cycling Rate}\label{field-maximum-cycling-rate-001}
-
-This numeric field contains the maximum on-off cycling rate for the compressor, which occurs at 50\% run time fraction. Suggested values are shown in Figure~\ref{fig:suggested-values-for-maximum-cycling-rate}. (Henderson et al. 1999):
-
-\begin{figure}[htbp]
-\centering
-\includegraphics{media/image295.png}
-\caption{Suggested values for maximum cycling rate \protect \label{fig:suggested-values-for-maximum-cycling-rate}}
-\end{figure}
-
-\paragraph{Field: Heat Pump Time Constant}\label{field-heat-pump-time-constant-000}
-
-This numeric field contains the time constant for the cooling coil's capacity to reach steady state after startup. Suggested values are shown in Figure~\ref{fig:suggested-values-for-heat-pump-time-constant}. (Henderson et al. 1999):
-
-\begin{figure}[htbp]
-\centering
-\includegraphics{media/image296.png}
-\caption{Suggested values for heat pump time constant \protect \label{fig:suggested-values-for-heat-pump-time-constant}}
-\end{figure}
-
-\paragraph{Field: Fraction of On-Cycle Power Use}\label{field-fraction-of-on-cycle-power-use-000}
-
-This numeric field contains the fraction of on-cycle power use to adjust the part load fraction based on the off-cycle power consumption due to crankcase heaters, controls, fans, and etc. Suggested value values are shown in Figure~\ref{fig:suggested-values-for-fraction-of-on-cycle-power-use}. (Henderson et al. 1999):
-
-\begin{figure}[htbp]
-\centering
-\includegraphics{media/image297.png}
-\caption{Suggested values for fraction of on cycle power use \protect \label{fig:suggested-values-for-fraction-of-on-cycle-power-use}}
-\end{figure}
-
-\paragraph{Field: Heat Pump Fan Delay Time}\label{field-heat-pump-fan-delay-time-000}
-
-This numeric field contains the time delay for the heat pump supply air fan to shut off after the compressor cycles off in seconds. This value can be obtained from the manufacturer or the heat pump catalog. Enter a value of zero when the heat pump's fan operating mode is continuous. Suggested value is 60 seconds.
-
\paragraph{Field: Ancillary On-Cycle Electric Power}\label{field-ancillary-on-cycle-electric-power}
This field defines ancillary electrical power (W) consumed during the on-cycle period (i.e., when the cooling or heating coil is operating). The model assumes that this ancillary power does not contribute to heating the supply air. The minimum value for this field is 0.0, and the default value is also 0.0 if the field is left blank.
@@ -436,10 +402,6 @@ \subsubsection{Inputs}\label{inputs-049}
50, !- Maximum Supply Air Temperature {C}
21, !- Maximum Outdoor Dry-Bulb Temperature for Supplemental Heater Operation {C}
, !- Outdoor Dry-Bulb Temperature Sensor Node Name
- , !- Maximum Cycling Rate {cycles/hr}
- , !- Heat Pump Time Constant {s}
- , !- Fraction of On-Cycle Power Use
- , !- Heat Pump Fan Delay Time {s}
, !- Ancillary On-Cycle Electric Power {W}
, !- Ancillary Off-Cycle Electric Power {W}
, !- Design Heat Recovery Water Flow Rate {m3/s}
@@ -728,7 +690,7 @@ \subsubsection{Inputs}\label{inputs-1-046}
\paragraph{Field: No Load Supply Air Flow Rate Ratio}\label{field-no-load-supply-air-flow-rate-ratio}
-This field defines the no load operating air flow rate when the system fan is specified to operate continuously. The allowed fractions are between 0 and 1 with a default value of 1. This fraction is usually set to the mimumum of heating and cooling operation lowest speed supply air flow fraction. The no load air flow rate will be calculated as this fraction multiplied by the minimum of the cooling and heating high speed supply air flow rate. If the cooling or heating coil is not present, this fraction is multiplied by the operating supply air flow rate.
+This field defines the no load operating air flow rate when the system fan is specified to operate continuously. The allowed fractions are between 0 and 1 with a default value of 1. This fraction is usually set to the minimum of heating and cooling operation lowest speed supply air flow fraction. The no load air flow rate will be calculated as this fraction multiplied by the minimum of the cooling and heating high speed supply air flow rate. If the cooling or heating coil is not present, this fraction is multiplied by the operating supply air flow rate.
\paragraph{Field Group: Heating and Cooling Speeds 1 to 10}\label{field-group-heating-and-cooling-speeds-1-to-10}
@@ -899,7 +861,7 @@ \subsubsection{Inputs}\label{inputs-2-043}
terminal unit (\hyperref[airterminalsingleductconstantvolumenoreheat]{AirTerminal:SingleDuct:ConstantVolume:NoReheat}) for each zone served by the furnace
\end{enumerate}
-Note: the furnace's fan, cooling coil, heating coil and optional reheat coil must be connected in the air loop according to the configuration shown above (Figure~\ref{fig:schematic-of-energyplus-heatcool-furnace}) when CoolReheat is selected as the dehujmidificaiton control type. In addition, the volumetric air flow rate specified in the terminal air unit for the controlling zone should properly reflect the fractional volumetric air flow rate specified in the furnace object.
+Note: the furnace's fan, cooling coil, heating coil and optional reheat coil must be connected in the air loop according to the configuration shown above (Figure~\ref{fig:schematic-of-energyplus-heatcool-furnace}) when CoolReheat is selected as the dehumidification control type. In addition, the volumetric air flow rate specified in the terminal air unit for the controlling zone should properly reflect the fractional volumetric air flow rate specified in the furnace object.
\begin{lstlisting}
@@ -921,7 +883,7 @@ \subsubsection{Inputs}\label{inputs-2-043}
Furnace Heating Coil 1, !- Heating coil name
Coil:Cooling:DX:SingleSpeed, !- Cooling coil type
Furnace ACDXCoil 1, !- Cooling coil name
- None; !- Dehumidificatioin Control Type
+ None; !- Dehumidification Control Type
Coil:Heating:Fuel,
@@ -1403,7 +1365,7 @@ \subsubsection{Inputs}\label{inputs-3-039}
Air Loop Outlet Node, ! Heat Pump air outlet node
1.3, !- Cooling Supply Air Flow Rate {m3/s}
1.3, !- Heating Supply Air Flow Rate {m3/s}
- 0.0, !- No Load Suuply Air Flow Rate {m3/s}
+ 0.0, !- No Load Supply Air Flow Rate {m3/s}
East Zone, ! Controlling zone or thermostat location
Fan:OnOff, ! Supply air fan type
Supply Fan 1, ! Supply air fan name –- same name used in fan object
@@ -2243,7 +2205,7 @@ \subsubsection{Outputs}\label{outputs-4-018}
\subsection{AirLoopHVAC:UnitaryHeatOnly}\label{airloophvacunitaryheatonly}
-The AirLoopHVAC:UnitaryHeatOnly is identical to the \hyperref[airloophvacunitaryfurnaceheatonly]{AirLoopHVAC:Unitary:Furnace:HeatOnly} model. The heat-only unitary system is a ``virtual'' component that consists of a fan component (OnOff or ConstantVolume) and a Gas or Electric heating coil component. The blow through unitary system configuraion is shown in the Figure below.
+The AirLoopHVAC:UnitaryHeatOnly is identical to the \hyperref[airloophvacunitaryfurnaceheatonly]{AirLoopHVAC:Unitary:Furnace:HeatOnly} model. The heat-only unitary system is a ``virtual'' component that consists of a fan component (OnOff or ConstantVolume) and a Gas or Electric heating coil component. The blow through unitary system configuration is shown in the Figure below.
\begin{figure}[hbtp] % fig 121
\centering
@@ -2523,40 +2485,6 @@ \subsubsection{Inputs}\label{inputs-7-029}
This numeric value allows the user to determine how close the air side has to be controlled. Lower the value of convergence better the control of air side conditions and less the zone temperature fluctuations. However in a poorly designed system, a lower convergence might result in warning errors which are caused due to the iteration limit for run time fraction calculation is limited to 20.
-\paragraph{Field: Maximum Cycling Rate}\label{field-maximum-cycling-rate-1-000}
-
-This numeric field contains the maximum on-off cycling rate for the compressor, which occurs at 50\% run time fraction. Suggested values are shown below (Henderson et al. 1999):
-
-\begin{figure}[htbp]
-\centering
-\includegraphics{media/image305.png}
-\caption{}
-\end{figure}
-
-\paragraph{Field: Heat Pump Time Constant}\label{field-heat-pump-time-constant-1}
-
-This numeric field contains the time constant for the cooling coil's capacity to reach steady state after startup. Suggested values are shown below (Henderson et al. 1999):
-
-\begin{figure}[htbp]
-\centering
-\includegraphics{media/image306.png}
-\caption{}
-\end{figure}
-
-\paragraph{Field: Fraction of On-Cycle Power Use}\label{field-fraction-of-on-cycle-power-use-1}
-
-This numeric field contains the fraction of on-cycle power use to adjust the part load fraction based on the off-cycle power consumption due to crankcase heaters, controls, fans, and etc. Suggested value values are below (Henderson et al. 1999):
-
-\begin{figure}[htbp]
-\centering
-\includegraphics{media/image307.png}
-\caption{}
-\end{figure}
-
-\paragraph{Field: Heat Pump Fan Delay Time}\label{field-heat-pump-fan-delay-time-1}
-
-This numeric field contains the time delay for the heat pump supply air fan to shut off after the compressor cycles off in seconds. This value can be obtained from the manufacturer or the heat pump catalog. Enter a value of zero when the heat pump's fan operating mode is continuous. Suggested value is 60 seconds.
-
\paragraph{Field: Supplemental Heating Coil Object Type}\label{field-supplemental-heating-coil-object-type-3}
This is the object type of the supplemental heating coil. The hot water and steam heating coils require specifying plant loop, branches, and connectors objects to support the heating coils, and are placed on the demand side of the plantloop. The hot water flow modulation through the supplemental heating coil does not require additional controller or \hyperref[controllerwatercoil]{Controller:WaterCoil} object. The parent object (AirLoop Unitary Water to Air Heat Pump) itself provides the ``controller'' function of modulating water flow. The valid choices are:
@@ -2623,7 +2551,7 @@ \subsubsection{Inputs}\label{inputs-7-029}
\textbf{CoolReheat} - cool beyond the dry-bulb temperature set point as required to meet the high humidity setpoint. The excess cooling beyond the cooling set point temperature is offset by the supplemental heating coil.
-The default is \textbf{None}. For \textbf{CoolReheat} dehumidification control modes, the maximum humidity setpoint is required. This must be set using a \textbf{\hyperref[zonecontrolhumidistat]{ZoneControl:Humidistat}} object. When extra dehumidification is required, the system may not be able to meet the humidity setpoint if its full capacity is not adequate. Supplemental heating coil (supplemental heating coil type and name) is a required input in WaterToAir HeatPumps. When dehumidification control is active the heating and the reheat load due to extra dehumidification are met with supplemetal heating coil. The supplemental heating coil capacity must be adequate enough to meet the heating coil load and offset the excess cooling load due to~ extra dehumidification. The dehumidification control type CoolReheat works only with \hyperref[coilcoolingwatertoairheatpumpequationfit]{Coil:Cooling:WaterToAirHeatPump:EquationFit} cooling coil type.
+The default is \textbf{None}. For \textbf{CoolReheat} dehumidification control modes, the maximum humidity setpoint is required. This must be set using a \textbf{\hyperref[zonecontrolhumidistat]{ZoneControl:Humidistat}} object. When extra dehumidification is required, the system may not be able to meet the humidity setpoint if its full capacity is not adequate. Supplemental heating coil (supplemental heating coil type and name) is a required input in WaterToAir HeatPumps. When dehumidification control is active the heating and the reheat load due to extra dehumidification are met with supplemental heating coil. The supplemental heating coil capacity must be adequate enough to meet the heating coil load and offset the excess cooling load due to~ extra dehumidification. The dehumidification control type CoolReheat works only with \hyperref[coilcoolingwatertoairheatpumpequationfit]{Coil:Cooling:WaterToAirHeatPump:EquationFit} cooling coil type.
\paragraph{Field: Heat Pump Coil Water Flow Mode}\label{field-heat-pump-coil-water-flow-mode-000}
@@ -2638,7 +2566,7 @@ \subsubsection{Inputs}\label{inputs-7-029}
CyclingOnDemand
\end{itemize}
-\textbf{Cycling} varies water flow through the coil based on the heat pump Part Load Ratio.~ This control method is appropriate for modeling heat pumps that are outfitted with a soleniod valve which allows water to flow through the coil only when the compressor is active. This is the default for EnergyPlus V8 and later.
+\textbf{Cycling} varies water flow through the coil based on the heat pump Part Load Ratio.~ This control method is appropriate for modeling heat pumps that are outfitted with a solenoid valve which allows water to flow through the coil only when the compressor is active. This is the default for EnergyPlus V8 and later.
\textbf{Constant} provides a constant water flow regardless of heat pump operation.~ Remember that EnergyPlus has two coils (a heating coil and a cooling coil) to approximate the operation of one coil that can operate in either heating mode or cooling mode.~ Therefore, when the water flow mode is constant, there will be full flow through either the heating coil or the cooling coil, but not both at the same time.
@@ -2663,10 +2591,6 @@ \subsubsection{Inputs}\label{inputs-7-029}
Coil:Cooling:WaterToAirHeatPump:ParameterEstimation, !- Cooling Coil Object Type
Heat Pump Cooling Mode, !- Cooling Coil Name
0.001, !- Cooling Convergence
- 2.5, !- Maximum Cycling Rate {cycles/hr}
- 60, !- Heat Pump Time Constant {s}
- 0.01, !- Fraction of On-Cycle Power Use
- 60, !- Heat Pump Fan Delay Time {s}
Coil:Heating:Fuel, !- Supplemental Heating Coil Object Type
Heat Pump DX Supp Heating Coil 1, !- Supplemental Heating Coil Name
50, !- Maximum Supply Air Temperature from Supplemental Heater {C}
@@ -3030,7 +2954,7 @@ \subsubsection{Inputs}\label{inputs-8-027}
LoadPriority
\end{itemize}
-If CoolingPriority is selected, the system operates to meet the cooling load if any zone served by this system (air loop) requires cooling. If no zones require cooling, then the system operates in heating mode if needed. If HeatingPriority is selected, the system operates to meet the heating load if any zone requires heating. If no zones require heating, then the system operates in cooling mode if needed. If ZonePriority is selected, the system operates based on the maximum number of zones requiring either heating or cooling. If the number of zones requiring cooling is greater than the number of zones requiring heating, then the system operates in cooling mode. If the number of zones requiring heating is greater than the number of zones requiring cooling, then the system operates in heating mode. If the number of zones requiring cooling equals the number of zones requiring heating, then the largest combined load (i.e., the sum of the cooling loads for zones requiring cooling compared to the sum of the heating loads for zones that require heating) sets the cooling or heating operating mode for the system during that simulation timestep. If LoadPriority is selected, the system operates based on the largest combined load (i.e., the sum of the cooling loads for zones requiring cooling compared to the sum of the heating loads for zones that require heating). If the toal load for zones requiring cooling is greater than the toal load for zones requiring heating, then the system operates in cooling mode. Similar logic is used for heating mode selection. If the toal cooling load equals the toal heating load, then cooling or heating operation reverts to the total number of zones requiring cooling or heating (and if equal reverts to cooling mode if the cooling load is non-zero, otherwise, heating mode.
+If CoolingPriority is selected, the system operates to meet the cooling load if any zone served by this system (air loop) requires cooling. If no zones require cooling, then the system operates in heating mode if needed. If HeatingPriority is selected, the system operates to meet the heating load if any zone requires heating. If no zones require heating, then the system operates in cooling mode if needed. If ZonePriority is selected, the system operates based on the maximum number of zones requiring either heating or cooling. If the number of zones requiring cooling is greater than the number of zones requiring heating, then the system operates in cooling mode. If the number of zones requiring heating is greater than the number of zones requiring cooling, then the system operates in heating mode. If the number of zones requiring cooling equals the number of zones requiring heating, then the largest combined load (i.e., the sum of the cooling loads for zones requiring cooling compared to the sum of the heating loads for zones that require heating) sets the cooling or heating operating mode for the system during that simulation timestep. If LoadPriority is selected, the system operates based on the largest combined load (i.e., the sum of the cooling loads for zones requiring cooling compared to the sum of the heating loads for zones that require heating). If the total load for zones requiring cooling is greater than the total load for zones requiring heating, then the system operates in cooling mode. Similar logic is used for heating mode selection. If the total cooling load equals the total heating load, then cooling or heating operation reverts to the total number of zones requiring cooling or heating (and if equal reverts to cooling mode if the cooling load is non-zero, otherwise, heating mode.
\paragraph{Field: Minimum Outlet Air Temperature During Cooling Operation}\label{field-minimum-outlet-air-temperature-during-cooling-operation}
diff --git a/doc/input-output-reference/src/overview/group-user-defined-hvac-and-plant-component.tex b/doc/input-output-reference/src/overview/group-user-defined-hvac-and-plant-component.tex
index bed10077dd1..7097806c0a0 100644
--- a/doc/input-output-reference/src/overview/group-user-defined-hvac-and-plant-component.tex
+++ b/doc/input-output-reference/src/overview/group-user-defined-hvac-and-plant-component.tex
@@ -178,7 +178,7 @@ \subsubsection{Field: Ambient Zone Name}\label{field-ambient-zone-name-1}
\subsection{Coil:UserDefined}\label{coiluserdefined}
-This object is used to define a generic coil for custom component modeling of a device that processes air as part of an air handeler. The Coil:UserDefined object appears directly on a \hyperref[branch]{Branch} object used to define the supply side of an air handler, or in the \hyperref[airloophvacoutdoorairsystemequipmentlist]{AirLoopHVAC:OutdoorAirSystem:EquipmentList} object used to define outdoor air systems. This object has one or two air connections and an optional plant connection. Water storage tanks can be connected for supply or collection. An ambient zone can be connected for skin losses to be treated as separate internal gains.
+This object is used to define a generic coil for custom component modeling of a device that processes air as part of an air handler. The Coil:UserDefined object appears directly on a \hyperref[branch]{Branch} object used to define the supply side of an air handler, or in the \hyperref[airloophvacoutdoorairsystemequipmentlist]{AirLoopHVAC:OutdoorAirSystem:EquipmentList} object used to define outdoor air systems. This object has one or two air connections and an optional plant connection. Water storage tanks can be connected for supply or collection. An ambient zone can be connected for skin losses to be treated as separate internal gains.
\subsubsection{Field: Name}\label{field-name-2-041}
@@ -261,7 +261,7 @@ \subsubsection{Field: Ambient Zone Name}\label{field-ambient-zone-name-2}
\begin{lstlisting}
EnergyManagementSystem:Program,
- MainHWCoil1_ModelOuput, !- Name
+ MainHWCoil1_Modeloutput, !- Name
Set HWcoil1_Water_MdotRequest = Water_MdotRequest, !- Program Line 1
Set HWcoil1_Air_Tout = Air_Tout, !- Program Line 2
Set HWcoil1_Air_Wout = Air_Wout, !-
@@ -274,7 +274,7 @@ \subsubsection{Field: Ambient Zone Name}\label{field-ambient-zone-name-2}
HWcoil1 tot heat Energy, !- Name
HWcoil1_tot_heat_Energy, !- EMS Variable Name
SystemTimestep, !- Update Frequency
- MainHWCoil1_ModelOuput, !- EMS Program or Subroutine Name
+ MainHWCoil1_Modeloutput, !- EMS Program or Subroutine Name
ENERGYTRANSFER, !- Resource Type
System, !- Group Type
HEATINGCOILS, !- End-Use Category
@@ -348,7 +348,7 @@ \subsubsection{Inputs}\label{plantcomponentuserdefined-inputs}
\paragraph{Field: Plant Connection \textless{}\#\textgreater{} Initialization Program Calling Manager Name}\label{field-plant-connection-x-initialization-program-calling-manager-name}
-This field specifies the Erl programs that are used to initialize and size the plant component with regard to this particular plant connection. This field should contain the name of an \hyperref[energymanagementsystemprogramcallingmanager]{EnergyManagementSystem:ProgramCallingManager} that is defined elsewhere and uses the calling point called UserDefinedComponentModel. The program manager referenced here should include all the Erl programs that are needed to do any initial setup that should occur before the main modeling programs are run. These include calculating and setting values for things that do not vary over time such as component sizes, control parameters, modeling constants etc. The user defined component will trigger this calling manager during the intitial setup routines for plant systems.
+This field specifies the Erl programs that are used to initialize and size the plant component with regard to this particular plant connection. This field should contain the name of an \hyperref[energymanagementsystemprogramcallingmanager]{EnergyManagementSystem:ProgramCallingManager} that is defined elsewhere and uses the calling point called UserDefinedComponentModel. The program manager referenced here should include all the Erl programs that are needed to do any initial setup that should occur before the main modeling programs are run. These include calculating and setting values for things that do not vary over time such as component sizes, control parameters, modeling constants etc. The user defined component will trigger this calling manager during the initial setup routines for plant systems.
\paragraph{Field: Plant Connection \textless{}\#\textgreater{} Simulation Program Calling Manager Name}\label{field-plant-connection-x-simulation-program-calling-manager-name}
diff --git a/doc/input-output-reference/src/overview/group-variable-refrigerant-flow-equipment.tex b/doc/input-output-reference/src/overview/group-variable-refrigerant-flow-equipment.tex
index 8c8ead67c18..a4ae6d7a9c4 100644
--- a/doc/input-output-reference/src/overview/group-variable-refrigerant-flow-equipment.tex
+++ b/doc/input-output-reference/src/overview/group-variable-refrigerant-flow-equipment.tex
@@ -647,7 +647,7 @@ \subsubsection{Outputs}\label{outputs-039}
\paragraph{\texorpdfstring{VRF Heat Pump COP{[]}}{VRF Heat Pump COP}}\label{vrf-heat-pump-cop}
-This is the operating coefficient of performance (COP) for the heat pump. This value is calculated using the ratio of the total terminal unit coil capacity (cooling plus heating and accounts for piping losses) and total system electric consumption rate (compressor, crankcase heater, evaporative condenser water pump, defrost, and terminal unit parasitic electric consumption rate). This output variable does not include pump power for a water-cooled system. This value is specific to overall system performance, is calculated for each HVAC system time step being simulated, and the results are averaged for the time step being reported.
+This is the operating coefficient of performance (COP) for the heat pump. This value is calculated using the ratio of the total terminal unit coil capacity (cooling plus heating and accounts for piping losses) and total system electric consumption rate (compressor, crankcase heater, evaporative condenser water pump, defrost, terminal unit fan power, and terminal unit parasitic electric consumption rate). This output variable does not include pump power for a water-cooled system. This value is specific to overall system performance, is calculated for each HVAC system time step being simulated, and the results are averaged for the time step being reported.
\paragraph{VRF Heat Pump Defrost Electricity Rate {[}W{]}}\label{vrf-heat-pump-defrost-electric-power-w}
@@ -927,11 +927,11 @@ \subsubsection{Inputs}\label{inputs-1-048}
\paragraph{Field: Loading Index i Evaporative Capacity Multiplier Function of Temperature Curve Name}\label{field-loading-index-i-evaporative-capacity-multiplier-function-of-temperature-curve-name}
-This alpha field defines the name of a BiQuadratic curve for the VRF operational mode corresponding to the i-th loading index. It parameterizes the variation of VRF evaporating capacity as a function of operating conditions, i.e., evaporating and condensing temperatures. The output of this curve is a dimensionless multiplier to be applied on the rated evaporative capacity to calculate the actual capacity.
+This alpha field defines the name of a BiQuadratic curve for the VRF operational mode corresponding to the i-th loading index. It parameterizes the variation of VRF evaporating capacity as a function of operating conditions, i.e., condensing (variable x) and evaporating temperatures (variable y). The output of this curve is a dimensionless multiplier to be applied on the rated evaporative capacity to calculate the actual capacity.
\paragraph{Field: Loading Index i Compressor Power Multiplier Function of Temperature Curve Name}\label{field-loading-index-i-compressor-power-multiplier-function-of-temperature-curve-name}
-This alpha field defines the name of a BiQuadratic curve for the VRF operational mode corresponding to the i-th loading index. It parameterizes the variation of compressor power as a function of operating conditions, i.e., evaporating and condensing temperatures. The output of this curve is a dimensionless multiplier to be applied on the rated compressor power to calculate the actual compressor power.
+This alpha field defines the name of a BiQuadratic curve for the VRF operational mode corresponding to the i-th loading index. It parameterizes the variation of compressor power as a function of operating conditions, i.e., condensing (variable x) and evaporating temperatures (variable y). The output of this curve is a dimensionless multiplier to be applied on the rated compressor power to calculate the actual compressor power.
\begin{lstlisting}
diff --git a/doc/input-output-reference/src/overview/group-water-heaters.tex b/doc/input-output-reference/src/overview/group-water-heaters.tex
index 54f6bf5340b..01d16a04aac 100644
--- a/doc/input-output-reference/src/overview/group-water-heaters.tex
+++ b/doc/input-output-reference/src/overview/group-water-heaters.tex
@@ -56,7 +56,7 @@ \section{Group -- Water Heaters and Thermal Storage}\label{group-water-heaters}
\item
better modeling of electric water heaters with two heating elements
\item
- better modeling of thermal storage applications which rely on stratification to improve heat transfer peformance.
+ better modeling of thermal storage applications which rely on stratification to improve heat transfer performance.
\end{itemize}
\subsection{Standard Ratings}\label{standard-ratings}
@@ -194,7 +194,7 @@ \subsubsection{Inputs}\label{inputs-052}
\paragraph{Field: Use Flow Rate Fraction Schedule Name}\label{field-use-flow-rate-fraction-schedule-name}
-The reference to the schedule object specifiying the current fraction of Peak Volumetric Use Flow Rate of domestic hot water usage for stand-alone operation.
+The reference to the schedule object specifying the current fraction of Peak Volumetric Use Flow Rate of domestic hot water usage for stand-alone operation.
\paragraph{Field: Cold Water Supply Temperature Schedule Name}\label{field-cold-water-supply-temperature-schedule-name}
@@ -658,7 +658,7 @@ \subsection{WaterHeater:Stratified}\label{waterheaterstratified}
For losses to the ambient environment, the ambient air temperature can be taken from a schedule, a zone, or the exterior. When used with a zone, a fraction of the skin losses can be added to the zone heat balance as internal heat gains.
-The WaterHeater:Stratified object allows two heating elements to be simulated. The two elements can cycle on and off to maintain the node temperature within the deadband. The Heater Priority Control field determines how the heaters work together. There are two options:~ MasterSlave or Simultaneous. In the MasterSlave option, Heater 1 is the master and Heater 2 is the slave. That is, both heaters are not allowed to turn on at the same time. If the thermostats ask for heat at both Heater 1 and 2, only Heater 1 will turn on. Once Heater 1 has met the set point, it turns off and Heater 2 can turn on, if necessary. In the Simultaneousoption, Heater 1 and Heater 2 can turn on and off independently.~ Autosizing is available for only Heater 1.
+The WaterHeater:Stratified object allows two heating elements to be simulated. The two elements can cycle on and off to maintain the node temperature within the deadband. The Heater Priority Control field determines how the heaters work together. There are two options:~ MasterSlave or Simultaneous. In the MasterSlave option, Heater 1 is the master and Heater 2 is the slave. That is, both heaters are not allowed to turn on at the same time. If the thermostats ask for heat at both Heater 1 and 2, only Heater 1 will turn on. Once Heater 1 has met the set point, it turns off and Heater 2 can turn on, if necessary. In the Simultaneous option, Heater 1 and Heater 2 can turn on and off independently.~ Autosizing is available for only Heater 1.
\subsubsection{Inputs}\label{inputs-1-049}
@@ -821,7 +821,7 @@ \subsubsection{Inputs}\label{inputs-1-049}
\paragraph{Field: Use Flow Rate Fraction Schedule Name}\label{field-use-flow-rate-fraction-schedule-name-1}
-The reference to the schedule object specifiying the current fraction of Peak Volumetric Use Flow Rate of domestic hot water usage for stand-alone operation. If blank, the fraction defaults to 1.0 at all times.
+The reference to the schedule object specifying the current fraction of Peak Volumetric Use Flow Rate of domestic hot water usage for stand-alone operation. If blank, the fraction defaults to 1.0 at all times.
\paragraph{Field: Cold Water Supply Temperature Schedule Name}\label{field-cold-water-supply-temperature-schedule-name-1}
@@ -869,7 +869,7 @@ \subsubsection{Inputs}\label{inputs-1-049}
\paragraph{Field: Inlet Mode}\label{field-inlet-mode-000}
-The inlet mode of entering fluid from the use and source sides. There are two options:~ \textbf{Fixed} or \textbf{Seeking}. In Fixed mode, the fluid enters at the fixed heights specified above. In Seeking mode, the fluid ``seeks out'' the stratified node that is closest to the inlet temperature and adds all flow to that node. The Seekingbmode provides maximum stratification. The default is \textbf{Fixed}.
+The inlet mode of entering fluid from the use and source sides. There are two options:~ \textbf{Fixed} or \textbf{Seeking}. In Fixed mode, the fluid enters at the fixed heights specified above. In Seeking mode, the fluid ``seeks out'' the stratified node that is closest to the inlet temperature and adds all flow to that node. The Seeking mode provides maximum stratification. The default is \textbf{Fixed}.
\paragraph{Field: Use Side Design Flow Rate}\label{field-use-side-design-flow-rate-1-000}
@@ -1102,7 +1102,7 @@ \subsubsection{Inputs}\label{inputs-2-045}
\paragraph{Field: Number of Bedrooms}\label{field-number-of-bedrooms}
-This field is used to enter the numer of bedrooms in the model.~ This field is only used if the Design Mode is ``\textbf{ResidentialHUD-FHAMinimum}.''
+This field is used to enter the number of bedrooms in the model.~ This field is only used if the Design Mode is ``\textbf{ResidentialHUD-FHAMinimum}.''
\paragraph{Field: Number of Bathrooms}\label{field-number-of-bathrooms}
@@ -2512,7 +2512,7 @@ \subsubsection{Inputs}\label{inputs-23-003}
\paragraph{Field: Temperature Sensor Height}\label{field-temperature-sensor-height}
-This field is used to describe the location in the tank where the temperature is sensed for control descisions.~ The program will associate one of the nodes with this height and use that node's temperature for control decisions.~ The location is described in meters from the bottom of the tank.
+This field is used to describe the location in the tank where the temperature is sensed for control decisions.~ The program will associate one of the nodes with this height and use that node's temperature for control decisions.~ The location is described in meters from the bottom of the tank.
\paragraph{Field: Minimum Temperature Limit}\label{field-minimum-temperature-limit-1}
diff --git a/doc/input-output-reference/src/overview/group-zone-controls-thermostats.tex b/doc/input-output-reference/src/overview/group-zone-controls-thermostats.tex
index 8b9689d21f6..4db73f47718 100644
--- a/doc/input-output-reference/src/overview/group-zone-controls-thermostats.tex
+++ b/doc/input-output-reference/src/overview/group-zone-controls-thermostats.tex
@@ -354,7 +354,7 @@ \subsubsection{Outputs}\label{outputs-042}
\paragraph{Zone Oscillating Temperatures During Occupancy Time{[}hr{]}}\label{zone-oscillating-temperatures-during-occupancy-timehr}
-Like Zone Oscillating Temperatures Time but for oscillations that occur only when the zone has occupancy. For zones unoccupied during night or weekend hours, ocscillations during those times may not have much impact on the accuracy of the annual energy prediction.
+Like Zone Oscillating Temperatures Time but for oscillations that occur only when the zone has occupancy. For zones unoccupied during night or weekend hours, oscillations during those times may not have much impact on the accuracy of the annual energy prediction.
\paragraph{Zone Oscillating Temperatures in Deadband Time{[}hr{]}}\label{zone-oscillating-temperatures-in-deadband-timehr}
@@ -603,7 +603,7 @@ \subsection{ZoneControl:Thermostat:TemperatureAndHumidity}\label{zonecontrolther
This object is used to modify the behavior of \hyperref[zonecontrolthermostat]{ZoneControl:Thermostat} objects (control types \hyperref[thermostatsetpointsinglecooling]{ThermostatSetpoint:SingleCooling} and \hyperref[thermostatsetpointdualsetpoint]{ThermostatSetpoint:DualSetpoint} only) based on zone air humidity conditions. Specifically, this TemperatureAndHumidity zone control resets the \hyperref[zonecontrolthermostat]{ZoneControl:Thermostat}'s cooling setpoint temperature downward when the zone air relative humidity exceeds the Dehumidifying Relative Humidity Setpoint defined in this object. The reduced cooling setpoint temperature typically results in longer cooling coil runtimes and additional dehumidification. The rate at which the cooling setpoint temperature is reduced is dictated by the user-specified Overcool Control Ratio. The maximum reduction in cooling setpoint temperature is defined by the user-entered OverCool Range (user choice of a constant value for the entire simulation or a schedule that can define how the overcool range varies over time). For details regarding the calculations, see the EnergyPlus Engineering Reference.
-Note: As described above, this ZoneControl:Thermostat:TemperatureAndHumidity control object modifies the cooling setpoint temperature of \hyperref[zonecontrolthermostat]{ZoneControl:Thermostat} objects. The ZoneControl:Thermostat:TemperatureAndHumidity object works independently of the \hyperref[zonecontrolhumidistat]{ZoneControl:Humidistat} object; that is, it does not replace the need for, or coordinate its input fields with, \hyperref[zonecontrolhumidistat]{ZoneControl:Humidistat} objects that are required for other types of high humidity control (e.g., ZoneControl:Humidstat objects are required for \hyperref[zonehvacdehumidifierdx]{ZoneHVAC:Dehumidifier:DX} objects, AirLoopHVAC:Unitary* objects with CoolReheat or MultiMode dehumidification control types, etc.)
+Note: As described above, this ZoneControl:Thermostat:TemperatureAndHumidity control object modifies the cooling setpoint temperature of \hyperref[zonecontrolthermostat]{ZoneControl:Thermostat} objects. The ZoneControl:Thermostat:TemperatureAndHumidity object works independently of the \hyperref[zonecontrolhumidistat]{ZoneControl:Humidistat} object; that is, it does not replace the need for, or coordinate its input fields with, \hyperref[zonecontrolhumidistat]{ZoneControl:Humidistat} objects that are required for other types of high humidity control (e.g., ZoneControl:Humidistat objects are required for \hyperref[zonehvacdehumidifierdx]{ZoneHVAC:Dehumidifier:DX} objects, AirLoopHVAC:Unitary* objects with CoolReheat or MultiMode dehumidification control types, etc.)
\subsubsection{Inputs}\label{inputs-6-031}
@@ -1041,7 +1041,7 @@ \subsubsection{Inputs}\label{inputs-9-025}
\subsubsection{Outputs}\label{outputs-3-024}
-Three outputs are available from the ZoneControl:Thermostat:ThermalComfort object. Two output variables used primarily for the ZoneControl:Thermost object are also described here to explain their meaning when using thermal comfort control.
+Three outputs are available from the ZoneControl:Thermostat:ThermalComfort object. Two output variables used primarily for the ZoneControl:Thermostat object are also described here to explain their meaning when using thermal comfort control.
\textbf{ZoneControl:ThermalComfort}
@@ -1275,4 +1275,4 @@ \subsubsection{Outputs}\label{outputs-4-020}
\paragraph{Zone Generic Air Contaminant Setpoint Concentration {[}ppm{]}}\label{zone-generic-air-contaminant-setpoint-concentration-ppm}
-This output variable is the averagegeneric contaminant setpoint value, in parts per million, for the time step being reported.
+This output variable is the average generic contaminant setpoint value, in parts per million, for the time step being reported.
diff --git a/doc/input-output-reference/src/overview/group-zone-equipment.tex b/doc/input-output-reference/src/overview/group-zone-equipment.tex
index 6fa33553629..69342703fce 100644
--- a/doc/input-output-reference/src/overview/group-zone-equipment.tex
+++ b/doc/input-output-reference/src/overview/group-zone-equipment.tex
@@ -111,7 +111,7 @@ \subsubsection{Inputs}\label{inputs-055}
\paragraph{Field: Constant Downstream Leakage Fraction}\label{field-constant-downstream-leakage-fraction}
-This is the leakage downstream of the terminal unit as a fraction of the current flow rate through the terminal unit. This fraction is held constant, so the leakage flow rate will vary proportinally with the supply air flow rate. This input is optional; the default is zero.
+This is the leakage downstream of the terminal unit as a fraction of the current flow rate through the terminal unit. This fraction is held constant, so the leakage flow rate will vary proportionally with the supply air flow rate. This input is optional; the default is zero.
\paragraph{Field: Design Specification Air Terminal Sizing Name}\label{design-specification-air-terminal-sizing-name2}
@@ -242,7 +242,7 @@ \subsubsection{Inputs}\label{inputs-2-048}
\paragraph{Field: Load Distribution Scheme}
-The Load Distribution Scheme selects the algorithm used to allocate the current zone load across the zone equipment. There are four choices: SequentialLoad, UniformLoad, UniformPLR, and SequentialUniformPLR. The default is SequentialLoad. In all cases, the equipment operates in the order specifed by the Zone Equipment Cooling Sequence and Heating or No-Load Sequence fields.
+The Load Distribution Scheme selects the algorithm used to allocate the current zone load across the zone equipment. There are four choices: SequentialLoad, UniformLoad, UniformPLR, and SequentialUniformPLR. The default is SequentialLoad. In all cases, the equipment operates in the order specified by the Zone Equipment Cooling Sequence and Heating or No-Load Sequence fields.
\begin{itemize}
\item
diff --git a/doc/input-output-reference/src/overview/group-zone-forced-air-units.tex b/doc/input-output-reference/src/overview/group-zone-forced-air-units.tex
index 1a311ee6d7d..8c9f169b093 100644
--- a/doc/input-output-reference/src/overview/group-zone-forced-air-units.tex
+++ b/doc/input-output-reference/src/overview/group-zone-forced-air-units.tex
@@ -146,7 +146,7 @@ \subsubsection{Inputs}\label{inputs-056}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-000}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Heating Air Flow Rate and Maximum Cooling Air Flow Rate in a Ideal Load Air System zone HVAC object. The scaled maximum heating and cooling air flow rates are used to size the heating and cooling capacities.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Heating Air Flow Rate and Maximum Cooling Air Flow Rate in a Ideal Load Air System zone HVAC object. The scaled maximum heating and cooling air flow rates are used to size the heating and cooling capacities.
An example of this object in an IDF is:
@@ -726,7 +726,7 @@ \subsubsection{Inputs}\label{inputs-1-053}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-1}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Air Flow Rate in this Four Pipe FanCoil zone HVAC object. The scaled Maximum Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Air Flow Rate in this Four Pipe FanCoil zone HVAC object. The scaled Maximum Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
\paragraph{Field: Supply Air Fan Operating Mode Schedule Name}\label{field-supply-air-fan-operating-mode-schedule-name-000}
@@ -994,7 +994,7 @@ \subsubsection{Inputs}\label{inputs-2-049}
\paragraph{Field: Maximum Outdoor Air Flow Rate}\label{field-maximum-outdoor-air-flow-rate-1-000}
-This field allows the user to enter the maximum volumetric flow rate of outdoor air that can be brought into the unit ventilator system in m\(^{3}\)/sec.~This parameter should be some real number greater than zero. Note that the value for this parameter may be less than the maximum air flow rate of the unit ventilator and this may affect the maximum fraction of outdoor air within the control strategy defined above. This parameter is an absolute maximum and will supercede any scheduled fraction of the unit ventilator maximum airflow rate. If ``FixedAmount'' type is selected as the outdoor air control strategy, this field will be ignored and be automatically set to be equal to the minimum outdoor air flow rate specified in the field above.
+This field allows the user to enter the maximum volumetric flow rate of outdoor air that can be brought into the unit ventilator system in m\(^{3}\)/sec.~This parameter should be some real number greater than zero. Note that the value for this parameter may be less than the maximum air flow rate of the unit ventilator and this may affect the maximum fraction of outdoor air within the control strategy defined above. This parameter is an absolute maximum and will supersede any scheduled fraction of the unit ventilator maximum airflow rate. If ``FixedAmount'' type is selected as the outdoor air control strategy, this field will be ignored and be automatically set to be equal to the minimum outdoor air flow rate specified in the field above.
\paragraph{Field: Maximum Outdoor Air Fraction or Temperature Schedule Name}\label{field-maximum-outdoor-air-fraction-or-temperature-schedule-name-000}
@@ -1113,7 +1113,7 @@ \subsubsection{Inputs}\label{inputs-2-049}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-2}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Air Flow Rate in this Unit Ventilator zone HVAC object. The scaled Maximum Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Air Flow Rate in this Unit Ventilator zone HVAC object. The scaled Maximum Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
An example input for a unit ventilator, including its constituent components, is shown below.
@@ -1365,7 +1365,7 @@ \subsubsection{Inputs}\label{inputs-3-043}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-3}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields \emph{Maximum Supply Air Flow Rate} in this Unit Heater zone HVAC object. The scaled maximum supply air flow rates is used to size Maximum Hot Water or Steam Flow Rate if specified as autosize. The scaled Maximum Air Flow Rate in turn is used to size heating capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields \emph{Maximum Supply Air Flow Rate} in this Unit Heater zone HVAC object. The scaled maximum supply air flow rates is used to size Maximum Hot Water or Steam Flow Rate if specified as autosize. The scaled Maximum Air Flow Rate in turn is used to size heating capacity of the unit.
An example input for a unit heater, including its constituent components, is shown below.
@@ -1545,7 +1545,7 @@ \subsubsection{Inputs}\label{inputs-4-040}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-4}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object defined elsewhere. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input field \emph{Design Supply Air Flow Rate} in Evaportaive Cooler zone HVAC object. The scaled design supply air flow rates in turn is used to size capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object defined elsewhere. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input field \emph{Design Supply Air Flow Rate} in Evaporative Cooler zone HVAC object. The scaled design supply air flow rates in turn is used to size capacity of the unit.
\paragraph{Field: Shut Off Relative Humidity}\label{shut-off-relative-humidity}
@@ -2004,7 +2004,7 @@ \subsubsection{Inputs}\label{inputs-7-031}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-5}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Air Flow Rate in this Window Air Conditioner zone HVAC object. The scaled Maximum Air Flow Rate in turn is used to size cooling capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Maximum Air Flow Rate in this Window Air Conditioner zone HVAC object. The scaled Maximum Air Flow Rate in turn is used to size cooling capacity of the unit.
Following is an example input for the cycling window air conditioner, along with its constituent components.
@@ -2278,7 +2278,7 @@ \subsubsection{Inputs}\label{inputs-8-029}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-6}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Cooling Supply Air Flow Rate in this Packaged Terminal Air Conditioner~ zone HVAC object. The scaled Supply Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Cooling Supply Air Flow Rate in this Packaged Terminal Air Conditioner~ zone HVAC object. The scaled Supply Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
\paragraph{Field: Capacity Control Method}\label{field-capacity-control-method-2}
@@ -2666,7 +2666,7 @@ \subsubsection{Inputs}\label{inputs-9-026}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-7}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Cooling Supply Air Flow Rate in this PTHP zone HVAC object. The scaled Supply Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Cooling Supply Air Flow Rate in this PTHP zone HVAC object. The scaled Supply Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
\paragraph{Field: Capacity Control Method}\label{field-capacity-control-method-3}
@@ -3112,7 +3112,7 @@ \subsubsection{Inputs}\label{inputs-11-023}
\paragraph{Field: Heat Pump Fan Delay Time}\label{field-heat-pump-fan-delay-time-001}
-This numeric field contains the time delay in seconds for the heat pump supply air fan to shut off after compressor cycle off. This value can be obtained from the manufacturer or the heat pump catalog. Suggested value is 60 seconds. This value is disregared at times when the WaterToAirHeatPump's fan operating mode schedule value is greater than 0 (i.e., continuous fan mode).
+This numeric field contains the time delay in seconds for the heat pump supply air fan to shut off after compressor cycle off. This value can be obtained from the manufacturer or the heat pump catalog. Suggested value is 60 seconds. This value is disregarded at times when the WaterToAirHeatPump's fan operating mode schedule value is greater than 0 (i.e., continuous fan mode).
\paragraph{Field: Supplemental Heating Coil Object Type}\label{field-supplemental-heating-coil-object-type-1-000}
@@ -3187,7 +3187,7 @@ \subsubsection{Inputs}\label{inputs-11-023}
CyclingOnDemand
\end{itemize}
-\textbf{Cycling} varies water flow through the coil based on the heat pump Part Load Ratio. This control method is appropriate for modeling heat pumps that are outfitted with a soleniod valve which allows water to flow through the coil only when the compressor is active. This is the default for EnergyPlus V8 and later.
+\textbf{Cycling} varies water flow through the coil based on the heat pump Part Load Ratio. This control method is appropriate for modeling heat pumps that are outfitted with a solenoid valve which allows water to flow through the coil only when the compressor is active. This is the default for EnergyPlus V8 and later.
\textbf{Constant} provides a constant water flow regardless of heat pump operation. Remember that EnergyPlus has two coils (a heating coil and a cooling coil) to approximate the operation of one coil that can operate in either heating mode or cooling mode. Therefore, when the water flow mode is constant, there will be full flow through either the heating coil or the cooling coil, but not both at the same time.
@@ -3195,7 +3195,7 @@ \subsubsection{Inputs}\label{inputs-11-023}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-8}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Cooling Supply Air Flow Rate in this Water To Air Heat Pump zone HVAC object. The scaled Supply Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Cooling Supply Air Flow Rate in this Water To Air Heat Pump zone HVAC object. The scaled Supply Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
\paragraph{Field: Design Specification Multispeed Object Type}\label{field-design-specification-multispeed-object-type-2}
@@ -3234,10 +3234,6 @@ \subsubsection{Inputs}\label{inputs-11-023}
Sys 1 Heat Pump Heating Mode, !- Heating Coil Name
Coil:Cooling:WaterToAirHeatPump:EquationFit, !- Cooling Coil Object Type
Sys 1 Heat Pump Cooling Mode, !- Cooling Coil Name
- 2.5, !- Maximum Cycling Rate
- 60.0, !- Heat Pump Time Constant
- 0.01, !- Fraction of On-Cycle Power Use
- 60, !- Heat Pump Fan Delay Time
Coil:Heating:Fuel, !- Supplemental Heating Coil Object Type
Heat Pump DX Supp Heating Coil 1, !- Supplemental Heating Coil Name
60.0, !- Maximum Supply Air Temperature from Supplemental Heater {C}
@@ -3858,7 +3854,7 @@ \subsubsection{Inputs}\label{inputs-13-018}
SetpointManager:Scheduled,
- Heat Exhchanger Supply Air Temp Manager, !- Name
+ Heat Exchanger Supply Air Temp Manager, !- Name
Temperature, !- Control variable
Heat Exchanger Supply Air Temp Sch, !- Schedule Name
Heat Exchanger Supply Air Nodes; !- Name of the set point Node List
@@ -3981,7 +3977,7 @@ \subsection{ZoneHVAC:TerminalUnit:VariableRefrigerantFlow}\label{zonehvactermina
For air loop equipment and outdoor air system equipment the VRF terminal unit inlet and outlet nodes define the location of the system in the air loop and outdoor air system. The node names must define the path of the air stream in order from the beginning of the air loop or outdoor air system to the outlet of that system.
-This VRF terminal unit can be controlled based on a load or set point. When the system is used as zone equipment, load control is always used. When the VRF terminal unit is used in an air loop and the control zone name or thermostat location is specified, the system is controlled based on zone load. If the control zone name or thermostat location is not specified the VRF terminal unit will be controlled based on termninal unit or coil outlet node set point temperature. When set point based control is used the node temperature set points may be placed at the outlet of the terminal unit or at individual coil outlet nodes. If the VRF terminal unit is used in an air loop's outdoor air system, control is always based on a termninal unit or coil outlet node temperature set point.
+This VRF terminal unit can be controlled based on a load or set point. When the system is used as zone equipment, load control is always used. When the VRF terminal unit is used in an air loop and the control zone name or thermostat location is specified, the system is controlled based on zone load. If the control zone name or thermostat location is not specified the VRF terminal unit will be controlled based on terminal unit or coil outlet node set point temperature. When set point based control is used the node temperature set points may be placed at the outlet of the terminal unit or at individual coil outlet nodes. If the VRF terminal unit is used in an air loop's outdoor air system, control is always based on a terminal unit or coil outlet node temperature set point.
The terminal units operate to satisfy a heating or cooling load in a zone based on a zone thermostat temperature set point. A direct-expansion (DX) cooling and/or DX heating coil is specified depending on the operating mode required. Both a DX cooling and DX heating coil will typically be installed in the terminal unit, however only one may be used if desired. An optional supplemental heating coil can also be added to the terminal unit to provide additional heating when the main DX heating coil could not meet the entire heating load of a zone during cold outdoor conditions. The Supplemental Heating Coil Object Type must be \hyperref[coilheatingelectric]{Coil:Heating:Electric}, \hyperref[coilheatinggas-000]{Coil:Heating:Fuel}, \hyperref[coilheatingwater]{Coil:Heating:Water}, or \hyperref[coilheatingsteam]{Coil:Heating:Steam}. Outdoor ventilation air is modeled with the use of an optional outside air mixer object. Outside air may be provided to the zone only when the coil is operating or can be supplied continuously even when the coil is not operating.
@@ -4101,7 +4097,7 @@ \subsubsection{Inputs}\label{inputs-14-018}
\paragraph{Field: Design Specification ZoneHVAC Sizing Object Name}\label{field-design-specification-zonehvac-sizing-object-name-9}
-This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Sepcification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Cooling Supply Air Flow Rate in this VRF terminal unit zone HVAC object. The scaled Supply Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
+This optional input field is the name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. The name must correspond to unique name of a \hyperref[designspecificationzonehvacsizing]{DesignSpecification:ZoneHVAC:Sizing} object. A Design Specification Zone HVAC Sizing object defines scalable sizing methods for sizing input fields such as Cooling Supply Air Flow Rate in this VRF terminal unit zone HVAC object. The scaled Supply Air Flow Rate in turn is used to size cooling and heating capacity of the unit.
\paragraph{Field: Supplemental Heating Coil Object Type}\label{field-supplemental-heating-coil-object-type-2-000}
@@ -4348,7 +4344,7 @@ \subsubsection{Inputs}
This optional alpha input field specifies the name of the schedule (ref: Group – Schedules) that specifies the minimum supply air humidity ratio allowed in each time step. Values in this schedule are used as a constraint in choosing the feasible settings for supply air flow rate and outdoor air fraction in each operating mode. If this field is blank, no minimum is imposed.
\paragraph{Field: Maximum Supply Air Humidity Ratio Schedule Name}
-This optional alpha input field specifies the name of the schedule (ref: Group – Schedules) that specifies the maximum supply air humidity raio allowed in each time step. Values in this schedule are used as a constraint in choosing the feasible settings for supply air flow rate and outdoor air fraction in each operating mode. If this field is blank, no maximum is imposed.
+This optional alpha input field specifies the name of the schedule (ref: Group – Schedules) that specifies the maximum supply air humidity ratio allowed in each time step. Values in this schedule are used as a constraint in choosing the feasible settings for supply air flow rate and outdoor air fraction in each operating mode. If this field is blank, no maximum is imposed.
\paragraph{Field: Method to Choose Controlled Inputs and Part Runtime Fraction}
This alpha input field specifies the method that will be used to choose operating mode(s), supply air flow rate(s), outdoor air fraction(s) and part runtime fraction(s) in each time step. The only valid choices are ''Automatic`` and ''User Defined``, ''Automatic`` chooses the controlled independent variables to minimize resource use within each time step, subject to constraints, while best satisfying zone sensible loads, latent loads, and the scheduled ventilation rate. ''User Defined`` indicates that the user will provide a custom control sequence, using Energy Management System objects or other means, to choose the controlled independent variables and determine system outputs in each time step.
diff --git a/doc/input-output-reference/src/parametric-objects.tex b/doc/input-output-reference/src/parametric-objects.tex
index e04e7c4ba6b..f459b691789 100644
--- a/doc/input-output-reference/src/parametric-objects.tex
+++ b/doc/input-output-reference/src/parametric-objects.tex
@@ -133,7 +133,7 @@ \subsection{Parametric:Logic}\label{parametriclogic}
The statements include PARAMETER, IF, ELSE, ELSEIF, ENDIF, SELECT, CASE, DEFAULT, ENDSELECT, ENABLE, DISABLE, and REMARK. Nested IF and SELECT statements are allowed.~ All objects are enabled until they are specifically disabled using the DISABLE statement and could be later re-enabled with ENABLE. An object that is named with the DISABLE statement would not appear in that simulation run.
-The PARAMETER statement declares the name of the parameter. It is necessary that every parameter used in the Parametric:Logic object be initialized using the PARAMETER statement unless the parametes are created using the \hyperref[parametricsetvalueforrun]{Parametric:SetValueForRun} object. Requiring explicit parameter declaration reduces errors in software programming. Parameter names would not be case sensitive.
+The PARAMETER statement declares the name of the parameter. It is necessary that every parameter used in the Parametric:Logic object be initialized using the PARAMETER statement unless the parameters are created using the \hyperref[parametricsetvalueforrun]{Parametric:SetValueForRun} object. Requiring explicit parameter declaration reduces errors in software programming. Parameter names would not be case sensitive.
The DISABLE and ENABLE commands can have one or two arguments. If a second argument is present it is the kind of object.
@@ -227,7 +227,7 @@ \subsubsection{Inputs}\label{inputs-1-027}
ENDSELECT
\end{lstlisting}
-With any number of CASE statements. The \textless{}expression\textgreater{} is evaluated and compared to the constants with each CASE statement. If a match is found the corresponding \textless{}case-block-of-statements\textgreater{} are executed otherwise if no match if found the \textless{}default-block-of-statements\textgreater{} is excecuted. One one matching CASE statement for each SELECT block is executed. An example of how this works is shown below:
+With any number of CASE statements. The \textless{}expression\textgreater{} is evaluated and compared to the constants with each CASE statement. If a match is found the corresponding \textless{}case-block-of-statements\textgreater{} are executed otherwise if no match if found the \textless{}default-block-of-statements\textgreater{} is executed. One one matching CASE statement for each SELECT block is executed. An example of how this works is shown below:
\begin{lstlisting}
diff --git a/doc/input-output-reference/src/standard-output-reports/output-table-annual.tex b/doc/input-output-reference/src/standard-output-reports/output-table-annual.tex
index a4bbb5c47a4..5f4fb7ab0c5 100644
--- a/doc/input-output-reference/src/standard-output-reports/output-table-annual.tex
+++ b/doc/input-output-reference/src/standard-output-reports/output-table-annual.tex
@@ -44,7 +44,7 @@ \subsection{Inputs}\label{inputs-062}
\textbf{HoursNonNegative} -- The HoursNonNegative option adds up the elapsed time during the month that this variable has non-negative value. Hours with a positive value and hours with a zero value are all included.
-\textbf{HourInTenBinsMinToMax} - Creates 10 columns for the specified variable and shows the number of hours in each of 10 bins based on the minimum and maximum value. The bin sizes will be rounded up to the next most signficant digit value (if the min is 0 and the max is 28786.3, the bin size would be 3000 not 2878.63). A table of the bin ranges would be generated below the main table when this option is selected.
+\textbf{HourInTenBinsMinToMax} - Creates 10 columns for the specified variable and shows the number of hours in each of 10 bins based on the minimum and maximum value. The bin sizes will be rounded up to the next most significant digit value (if the min is 0 and the max is 28786.3, the bin size would be 3000 not 2878.63). A table of the bin ranges would be generated below the main table when this option is selected.
\textbf{HourInTenBinsZeroToMax} - Creates 11 columns for the specified variable and shows the number of hours in each of 10 bins from zero to the maximum value and a bin for hours below zero. The bin sizes will be rounded up to the next most significant digit value (if the min is 0 and the max is 28786.3, the bin size would be 3000 not 2878.63). A table of the bin ranges would be generated below the main table when this option is selected.
diff --git a/doc/input-output-reference/src/standard-output-reports/output-table-monthly.tex b/doc/input-output-reference/src/standard-output-reports/output-table-monthly.tex
index 479fef4df9a..e45edd3235c 100644
--- a/doc/input-output-reference/src/standard-output-reports/output-table-monthly.tex
+++ b/doc/input-output-reference/src/standard-output-reports/output-table-monthly.tex
@@ -42,7 +42,7 @@ \subsection{Inputs}\label{inputs-063}
\emph{Advanced Aggregation Types}
-The advanced aggregation types are described below. These aggregation types rely on doing an operation on the current variable but only during the time or times defined by a previously defined field. The ValueWhenMaxOrMin displays the value of one variable at the same time as the maximum or minimum is set on a previous field that is defined as either a maximum or minimum. The ``Hours---`` aggregation types display then number of hours that a variable meets a condition. The ``---DuringHoursShown'' aggregation types perform those aggretations but instead of for all the hours in the month, only for the hours that the previous ``Hours---`` entry applies. Multiple ``---DuringHoursShown'' after an ``Hours---`` will all be based on that single ``Hours---`` entry, in fact the ``---DuringHoursShown'' is based on the next column to the left that contains an ``Hours---`` entry even if other types of aggregations are used in intermediate columns. Order of the variables in the report is important when using the advanced aggregation types since they often depend on a previous entry.
+The advanced aggregation types are described below. These aggregation types rely on doing an operation on the current variable but only during the time or times defined by a previously defined field. The ValueWhenMaxOrMin displays the value of one variable at the same time as the maximum or minimum is set on a previous field that is defined as either a maximum or minimum. The ``Hours---`` aggregation types display then number of hours that a variable meets a condition. The ``---DuringHoursShown'' aggregation types perform those aggregations but instead of for all the hours in the month, only for the hours that the previous ``Hours---`` entry applies. Multiple ``---DuringHoursShown'' after an ``Hours---`` will all be based on that single ``Hours---`` entry, in fact the ``---DuringHoursShown'' is based on the next column to the left that contains an ``Hours---`` entry even if other types of aggregations are used in intermediate columns. Order of the variables in the report is important when using the advanced aggregation types since they often depend on a previous entry.
\textbf{ValueWhenMaximumOrMinimum} -- The ValueWhenMaximumOrMinimum option looks at the previous variable in the report that sets a maximum or minimum and displays the value of the current variable at that same timestep. Order of the variables in the report is important when using ValueWhenMaxMin. This can be used, for example, when an outdoor temperature should be reported for the time of the maximum cooling load.
diff --git a/doc/input-output-reference/src/standard-output-reports/output-table-summaryreports.tex b/doc/input-output-reference/src/standard-output-reports/output-table-summaryreports.tex
index 99dbb39439d..744a6fa6d63 100644
--- a/doc/input-output-reference/src/standard-output-reports/output-table-summaryreports.tex
+++ b/doc/input-output-reference/src/standard-output-reports/output-table-summaryreports.tex
@@ -129,7 +129,7 @@ \subsubsection{Predefined Annual Summary Reports}\label{predefined-annual-summar
\item
Cooling Coils includes the nominal total, sensible and latent capacities, the nominal sensible heat ratio, the nominal efficiency, nominal UA value, and nominal~ surface area for each cooling coil. These values are calculated by calling the cooling coil simulation routine with the rated inlet conditions: inlet air dry bulb temperature = 26.67C, inlet air wet bulb temperature = 19.44C, inlet chilled water temperature = 6.67C.
\item
- DX Cooling Coils summarizes the Standard Rating (Net) Cooling Capacity, SEER, EER and IEER values at AHRI standard test. Currently, these values are only reported for coil type = \hyperref[coilcoolingdxsinglespeed]{Coil:Cooling:DX:SingleSpeed} and \hyperref[coilcoolingdxmultispeed]{Coil:Cooling:DX:MultiSpeeed} with condenser type = AirCooled. However, the EER value is not reported for the mulit-speed DX cooling coil. There are two SEER values reported: \textit{SEER} and \textit{SEER Default}. The \textit{SEER} value is calculated using user specified Part Load Factor (PLF) curve used for energy performance calculation and the \textit{SEER Default} value is calculated using the AHRI Standard 210/240-2008 default PLF curve and cooling coefficent of degradation value of 0.25.
+ DX Cooling Coils summarizes the Standard Rating (Net) Cooling Capacity, SEER, EER and IEER values at AHRI standard test. Currently, these values are only reported for coil type = \hyperref[coilcoolingdxsinglespeed]{Coil:Cooling:DX:SingleSpeed} and \hyperref[coilcoolingdxmultispeed]{Coil:Cooling:DX:MultiSpeeed} with condenser type = AirCooled. However, the EER value is not reported for the multi-speed DX cooling coil. There are two SEER values reported: \textit{SEER} and \textit{SEER Default}. The \textit{SEER} value is calculated using user specified Part Load Factor (PLF) curve used for energy performance calculation and the \textit{SEER Default} value is calculated using the AHRI Standard 210/240-2008 default PLF curve and cooling coefficient of degradation value of 0.25.
\item
DX Heating Coils summarizes the High Temperature Heating Standard (Net) Rating Capacity, Low Temperature Heating Standard (Net) Rating Capacity and Heating Seasonal Performance Factor (HSPF) values at AHRI standard test. Currently, these values are only reported for coil type = \hyperref[coilheatingdxsinglespeed]{Coil:Heating:DX:SingleSpeed}.
\item
@@ -399,7 +399,7 @@ \subsubsection{Predefined Annual Summary Reports}\label{predefined-annual-summar
The Air Loop Component Summary tables also include tables that indicate the zones included in the aggregated results for heating and cooling.
-If the time of the peak load for each Zone for cooling exactly matches the time of the peak load for the AirLoop or Facility than the Estimated Cooling Peak Load Components will represent a sum of the values from the corresponding zones. Likewise the Estimated Heating Peak Load Components will add up for the AirLoop or Facility if the times of the heating peaks exactly match. This is not necessarily the case for Peak Conditions or the Engineering Checks tables. Since the sizing of Airloops is based on the system sizing they usually will be different than the sum of the corresonding zones.
+If the time of the peak load for each Zone for cooling exactly matches the time of the peak load for the AirLoop or Facility than the Estimated Cooling Peak Load Components will represent a sum of the values from the corresponding zones. Likewise the Estimated Heating Peak Load Components will add up for the AirLoop or Facility if the times of the heating peaks exactly match. This is not necessarily the case for Peak Conditions or the Engineering Checks tables. Since the sizing of Airloops is based on the system sizing they usually will be different than the sum of the corresponding zones.
\paragraph{Standard 62.1 Summary}\label{standard-62.1-summary}
@@ -450,7 +450,7 @@ \subsubsection{Predefined Annual Summary Reports}\label{predefined-annual-summar
\paragraph{Component Cost Economics Summary}\label{component-cost-economics-summary}
-The Component Cost Economics Summary provides the construction cost estimate summary for the project. The costs are broken into eight catagories and the reference building costs are provided as a comparison. A second table is also produced that provides line item details with one line for every line item object. The key used to obtain this report is ComponentCostEconomicsSummary.
+The Component Cost Economics Summary provides the construction cost estimate summary for the project. The costs are broken into eight categories and the reference building costs are provided as a comparison. A second table is also produced that provides line item details with one line for every line item object. The key used to obtain this report is ComponentCostEconomicsSummary.
\paragraph{Life Cycle Cost Report}\label{LifeCycleCostReport}
@@ -497,7 +497,7 @@ \subsubsection{Predefined Annual Summary Reports}\label{predefined-annual-summar
\subsubsection{Predefined Monthly Summary Reports}\label{predefined-monthly-summary-reports}
-The predefined monthly report options are shown below. The key name of the predefined monthly report is all that is needed to have that report appear in the tabular output file. After each report name below are the output variables and aggregation types used. These cannot be modified when using the predefined reports but if changes are desired, a \hyperref[outputtablemonthly]{Output:Table:Monthly} can be used instead. The StandardReports.idf file in the DataSets directory includes a \hyperref[outputtablemonthly]{Output:Table:Monthly} that exactly corresponds to the predefined monthly reports shown below. They can be copied into an IDF file and extended if additional variables are desired. A listing of each available key for predefined monthly summary reports follows with a discrption of the variables included.
+The predefined monthly report options are shown below. The key name of the predefined monthly report is all that is needed to have that report appear in the tabular output file. After each report name below are the output variables and aggregation types used. These cannot be modified when using the predefined reports but if changes are desired, a \hyperref[outputtablemonthly]{Output:Table:Monthly} can be used instead. The StandardReports.idf file in the DataSets directory includes a \hyperref[outputtablemonthly]{Output:Table:Monthly} that exactly corresponds to the predefined monthly reports shown below. They can be copied into an IDF file and extended if additional variables are desired. A listing of each available key for predefined monthly summary reports follows with a description of the variables included.
\paragraph{ZoneCoolingSummaryMonthly}\label{zonecoolingsummarymonthly}
diff --git a/doc/input-output-reference/src/weather-data/weather-file-data-reporting-errors-during.tex b/doc/input-output-reference/src/weather-data/weather-file-data-reporting-errors-during.tex
index fe976b90003..81f8c83518e 100644
--- a/doc/input-output-reference/src/weather-data/weather-file-data-reporting-errors-during.tex
+++ b/doc/input-output-reference/src/weather-data/weather-file-data-reporting-errors-during.tex
@@ -1,6 +1,6 @@
\section{Weather File Data Reporting (errors) during Simulation}\label{weather-file-data-reporting-errors-during-simulation}
-Missing data on the weather file used will be summarized on the \textbf{eplusout.err} file. In EnergyPlus, ``missing data'' is shown only for fields that EnergyPlus will use. For the ``WeatherCodes'', an invalid field count (where the number of items in the field does not = 9) will be shown. The number of items count refers to the number of records on the weather file that are in error or missing -- for an hourly weather file, this is the number of hours. Likewise out of range values (see specific fields in the previous definition) will be counted for each occurance and summarized. Note that the out of range values will not be changed by EnergyPlus and could affect your simulation results.
+Missing data on the weather file used will be summarized on the \textbf{eplusout.err} file. In EnergyPlus, ``missing data'' is shown only for fields that EnergyPlus will use. For the ``WeatherCodes'', an invalid field count (where the number of items in the field does not = 9) will be shown. The number of items count refers to the number of records on the weather file that are in error or missing -- for an hourly weather file, this is the number of hours. Likewise out of range values (see specific fields in the previous definition) will be counted for each occurrence and summarized. Note that the out of range values will not be changed by EnergyPlus and could affect your simulation results.
For example:
diff --git a/idd/Energy+.idd.in b/idd/Energy+.idd.in
index 0c73a3aa715..c56015d4662 100644
--- a/idd/Energy+.idd.in
+++ b/idd/Energy+.idd.in
@@ -441,7 +441,7 @@ SimulationControl,
\key No
\default Yes
A6, \field Do HVAC Sizing Simulation for Sizing Periods
- \note If Yes, SizingPeriod:* objects are exectuted additional times for advanced sizing.
+ \note If Yes, SizingPeriod:* objects are executed additional times for advanced sizing.
\note Currently limited to use with coincident plant sizing, see Sizing:Plant object
\type choice
\key Yes
@@ -449,7 +449,7 @@ SimulationControl,
\default No
N1; \field Maximum Number of HVAC Sizing Simulation Passes
\note the entire set of SizingPeriod:* objects may be repeated to fine tune size results
- \note this input sets a limit on the number of passes that the sizing algorithms can repeate the set
+ \note this input sets a limit on the number of passes that the sizing algorithms can repeat the set
\type integer
\minimum 1
\default 1
@@ -1260,7 +1260,7 @@ SizingPeriod:DesignDay,
\type integer
A13; \field Begin Environment Reset Mode
\note If used this can control if you want the thermal history to be reset at the beginning of the design day.
- \note When using a series of similiar design days, this field can be used to retain warmup state from the previous design day.
+ \note When using a series of similar design days, this field can be used to retain warmup state from the previous design day.
\type choice
\key FullResetAtBeginEnvironment
\key SuppressAllBeginEnvironmentResets
@@ -1966,7 +1966,7 @@ Site:GroundTemperature:Undisturbed:Xing,
\type real
\units J/kg-K
\minimum> 0.0
- N4, \field Average Soil Surface Tempeature
+ N4, \field Average Soil Surface Temperature
\required-field
\type real
\units C
@@ -8943,7 +8943,7 @@ ConstructionProperty:InternalHeatSource,
\type real
\units m
\minimum 0.01
- \maximum 1.0
+ \maximum 1.0
\note uniform spacing between tubes or resistance wires in direction
\note perpendicular to main intended direction of heat transfer
N5; \field Two-Dimensional Temperature Calculation Position
@@ -9091,22 +9091,22 @@ Construction:ComplexFenestrationState,
\type object-list
\object-list CFSGlazingName
\object-list WindowComplexShades
- A11, \field Outside Layer Directional Front Absoptance Matrix Name
+ A11, \field Outside Layer Directional Front Absorptance Matrix Name
\required-field
\type object-list
\object-list DataMatrices
- A12, \field Outside Layer Directional Back Absoptance Matrix Name
+ A12, \field Outside Layer Directional Back Absorptance Matrix Name
\required-field
\type object-list
\object-list DataMatrices
A13, \field Gap 1 Name
\type object-list
\object-list CFSGap
- A14, \field CFS Gap 1 Directional Front Absoptance Matrix Name
+ A14, \field CFS Gap 1 Directional Front Absorptance Matrix Name
\note Reserved for future use. Leave it blank for this version
\type object-list
\object-list DataMatrices
- A15, \field CFS Gap 1 Directional Back Absoptance Matrix Name
+ A15, \field CFS Gap 1 Directional Back Absorptance Matrix Name
\note Reserved for future use. Leave it blank for this version
\type object-list
\object-list DataMatrices
@@ -9114,20 +9114,20 @@ Construction:ComplexFenestrationState,
\type object-list
\object-list CFSGlazingName
\object-list WindowComplexShades
- A17, \field Layer 2 Directional Front Absoptance Matrix Name
+ A17, \field Layer 2 Directional Front Absorptance Matrix Name
\type object-list
\object-list DataMatrices
- A18, \field Layer 2 Directional Back Absoptance Matrix Name
+ A18, \field Layer 2 Directional Back Absorptance Matrix Name
\type object-list
\object-list DataMatrices
A19, \field Gap 2 Name
\type object-list
\object-list CFSGap
- A20, \field Gap 2 Directional Front Absoptance Matrix Name
+ A20, \field Gap 2 Directional Front Absorptance Matrix Name
\note Reserved for future use. Leave it blank for this version
\type object-list
\object-list DataMatrices
- A21, \field Gap 2 Directional Back Absoptance Matrix Name
+ A21, \field Gap 2 Directional Back Absorptance Matrix Name
\note Reserved for future use. Leave it blank for this version
\type object-list
\object-list DataMatrices
@@ -9135,20 +9135,20 @@ Construction:ComplexFenestrationState,
\type object-list
\object-list CFSGlazingName
\object-list WindowComplexShades
- A23, \field Layer 3 Directional Front Absoptance Matrix Name
+ A23, \field Layer 3 Directional Front Absorptance Matrix Name
\type object-list
\object-list DataMatrices
- A24, \field Layer 3 Directional Back Absoptance Matrix Name
+ A24, \field Layer 3 Directional Back Absorptance Matrix Name
\type object-list
\object-list DataMatrices
A25, \field Gap 3 Name
\type object-list
\object-list CFSGap
- A26, \field Gap 3 Directional Front Absoptance Matrix Name
+ A26, \field Gap 3 Directional Front Absorptance Matrix Name
\note Reserved for future use. Leave it blank for this version
\type object-list
\object-list DataMatrices
- A27, \field Gap 3 Directional Back Absoptance Matrix Name
+ A27, \field Gap 3 Directional Back Absorptance Matrix Name
\note Reserved for future use. Leave it blank for this version
\type object-list
\object-list DataMatrices
@@ -9156,20 +9156,20 @@ Construction:ComplexFenestrationState,
\type object-list
\object-list CFSGlazingName
\object-list WindowComplexShades
- A29, \field Layer 4 Directional Front Absoptance Matrix Name
+ A29, \field Layer 4 Directional Front Absorptance Matrix Name
\type object-list
\object-list DataMatrices
- A30, \field Layer 4 Directional Back Absoptance Matrix Name
+ A30, \field Layer 4 Directional Back Absorptance Matrix Name
\type object-list
\object-list DataMatrices
A31, \field Gap 4 Name
\type object-list
\object-list CFSGap
- A32, \field Gap 4 Directional Front Absoptance Matrix Name
+ A32, \field Gap 4 Directional Front Absorptance Matrix Name
\note Reserved for future use. Leave it blank for this version
\type object-list
\object-list DataMatrices
- A33, \field Gap 4 Directional Back Absoptance Matrix Name
+ A33, \field Gap 4 Directional Back Absorptance Matrix Name
\note Reserved for future use. Leave it blank for this version
\type object-list
\object-list DataMatrices
@@ -9177,10 +9177,10 @@ Construction:ComplexFenestrationState,
\type object-list
\object-list CFSGlazingName
\object-list WindowComplexShades
- A35, \field Layer 5 Directional Front Absoptance Matrix Name
+ A35, \field Layer 5 Directional Front Absorptance Matrix Name
\type object-list
\object-list DataMatrices
- A36; \field Layer 5 Directional Back Absoptance Matrix Name
+ A36; \field Layer 5 Directional Back Absorptance Matrix Name
Construction:WindowEquivalentLayer,
\memo Start with outside layer and work your way to the inside Layer
@@ -17408,7 +17408,7 @@ SurfaceProperty:ExposedFoundationPerimeter,
\note exposed. Value * Fraction = Total exposed perimeter
\note BySegment => define whether the segment between each set of
\note consecutive vertices of the floor surface is exposed.
- \note SUM(exposed segement lengths) = Total exposed perimeter
+ \note SUM(exposed segment lengths) = Total exposed perimeter
\required-field
\type choice
\key TotalExposedPerimeter
@@ -19037,7 +19037,7 @@ ZoneProperty:UserViewFactors:BySurfaceName,
\format ViewFactor
A1, \field Zone or ZoneList or Space or SpaceList Name
\note View factors may be entered for a space, zone, group of spaces, or group of zones in the same enclosure
- \note by way of Constructon:AirBoundary or open spaces within a zone. This name must align with an enclosure
+ \note by way of Construction:AirBoundary or open spaces within a zone. This name must align with an enclosure
\note encompassing the same zones or spaces.
\type object-list
\object-list SpaceNames
@@ -19409,10 +19409,10 @@ GroundHeatTransfer:Slab:MatlProps,
GroundHeatTransfer:Slab:BoundConds,
\memo Supplies some of the boundary conditions used in the ground heat transfer calculations.
A1, \field EVTR: Is surface evapotranspiration modeled
- \note This field specifies whether or not to use the evapotransporation model.
- \note The inclusion of evapotransporation in the calculation has the greatest
+ \note This field specifies whether or not to use the evapotranspiration model.
+ \note The inclusion of evapotranspiration in the calculation has the greatest
\note effect in warm dry climates, primarily on the ground surface temperature.
- \note This field can be used to turn the evapotransporation off and on to check
+ \note This field can be used to turn the evapotranspiration off and on to check
\note sensitivity to it.
\type choice
\key TRUE
@@ -22829,7 +22829,7 @@ ElectricEquipment:ITE:AirCooled,
\type object-list
\object-list BivariateFunctions
\note The name of a two-variable curve or table lookup object which modifies the recirculation
- \note fractionas a function of CPU loading (x) and supply air node temperature (y).
+ \note fraction as a function of CPU loading (x) and supply air node temperature (y).
\note This curve (table) should equal 1.0 at design conditions (CPU loading = 1.0 and
\note Design Entering Air Temperature).This field is used only if the
\note Air Node Connection Type = AdjustedSupply. If this curve is left blank, then the curve
@@ -24328,7 +24328,7 @@ ZoneCrossMixing,
A6 , \field Delta Temperature Schedule Name
\type object-list
\object-list ScheduleNames
- \note This scheulde contains the temperature differential between source and
+ \note This schedule contains the temperature differential between source and
\note receiving zone or space below which mixing is shutoff. If a source zone is
\note specified and it contains more than one space, the average source zone temperature
\note will be used for control. Schedule values must be greater than or equal to zero.
@@ -24527,10 +24527,58 @@ ZoneEarthtube,
\note "C" in Equation
\type real
\default 0
- N18; \field Velocity Squared Term Flow Coefficient
+ N18, \field Velocity Squared Term Flow Coefficient
\note "D" in Equation
\type real
\default 0
+ A5, \field Earth Tube Model Type
+ \type choice
+ \key Basic
+ \key Vertical
+ \default Basic
+ A6; \field Earth Tube Model Parameters
+ \type object-list
+ \object-list EarthTubeParameterNames
+
+ZoneEarthtube:Parameters,
+ \memo Parameters that apply to the vertical model for an earth tube
+ \min-fields 6
+ A1, \field Earth Tube Model Parameters Name
+ \required-field
+ \reference EarthTubeParameterNames
+ N1, \field Nodes Above Earth Tube
+ \type integer
+ \units dimensionless
+ \minimum 3
+ \maximum 10
+ \default 5
+ N2, \field Nodes Below Earth Tube
+ \type integer
+ \units dimensionless
+ \minimum 3
+ \maximum 10
+ \default 3
+ N3, \field Earth Tube Dimensionless Boundary Above
+ \note When set to 1.0, the upper boundary is one earth tube radius below ground.
+ \type real
+ \units dimensionless
+ \minimum 0.25
+ \maximum 1.0
+ \default 1.0
+ N4, \field Earth Tube Dimensionless Boundary Above
+ \note When set to 1.0, the upper boundary is one earth tube radius below ground.
+ \type real
+ \units dimensionless
+ \minimum 0.25
+ \maximum 1.0
+ \default 0.25
+ N5; \field Earth Tube Solution Space Width
+ \note Width of the nodes in the direction parallel to the ground, multiplied by earth tube radius
+ \type real
+ \units dimensionless
+ \minimum 3.0
+ \maximum 20.0
+ \default 4.0
ZoneCoolTower:Shower,
\memo A cooltower (sometimes referred to as a wind tower or a shower cooling tower)
@@ -25067,7 +25115,7 @@ AirflowNetwork:SimulationControl,
\default SkylineLU
A9 , \field Allow Unsupported Zone Equipment
\note Set this input to Yes to have zone equipment that are currently unsupported in the AirflowNetwork model
- \note allowed in the simulation if present. Setting this field to Yes, allows the following equipments
+ \note allowed in the simulation if present. Setting this field to Yes, allows the following equipment
\note to be modeled along an AirflowNetwork model: ZoneHVAC:Dehumidifier, ZoneHVAC:EnergyRecoveryVentilator,
\note WaterHeater:HeatPump:*.
\type choice
@@ -26810,9 +26858,9 @@ AirflowNetwork:Distribution:DuctSizing,
\maximum 25.0
\default 5.0
\note Used only if Duct Sizing Type = MaximumVelocity or PressureLossWithMaximumVelocity.
- \note When MaximumVelocity is entered, duct diameter is calculated at D = flow rate /
+ \note When MaximumVelocity is entered, duct diameter is calculated at D = flow rate /
\note cross section area.
- \note When PressureLossWithMaximumVelocity is entered, duct diameter is calculated based on
+ \note When PressureLossWithMaximumVelocity is entered, duct diameter is calculated based on
\note PressureLoss. The value is used to check to ensure the final velocity is less than
\note the maximum value. If greater, final value will be obtained from MaximumVelocity.
\note This field is apply for trunk size, while branch size is based on total pressure drop.
@@ -26821,8 +26869,8 @@ AirflowNetwork:Distribution:DuctSizing,
\units Pa
\minimum >0.0
\note Used only if Duct Sizing Type = PressureLoss or PressureLossWithMaximumVelocity.
- \note When PressureLoss is entered, duct diameter is calculated using Colebrook's equation
- \note When PressureLossWithMaximumVelocity is entered, duct diameter is calculated based on
+ \note When PressureLoss is entered, duct diameter is calculated using Colebrook's equation
+ \note When PressureLossWithMaximumVelocity is entered, duct diameter is calculated based on
\note PressureLoss. The value is used to check to ensure the final velocity is less than
\note the maximum value. If greater, final value will be obtained from MaximumVelocity.
\note This field is apply for trunk size, while branch size is based on total pressure drop.
@@ -26830,20 +26878,20 @@ AirflowNetwork:Distribution:DuctSizing,
\type real
\units Pa
\minimum >0.0
- \note Duct diameter is calculated using Colebrook's equation. When there is no solution,
- \note velocity = 5 m/s is used to calculate duct diameter.
+ \note Duct diameter is calculated using Colebrook's equation. When there is no solution,
+ \note velocity = 5 m/s is used to calculate duct diameter.
N5 , \field Total Pressure Loss Across Return Trunk
\type real
\units Pa
\minimum >0.0
- \note Duct diameter is calculated using Colebrook's equation. When there is no solution,
- \note velocity = 5 m/s is used to calculate duct diameter.
+ \note Duct diameter is calculated using Colebrook's equation. When there is no solution,
+ \note velocity = 5 m/s is used to calculate duct diameter.
N6 ; \field Total Pressure Loss Across Return Branch
\type real
\units Pa
\minimum >0.0
- \note Duct diameter is calculated using Colebrook's equation. When there is no solution,
- \note velocity = 5 m/s is used to calculate duct diameter.
+ \note Duct diameter is calculated using Colebrook's equation. When there is no solution,
+ \note velocity = 5 m/s is used to calculate duct diameter.
AirflowNetwork:OccupantVentilationControl,
\memo This object is used to provide advanced thermal comfort control of window opening and closing
@@ -28157,7 +28205,7 @@ HVACTemplate:Zone:PTHP,
\default None
HVACTemplate:Zone:WaterToAirHeatPump,
- \min-fields 44
+ \min-fields 43
\memo Water to Air Heat Pump to be used with HVACTemplate:Plant:MixedWaterLoop
A1, \field Zone Name
\required-field
@@ -28328,7 +28376,7 @@ HVACTemplate:Zone:WaterToAirHeatPump,
\default 2.5
\note The maximum on-off cycling rate for the compressor
\note Suggested value is 2.5 for a typical heat pump
- N19, \field Heat Pump Time Constant
+ N19, \field Latent Capacity Time Constant
\type real
\units s
\minimum 0.0
@@ -28336,14 +28384,7 @@ HVACTemplate:Zone:WaterToAirHeatPump,
\default 60.0
\note Time constant for the cooling coil's capacity to reach steady state after startup
\note Suggested value is 60 for a typical heat pump
- N20, \field Fraction of On-Cycle Power Use
- \minimum 0.0
- \maximum 0.05
- \default 0.01
- \note The fraction of on-cycle power use to adjust the part load fraction based on
- \note the off-cycle power consumption due to crankcase heaters, controls, fans, and etc.
- \note Suggested value is 0.01 for a typical heat pump
- N21, \field Heat Pump Fan Delay Time
+ N20, \field Heat Pump Fan Delay Time
\units s
\minimum 0.0
\default 60
@@ -28368,13 +28409,13 @@ HVACTemplate:Zone:WaterToAirHeatPump,
\key SupplyAirTemperature
\key TemperatureDifference
\default SupplyAirTemperature
- N22, \field Zone Cooling Design Supply Air Temperature
+ N21, \field Zone Cooling Design Supply Air Temperature
\type real
\units C
\default 14.0
\note Zone Cooling Design Supply Air Temperature is only used when Zone Cooling Design
\note Supply Air Temperature Input Method = SupplyAirTemperature
- N23, \field Zone Cooling Design Supply Air Temperature Difference
+ N22, \field Zone Cooling Design Supply Air Temperature Difference
\type real
\units deltaC
\default 11.11
@@ -28389,13 +28430,13 @@ HVACTemplate:Zone:WaterToAirHeatPump,
\key SupplyAirTemperature
\key TemperatureDifference
\default SupplyAirTemperature
- N24, \field Zone Heating Design Supply Air Temperature
+ N23, \field Zone Heating Design Supply Air Temperature
\type real
\units C
\default 50.0
\note Zone Heating Design Supply Air Temperature is only used when Zone Heating Design
\note Supply Air Temperature Input Method = SupplyAirTemperature
- N25, \field Zone Heating Design Supply Air Temperature Difference
+ N24, \field Zone Heating Design Supply Air Temperature Difference
\type real
\units deltaC
\default 30.0
@@ -28432,7 +28473,7 @@ HVACTemplate:Zone:WaterToAirHeatPump,
\note If blank, always on
\type object-list
\object-list ScheduleNames
- N26; \field Baseboard Heating Capacity
+ N25; \field Baseboard Heating Capacity
\autosizable
\default autosize
\units W
@@ -34201,7 +34242,7 @@ Sizing:Zone,
\note Use SupplyAirHumidityRatio to enter the humidity ratio when zone dehumidification
\note is required. The supply air humidity ratio should be less than the zone humidity
\note ratio at the zone thermostat and humidistat set point condition.
- \note Use HumidityRatioDifference to enter the difference in humidity ratio from the
+ \note Use HumidityRatioDifference to enter the difference in humidity ratio from the
\note zone thermostat and humidistat set point condition.
\type choice
\key SupplyAirHumidityRatio
@@ -34220,7 +34261,7 @@ Sizing:Zone,
\note Zone Latent Cooling Design Supply Air Humidity Ratio Input Method = HumidityRatioDifference.
\note This input is a positive value and defines the difference between the zone humidity
\note ratio at the thermostat and humidistat set point condition and the supply air
- \note humidity ratio entering the zone.
+ \note humidity ratio entering the zone.
\minimum> 0.0
\type real
\default 0.005
@@ -34229,7 +34270,7 @@ Sizing:Zone,
\note Use SupplyAirHumidityRatio to enter the humidity ratio when zone humidification
\note is required. The supply air humidity ratio should be greater than the zone humidity
\note ratio at the zone thermostat and humidistat set point condition.
- \note Use HumidityRatioDifference to enter the difference in humidity ratio from the
+ \note Use HumidityRatioDifference to enter the difference in humidity ratio from the
\note zone thermostat and humidistat set point condition.
\type choice
\key SupplyAirHumidityRatio
@@ -34248,7 +34289,7 @@ Sizing:Zone,
\note Heating Design Supply Air Humidity Ratio Input Method = HumidityRatioDifference.
\note This input is a positive value and defines the difference between the zone humidity
\note ratio at the thermostat and humidistat set point condition and the supply air
- \note humidity ratio entering the zone.
+ \note humidity ratio entering the zone.
\minimum 0.0
\type real
\default 0.005
@@ -35434,7 +35475,7 @@ ZoneHVAC:IdealLoadsAirSystem,
\note This field is only required when the Ideal Loads Air System is connected to an
\note AirloopHVAC:ZoneReturnPlenum, otherwise leave this field blank. When connected to a plenum
\note the return plenum Outlet Node Name (or Induced Air Outlet Node Name when connecting multiple
- \note ideal loads air sytems) is entered here. The two ideal loads air system node name fields described above,
+ \note ideal loads air systems) is entered here. The two ideal loads air system node name fields described above,
\note the Zone Supply Air Node Name and the Zone Exhaust Air Node Name must also be entered.
\note The Zone Supply Air Node Name must match a zone inlet air node name for the zone where this
\note Ideal Loads Air System is connected. The Zone Exhaust Air Node Name must match an inlet air
@@ -36246,7 +36287,7 @@ ZoneHVAC:WaterToAirHeatPump,
\memo Water-to-air heat pump. Forced-convection heating-cooling unit with supply fan,
\memo water-to-air cooling and heating coils, supplemental heating coil (gas, electric, hot
\memo water, or steam), and fixed-position outdoor air mixer.
- \min-fields 25
+ \min-fields 21
A1, \field Name
\required-field
\type alpha
@@ -36363,36 +36404,6 @@ ZoneHVAC:WaterToAirHeatPump,
\object-list CoolingCoilsWaterToAirHP
\object-list CoolingCoilsWaterToAirVSHP
\note Needs to match in the water-to-air heat pump cooling coil object
- N7, \field Maximum Cycling Rate
- \type real
- \units cycles/hr
- \minimum 0.0
- \maximum 5.0
- \default 2.5
- \note The maximum on-off cycling rate for the compressor
- \note Suggested value is 2.5 for a typical heat pump
- N8, \field Heat Pump Time Constant
- \type real
- \units s
- \minimum 0.0
- \maximum 500.0
- \default 60.0
- \note Time constant for the cooling coil's capacity to reach steady state after startup
- \note Suggested value is 60 for a typical heat pump
- N9, \field Fraction of On-Cycle Power Use
- \minimum 0.0
- \maximum 0.05
- \default 0.01
- \note The fraction of on-cycle power use to adjust the part load fraction based on
- \note the off-cycle power consumption due to crankcase heaters, controls, fans, and etc.
- \note Suggested value is 0.01 for a typical heat pump
- N10, \field Heat Pump Fan Delay Time
- \units s
- \minimum 0.0
- \default 60
- \note Programmed time delay for heat pump fan to shut off after compressor cycle off.
- \note Only required when fan operating mode is cycling
- \note Enter 0 when fan operating mode is continuous
A13, \field Supplemental Heating Coil Object Type
\required-field
\type choice
@@ -36406,14 +36417,14 @@ ZoneHVAC:WaterToAirHeatPump,
\type object-list
\object-list HeatingCoilName
\note Needs to match in the supplemental heating coil object
- N11, \field Maximum Supply Air Temperature from Supplemental Heater
+ N7, \field Maximum Supply Air Temperature from Supplemental Heater
\required-field
\type real
\units C
\autosizable
\default autosize
\note Supply air temperature from the supplemental heater will not exceed this value.
- N12, \field Maximum Outdoor Dry-Bulb Temperature for Supplemental Heater Operation
+ N8, \field Maximum Outdoor Dry-Bulb Temperature for Supplemental Heater Operation
\type real
\maximum 21.0
\default 21.0
@@ -36985,7 +36996,7 @@ ZoneHVAC:EvaporativeCoolerUnit,
\key ZoneCoolingLoadOnOffCycling
\key ZoneCoolingLoadVariableSpeedFan
N2 , \field Throttling Range Temperature Difference
- \note used for ZoneTemperatureDeadbandOnOffCycling hystersis range for thermostatic control
+ \note used for ZoneTemperatureDeadbandOnOffCycling hysteresis range for thermostatic control
\type real
\units deltaC
\default 1.0
@@ -37033,8 +37044,8 @@ ZoneHVAC:EvaporativeCoolerUnit,
\units percent
ZoneHVAC:HybridUnitaryHVAC,
- \memo Hybrid Unitary HVAC. A black box model for multi-mode packaged forced air equipment. Independent variables include outdoor air conditions and indoor air conditions. Controlled inputs include operating mode, supply air flow rate, and outdoor air faction. Emperical lookup tables are required to map supply air temperature supply air humidity, electricity use, fuel uses, water use, fan electricity use, and external static pressure as a function of each indpednent varaible and each controlled input. In each timestep the model will choose one or more combinations of settings for mode, supply air flow rate, outdoor air faction, and part runtime fraction so as to satisfy zone requests for sensible cooling, heating, ventilation, and/or dehumidification with the least resource consumption. Equipment in this class may consume electricity, water, and up to two additional fuel types.
- \extensible:25 repeat last twentyfive fields remembering to move the semi-colon to the last value
+ \memo Hybrid Unitary HVAC. A black box model for multi-mode packaged forced air equipment. Independent variables include outdoor air conditions and indoor air conditions. Controlled inputs include operating mode, supply air flow rate, and outdoor air faction. Empirical lookup tables are required to map supply air temperature supply air humidity, electricity use, fuel uses, water use, fan electricity use, and external static pressure as a function of each independent variable and each controlled input. In each timestep the model will choose one or more combinations of settings for mode, supply air flow rate, outdoor air faction, and part runtime fraction so as to satisfy zone requests for sensible cooling, heating, ventilation, and/or dehumidification with the least resource consumption. Equipment in this class may consume electricity, water, and up to two additional fuel types.
+ \extensible:25 repeat last twenty five fields remembering to move the semi-colon to the last value
A1, \field Name
\required-field
\type alpha
@@ -37048,7 +37059,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type object-list
\object-list SystemAvailabilityManagerLists
A4, \field Minimum Supply Air Temperature Schedule Name
- \note Values in this schedule are used as a constraint in choosing the feasible settings for supply air flow rate and ouside air fraction in each operating mode. If this field is blank, no minimum is imposed.
+ \note Values in this schedule are used as a constraint in choosing the feasible settings for supply air flow rate and outside air fraction in each operating mode. If this field is blank, no minimum is imposed.
\type object-list
\object-list ScheduleNames
A5, \field Maximum Supply Air Temperature Schedule Name
@@ -37087,7 +37098,7 @@ ZoneHVAC:HybridUnitaryHVAC,
N1, \field System Maximum Supply Air Flow Rate
\type real
\minimum> 0
- \note The value in this field represents the maximum supply air volume flow rate among all operating modes. Values of extensive variables in lookup tables are normalized by the system maximum supply air mass flow rate that was used to build performance curves. The value in this field is used to rescale the output from exenstive variables to a desired system size.
+ \note The value in this field represents the maximum supply air volume flow rate among all operating modes. Values of extensive variables in lookup tables are normalized by the system maximum supply air mass flow rate that was used to build performance curves. The value in this field is used to rescale the output from extensive variables to a desired system size.
\units m3/s
N2, \field External Static Pressure at System Maximum Supply Air Flow Rate
\type real
@@ -37199,7 +37210,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type alpha
\retaincase
\note Enter a name for Mode 0.
- \note Mode 0 describes equipment performance in standby. Mode 0 is usually characterized by electricity use for controls and crankcase heaters, or other standby resouce consumption. Mode 0 will be chosen for any timestep, or portion of timestep, when no ventilation, cooling, humidification, or dehumidification is required. Mode 0 is available at any environmental condition.
+ \note Mode 0 describes equipment performance in standby. Mode 0 is usually characterized by electricity use for controls and crankcase heaters, or other standby resource consumption. Mode 0 will be chosen for any timestep, or portion of timestep, when no ventilation, cooling, humidification, or dehumidification is required. Mode 0 is available at any environmental condition.
A21, \field Mode 0 Supply Air Temperature Lookup Table Name
\type object-list
\object-list MultivariateFunctions
@@ -37211,7 +37222,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\object-list MultivariateFunctions
\note Enter the name of the Supply Air Humidity Ratio Lookup Table for Mode 0.
\note Units for lookup table values should be in kgWater/kgDryAir.
- \note If this field is blank, Mode 0 will not be considered for any period that requires ventilation, heating, cooling, humidification, or dehumidification. If this field is blank, when Mode 0 is chosen (during standby periods) the supply air humidty ratio will equal the return air humidity ratio.
+ \note If this field is blank, Mode 0 will not be considered for any period that requires ventilation, heating, cooling, humidification, or dehumidification. If this field is blank, when Mode 0 is chosen (during standby periods) the supply air humidity ratio will equal the return air humidity ratio.
A23, \field Mode 0 System Electric Power Lookup Table Name
\type object-list
\object-list MultivariateFunctions
@@ -37334,7 +37345,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 1.
- \note Mode 1 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 1 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N11, \field Mode 1 Maximum Outdoor Air Humidity Ratio
@@ -37375,7 +37386,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 1.
- \note Mode 1 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 1 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N16, \field Mode 1 Minimum Return Air Humidity Ratio
\type real
@@ -37410,7 +37421,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 1.
+ \note Enter the maximum return air relative humidity allowed for Mode 1.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 1 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -37519,7 +37530,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 2.
- \note Mode 2 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 2 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N27, \field Mode 2 Maximum Outdoor Air Humidity Ratio
@@ -37560,7 +37571,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 2.
- \note Mode 2 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 2 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N32, \field Mode 2 Minimum Return Air Humidity Ratio
\type real
@@ -37595,7 +37606,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 2.
+ \note Enter the maximum return air relative humidity allowed for Mode 2.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 2 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -37704,7 +37715,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 3.
- \note Mode 3 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 3 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N43, \field Mode 3 Maximum Outdoor Air Humidity Ratio
@@ -37745,7 +37756,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 3.
- \note Mode 3 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 3 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N48, \field Mode 3 Minimum Return Air Humidity Ratio
\type real
@@ -37780,7 +37791,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 3.
+ \note Enter the maximum return air relative humidity allowed for Mode 3.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 3 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -37889,7 +37900,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 4.
- \note Mode 4 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 4 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N59, \field Mode 4 Maximum Outdoor Air Humidity Ratio
@@ -37930,7 +37941,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 4.
- \note Mode 4 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 4 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N64, \field Mode 4 Minimum Return Air Humidity Ratio
\type real
@@ -37965,7 +37976,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 4.
+ \note Enter the maximum return air relative humidity allowed for Mode 4.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 4 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -38074,7 +38085,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 5.
- \note Mode 5 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 5 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N75, \field Mode 5 Maximum Outdoor Air Humidity Ratio
@@ -38115,7 +38126,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 5.
- \note Mode 5 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 5 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N80, \field Mode 5 Minimum Return Air Humidity Ratio
\type real
@@ -38150,7 +38161,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 5.
+ \note Enter the maximum return air relative humidity allowed for Mode 5.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 5 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -38259,7 +38270,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 6.
- \note Mode 6 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 6 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N91, \field Mode 6 Maximum Outdoor Air Humidity Ratio
@@ -38300,7 +38311,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 6.
- \note Mode 6 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 6 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N96, \field Mode 6 Minimum Return Air Humidity Ratio
\type real
@@ -38335,7 +38346,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 6.
+ \note Enter the maximum return air relative humidity allowed for Mode 6.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 6 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -38444,7 +38455,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 7.
- \note Mode 7 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 7 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N107, \field Mode 7 Maximum Outdoor Air Humidity Ratio
@@ -38485,7 +38496,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 7.
- \note Mode 7 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 7 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N112, \field Mode 7 Minimum Return Air Humidity Ratio
\type real
@@ -38520,7 +38531,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 7.
+ \note Enter the maximum return air relative humidity allowed for Mode 7.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 7 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -38629,7 +38640,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 8.
- \note Mode 8 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 8 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N123, \field Mode 8 Maximum Outdoor Air Humidity Ratio
@@ -38670,7 +38681,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 8.
- \note Mode 8 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 8 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N128, \field Mode 8 Minimum Return Air Humidity Ratio
\type real
@@ -38705,7 +38716,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 8.
+ \note Enter the maximum return air relative humidity allowed for Mode 8.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 8 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -38814,7 +38825,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 9.
- \note Mode 9 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 9 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N139, \field Mode 9 Maximum Outdoor Air Humidity Ratio
@@ -38855,7 +38866,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 9.
- \note Mode 9 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 9 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N144, \field Mode 9 Minimum Return Air Humidity Ratio
\type real
@@ -38890,7 +38901,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 9.
+ \note Enter the maximum return air relative humidity allowed for Mode 9.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 9 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -39004,7 +39015,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 10.
- \note Mode 10 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 10 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N155, \field Mode 10 Maximum Outdoor Air Humidity Ratio
@@ -39045,7 +39056,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 10.
- \note Mode 10 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 10 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N160, \field Mode 10 Minimum Return Air Humidity Ratio
\type real
@@ -39080,7 +39091,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 10.
+ \note Enter the maximum return air relative humidity allowed for Mode 10.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 10 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -39189,7 +39200,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 11.
- \note Mode 11 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 11 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N171, \field Mode 11 Maximum Outdoor Air Humidity Ratio
@@ -39230,7 +39241,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 11.
- \note Mode 11 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 11 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N176, \field Mode 11 Minimum Return Air Humidity Ratio
\type real
@@ -39265,7 +39276,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 11.
+ \note Enter the maximum return air relative humidity allowed for Mode 11.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 11 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -39374,7 +39385,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 12.
- \note Mode 12 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 12 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N187, \field Mode 12 Maximum Outdoor Air Humidity Ratio
@@ -39415,7 +39426,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 12.
- \note Mode 12 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 12 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N192, \field Mode 12 Minimum Return Air Humidity Ratio
\type real
@@ -39450,7 +39461,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 12.
+ \note Enter the maximum return air relative humidity allowed for Mode 12.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 12 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -39559,7 +39570,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 13.
- \note Mode 13 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 13 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N203, \field Mode 13 Maximum Outdoor Air Humidity Ratio
@@ -39600,7 +39611,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 13.
- \note Mode 13 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 13 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N208, \field Mode 13 Minimum Return Air Humidity Ratio
\type real
@@ -39635,7 +39646,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 13.
+ \note Enter the maximum return air relative humidity allowed for Mode 13.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 13 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -39744,7 +39755,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 14.
- \note Mode 14 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 14 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N219, \field Mode 14 Maximum Outdoor Air Humidity Ratio
@@ -39785,7 +39796,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 14.
- \note Mode 14 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 14 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N224, \field Mode 14 Minimum Return Air Humidity Ratio
\type real
@@ -39820,7 +39831,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 14.
+ \note Enter the maximum return air relative humidity allowed for Mode 14.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 14 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -39929,7 +39940,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 15.
- \note Mode 15 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 15 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N235, \field Mode 15 Maximum Outdoor Air Humidity Ratio
@@ -39970,7 +39981,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 15.
- \note Mode 15 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 15 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N240, \field Mode 15 Minimum Return Air Humidity Ratio
\type real
@@ -40005,7 +40016,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 15.
+ \note Enter the maximum return air relative humidity allowed for Mode 15.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 15 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -40114,7 +40125,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 16.
- \note Mode 16 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 16 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N251, \field Mode 16 Maximum Outdoor Air Humidity Ratio
@@ -40155,7 +40166,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 16.
- \note Mode 16 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 16 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N256, \field Mode 16 Minimum Return Air Humidity Ratio
\type real
@@ -40190,7 +40201,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 16.
+ \note Enter the maximum return air relative humidity allowed for Mode 16.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 16 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -40299,7 +40310,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 17.
- \note Mode 17 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 17 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N267, \field Mode 17 Maximum Outdoor Air Humidity Ratio
@@ -40340,7 +40351,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 17.
- \note Mode 17 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 17 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N272, \field Mode 17 Minimum Return Air Humidity Ratio
\type real
@@ -40375,7 +40386,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 17.
+ \note Enter the maximum return air relative humidity allowed for Mode 17.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 17 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -40484,7 +40495,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 18.
- \note Mode 18 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 18 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N283, \field Mode 18 Maximum Outdoor Air Humidity Ratio
@@ -40525,7 +40536,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 18.
- \note Mode 18 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 18 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N288, \field Mode 18 Minimum Return Air Humidity Ratio
\type real
@@ -40560,7 +40571,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 18.
+ \note Enter the maximum return air relative humidity allowed for Mode 18.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 18 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -40669,7 +40680,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 19.
- \note Mode 19 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 19 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N299, \field Mode 19 Maximum Outdoor Air Humidity Ratio
@@ -40710,7 +40721,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 19.
- \note Mode 19 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 19 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N304, \field Mode 19 Minimum Return Air Humidity Ratio
\type real
@@ -40745,7 +40756,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 19.
+ \note Enter the maximum return air relative humidity allowed for Mode 19.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 19 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -40854,7 +40865,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 20.
- \note Mode 20 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 20 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N315, \field Mode 20 Maximum Outdoor Air Humidity Ratio
@@ -40895,7 +40906,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 20.
- \note Mode 20 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 20 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N320, \field Mode 20 Minimum Return Air Humidity Ratio
\type real
@@ -40930,7 +40941,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 20.
+ \note Enter the maximum return air relative humidity allowed for Mode 20.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 20 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -41039,7 +41050,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 21.
- \note Mode 21 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 21 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N331, \field Mode 21 Maximum Outdoor Air Humidity Ratio
@@ -41080,7 +41091,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 21.
- \note Mode 21 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 21 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N336, \field Mode 21 Minimum Return Air Humidity Ratio
\type real
@@ -41115,7 +41126,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 21.
+ \note Enter the maximum return air relative humidity allowed for Mode 21.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 21 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -41224,7 +41235,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 22.
- \note Mode 22 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 22 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N347, \field Mode 22 Maximum Outdoor Air Humidity Ratio
@@ -41265,7 +41276,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 22.
- \note Mode 22 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 22 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N352, \field Mode 22 Minimum Return Air Humidity Ratio
\type real
@@ -41300,7 +41311,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 22.
+ \note Enter the maximum return air relative humidity allowed for Mode 22.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 22 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -41409,7 +41420,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 23.
- \note Mode 23 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 23 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N363, \field Mode 23 Maximum Outdoor Air Humidity Ratio
@@ -41450,7 +41461,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 23.
- \note Mode 23 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 23 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N368, \field Mode 23 Minimum Return Air Humidity Ratio
\type real
@@ -41485,7 +41496,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 23.
+ \note Enter the maximum return air relative humidity allowed for Mode 23.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 23 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -41594,7 +41605,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 24.
- \note Mode 24 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 24 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N379, \field Mode 24 Maximum Outdoor Air Humidity Ratio
@@ -41635,7 +41646,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 24.
- \note Mode 24 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 24 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N384, \field Mode 24 Minimum Return Air Humidity Ratio
\type real
@@ -41670,7 +41681,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 24.
+ \note Enter the maximum return air relative humidity allowed for Mode 24.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 24 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -41779,7 +41790,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\maximum 0.10
\units kgWater/kgDryAir
\note Enter the minimum outdoor humidity ratio allowed for Mode 25.
- \note Mode 25 will not be considerd when outdoor air absolute humidity is below the value in this field.
+ \note Mode 25 will not be considered when outdoor air absolute humidity is below the value in this field.
\note If this field is blank, the lower constraint on outdoor air humidity ratio will be 0.00 kgWater/kgDryAir.
\default 0.00
N395, \field Mode 25 Maximum Outdoor Air Humidity Ratio
@@ -41820,7 +41831,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\type real
\units C
\note Enter the maximum return air temperature allowed for Mode 25.
- \note Mode 25 will not be considred when the return air temperature is above the value in this field.
+ \note Mode 25 will not be considered when the return air temperature is above the value in this field.
\note If this field is blank, there will be no upper constraint on return air temperature.
N400, \field Mode 25 Minimum Return Air Humidity Ratio
\type real
@@ -41855,7 +41866,7 @@ ZoneHVAC:HybridUnitaryHVAC,
\minimum 0.00
\maximum 100.00
\units percent
- \note Enter the maximum return air relative humdity allowed for Mode 25.
+ \note Enter the maximum return air relative humidity allowed for Mode 25.
\note Relative humidity as percent from 0.00 to 100.00.
\note Mode 25 will not be considered when the return air relative humidity is above the value in this field.
\note If this field is blank, the upper constraint on return air relative humidity will be 100%.
@@ -42177,7 +42188,7 @@ ZoneHVAC:TerminalUnit:VariableRefrigerantFlow,
\units m3/s
\minimum 0.0
\autosizable
- \note This field is used only when an oudoor air mixer is included.
+ \note This field is used only when an outdoor air mixer is included.
\note This field is set to zero flow when the VRF terminal unit is connected to
\note central dedicated outdoor air through air terminal single duct mixer object.
\note When this VRF terminal is used as air loop equipment the autosized flow
@@ -42188,7 +42199,7 @@ ZoneHVAC:TerminalUnit:VariableRefrigerantFlow,
\units m3/s
\minimum 0.0
\autosizable
- \note This field is used only when an oudoor air mixer is included.
+ \note This field is used only when an outdoor air mixer is included.
\note This field is set to zero flow when the VRF terminal unit is connected to
\note central dedicated outdoor air through air terminal single duct mixer object.
\note When this VRF terminal is used as air loop equipment the autosized flow
@@ -42199,7 +42210,7 @@ ZoneHVAC:TerminalUnit:VariableRefrigerantFlow,
\units m3/s
\minimum 0.0
\autosizable
- \note This field is used only when an oudoor air mixer is included.
+ \note This field is used only when an outdoor air mixer is included.
\note This field is set to zero flow when the VRF terminal unit is connected to
\note central dedicated outdoor air through air terminal single duct mixer object.
\note When this VRF terminal is used as air loop equipment the autosized flow
@@ -45853,7 +45864,7 @@ ZoneHVAC:LowTemperatureRadiant:VariableFlow:Design,
\default 1.0
A10; \field Changeover Delay Time Period Schedule
\note Changeover delay schedule name for this system. Schedule value <= 0 allows changeover with no delay
- \note The schedule values are interpretted as hours.
+ \note The schedule values are interpreted as hours.
\note If this field is blank, the system allows changeover with no delay
\type object-list
\object-list ScheduleNames
@@ -46039,7 +46050,7 @@ ZoneHVAC:LowTemperatureRadiant:ConstantFlow:Design,
\default 1.0
A5 ; \field Changeover Delay Time Period Schedule
\note Changeover delay schedule name for this system. Schedule value <= 0 allows changeover with no delay
- \note The schedule values are interpretted as hours.
+ \note The schedule values are interpreted as hours.
\note If this field is blank, the system allows changeover with no delay
\type object-list
\object-list ScheduleNames
@@ -48695,7 +48706,7 @@ AirTerminal:SingleDuct:ConstantVolume:FourPipeBeam,
\minimum> 0.0
\default 27.8
N11, \field Beam Rated Hot Water Volume Flow Rate per Beam Length
- \note The volume flow rate of hoy water per meter of beam length at the rating point.
+ \note The volume flow rate of hot water per meter of beam length at the rating point.
\type real
\units m3/s-m
\ip-units gal/min-ft
@@ -48902,7 +48913,7 @@ AirTerminal:SingleDuct:Mixer,
\note If Outdoor Air Flow per Person is non-zero, then the outdoor air requirement will
\note be computed based on the current number of occupants in the zone, as for demand controlled ventilation.
\note If this field is blank, then the terminal unit will be controlled using the
- \note DesignSpecification:OutdoorAir objec referenced in the Sizing:Zone object.
+ \note DesignSpecification:OutdoorAir object referenced in the Sizing:Zone object.
A9; \field Per Person Ventilation Rate Mode
\type choice
\key CurrentOccupancy
@@ -49089,13 +49100,13 @@ ZoneHVAC:AirDistributionUnit,
\object-list DesignSpecificationAirTerminalSizingName
ZoneHVAC:ExhaustControl,
- \memo Defines a controlled exhaust flow from a zone which finally feeds into
+ \memo Defines a controlled exhaust flow from a zone which finally feeds into
\memo one of AirLoopHVAC:ZoneMixer's inlets, which are part of an AirLoopHVAC:ExhaustSystem.
A1 , \field Name
\required-field
A2 , \field Availability Schedule Name
\note Availability schedule name for this exhaust system. Schedule value > 0 means it is available.
- \note If this field is blank, the exhaust system is always available. If the attached
+ \note If this field is blank, the exhaust system is always available. If the attached
\note AirLoopHVAC:ExhaustSystem is off, then the flow will be zero.
\type object-list
\object-list ScheduleNames
@@ -50538,7 +50549,7 @@ Fan:VariableVolume,
\maximum 1.0
N8 , \field Fan Power Coefficient 1
\note all Fan Power Coefficients should not be 0.0 or no fan power will be consumed.
- \note Fan Power Coefficents are specified as function of full flow rate/power
+ \note Fan Power Coefficients are specified as function of full flow rate/power
\note Equation:
N9 , \field Fan Power Coefficient 2
N10, \field Fan Power Coefficient 3
@@ -51148,9 +51159,9 @@ Coil:Cooling:Water:DetailedGeometry,
\autosizable
\default autosize
\minimum> 0
- \note This input field is optional. If specified, it is used for sizing the coil Design Geomtery
+ \note This input field is optional. If specified, it is used for sizing the coil Design Geometry
\note Parameters. If autosized, the Design Loop Exit Temperature value specified in Sizing:Plant
- \note object is used for sizing the coil Design Geomtery Parameters. If the autosized value is
+ \note object is used for sizing the coil Design Geometry Parameters. If the autosized value is
\note higher than the coil design outlet air temperature, then the design inlet water temperature
\note value is reset to coil design outlet air temperature minus 5.0 DeltaC.
@@ -51723,7 +51734,7 @@ Coil:Cooling:DX:SingleSpeed,
\note should be between 0.00004027 m3/s and .00006041 m3/s per watt of rated total cooling capacity
N5 , \field 2017 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
+ \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
\note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), Energy
\note Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER), and the Standard Rating
@@ -51980,7 +51991,7 @@ Coil:Cooling:DX:TwoSpeed,
\note of rated total cooling capacity.
N5 , \field High Speed 2017 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
+ \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
\note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), Energy
\note Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER), and the Standard Rating
@@ -52090,7 +52101,7 @@ Coil:Cooling:DX:TwoSpeed,
\note of rated total cooling capacity.
N12, \field Low Speed 2017 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
+ \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
\note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), Energy
\note Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER), and the Standard Rating
@@ -53002,7 +53013,7 @@ Coil:Cooling:DX:VariableSpeed,
\memo wet coil when compressor cycles off with continuous fan operation. Requires two to
\memo ten sets of performance data and will interpolate between speeds. Modeled as a
\memo single coil with variable-speed compressor.
- \min-fields 31
+ \min-fields 36
A1, \field Name
\required-field
\type alpha
@@ -53046,6 +53057,28 @@ Coil:Cooling:DX:VariableSpeed,
\type real
\minimum 0
\default 0
+ N7, \field Maximum Cycling Rate
+ \note The maximum on-off cycling Rate for the compressor, which occurs at 50% run time
+ \note fraction. Suggested value is 3; zero value means latent degradation model is disabled.
+ \type real
+ \units cycles/hr
+ \minimum 0.0
+ \maximum 5.0
+ \default 2.5
+ N8, \field Latent Capacity Time Constant
+ \note Time constant for the cooling coil's latent capacity to reach steady state after
+ \note startup. Suggested value is 45; zero value means latent degradation model is disabled.
+ \type real
+ \units s
+ \minimum 0.0
+ \maximum 500.0
+ \default 60
+ N9, \field Fan Delay Time
+ \units s
+ \minimum 0.0
+ \default 60
+ \note Programmed time delay for fan to shut off after compressor cycle off.
+ \note Enter 0 when fan operating mode is continuous
A4, \field Energy Part Load Fraction Curve Name
\required-field
\type object-list
@@ -53062,25 +53095,25 @@ Coil:Cooling:DX:VariableSpeed,
\key AirCooled
\key EvaporativelyCooled
\default AirCooled
- N7, \field Evaporative Condenser Pump Rated Power Consumption
+ N10, \field Evaporative Condenser Pump Rated Power Consumption
\type real
\units W
\minimum 0.0
\default 0.0
\autosizable
\note Rated power consumed by the evaporative condenser's water pump
- N8, \field Crankcase Heater Capacity
+ N11, \field Crankcase Heater Capacity
\type real
\minimum 0.0
\default 0.0
\units W
\ip-units W
- N9, \field Maximum Outdoor Dry-Bulb Temperature for Crankcase Heater Operation
+ N12, \field Maximum Outdoor Dry-Bulb Temperature for Crankcase Heater Operation
\type real
\minimum 0.0
\default 10.0
\units C
- N10, \field Minimum Outdoor Dry-Bulb Temperature for Compressor Operation
+ N13, \field Minimum Outdoor Dry-Bulb Temperature for Compressor Operation
\type real
\default -25.0
\units C
@@ -53090,7 +53123,7 @@ Coil:Cooling:DX:VariableSpeed,
A8, \field Condensate Collection Water Storage Tank Name
\type object-list
\object-list WaterStorageTankNames
- N11, \field Basin Heater Capacity
+ N14, \field Basin Heater Capacity
\type real
\units W/K
\minimum 0.0
@@ -53100,7 +53133,7 @@ Coil:Cooling:DX:VariableSpeed,
\note For this situation, the heater maintains the basin water temperature at the basin heater
\note setpoint temperature when the outdoor air temperature falls below the setpoint temperature.
\note The basin heater only operates when the DX coil is off.
- N12, \field Basin Heater Setpoint Temperature
+ N15, \field Basin Heater Setpoint Temperature
\type real
\units C
\minimum 2.0
@@ -53115,29 +53148,29 @@ Coil:Cooling:DX:VariableSpeed,
\note air dry-bulb temperature is below the basin heater setpoint temperature.
\note If a schedule name is not entered, the basin heater is allowed to operate
\note throughout the entire simulation.
- N13, \field Speed 1 Reference Unit Gross Rated Total Cooling Capacity
+ N16, \field Speed 1 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
\required-field
- N14, \field Speed 1 Reference Unit Gross Rated Sensible Heat Ratio
+ N17, \field Speed 1 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
\required-field
- N15, \field Speed 1 Reference Unit Gross Rated Cooling COP
+ N18, \field Speed 1 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
\required-field
- N16, \field Speed 1 Reference Unit Rated Air Flow Rate
+ N19, \field Speed 1 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
\required-field
- N17, \field 2017 Speed 1 Rated Evaporator Fan Power Per Volume Flow Rate
+ N20, \field 2017 Speed 1 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53149,7 +53182,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N18, \field 2023 Speed 1 Rated Evaporator Fan Power Per Volume Flow Rate
+ N21, \field 2023 Speed 1 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53161,12 +53194,12 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N19, \field Speed 1 Reference Unit Rated Condenser Air Flow Rate
+ N22, \field Speed 1 Reference Unit Rated Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
\note This field is only used for Condenser Type = EvaporativelyCooled
- N20, \field Speed 1 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N23, \field Speed 1 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53200,25 +53233,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N21, \field Speed 2 Reference Unit Gross Rated Total Cooling Capacity
+ N24, \field Speed 2 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N22, \field Speed 2 Reference Unit Gross Rated Sensible Heat Ratio
+ N25, \field Speed 2 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N23, \field Speed 2 Reference Unit Gross Rated Cooling COP
+ N26, \field Speed 2 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N24, \field Speed 2 Reference Unit Rated Air Flow Rate
+ N27, \field Speed 2 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N25, \field 2017 Speed 2 Rated Evaporator Fan Power Per Volume Flow Rate
+ N28, \field 2017 Speed 2 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53230,7 +53263,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N26, \field 2023 Speed 2 Rated Evaporator Fan Power Per Volume Flow Rate
+ N29, \field 2023 Speed 2 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53242,11 +53275,11 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N27, \field Speed 2 Reference Unit Rated Condenser Air Flow Rate
+ N30, \field Speed 2 Reference Unit Rated Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
- N28, \field Speed 2 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N31, \field Speed 2 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53275,25 +53308,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N29, \field Speed 3 Reference Unit Gross Rated Total Cooling Capacity
+ N32, \field Speed 3 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N30, \field Speed 3 Reference Unit Gross Rated Sensible Heat Ratio
+ N33, \field Speed 3 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N31, \field Speed 3 Reference Unit Gross Rated Cooling COP
+ N34, \field Speed 3 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N32, \field Speed 3 Reference Unit Rated Air Flow Rate
+ N35, \field Speed 3 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N33, \field 2017 Speed 3 Rated Evaporator Fan Power Per Volume Flow Rate
+ N36, \field 2017 Speed 3 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53305,7 +53338,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N34, \field 2023 Speed 3 Rated Evaporator Fan Power Per Volume Flow Rate
+ N37, \field 2023 Speed 3 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53317,11 +53350,11 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N35, \field Speed 3 Reference Unit Rated Condenser Air Flow Rate
+ N38, \field Speed 3 Reference Unit Rated Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
- N36, \field Speed 3 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N39, \field Speed 3 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53350,25 +53383,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N37, \field Speed 4 Reference Unit Gross Rated Total Cooling Capacity
+ N40, \field Speed 4 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N38, \field Speed 4 Reference Unit Gross Rated Sensible Heat Ratio
+ N41, \field Speed 4 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N39, \field Speed 4 Reference Unit Gross Rated Cooling COP
+ N42, \field Speed 4 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N40, \field Speed 4 Reference Unit Rated Air Flow Rate
+ N43, \field Speed 4 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N41, \field 2017 Speed 4 Rated Evaporator Fan Power Per Volume Flow Rate
+ N44, \field 2017 Speed 4 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53380,7 +53413,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N42, \field 2023 Speed 4 Rated Evaporator Fan Power Per Volume Flow Rate
+ N45, \field 2023 Speed 4 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53392,11 +53425,11 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N43, \field Speed 4 Reference Unit Rated Condenser Air Flow Rate
+ N46, \field Speed 4 Reference Unit Rated Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
- N44, \field Speed 4 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N47, \field Speed 4 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53425,25 +53458,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N45, \field Speed 5 Reference Unit Gross Rated Total Cooling Capacity
+ N48, \field Speed 5 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N46, \field Speed 5 Reference Unit Gross Rated Sensible Heat Ratio
+ N49, \field Speed 5 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N47, \field Speed 5 Reference Unit Gross Rated Cooling COP
+ N50, \field Speed 5 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N48, \field Speed 5 Reference Unit Rated Air Flow Rate
+ N51, \field Speed 5 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N49, \field 2017 Speed 5 Rated Evaporator Fan Power Per Volume Flow Rate
+ N52, \field 2017 Speed 5 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53455,7 +53488,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N50, \field 2023 Speed 5 Rated Evaporator Fan Power Per Volume Flow Rate
+ N53, \field 2023 Speed 5 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53467,11 +53500,11 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N51, \field Speed 5 Reference Unit Rated Condenser Air Flow Rate
+ N54, \field Speed 5 Reference Unit Rated Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
- N52, \field Speed 5 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N55, \field Speed 5 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53500,25 +53533,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N53, \field Speed 6 Reference Unit Gross Rated Total Cooling Capacity
+ N56, \field Speed 6 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N54, \field Speed 6 Reference Unit Gross Rated Sensible Heat Ratio
+ N57, \field Speed 6 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N55, \field Speed 6 Reference Unit Gross Rated Cooling COP
+ N58, \field Speed 6 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N56, \field Speed 6 Reference Unit Rated Air Flow Rate
+ N59, \field Speed 6 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N57, \field 2017 Speed 6 Rated Evaporator Fan Power Per Volume Flow Rate
+ N60, \field 2017 Speed 6 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53530,7 +53563,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N58, \field 2023 Speed 6 Rated Evaporator Fan Power Per Volume Flow Rate
+ N61, \field 2023 Speed 6 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53542,11 +53575,11 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N59, \field Speed 6 Reference Unit Condenser Air Flow Rate
+ N62, \field Speed 6 Reference Unit Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
- N60, \field Speed 6 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N63, \field Speed 6 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53575,25 +53608,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N61, \field Speed 7 Reference Unit Gross Rated Total Cooling Capacity
+ N64, \field Speed 7 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N62, \field Speed 7 Reference Unit Gross Rated Sensible Heat Ratio
+ N65, \field Speed 7 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N63, \field Speed 7 Reference Unit Gross Rated Cooling COP
+ N66, \field Speed 7 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N64, \field Speed 7 Reference Unit Rated Air Flow Rate
+ N67, \field Speed 7 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N65, \field 2017 Speed 7 Rated Evaporator Fan Power Per Volume Flow Rate
+ N68, \field 2017 Speed 7 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53605,7 +53638,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N66, \field 2023 Speed 7 Rated Evaporator Fan Power Per Volume Flow Rate
+ N69, \field 2023 Speed 7 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53617,11 +53650,11 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N67, \field Speed 7 Reference Unit Condenser Flow Rate
+ N70, \field Speed 7 Reference Unit Condenser Flow Rate
\units m3/s
\type real
\minimum 0
- N68, \field Speed 7 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N71, \field Speed 7 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53650,25 +53683,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N69, \field Speed 8 Reference Unit Gross Rated Total Cooling Capacity
+ N72, \field Speed 8 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N70, \field Speed 8 Reference Unit Gross Rated Sensible Heat Ratio
+ N73, \field Speed 8 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N71, \field Speed 8 Reference Unit Gross Rated Cooling COP
+ N74, \field Speed 8 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N72, \field Speed 8 Reference Unit Rated Air Flow Rate
+ N75, \field Speed 8 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N73, \field 2017 Speed 8 Rated Evaporator Fan Power Per Volume Flow Rate
+ N76, \field 2017 Speed 8 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53680,7 +53713,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N74, \field 2023 Speed 8 Rated Evaporator Fan Power Per Volume Flow Rate
+ N77, \field 2023 Speed 8 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53692,11 +53725,11 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N75, \field Speed 8 Reference Unit Condenser Air Flow Rate
+ N78, \field Speed 8 Reference Unit Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
- N76, \field Speed 8 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N79, \field Speed 8 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53725,25 +53758,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N77, \field Speed 9 Reference Unit Gross Rated Total Cooling Capacity
+ N80, \field Speed 9 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N78, \field Speed 9 Reference Unit Gross Rated Sensible Heat Ratio
+ N81, \field Speed 9 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N79, \field Speed 9 Reference Unit Gross Rated Cooling COP
+ N82, \field Speed 9 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N80, \field Speed 9 Reference Unit Rated Air Flow Rate
+ N83, \field Speed 9 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N81, \field 2017 Speed 9 Rated Evaporator Fan Power Per Volume Flow Rate
+ N84, \field 2017 Speed 9 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53755,7 +53788,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N82, \field 2023 Speed 9 Rated Evaporator Fan Power Per Volume Flow Rate
+ N85, \field 2023 Speed 9 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53767,12 +53800,12 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N83, \field Speed 9 Reference Unit Condenser Air Flow Rate
+ N86, \field Speed 9 Reference Unit Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
\note optional
- N84, \field Speed 9 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N87, \field Speed 9 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -53802,25 +53835,25 @@ Coil:Cooling:DX:VariableSpeed,
\note quadratic curve = a + b*ffa + c*ffa**2
\note cubic curve = a + b*ffa + c*ffa**2 + d*ffa**3
\note ffa = Fraction of the full load Air Flow
- N85, \field Speed 10 Reference Unit Gross Rated Total Cooling Capacity
+ N88, \field Speed 10 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N86, \field Speed 10 Reference Unit Gross Rated Sensible Heat Ratio
+ N89, \field Speed 10 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N87, \field Speed 10 Reference Unit Gross Rated Cooling COP
+ N90, \field Speed 10 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N88, \field Speed 10 Reference Unit Rated Air Flow Rate
+ N91, \field Speed 10 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N89, \field 2017 Speed 10 Rated Evaporator Fan Power Per Volume Flow Rate
+ N92, \field 2017 Speed 10 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53832,7 +53865,7 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1250.0
\default 773.3
- N90, \field 2023 Speed 10 Rated Evaporator Fan Power Per Volume Flow Rate
+ N93, \field 2023 Speed 10 Rated Evaporator Fan Power Per Volume Flow Rate
\note Enter the evaporator fan power per air volume flow rate at the rated test conditions
\note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on total cooling capacity.
@@ -53844,12 +53877,12 @@ Coil:Cooling:DX:VariableSpeed,
\minimum 0.0
\maximum 1505.0
\default 934.4
- N91, \field Speed 10 Reference Unit Condenser Air Flow Rate
+ N94, \field Speed 10 Reference Unit Condenser Air Flow Rate
\units m3/s
\type real
\minimum 0
\note optional
- N92, \field Speed 10 Reference Unit Rated Pad Effectiveness of Evap Precooling
+ N95, \field Speed 10 Reference Unit Rated Pad Effectiveness of Evap Precooling
\units dimensionless
\type real
\minimum 0
@@ -54891,7 +54924,7 @@ Coil:Heating:DX:SingleSpeed,
\note should be between 0.00004027 m3/s and .00006041 m3/s per watt of rated heating capacity
N4 , \field 2017 Rated Supply Fan Power Per Volume Flow Rate
\note Enter the supply fan power per air volume flow rate at the rated test conditions.
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
+ \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on heating capacity.
\note This value is only used to calculate Heating Seasonal Performance Factor(HSPF).
\note This value is not used for modeling the supply (condenser) fan during simulations.
@@ -54902,7 +54935,7 @@ Coil:Heating:DX:SingleSpeed,
\default 773.3
N5 , \field 2023 Rated Supply Fan Power Per Volume Flow Rate
\note Enter the supply fan power per air volume flow rate at the rated test conditions.
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
+ \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
\note The test conditions vary external static pressure based on heating capacity.
\note This value is only used to calculate Heating Seasonal Performance Factor(HSPF).
\note This value is not used for modeling the supply (condenser) fan during simulations.
@@ -56528,7 +56561,7 @@ Coil:Cooling:WaterToAirHeatPump:ParameterEstimation,
\memo evaporation from wet coil when compressor cycles off with continuous fan operation.
\memo Parameter estimation model is a deterministic model that requires a consistent set of
\memo parameters to describe the operating conditions of the heat pump components.
- \min-fields 18
+ \min-fields 31
A1 , \field Name
\required-field
\type alpha
@@ -56686,20 +56719,49 @@ Coil:Cooling:WaterToAirHeatPump:ParameterEstimation,
\minimum 0.0
\units dimensionless
\type real
- N20; \field Source Side Heat Transfer Resistance2
+ N20, \field Source Side Heat Transfer Resistance2
\note Use when Source Side Fluid Name is an antifreeze
\note Leave this field blank for Source Side Fluid is Water
\note Previously part of Parameter 10
\units W/K
\minimum 0.0
\type real
+ A8, \field Part Load Fraction Correlation Curve Name
+ \note quadratic curve = a + b*PLR + c*PLR**2
+ \note cubic curve = a + b*PLR + c*PLR**2 + d*PLR**3
+ \note PLR = part load ratio (cooling load/steady state capacity)
+ \type object-list
+ \object-list UnivariateFunctions
+ N21, \field Maximum Cycling Rate
+ \note The maximum on-off cycling Rate for the compressor, which occurs at 50% run time
+ \note fraction. Suggested value is 3; zero value means latent degradation model is disabled.
+ \type real
+ \units cycles/hr
+ \minimum 0.0
+ \maximum 5.0
+ \default 0.0
+ N22, \field Latent Capacity Time Constant
+ \note Time constant for the cooling coil's latent capacity to reach steady state after
+ \note startup. Suggested value is 45; zero value means latent degradation model is disabled.
+ \type real
+ \units s
+ \minimum 0.0
+ \maximum 500.0
+ \default 0.0
+ N23; \field Fan Delay Time
+ \units s
+ \minimum 0.0
+ \default 60
+ \note Programmed time delay for heat pump fan to shut off after compressor cycle off.
+ \note Only required when fan operating mode is cycling
+ \note Enter 0 when fan operating mode is continuous
Coil:Heating:WaterToAirHeatPump:ParameterEstimation,
\memo Direct expansion (DX) heating coil for water-to-air heat pump (includes electric
\memo compressor), single-speed, parameter estimation model. Parameter estimation model is
\memo a deterministic model that requires a consistent set of parameters to describe
\memo the operating conditions of the heat pump components.
- \min-fields 15
+ \min-fields 25
A1 , \field Name
\required-field
\type alpha
@@ -56833,19 +56895,26 @@ Coil:Heating:WaterToAirHeatPump:ParameterEstimation,
\minimum 0.0
\units dimensionless
\type real
- N17; \field Source Side Heat Transfer Resistance2
+ N17, \field Source Side Heat Transfer Resistance2
\note Use when Source Side Fluid Name is an antifreeze
\note Leave this field blank for Source Side Fluid is Water
\note Previously part of Parameter 9
\units W/K
\minimum 0.0
\type real
+ A8; \field Part Load Fraction Correlation Curve Name
+ \note quadratic curve = a + b*PLR + c*PLR**2
+ \note cubic curve = a + b*PLR + c*PLR**2 + d*PLR**3
+ \note PLR = part load ratio (heating load/steady state capacity)
+ \type object-list
+ \object-list UnivariateFunctions
Coil:Cooling:WaterToAirHeatPump:EquationFit,
\memo Direct expansion (DX) cooling coil for water-to-air heat pump (includes electric
\memo compressor), single-speed, equation-fit model. Optional inputs for moisture
\memo evaporation from wet coil when compressor cycles off with continuous fan operation.
\memo Equation-fit model uses normalized curves to describe the heat pump performance.
+ \min-fields 22
A1, \field Name
\required-field
\type alpha
@@ -56871,59 +56940,33 @@ Coil:Cooling:WaterToAirHeatPump:EquationFit,
\minimum> 0.0
\units m3/s
\autosizable
- N2 , \field 2017 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), Energy
- \note Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER), and the Standard Rating
- \note (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file. This value is not
- \note used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N3 , \field 2023 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), Energy
- \note Efficiency Ratio (EER), Integrated Energy Efficiency Ratio (IEER), and the Standard Rating
- \note (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file. This value is not
- \note used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N4, \field Rated Water Flow Rate
+ N2, \field Rated Water Flow Rate
\required-field
\type real
\minimum> 0.0
\units m3/s
\ip-units gal/min
\autosizable
- N5, \field Gross Rated Total Cooling Capacity
+ N3, \field Gross Rated Total Cooling Capacity
\note Total cooling capacity at rated conditions not accounting for the effect of supply air fan heat
\required-field
\type real
\minimum> 0.0
\units W
\autosizable
- N6, \field Gross Rated Sensible Cooling Capacity
+ N4, \field Gross Rated Sensible Cooling Capacity
\required-field
\type real
\minimum> 0.0
\units W
\autosizable
- N7, \field Gross Rated Cooling COP
+ N5, \field Gross Rated Cooling COP
\note Gross cooling COP at rated conditions
\required-field
\type real
\units W/W
\minimum> 0.0
- N8, \field Rated Entering Water Temperature
+ N6, \field Rated Entering Water Temperature
\note Rated entering water temperature corresponding to the water-to
\note -air application for which this coil is used. For example: for water loop
\note applications, the rated temperature is 30 degree Celsius
@@ -56931,7 +56974,7 @@ Coil:Cooling:WaterToAirHeatPump:EquationFit,
\type real
\minimum> 0
\default 30
- N9, \field Rated Entering Air Dry-Bulb Temperature
+ N7, \field Rated Entering Air Dry-Bulb Temperature
\note Rated entering air dry-bulb temperature corresponding to the
\note water-to-air application for which this coil is used. For example: for
\note water loop applications, the rated temperature is 27 degree Celsius
@@ -56939,7 +56982,7 @@ Coil:Cooling:WaterToAirHeatPump:EquationFit,
\type real
\default 27
\minimum> 0
- N10, \field Rated Entering Air Wet-Bulb Temperature
+ N8, \field Rated Entering Air Wet-Bulb Temperature
\note Rated entering air wet-bulb temperature corresponding to the
\note water-to-air application for which this coil is used. For example: for
\note water loop applications, the rated temperature is 19 degree Celsius
@@ -56959,7 +57002,13 @@ Coil:Cooling:WaterToAirHeatPump:EquationFit,
\required-field
\type object-list
\object-list QuadvariateFunctions
- N11, \field Nominal Time for Condensate Removal to Begin
+ A9, \field Part Load Fraction Correlation Curve Name
+ \note quadratic curve = a + b*PLR + c*PLR**2
+ \note cubic curve = a + b*PLR + c*PLR**2 + d*PLR**3
+ \note PLR = part load ratio (cooling load/steady state capacity)
+ \type object-list
+ \object-list UnivariateFunctions
+ N9, \field Nominal Time for Condensate Removal to Begin
\type real
\units s
\minimum 0.0
@@ -56970,7 +57019,7 @@ Coil:Cooling:WaterToAirHeatPump:EquationFit,
\note Nominal time is equal to the ratio of the energy of the coil's maximum
\note condensate holding capacity (J) to the coil's steady state latent capacity (W).
\note Suggested value is 1000; zero value means latent degradation model is disabled.
- N12; \field Ratio of Initial Moisture Evaporation Rate and Steady State Latent Capacity
+ N10, \field Ratio of Initial Moisture Evaporation Rate and Steady State Latent Capacity
\type real
\units dimensionless
\minimum 0.0
@@ -56980,6 +57029,29 @@ Coil:Cooling:WaterToAirHeatPump:EquationFit,
\note the compressor first turns off) and the coil's steady state latent capacity
\note at rated air flow rate and temperature conditions. Suggested value is 1.5; zero value
\note means latent degradation model is disabled.
+ N11, \field Maximum Cycling Rate
+ \note The maximum on-off cycling Rate for the compressor, which occurs at 50% run time
+ \note fraction. Suggested value is 3; zero value means latent degradation model is disabled.
+ \type real
+ \units cycles/hr
+ \minimum 0.0
+ \maximum 5.0
+ \default 0.0
+ N12, \field Latent Capacity Time Constant
+ \note Time constant for the cooling coil's latent capacity to reach steady state after
+ \note startup. Suggested value is 45; zero value means latent degradation model is disabled.
+ \type real
+ \units s
+ \minimum 0.0
+ \maximum 500.0
+ \default 0.0
+ N13; \field Fan Delay Time
+ \units s
+ \minimum 0.0
+ \default 60
+ \note Programmed time delay for heat pump fan to shut off after compressor cycle off.
+ \note Only required when fan operating mode is cycling
+ \note Enter 0 when fan operating mode is continuous
Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\memo Direct expansion (DX) cooling coil for water-to-air heat pump (includes electric
@@ -56988,7 +57060,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\memo Equation-fit model uses normalized curves to describe the heat pump performance.
\memo Requires two to ten sets of performance data and will interpolate between speeds.
\memo Modeled as a single coil with variable-speed compressor.
- \min-fields 27
+ \min-fields 30
A1, \field Name
\required-field
\type alpha
@@ -57045,7 +57117,29 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\type real
\minimum 0
\default 0
- N8, \field Flag for Using Hot Gas Reheat, 0 or 1
+ N8, \field Maximum Cycling Rate
+ \note The maximum on-off cycling Rate for the compressor, which occurs at 50% run time
+ \note fraction. Suggested value is 3; zero value means latent degradation model is disabled.
+ \type real
+ \units cycles/hr
+ \minimum 0.0
+ \maximum 5.0
+ \default 0.0
+ N9, \field Latent Capacity Time Constant
+ \note Time constant for the cooling coil's latent capacity to reach steady state after
+ \note startup. Suggested value is 45; zero value means latent degradation model is disabled.
+ \type real
+ \units s
+ \minimum 0.0
+ \maximum 500.0
+ \default 0.0
+ N10, \field Fan Delay Time
+ \units s
+ \minimum 0.0
+ \default 60
+ \note Programmed time delay for heat pump fan to shut off after compressor cycle off.
+ \note Enter 0 when fan operating mode is continuous
+ N11, \field Flag for Using Hot Gas Reheat, 0 or 1
\note Flag for using hot gas reheat, 0 - not used, 1 - used
\units dimensionless
\type real
@@ -57058,53 +57152,29 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*PLR + c*PLR**2
\note cubic curve = a + b*PLR + c*PLR**2 + d*PLR**3
\note PLR = part load ratio (cooling load/steady state capacity)
- N9, \field Speed 1 Reference Unit Gross Rated Total Cooling Capacity
+ N12, \field Speed 1 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
\required-field
- N10, \field Speed 1 Reference Unit Gross Rated Sensible Heat Ratio
+ N13, \field Speed 1 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
\required-field
- N11, \field Speed 1 Reference Unit Gross Rated Cooling COP
+ N14, \field Speed 1 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
\required-field
- N12, \field Speed 1 Reference Unit Rated Air Flow Rate
+ N15, \field Speed 1 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
\required-field
- N13, \field 2017 Speed 1 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N14, \field 2023 Speed 1 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N15, \field Speed 1 Reference Unit Rated Water Flow Rate
+ N16, \field Speed 1 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57152,7 +57222,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N16, \field Speed 1 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N17, \field Speed 1 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57164,49 +57234,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N17, \field Speed 2 Reference Unit Gross Rated Total Cooling Capacity
+ N18, \field Speed 2 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N18, \field Speed 2 Reference Unit Gross Rated Sensible Heat Ratio
+ N19, \field Speed 2 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N19, \field Speed 2 Reference Unit Gross Rated Cooling COP
+ N20, \field Speed 2 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N20, \field Speed 2 Reference Unit Rated Air Flow Rate
+ N21, \field Speed 2 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N21, \field 2017 Speed 2 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N22, \field 2023 Speed 2 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N23, \field Speed 2 Reference Unit Rated Water Flow Rate
+ N22, \field Speed 2 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57232,7 +57278,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
A17, \field Speed 2 Energy Input Ratio Function of Temperature Curve Name
\type object-list
\object-list BivariateFunctions
- \note curve = a + b*wb + c*wb**2 + d*ewet + e*ewt**2 + f*wb*ewt
+ \note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
A18, \field Speed 2 Energy Input Ratio Function of Air Flow Fraction Curve Name
@@ -57247,7 +57293,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N24, \field Speed 2 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N23, \field Speed 2 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57257,49 +57303,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N25, \field Speed 3 Reference Unit Gross Rated Total Cooling Capacity
+ N24, \field Speed 3 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N26, \field Speed 3 Reference Unit Gross Rated Sensible Heat Ratio
+ N25, \field Speed 3 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N27, \field Speed 3 Reference Unit Gross Rated Cooling COP
+ N26, \field Speed 3 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N28, \field Speed 3 Reference Unit Rated Air Flow Rate
+ N27, \field Speed 3 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N29, \field 2017 Speed 3 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N30, \field 2023 Speed 3 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N31, \field Speed 3 Reference Unit Rated Water Flow Rate
+ N28, \field Speed 3 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57346,7 +57368,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N32, \field Speed 3 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N29, \field Speed 3 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57357,49 +57379,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N33, \field Speed 4 Reference Unit Gross Rated Total Cooling Capacity
+ N30, \field Speed 4 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N34, \field Speed 4 Reference Unit Gross Rated Sensible Heat Ratio
+ N31, \field Speed 4 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N35, \field Speed 4 Reference Unit Gross Rated Cooling COP
+ N32, \field Speed 4 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N36, \field Speed 4 Reference Unit Rated Air Flow Rate
+ N33, \field Speed 4 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N37, \field 2017 Speed 4 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N38, \field 2023 Speed 4 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N39, \field Speed 4 Reference Unit Rated Water Flow Rate
+ N34, \field Speed 4 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57446,7 +57444,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N40, \field Speed 4 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N35, \field Speed 4 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57457,49 +57455,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N41, \field Speed 5 Reference Unit Gross Rated Total Cooling Capacity
+ N36, \field Speed 5 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N42, \field Speed 5 Reference Unit Gross Rated Sensible Heat Ratio
+ N37, \field Speed 5 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N43, \field Speed 5 Reference Unit Gross Rated Cooling COP
+ N38, \field Speed 5 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N44, \field Speed 5 Reference Unit Rated Air Flow Rate
+ N39, \field Speed 5 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N45, \field 2017 Speed 5 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N46, \field 2023 Speed 5 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N47, \field Speed 5 Reference Unit Rated Water Flow Rate
+ N40, \field Speed 5 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57546,7 +57520,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N48, \field Speed 5 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N41, \field Speed 5 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57557,49 +57531,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N49, \field Speed 6 Reference Unit Gross Rated Total Cooling Capacity
+ N42, \field Speed 6 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N50, \field Speed 6 Reference Unit Gross Rated Sensible Heat Ratio
+ N43, \field Speed 6 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N51, \field Speed 6 Reference Unit Gross Rated Cooling COP
+ N44, \field Speed 6 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N52, \field Speed 6 Reference Unit Rated Air Flow Rate
+ N45, \field Speed 6 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N53, \field 2017 Speed 6 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N54, \field 2023 Speed 6 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N55, \field Speed 6 Reference Unit Rated Water Flow Rate
+ N46, \field Speed 6 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57646,7 +57596,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N56, \field Speed 6 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N47, \field Speed 6 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57657,49 +57607,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N57, \field Speed 7 Reference Unit Gross Rated Total Cooling Capacity
+ N48, \field Speed 7 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N58, \field Speed 7 Reference Unit Gross Rated Sensible Heat Ratio
+ N49, \field Speed 7 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N59, \field Speed 7 Reference Unit Gross Rated Cooling COP
+ N50, \field Speed 7 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N60, \field Speed 7 Reference Unit Rated Air Flow Rate
+ N51, \field Speed 7 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N61, \field 2017 Speed 7 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N62, \field 2023 Speed 7 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N63, \field Speed 7 Reference Unit Rated Water Flow Rate
+ N52, \field Speed 7 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57746,7 +57672,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N64, \field Speed 7 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N53, \field Speed 7 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57757,49 +57683,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N65, \field Speed 8 Reference Unit Gross Rated Total Cooling Capacity
+ N54, \field Speed 8 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N66, \field Speed 8 Reference Unit Gross Rated Sensible Heat Ratio
+ N55, \field Speed 8 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N67, \field Speed 8 Reference Unit Gross Rated Cooling COP
+ N56, \field Speed 8 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N68, \field Speed 8 Reference Unit Rated Air Flow Rate
+ N57, \field Speed 8 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N69, \field 2017 Speed 8 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N70, \field 2023 Speed 8 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N71, \field Speed 8 Reference Unit Rated Water Flow Rate
+ N58, \field Speed 8 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57846,7 +57748,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N72, \field Speed 8 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N59, \field Speed 8 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57857,49 +57759,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N73, \field Speed 9 Reference Unit Gross Rated Total Cooling Capacity
+ N60, \field Speed 9 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N74, \field Speed 9 Reference Unit Gross Rated Sensible Heat Ratio
+ N61, \field Speed 9 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N75, \field Speed 9 Reference Unit Gross Rated Cooling COP
+ N62, \field Speed 9 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N76, \field Speed 9 Reference Unit Rated Air Flow Rate
+ N63, \field Speed 9 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N77, \field 2017 Speed 9 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N78, \field 2023 Speed 9 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N79, \field Speed 9 Reference Unit Rated Water Flow Rate
+ N64, \field Speed 9 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -57946,7 +57824,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N80, \field Speed 9 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N65, \field Speed 9 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -57957,49 +57835,25 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note curve = a + b*wb + c*wb**2 + d*ewt + e*ewt**2 + f*wb*ewt
\note wb = entering wet-bulb temperature (C)
\note ewt = water entering temperature seen by the condenser (C)
- N81, \field Speed 10 Reference Unit Gross Rated Total Cooling Capacity
+ N66, \field Speed 10 Reference Unit Gross Rated Total Cooling Capacity
\note Total cooling capacity not accounting for the effect of supply air fan heat
\units W
\type real
\minimum 0
- N82, \field Speed 10 Reference Unit Gross Rated Sensible Heat Ratio
+ N67, \field Speed 10 Reference Unit Gross Rated Sensible Heat Ratio
\units dimensionless
\type real
\minimum 0
\maximum 1.0
- N83, \field Speed 10 Reference Unit Gross Rated Cooling COP
+ N68, \field Speed 10 Reference Unit Gross Rated Cooling COP
\type real
\units W/W
\minimum> 0.0
- N84, \field Speed 10 Reference Unit Rated Air Flow Rate
+ N69, \field Speed 10 Reference Unit Rated Air Flow Rate
\units m3/s
\type real
\minimum 0
- N85, \field 2017 Speed 10 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2017 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1250.0
- \default 773.3
- N86, \field 2023 Speed 10 Rated Evaporator Fan Power Per Volume Flow Rate
- \note Enter the evaporator fan power per air volume flow rate at the rated test conditions
- \note as defined in the 2023 version of ANSI/AHRI Standard 210/240.
- \note The test conditions vary external static pressure based on total cooling capacity.
- \note This value is only used to calculate Seasonal Energy Efficiency Ratio (SEER2), and the
- \note Standard Rating (Net) Cooling Capacity which will be outputs in the EnergyPlus eio file.
- \note This value is not used for modeling the evaporator fan during simulations.
- \type real
- \units W/(m3/s)
- \minimum 0.0
- \maximum 1505.0
- \default 934.4
- N87, \field Speed 10 Reference Unit Rated Water Flow Rate
+ N70, \field Speed 10 Reference Unit Rated Water Flow Rate
\units m3/s
\ip-units gal/min
\type real
@@ -58046,7 +57900,7 @@ Coil:Cooling:WaterToAirHeatPump:VariableSpeedEquationFit,
\note quadratic curve = a + b*ffw + c*ffw**2
\note cubic curve = a + b*ffw + c*ffw**2 + d*ffw**3
\note ffw = Fraction of the full load Water Flow
- N88, \field Speed 10 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
+ N71, \field Speed 10 Reference Unit Waste Heat Fraction of Input Power At Rated Conditions
\units dimensionless
\type real
\minimum 0
@@ -58062,6 +57916,7 @@ Coil:Heating:WaterToAirHeatPump:EquationFit,
\memo Direct expansion (DX) heating coil for water-to-air heat pump (includes electric
\memo compressor), single-speed, equation-fit model. Equation-fit model uses normalized
\memo curves to describe the heat pump performance.
+ \min-fields 12
A1, \field Name
\required-field
\type alpha
@@ -58124,7 +57979,7 @@ Coil:Heating:WaterToAirHeatPump:EquationFit,
N7, \field Ratio of Rated Heating Capacity to Rated Cooling Capacity
\note Ratio of rated heating capacity to rated cooling capacity. This
\note input is used to calculate the heating or cooling capacity when autosizing.
- \note This input is only used if a companion cooling coil of the same type
+ \note This input is only used if a companion cooling coil of the same type
\note (Coil:Cooling:WaterToAirHeatPump:EquationFit) is used. This input is only
\note used when a sizing run for the system which uses this object is requested
\note and when the coil capacity is autosized.
@@ -58135,10 +57990,16 @@ Coil:Heating:WaterToAirHeatPump:EquationFit,
\required-field
\type object-list
\object-list QuadvariateFunctions
- A7; \field Heating Power Consumption Curve Name
+ A7, \field Heating Power Consumption Curve Name
\required-field
\type object-list
\object-list QuadvariateFunctions
+ A8; \field Part Load Fraction Correlation Curve Name
+ \note quadratic curve = a + b*PLR + c*PLR**2
+ \note cubic curve = a + b*PLR + c*PLR**2 + d*PLR**3
+ \note PLR = part load ratio (heat load/steady state capacity)
+ \type object-list
+ \object-list UnivariateFunctions
Coil:Heating:WaterToAirHeatPump:VariableSpeedEquationFit,
\memo Direct expansion (DX) heating coil for water-to-air heat pump (includes electric
@@ -59291,7 +59152,7 @@ Coil:WaterHeating:AirToWaterHeatPump:Wrapped,
\note due to variations in part load ratio.
Coil:WaterHeating:AirToWaterHeatPump:VariableSpeed,
- \memo vairlable-speed Heat pump water heater (VSHPWH) heating coil, air-to-water direct-expansion (DX)
+ \memo variable-speed Heat pump water heater (VSHPWH) heating coil, air-to-water direct-expansion (DX)
\memo system which includes a variable-speed water heating coil, evaporator air coil, evaporator
\memo fan, electric compressor, and water pump. Part of a WaterHeater:HeatPump system.
\min-fields 33
@@ -61661,7 +61522,7 @@ EvaporativeCooler:Indirect:ResearchSpecial,
N2 , \field Cooler Drybulb Design Effectiveness
\type real
\note dry operation effectiveness with respect to drybulb temperature difference
- \note this is the nominal design dryblub effectiveness at design air flow rates, no evaporation water active
+ \note this is the nominal design drybulb effectiveness at design air flow rates, no evaporation water active
\minimum 0.0
A4 , \field Drybulb Effectiveness Flow Ratio Modifier Curve Name
\note this curve modifies the drybulb effectiveness in the previous field (eff_db_design)
@@ -61707,7 +61568,7 @@ EvaporativeCooler:Indirect:ResearchSpecial,
\type real
\units dimensionless
\default 1.0
- \note This field is used when the previous field is set to autoize. The Primary Design Air Flow Rate is scaled using this factor
+ \note This field is used when the previous field is set to autosize. The Primary Design Air Flow Rate is scaled using this factor
\note to calculate the secondary design air flow rate.
N7 , \field Secondary Air Fan Design Power
\type real
@@ -63256,55 +63117,19 @@ AirLoopHVAC:UnitarySystem,
\note If this field is blank, outdoor temperature from the weather file is used.
\note If this field is not blank, the node name specified determines the outdoor temperature used
\note for controlling supplemental heater operation.
- N19, \field Maximum Cycling Rate
- \type real
- \units cycles/hr
- \minimum 0.0
- \maximum 5.0
- \default 2.5
- \note Used only for water source heat pump.
- \note The maximum on-off cycling rate for the compressor.
- \note Suggested value is 2.5 for a typical heat pump.
- N20, \field Heat Pump Time Constant
- \type real
- \units s
- \minimum 0.0
- \maximum 500.0
- \default 60.0
- \note Used only for water source heat pump.
- \note Time constant for the cooling coil's capacity to reach steady state after startup.
- \note Suggested value is 60 for a typical heat pump.
- N21, \field Fraction of On-Cycle Power Use
- \type real
- \minimum 0.0
- \maximum 0.05
- \default 0.01
- \note Used only for water source heat pump.
- \note The fraction of on-cycle power use to adjust the part load fraction based on
- \note the off-cycle power consumption due to crankcase heaters, controls, fans, and etc.
- \note Suggested value is 0.01 for a typical heat pump.
- N22, \field Heat Pump Fan Delay Time
- \type real
- \units s
- \minimum 0.0
- \default 60
- \note Used only for water source heat pump.
- \note Programmed time delay for heat pump fan to shut off after compressor cycle off.
- \note Only required when fan operating mode is cycling.
- \note Enter 0 when fan operating mode is continuous.
- N23, \field Ancillary On-Cycle Electric Power
+ N19, \field Ancillary On-Cycle Electric Power
\type real
\units W
\minimum 0
\default 0
\note Enter the value of ancillary electric power for controls or other devices consumed during the on cycle.
- N24, \field Ancillary Off-Cycle Electric Power
+ N20, \field Ancillary Off-Cycle Electric Power
\type real
\units W
\minimum 0
\default 0
\note Enter the value of ancillary electric power for controls or other devices consumed during the off cycle.
- N25, \field Design Heat Recovery Water Flow Rate
+ N21, \field Design Heat Recovery Water Flow Rate
\type real
\units m3/s
\ip-units gal/min
@@ -63312,7 +63137,7 @@ AirLoopHVAC:UnitarySystem,
\default 0.0
\note If non-zero, then the heat recovery inlet and outlet node names must be entered.
\note Used for heat recovery to an EnergyPlus plant loop.
- N26, \field Maximum Temperature for Heat Recovery
+ N22, \field Maximum Temperature for Heat Recovery
\type real
\units C
\maximum 100.0
@@ -64124,7 +63949,7 @@ AirLoopHVAC:UnitaryHeatPump:WaterToAir,
\memo supply fan (continuous or cycling), direct expansion (DX) cooling coil, DX heating
\memo coil (water-to-air heat pump), and supplemental heating coil (gas, electric,
\memo hot water, or steam).
- \min-fields 25
+ \min-fields 21
A1, \field Name
\required-field
\type alpha
@@ -64194,36 +64019,6 @@ AirLoopHVAC:UnitaryHeatPump:WaterToAir,
\type real
\minimum> 0.0
\default 0.001
- N4, \field Maximum Cycling Rate
- \type real
- \units cycles/hr
- \minimum 0.0
- \maximum 5.0
- \default 2.5
- \note The maximum on-off cycling rate for the compressor
- \note Suggested value is 2.5 for a typical heat pump
- N5, \field Heat Pump Time Constant
- \type real
- \units s
- \minimum 0.0
- \maximum 500.0
- \default 60.0
- \note Time constant for the cooling coil's capacity to reach steady state after startup
- \note Suggested value is 60 for a typical heat pump
- N6, \field Fraction of On-Cycle Power Use
- \minimum 0.0
- \maximum 0.05
- \default 0.01
- \note The fraction of on-cycle power use to adjust the part load fraction based on
- \note the off-cycle power consumption due to crankcase heaters, controls, fans, and etc.
- \note Suggested value is 0.01 for a typical heat pump
- N7, \field Heat Pump Fan Delay Time
- \units s
- \minimum 0.0
- \default 60
- \note Programmed time delay for heat pump fan to shut off after compressor cycle off.
- \note Only required when fan operating mode is cycling
- \note Enter 0 when fan operating mode is continuous
A12, \field Supplemental Heating Coil Object Type
\required-field
\type choice
@@ -64237,12 +64032,12 @@ AirLoopHVAC:UnitaryHeatPump:WaterToAir,
\type object-list
\object-list HeatingCoilName
\note Needs to match in the supplemental heating coil object
- N8, \field Maximum Supply Air Temperature from Supplemental Heater
+ N4, \field Maximum Supply Air Temperature from Supplemental Heater
\required-field
\type real
\units C
\autosizable
- N9, \field Maximum Outdoor Dry-Bulb Temperature for Supplemental Heater Operation
+ N5, \field Maximum Outdoor Dry-Bulb Temperature for Supplemental Heater Operation
\type real
\maximum 21.0
\default 21.0
@@ -66520,7 +66315,7 @@ Controller:MechanicalVentilation,
\object-list DSOASpaceListNames
A7, \field Design Specification Zone Air Distribution Object Name 1
\note If left blank, the name will be taken from the Sizing:Zone object for this zone.
- \note If no specification is found for this zone, then effectivness will be 1.0 and
+ \note If no specification is found for this zone, then effectiveness will be 1.0 and
\note and secondary recirculation will be zero.
\type object-list
\object-list DesignSpecificationZoneAirDistributionNames
@@ -71456,7 +71251,7 @@ Pump:VariableSpeed,
\type object-list
\object-list ScheduleNames
A13, \field Zone Name
- \note optional, if used pump losses transfered to zone as internal gains
+ \note optional, if used pump losses transferred to zone as internal gains
\type object-list
\object-list ZoneNames
N12, \field Skin Loss Radiative Fraction
@@ -71571,7 +71366,7 @@ Pump:ConstantSpeed,
\type real
\note "N" in above expression in field A6
A7, \field Zone Name
- \note optional, if used pump losses transfered to zone as internal gains
+ \note optional, if used pump losses transferred to zone as internal gains
\type object-list
\object-list ZoneNames
N8, \field Skin Loss Radiative Fraction
@@ -71666,7 +71461,7 @@ Pump:VariableSpeed:Condensate,
\type object-list
\object-list ScheduleNames
A5 , \field Zone Name
- \note optional, if used pump losses transfered to zone as internal gains
+ \note optional, if used pump losses transferred to zone as internal gains
\type object-list
\object-list ZoneNames
N10, \field Skin Loss Radiative Fraction
@@ -71766,7 +71561,7 @@ HeaderedPumps:ConstantSpeed,
\type object-list
\object-list ScheduleNames
A7 , \field Zone Name
- \note optional, if used pump losses transfered to zone as internal gains
+ \note optional, if used pump losses transferred to zone as internal gains
\type object-list
\object-list ZoneNames
N7 , \field Skin Loss Radiative Fraction
@@ -71879,7 +71674,7 @@ HeaderedPumps:VariableSpeed,
\type object-list
\object-list ScheduleNames
A7 , \field Zone Name
- \note optional, if used pump losses transfered to zone as internal gains
+ \note optional, if used pump losses transferred to zone as internal gains
\type object-list
\object-list ZoneNames
N12, \field Skin Loss Radiative Fraction
@@ -72913,10 +72708,10 @@ Chiller:Electric:ASHRAE205,
\minimum> 0
\ip-units gal/min
A21, \field Heat Recovery Inlet Node Name
- \note Not yet implemented / reserved for future use. Heat recovery is not yet within scope of ASHRAE Stanard 205.
+ \note Not yet implemented / reserved for future use. Heat recovery is not yet within scope of ASHRAE Standard 205.
\type node
A22, \field Heat Recovery Outlet Node Name
- \note Not yet implemented / reserved for future use. Heat recovery is not yet within scope of ASHRAE Stanard 205.
+ \note Not yet implemented / reserved for future use. Heat recovery is not yet within scope of ASHRAE Standard 205.
\type node
A23; \field End-Use Subcategory
\note Any text may be used here to categorize the end-uses in the ABUPS End Uses by Subcategory table.
@@ -74882,7 +74677,7 @@ HeatPump:AirToWater:FuelFired:Heating,
\autosizable
\minimum> 0
\units W
- \note Nominal Heating Capacity in [W] (autosizeable)
+ \note Nominal Heating Capacity in [W] (autosizable)
N2 , \field Nominal COP
\required-field
\type real
@@ -74894,7 +74689,7 @@ HeatPump:AirToWater:FuelFired:Heating,
\autosizable
\minimum> 0
\units m3/s
- \note Design Flow Rate in m3/s (autosizeable)
+ \note Design Flow Rate in m3/s (autosizable)
N4 , \field Design Supply Temperature
\default 60
\units C
@@ -75062,7 +74857,7 @@ HeatPump:AirToWater:FuelFired:Cooling,
\autosizable
\minimum> 0
\units W
- \note Nominal Cooling Capacity in [W] (autosizeable)
+ \note Nominal Cooling Capacity in [W] (autosizable)
N2 , \field Nominal COP
\required-field
\type real
@@ -75074,7 +74869,7 @@ HeatPump:AirToWater:FuelFired:Cooling,
\autosizable
\minimum> 0
\units m3/s
- \note Design Flow Rate in m3/s (autosizeable)
+ \note Design Flow Rate in m3/s (autosizable)
N4 , \field Design Supply Temperature
\default 7.0
\units C
@@ -81265,7 +81060,7 @@ PlantLoop,
\key None
\default None
N6; \field Loop Circulation Time
- \note This field is only used to autocalulate the Plant Loop Volume.
+ \note This field is only used to autocalculate the Plant Loop Volume.
\note Loop Volume = Loop Circulation Time * Maximum Loop Flow Rate
\type real
\units minutes
@@ -81364,7 +81159,7 @@ CondenserLoop,
\key None
\default None
N6; \field Loop Circulation Time
- \note This field is only used to autocalulate the Condenser Loop Volume.
+ \note This field is only used to autocalculate the Condenser Loop Volume.
\note Loop Volume = Loop Circulation Time * Maximum Loop Flow Rate
\type real
\units minutes
@@ -92562,7 +92357,7 @@ ElectricLoadCenter:Distribution,
\note while accounting for any on-site generation. Only excess on site generation gets stored (legacy behavior).
\default TrackFacilityElectricDemandStoreExcessOnSite
\key TrackMeterDemandStoreExcessOnSite
- \note TrackMeterDemandStoreExcessOnSite indicates that storage discharge control will follow an electric meter named in the field called Storage Control Track Meter Name. This scheme is similiar
+ \note TrackMeterDemandStoreExcessOnSite indicates that storage discharge control will follow an electric meter named in the field called Storage Control Track Meter Name. This scheme is similar
\note to TrackFacilityElectricDemandStoreExcessOnSite except that instead of the main facility electric meter, the control is based off of a user-selected meter.
\key TrackChargeDischargeSchedules
\note TrackChargeDischargeSchedules indicates that control will follow the charging and discharging power and schedules defined in the fields called Maximum Storage Charge Grid Supply Power,
@@ -105495,7 +105290,7 @@ Output:Table:Annual,
\note hours with a zero value are all included.
\note HourInTenBinsMinToMax - Creates 10 columns for the specified variable and shows the number
\note of hours in each of 10 bins based on the minimum and maximum value. The bin sizes will
- \note be rounded up to the next most signficant digit value.
+ \note be rounded up to the next most significant digit value.
\note HourInTenBinsZeroToMax - Creates 11 columns for the specified variable and shows the number
\note of hours in each of 10 bins from zero to the maximum value and a bin for hours below zero.
\note The bin sizes will be rounded up to the next most significant digit value.
diff --git a/performance_tests/PipingSystem_Underground_FHX.idf b/performance_tests/PipingSystem_Underground_FHX.idf
index 7a775a02255..2be1396348c 100644
--- a/performance_tests/PipingSystem_Underground_FHX.idf
+++ b/performance_tests/PipingSystem_Underground_FHX.idf
@@ -821,10 +821,6 @@
Sys 2 Heat Pump Heating Mode, !- Heating Coil Name
Coil:Cooling:WaterToAirHeatPump:EquationFit, !- Cooling Coil Object Type
Sys 2 Heat Pump Cooling Mode, !- Cooling Coil Name
- 2.5, !- Maximum Cycling Rate {cycles/hr}
- 60.0, !- Heat Pump Time Constant {s}
- 0.01, !- Fraction of On-Cycle Power Use
- 60, !- Heat Pump Fan Delay Time {s}
Coil:Heating:Fuel, !- Supplemental Heating Coil Object Type
Heat Pump DX Supp Heating Coil 2, !- Supplemental Heating Coil Name
60.0, !- Maximum Supply Air Temperature from Supplemental Heater {C}
@@ -952,8 +948,6 @@
Sys 2 Cooling Coil Air Inlet Node, !- Air Inlet Node Name
Sys 2 Heating Coil Air Inlet Node, !- Air Outlet Node Name
Autosize, !- Rated Air Flow Rate {m3/s}
- , !- 2017 Rated Evaporator Fan Power Per Volume Flow Rate {W/(m3/s)}
- , !- 2023 Rated Evaporator Fan Power Per Volume Flow Rate {W/(m3/s)}
Autosize, !- Rated Water Flow Rate {m3/s}
Autosize, !- Gross Rated Total Cooling Capacity {W}
Autosize, !- Gross Rated Sensible Cooling Capacity {W}
@@ -964,6 +958,7 @@
TotCoolCapCurve, !- Total Cooling Capacity Curve Name
CoolSensCapCurve, !- Sensible Cooling Capacity Curve Name
CoolPowCurve, !- Cooling Power Consumption Curve Name
+ HPACCOOLPLFFPLR, !- Part Load Fraction Correlation Curve Name
0, !- Nominal Time for Condensate Removal to Begin {s}
0; !- Ratio of Initial Moisture Evaporation Rate and Steady State Latent Capacity {dimensionless}
@@ -981,7 +976,8 @@
20.0, !- Rated Entering Air Dry-Bulb Temperature {C}
1.0, !- Ratio of Rated Heating Capacity to Rated Cooling Capacity
HeatCapCurve, !- Heating Capacity Curve Name
- HeatPowCurve; !- Heating Power Consumption Curve Name
+ HeatPowCurve, !- Heating Power Consumption Curve Name
+ HPACHEATPLFFPLR; !- Part Load Fraction Correlation Curve Name
Fan:OnOff,
Zone 2 Fan, !- Name
@@ -1044,10 +1040,6 @@
Sys 1 Heat Pump Heating Mode, !- Heating Coil Name
Coil:Cooling:WaterToAirHeatPump:EquationFit, !- Cooling Coil Object Type
Sys 1 Heat Pump Cooling Mode, !- Cooling Coil Name
- 2.5, !- Maximum Cycling Rate {cycles/hr}
- 60.0, !- Heat Pump Time Constant {s}
- 0.01, !- Fraction of On-Cycle Power Use
- 60, !- Heat Pump Fan Delay Time {s}
Coil:Heating:Fuel, !- Supplemental Heating Coil Object Type
Heat Pump DX Supp Heating Coil 1, !- Supplemental Heating Coil Name
60.0, !- Maximum Supply Air Temperature from Supplemental Heater {C}
@@ -1082,8 +1074,6 @@
Sys 1 Cooling Coil Air Inlet Node, !- Air Inlet Node Name
Sys 1 Heating Coil Air Inlet Node, !- Air Outlet Node Name
Autosize, !- Rated Air Flow Rate {m3/s}
- , !- 2017 Rated Evaporator Fan Power Per Volume Flow Rate {W/(m3/s)}
- , !- 2023 Rated Evaporator Fan Power Per Volume Flow Rate {W/(m3/s)}
Autosize, !- Rated Water Flow Rate {m3/s}
Autosize, !- Gross Rated Total Cooling Capacity {W}
Autosize, !- Gross Rated Sensible Cooling Capacity {W}
@@ -1094,6 +1084,7 @@
TotCoolCapCurve, !- Total Cooling Capacity Curve Name
CoolSensCapCurve, !- Sensible Cooling Capacity Curve Name
CoolPowCurve, !- Cooling Power Consumption Curve Name
+ HPACCOOLPLFFPLR, !- Part Load Fraction Correlation Curve Name
0, !- Nominal Time for Condensate Removal to Begin {s}
0; !- Ratio of Initial Moisture Evaporation Rate and Steady State Latent Capacity {dimensionless}
@@ -1111,7 +1102,8 @@
20.0, !- Rated Entering Air Dry-Bulb Temperature {C}
1.0, !- Ratio of Rated Heating Capacity to Rated Cooling Capacity
HeatCapCurve, !- Heating Capacity Curve Name
- HeatPowCurve; !- Heating Power Consumption Curve Name
+ HeatPowCurve, !- Heating Power Consumption Curve Name
+ HPACHEATPLFFPLR; !- Part Load Fraction Correlation Curve Name
Fan:OnOff,
Zone 1 Fan, !- Name
diff --git a/scripts/dev/check_for_enum_scope_usage.py b/scripts/dev/check_for_enum_scope_usage.py
index 5ef0f1c72ba..5dfaa7018a4 100755
--- a/scripts/dev/check_for_enum_scope_usage.py
+++ b/scripts/dev/check_for_enum_scope_usage.py
@@ -198,7 +198,7 @@ def run(self):
apparent_enums_in_zero_source_files.append(e.describe())
unique_files_in_usages: Set[str] = set()
# exceptions listed by :
- exceptions = ["DataGlobalConstants.hh:eFuel", "DataGlobalConstants.hh:ePollutant"]
+ exceptions = ["DataGlobalConstants.hh:ePollutant"]
if f"{e.file_path.name}:{e.enum_name}" not in exceptions:
for u in e.usages:
unique_files_in_usages.add(u.file_path.name)
diff --git a/scripts/dev/check_non_utf8.py b/scripts/dev/check_non_utf8.py
index 0e4b3475b14..fc7825d3f70 100755
--- a/scripts/dev/check_non_utf8.py
+++ b/scripts/dev/check_non_utf8.py
@@ -59,10 +59,9 @@
import io # For Python 2 compat
import sys
-# note I am skipping docs for right now; I want to do those files
DIRS_TO_SKIP = [
'.git', 'build', 'builds', 'cmake-build-debug',
- 'cmake-build-release', 'design', 'doc', 'release', 'third_party'
+ 'cmake-build-release', 'design', 'release',
]
# these CC files purposefully have bad characters
diff --git a/src/EnergyPlus/ConvectionCoefficients.cc b/src/EnergyPlus/ConvectionCoefficients.cc
index 21d74f047aa..17c79b01c3f 100644
--- a/src/EnergyPlus/ConvectionCoefficients.cc
+++ b/src/EnergyPlus/ConvectionCoefficients.cc
@@ -388,7 +388,8 @@ void InitExtConvCoeff(EnergyPlusData &state,
Real64 &HExt, // Convection coefficient to exterior air
Real64 &HSky, // "Convection" coefficient to sky temperature
Real64 &HGround, // "Convection" coefficient to ground temperature
- Real64 &HAir // Radiation to Air Component
+ Real64 &HAir, // Radiation to Air Component
+ Real64 &HSrdSurf // Radiation to surrounding surfaces
)
{
@@ -432,6 +433,7 @@ void InitExtConvCoeff(EnergyPlusData &state,
Real64 TSurf = TempExt + Constant::KelvinConv;
Real64 TSky = state.dataEnvrn->SkyTempKelvin;
Real64 TGround = TAir;
+ HSrdSurf = 0.0;
if (surface.SurfHasSurroundingSurfProperty) {
int SrdSurfsNum = surface.SurfSurroundingSurfacesNum;
@@ -439,6 +441,7 @@ void InitExtConvCoeff(EnergyPlusData &state,
TSky = ScheduleManager::GetCurrentScheduleValue(state, state.dataSurface->SurroundingSurfsProperty(SrdSurfsNum).SkyTempSchNum) +
Constant::KelvinConv;
}
+ HSrdSurf = SurroundingSurfacesRadCoeffAverage(state, SurfNum, TSurf, AbsExt);
}
if (surface.UseSurfPropertyGndSurfTemp) {
int gndSurfsNum = surface.SurfPropertyGndSurfIndex;
@@ -6536,4 +6539,17 @@ void ShowSevereScheduleOutOfRange(EnergyPlusData &state,
if (!msg.empty()) ShowContinueError(state, msg);
}
+Real64 SurroundingSurfacesRadCoeffAverage(EnergyPlusData &state, int const SurfNum, Real64 const TSurfK, Real64 const AbsExt)
+{
+ // compute exterior surfaces LW radiation transfer coefficient to surrounding surfaces
+ // the surface.SrdSurfTemp is weighed by surrounding surfaces view factor
+ Real64 HSrdSurf = 0.0;
+ auto &surface = state.dataSurface->Surface(SurfNum);
+ Real64 SrdSurfsTK = surface.SrdSurfTemp + Constant::KelvinConv;
+ if (TSurfK != SrdSurfsTK) {
+ HSrdSurf = Constant::StefanBoltzmann * AbsExt * surface.ViewFactorSrdSurfs * (pow_4(TSurfK) - pow_4(SrdSurfsTK)) / (TSurfK - SrdSurfsTK);
+ }
+ return HSrdSurf;
+}
+
} // namespace EnergyPlus::Convect
diff --git a/src/EnergyPlus/ConvectionCoefficients.hh b/src/EnergyPlus/ConvectionCoefficients.hh
index da8e0c50f63..5b5f421e004 100644
--- a/src/EnergyPlus/ConvectionCoefficients.hh
+++ b/src/EnergyPlus/ConvectionCoefficients.hh
@@ -234,7 +234,14 @@ namespace Convect {
Real64 &HExt, // Convection coefficient to exterior air
Real64 &HSky, // "Convection" coefficient to sky temperature
Real64 &HGround, // "Convection" coefficient to ground temperature
- Real64 &HAir // Radiation to Air Component
+ Real64 &HAir, // Radiation to Air Component
+ Real64 &HSrdSurf // Radiation to surrounding surfaces
+ );
+
+ Real64 SurroundingSurfacesRadCoeffAverage(EnergyPlusData &state,
+ int const SurfNum, // Surface number (in Surface derived type)
+ Real64 const TempExtK, // Exterior surface temperature (K)
+ Real64 const AbsExt // Exterior thermal absorptance
);
Real64 CalcHfExteriorSparrow(Real64 SurfWindSpeed, // Local wind speed at height of the heat transfer surface (m/s)
diff --git a/src/EnergyPlus/DElightManagerF.cc b/src/EnergyPlus/DElightManagerF.cc
index 8e6dcb0f90d..3978c92e551 100644
--- a/src/EnergyPlus/DElightManagerF.cc
+++ b/src/EnergyPlus/DElightManagerF.cc
@@ -252,8 +252,8 @@ namespace DElightManagerF {
ShowWarningError(state, format("Maximum of 100 Reference Points exceeded for daylighting zone using DElight ={}", znDayl.Name));
ShowWarningError(state, " Only first 100 Reference Points included in DElight analysis");
}
- znDayl.DaylRefPtAbsCoord.allocate(3, znDayl.TotalDaylRefPoints);
- znDayl.DaylRefPtAbsCoord = 0.0;
+ znDayl.DaylRefPtAbsCoord.allocate(znDayl.TotalDaylRefPoints);
+ std::fill(znDayl.DaylRefPtAbsCoord.begin(), znDayl.DaylRefPtAbsCoord.end(), Vector3(0.0));
// RJH 2008-03-07: Allocate and Init DaylIllumAtRefPt array for this DElight zone
znDayl.DaylIllumAtRefPt.allocate(znDayl.TotalDaylRefPoints);
@@ -595,7 +595,7 @@ namespace DElightManagerF {
RefPt_WCS_Coord(2) = Xtrans * SinBldgRelNorth + Ytrans * CosBldgRelNorth;
}
}
- znDayl.DaylRefPtAbsCoord({1, 3}, refPt.indexToFracAndIllum) = RefPt_WCS_Coord({1, 3});
+ znDayl.DaylRefPtAbsCoord(refPt.indexToFracAndIllum) = {RefPt_WCS_Coord(1), RefPt_WCS_Coord(2), RefPt_WCS_Coord(3)};
// Validate that Reference Point coordinates are within the host Zone
if (RefPt_WCS_Coord(1) < thisZone.MinimumX || RefPt_WCS_Coord(1) > thisZone.MaximumX) {
diff --git a/src/EnergyPlus/DXCoils.cc b/src/EnergyPlus/DXCoils.cc
index 130eb4964ec..13235a7d9e9 100644
--- a/src/EnergyPlus/DXCoils.cc
+++ b/src/EnergyPlus/DXCoils.cc
@@ -4194,7 +4194,7 @@ void GetDXCoils(EnergyPlusData &state)
ShowContinueError(state, format("...required {} is blank.", cAlphaFields(17 + (I - 1) * 6)));
} else {
ShowSevereError(state, format("{}{}=\"{}\", invalid", RoutineName, CurrentModuleObject, thisDXCoil.Name));
- ShowContinueError(state, format("...not found {}=\"{}\".", cAlphaFields(17 + (I - 1) * 6), Alphas(16 + (I - 1) * 6)));
+ ShowContinueError(state, format("...not found {}=\"{}\".", cAlphaFields(17 + (I - 1) * 6), Alphas(17 + (I - 1) * 6)));
}
ErrorsFound = true;
} else {
diff --git a/src/EnergyPlus/DataDaylighting.hh b/src/EnergyPlus/DataDaylighting.hh
index 77969978842..2132e361c9d 100644
--- a/src/EnergyPlus/DataDaylighting.hh
+++ b/src/EnergyPlus/DataDaylighting.hh
@@ -57,6 +57,7 @@
// EnergyPlus Headers
#include
#include
+#include
#include
#include
@@ -163,9 +164,10 @@ namespace Dayltg {
int enclIndex = 0; // Index to enclosure where the daylighting:controls object is located
Dayltg::DaylightingMethod DaylightMethod = DaylightingMethod::None; // Type of Daylighting (1=SplitFlux, 2=DElight)
int AvailSchedNum = 0; // pointer to availability schedule if present
- int TotalDaylRefPoints = 0; // Number of daylighting reference points for this control
- Array1D_int DaylRefPtNum; // Reference number to DaylRefPt array that stores Daylighting:ReferencePoint
- Array2D DaylRefPtAbsCoord; // =0.0 ! X,Y,Z coordinates of all daylighting reference points
+ int TotalExtWindows = 0;
+ int TotalDaylRefPoints = 0; // Number of daylighting reference points for this control
+ Array1D_int DaylRefPtNum; // Reference number to DaylRefPt array that stores Daylighting:ReferencePoint
+ Array1D> DaylRefPtAbsCoord; // =0.0 ! X,Y,Z coordinates of all daylighting reference points
// in absolute coordinate system (m)
// Points 1 and 2 are the control reference points
Array1D_bool DaylRefPtInBounds; // True when coordinates are in bounds of zone coordinates
@@ -185,14 +187,16 @@ namespace Dayltg {
Real64 DElightGriddingResolution = 0.0; // Field: Delight Gridding Resolution
Array1D RefPtPowerReductionFactor; // =1.0 ! Electric power reduction factor at reference points
// due to daylighting
- Array1D DaylIllumAtRefPt; // =0.0 ! Daylight illuminance at reference points (lux)
- Array1D GlareIndexAtRefPt; // =0.0 ! Glare index at reference points
- Array1D BacLum; // =0.0 ! Background luminance at each reference point (cd/m2)
- Array2D SolidAngAtRefPt; // (Number of Zones, Total Daylighting Reference Points)
- Array2D SolidAngAtRefPtWtd; // (Number of Zones, Total Daylighting Reference Points)
- Array3D IllumFromWinAtRefPt; // (Number of Zones, 2, Total Daylighting Reference Points)
- Array3D BackLumFromWinAtRefPt; // (Number of Zones, 2, Total Daylighting Reference Points)
- Array3D SourceLumFromWinAtRefPt; // (Number of Zones, 2, Total Daylighting Reference Points)
+ Array1D DaylIllumAtRefPt; // =0.0 ! Daylight illuminance at reference points (lux)
+ Array1D GlareIndexAtRefPt; // =0.0 ! Glare index at reference points
+ Array1D BacLum; // =0.0 ! Background luminance at each reference point (cd/m2)
+ Array2D SolidAngAtRefPt; // (Number of Zones, Total Daylighting Reference Points)
+ Array2D SolidAngAtRefPtWtd; // (Number of Zones, Total Daylighting Reference Points)
+ Array2D> IllumFromWinAtRefPt; // (Number of Zones, 2, Total Daylighting Reference Points)
+ Array2D>
+ BackLumFromWinAtRefPt; // (Number of Zones, 2, Total Daylighting Reference Points)
+ Array2D>
+ SourceLumFromWinAtRefPt; // (Number of Zones, 2, Total Daylighting Reference Points)
Array1D TimeExceedingGlareIndexSPAtRefPt;
// Allocatable daylight factor arrays
// Arguments (dimensions) for Dayl---Sky are:
@@ -256,17 +260,17 @@ namespace Dayltg {
struct MapCalcData
{
// Members
- int TotalMapRefPoints = 0; // Number of illuminance map reference points in this zone (up to 100)
- int zoneIndex = 0; // Pointer to zone being mapped
- int enclIndex = 0; // Index to enclosure for this map
- Array2D MapRefPtAbsCoord; // X,Y,Z coordinates of all illuminance map reference points
+ int TotalMapRefPoints = 0; // Number of illuminance map reference points in this zone (up to 100)
+ int zoneIndex = 0; // Pointer to zone being mapped
+ int enclIndex = 0; // Index to enclosure for this map
+ Array1D> MapRefPtAbsCoord; // X,Y,Z coordinates of all illuminance map reference points
// in absolute coordinate system (m)
// Points 1 and 2 are the control reference points
Array1D_bool MapRefPtInBounds; // True when coordinates are in bounds of zone coordinates
Array1D DaylIllumAtMapPt; // Daylight illuminance at illuminance map points (lux)
// following Hr - report avg hr
- Array1D DaylIllumAtMapPtHr; // Daylight illuminance at illuminance map points (lux)
- Array3D IllumFromWinAtMapPt; // (Number of Zones, 2, Total Map Reference Points)
+ Array1D DaylIllumAtMapPtHr; // Daylight illuminance at illuminance map points (lux)
+ Array2D> IllumFromWinAtMapPt; // (Number of Zones, Total Map Reference Points)
// Arguments (dimensions) for Dayl---Sky are:
// 1: Sun position index / HourOfDay (1 to 24)
// 2: Daylit window number (1 to NumOfDayltgExtWins)
diff --git a/src/EnergyPlus/DataHeatBalSurface.hh b/src/EnergyPlus/DataHeatBalSurface.hh
index 57a5f7e25be..39a2dfa45a1 100644
--- a/src/EnergyPlus/DataHeatBalSurface.hh
+++ b/src/EnergyPlus/DataHeatBalSurface.hh
@@ -120,6 +120,7 @@ struct HeatBalSurfData : BaseGlobalStruct
Array1D SurfTempSource; // Temperature at the source location for each heat transfer surface
Array1D SurfTempUserLoc; // Temperature at the user specified location for each heat transfer surface
Array1D SurfTempInMovInsRep; // Temperature of interior movable insulation on the side facing the zone
+ Array1D SurfHSrdSurfExt; // Outside Radiation Coefficient to Surrounding Surfaces
Array1D SurfQConvInReport; // Surface convection heat gain at inside face [J]
Array1D SurfQdotConvInRep; // Surface convection heat transfer rate at inside face surface [W] (report)
diff --git a/src/EnergyPlus/DataSurfaces.cc b/src/EnergyPlus/DataSurfaces.cc
index e1d82b73148..784779d8b98 100644
--- a/src/EnergyPlus/DataSurfaces.cc
+++ b/src/EnergyPlus/DataSurfaces.cc
@@ -568,6 +568,7 @@ void SurfaceData::make_hash_key(EnergyPlusData &state, const int SurfNum)
calcHashKey.LinkedOutAirNode = state.dataSurface->Surface(SurfNum).SurfLinkedOutAirNode;
calcHashKey.OutsideHeatSourceTermSchedule = OutsideHeatSourceTermSchedule;
calcHashKey.InsideHeatSourceTermSchedule = InsideHeatSourceTermSchedule;
+ calcHashKey.ViewFactorSrdSurfs = state.dataSurface->Surface(SurfNum).ViewFactorSrdSurfs;
}
void SurfaceData::set_representative_surface(EnergyPlusData &state, const int SurfNum)
diff --git a/src/EnergyPlus/DataSurfaces.hh b/src/EnergyPlus/DataSurfaces.hh
index 3a913202608..56b77b11504 100644
--- a/src/EnergyPlus/DataSurfaces.hh
+++ b/src/EnergyPlus/DataSurfaces.hh
@@ -167,6 +167,16 @@ namespace DataSurfaces {
Num // The counter representing the total number of surface class, always stays at the bottom
};
+ // A coarse grain version of SurfaceClass
+ enum class FWC
+ {
+ Invalid = -1,
+ Floor,
+ Wall,
+ Ceiling,
+ Num
+ };
+
enum class SurfaceFilter
{
Invalid = -1,
@@ -196,6 +206,14 @@ namespace DataSurfaces {
"ALLINTERIORCEILINGS",
"ALLINTERIORFLOORS"};
+ enum class WinCover
+ {
+ Invalid = -1,
+ Bare,
+ Shaded,
+ Num
+ };
+
enum class WinShadingType
{
Invalid = -1,
@@ -514,20 +532,21 @@ namespace DataSurfaces {
{
// Values that must be the same in order for surfaces to use a representative calculation
- int Construction; // Pointer to the construction in the Construct derived type
- Real64 Azimuth; // Direction the surface outward normal faces (degrees) or FACING
- Real64 Tilt; // Angle (deg) between the ground outward normal and the surface outward normal
- Real64 Height; // Height of the surface (m)
- int Zone; // Interior environment or zone the surface is a part of
- int EnclIndex; // Pointer to enclosure this surface belongs to
- int TAirRef; // Flag for reference air temperature
- int ExtZone; // For an "interzone" surface, this is the adjacent ZONE number (not adjacent SURFACE number).
- int ExtCond; // Exterior condition type. Same as ExtBoundCond for non-interzone surfaces. Value = 1 for interzone surfaces.
- int ExtEnclIndex; // For an "interzone" surface, this is the adjacent ENCLOSURE number
- bool ExtSolar; // True if the "outside" of the surface is exposed to solar
- bool ExtWind; // True if the "outside" of the surface is exposed to wind
- Real64 ViewFactorGround; // View factor to the ground from the exterior of the surface for diffuse solar radiation
- Real64 ViewFactorSky; // View factor to the sky from the exterior of the surface for diffuse solar radiation
+ int Construction; // Pointer to the construction in the Construct derived type
+ Real64 Azimuth; // Direction the surface outward normal faces (degrees) or FACING
+ Real64 Tilt; // Angle (deg) between the ground outward normal and the surface outward normal
+ Real64 Height; // Height of the surface (m)
+ int Zone; // Interior environment or zone the surface is a part of
+ int EnclIndex; // Pointer to enclosure this surface belongs to
+ int TAirRef; // Flag for reference air temperature
+ int ExtZone; // For an "interzone" surface, this is the adjacent ZONE number (not adjacent SURFACE number).
+ int ExtCond; // Exterior condition type. Same as ExtBoundCond for non-interzone surfaces. Value = 1 for interzone surfaces.
+ int ExtEnclIndex; // For an "interzone" surface, this is the adjacent ENCLOSURE number
+ bool ExtSolar; // True if the "outside" of the surface is exposed to solar
+ bool ExtWind; // True if the "outside" of the surface is exposed to wind
+ Real64 ViewFactorGround; // View factor to the ground from the exterior of the surface for diffuse solar radiation
+ Real64 ViewFactorSky; // View factor to the sky from the exterior of the surface for diffuse solar radiation
+ Real64 ViewFactorSrdSurfs; // View factor to the surrounding surfaces seen from the exterior of the surface
// Special Properties
HeatTransferModel HeatTransferAlgorithm; // used for surface-specific heat transfer algorithm.
@@ -782,6 +801,8 @@ namespace DataSurfaces {
int SurfLinkedOutAirNode; // Index of the an OutdoorAir:Node, zero if none
Real64 AE = 0.0; // Product of area and emissivity for each surface
Real64 enclAESum = 0.0; // Sum of area times emissivity for all other surfaces in enclosure
+ Real64 SrdSurfTemp; // surrounding surfaces average temperature seen by an exterior surface (C)
+ Real64 ViewFactorSrdSurfs; // surrounding surfaces view factor sum seen by an exterior surface(-)
// Default Constructor
SurfaceData()
@@ -799,7 +820,7 @@ namespace DataSurfaces {
SolarEnclIndex(0), SolarEnclSurfIndex(0), IsAirBoundarySurf(false), IsSurfPropertyGndSurfacesDefined(false),
SurfPropertyGndSurfIndex(0), UseSurfPropertyGndSurfTemp(false), UseSurfPropertyGndSurfRefl(false), GndReflSolarRad(0.0),
SurfHasSurroundingSurfProperty(false), SurfSchedExternalShadingFrac(false), SurfSurroundingSurfacesNum(0), SurfExternalShadingSchInd(0),
- SurfLinkedOutAirNode(0)
+ SurfLinkedOutAirNode(0), SrdSurfTemp(0.0), ViewFactorSrdSurfs(0.0)
{
}
@@ -837,13 +858,15 @@ namespace DataSurfaces {
struct SurfaceWindowCalc // Calculated window-related values
{
// Members
- Array1D SolidAngAtRefPt; // Solid angle subtended by window from daylit ref points 1 and 2
- Array1D SolidAngAtRefPtWtd; // Solid angle subtended by window from ref pts weighted by glare pos factor
- Array2D IllumFromWinAtRefPt; // Illuminance from window at ref pts for window with and w/o shade (lux)
- Array2D BackLumFromWinAtRefPt; // Window background luminance from window wrt ref pts (cd/m2) with and w/o shade (cd/m2)
- Array2D SourceLumFromWinAtRefPt; // Window luminance at ref pts for window with and w/o shade (cd/m2)
- Vector3 WinCenter; // X,Y,Z coordinates of window center point in building coord system
- Array1D ThetaFace; // Face temperatures of window layers (K)
+ Array1D SolidAngAtRefPt; // Solid angle subtended by window from daylit ref points 1 and 2
+ Array1D SolidAngAtRefPtWtd; // Solid angle subtended by window from ref pts weighted by glare pos factor
+ EPVector>
+ IllumFromWinAtRefPt; // Illuminance from window at ref pts for window with and w/o shade (lux)
+ EPVector>
+ BackLumFromWinAtRefPt; // Window background luminance from window wrt ref pts (cd/m2) with and w/o shade (cd/m2)
+ EPVector> SourceLumFromWinAtRefPt; // Window luminance at ref pts for window with and w/o shade (cd/m2)
+ Vector3 WinCenter = {0.0, 0.0, 0.0}; // X,Y,Z coordinates of window center point in building coord system
+ Array1D ThetaFace; // Face temperatures of window layers (K)
Array1D OutProjSLFracMult; // Multiplier on sunlit fraction due to shadowing of glass by frame
// and divider outside projections
@@ -855,9 +878,11 @@ namespace DataSurfaces {
Array1D IllumFromWinAtRefPtRep; // Illuminance from window at reference point N [lux]
Array1D LumWinFromRefPtRep; // Window luminance as viewed from reference point N [cd/m2]
// for shadowing of ground by building and obstructions [W/m2]
- Array1D EnclAreaMinusThisSurf; // Enclosure inside surface area minus this surface and its subsurfaces
+ std::array EnclAreaMinusThisSurf = {
+ 0.0, 0.0, 0.0}; // Enclosure inside surface area minus this surface and its subsurfaces
// for floor/wall/ceiling (m2)
- Array1D EnclAreaReflProdMinusThisSurf; // Enclosure product of inside surface area times vis reflectance
+ std::array EnclAreaReflProdMinusThisSurf = {
+ 0.0, 0.0, 0.0}; // Enclosure product of inside surface area times vis reflectance
// minus this surface and its subsurfaces,
// for floor/wall/ceiling (m2)
@@ -865,9 +890,8 @@ namespace DataSurfaces {
// Default Constructor
SurfaceWindowCalc()
- : WinCenter(0.0, 0.0, 0.0), ThetaFace(10, 296.15), OutProjSLFracMult(24, 1.0), InOutProjSLFracMult(24, 1.0),
- EffShBlindEmiss(Material::MaxSlatAngs, 0.0), EffGlassEmiss(Material::MaxSlatAngs, 0.0), EnclAreaMinusThisSurf(3, 0.0),
- EnclAreaReflProdMinusThisSurf(3, 0.0)
+ : ThetaFace(10, 296.15), OutProjSLFracMult(24, 1.0), InOutProjSLFracMult(24, 1.0), EffShBlindEmiss(Material::MaxSlatAngs, 0.0),
+ EffGlassEmiss(Material::MaxSlatAngs, 0.0)
{
}
};
@@ -1264,6 +1288,7 @@ namespace DataSurfaces {
std::string Name;
Real64 SkyViewFactor = 0.0; // sky view factor
Real64 GroundViewFactor = 0.0; // ground view factor
+ Real64 SurfsViewFactorSum = 0.0; // surrounding surfaces view factor sum
int SkyTempSchNum = 0; // schedule pointer
int GroundTempSchNum = 0; // schedule pointer
int TotSurroundingSurface = 0; // Total number of surrounding surfaces defined for an exterior surface
@@ -1755,329 +1780,7 @@ struct SurfacesData : BaseGlobalStruct
void clear_state() override
{
- this->TotSurfaces = 0;
- this->TotWindows = 0;
- this->TotStormWin = 0;
- this->TotWinShadingControl = 0;
- this->TotUserIntConvModels = 0;
- this->TotUserExtConvModels = 0;
- this->TotOSC = 0;
- this->TotOSCM = 0;
- this->TotExtVentCav = 0;
- this->TotSurfIncSolSSG = 0;
- this->TotSurfIncSolMultiplier = 0;
- this->TotFenLayAbsSSG = 0;
- this->TotSurfLocalEnv = 0;
- this->TotSurfPropGndSurfs = 0;
- this->Corner = 0;
- this->MaxVerticesPerSurface = 4;
- this->BuildingShadingCount = 0;
- this->FixedShadingCount = 0;
- this->AttachedShadingCount = 0;
- this->ShadingSurfaceFirst = 0;
- this->ShadingSurfaceLast = -1;
- this->AspectTransform = false;
- this->CalcSolRefl = false;
- this->CCW = false;
- this->WorldCoordSystem = false;
- this->DaylRefWorldCoordSystem = false;
- this->MaxRecPts = 0;
- this->MaxReflRays = 0;
- this->GroundLevelZ = 0.0;
- this->AirflowWindows = false;
- this->ShadingTransmittanceVaries = false;
- this->UseRepresentativeSurfaceCalculations = false;
- this->AnyMovableInsulation = false;
- this->AnyMovableSlat = false;
- this->SurfWinInsideGlassCondensationFlag.deallocate();
- this->SurfWinInsideFrameCondensationFlag.deallocate();
- this->SurfWinInsideDividerCondensationFlag.deallocate();
- this->SurfAdjacentZone.deallocate();
- this->X0.deallocate();
- this->Y0.deallocate();
- this->Z0.deallocate();
- this->RepresentativeSurfaceMap.clear();
- this->AllHTSurfaceList.clear();
- this->AllExtSolarSurfaceList.clear();
- this->AllExtSolAndShadingSurfaceList.clear();
- this->AllShadowPossObstrSurfaceList.clear();
- this->AllIZSurfaceList.clear();
- this->AllHTNonWindowSurfaceList.clear();
- this->AllHTWindowSurfaceList.clear();
- this->AllExtSolWindowSurfaceList.clear();
- this->AllExtSolWinWithFrameSurfaceList.clear();
- this->AllHTKivaSurfaceList.clear();
- this->AllSurfaceListReportOrder.clear();
- this->AllVaryAbsOpaqSurfaceList.clear();
-
- this->SurfOutDryBulbTemp.deallocate();
- this->SurfOutWetBulbTemp.deallocate();
- this->SurfOutWindSpeed.deallocate();
- this->SurfOutWindDir.deallocate();
- this->SurfGenericContam.deallocate();
- this->SurfLowTempErrCount.deallocate();
- this->SurfHighTempErrCount.deallocate();
- this->SurfAirSkyRadSplit.deallocate();
- this->SurfSunCosHourly.deallocate();
- this->SurfSunlitArea.deallocate();
- this->SurfSunlitFrac.deallocate();
- this->SurfSkySolarInc.deallocate();
- this->SurfGndSolarInc.deallocate();
- this->SurfBmToBmReflFacObs.deallocate();
- this->SurfBmToDiffReflFacObs.deallocate();
- this->SurfBmToDiffReflFacGnd.deallocate();
- this->SurfSkyDiffReflFacGnd.deallocate();
- this->SurfOpaqAI.deallocate();
- this->SurfOpaqAO.deallocate();
- this->SurfPenumbraID.deallocate();
- this->SurfReflFacBmToDiffSolObs.deallocate();
- this->SurfReflFacBmToDiffSolGnd.deallocate();
- this->SurfReflFacBmToBmSolObs.deallocate();
- this->SurfReflFacSkySolObs.deallocate();
- this->SurfReflFacSkySolGnd.deallocate();
- this->SurfCosIncAveBmToBmSolObs.deallocate();
- this->SurfShadowDiffuseSolRefl.deallocate();
- this->SurfShadowDiffuseVisRefl.deallocate();
- this->SurfShadowGlazingFrac.deallocate();
- this->SurfShadowGlazingConstruct.deallocate();
- this->SurfShadowRecSurfNum.deallocate();
- this->SurfShadowDisabledZoneList.deallocate();
- this->SurfMaterialMovInsulExt.deallocate();
- this->SurfMaterialMovInsulInt.deallocate();
- this->SurfSchedMovInsulExt.deallocate();
- this->SurfSchedMovInsulInt.deallocate();
- this->SurfEMSConstructionOverrideON.deallocate();
- this->SurfEMSConstructionOverrideValue.deallocate();
- this->SurfEMSOverrideIntConvCoef.deallocate();
- this->SurfEMSValueForIntConvCoef.deallocate();
- this->SurfEMSOverrideExtConvCoef.deallocate();
- this->SurfEMSValueForExtConvCoef.deallocate();
- this->SurfOutDryBulbTempEMSOverrideOn.deallocate();
- this->SurfOutDryBulbTempEMSOverrideValue.deallocate();
- this->SurfOutWetBulbTempEMSOverrideOn.deallocate();
- this->SurfOutWetBulbTempEMSOverrideValue.clear();
- this->SurfWindSpeedEMSOverrideOn.deallocate();
- this->SurfWindSpeedEMSOverrideValue.deallocate();
- this->SurfViewFactorGroundEMSOverrideOn.deallocate();
- this->SurfViewFactorGroundEMSOverrideValue.deallocate();
- this->SurfWindDirEMSOverrideOn.deallocate();
- this->SurfWindDirEMSOverrideValue.deallocate();
- this->SurfDaylightingShelfInd.deallocate();
- this->SurfExtEcoRoof.deallocate();
- this->SurfExtCavityPresent.deallocate();
- this->SurfExtCavNum.deallocate();
- this->SurfIsPV.deallocate();
- this->SurfIsICS.deallocate();
- this->SurfIsPool.deallocate();
- this->SurfICSPtr.deallocate();
- this->SurfIsRadSurfOrVentSlabOrPool.deallocate();
- this->SurfTAirRef.deallocate();
- this->SurfTAirRefRpt.deallocate();
-
- this->surfIntConv.deallocate();
- this->surfExtConv.deallocate();
- this->SurfWinA.deallocate();
- this->SurfWinADiffFront.deallocate();
- this->SurfWinACFOverlap.deallocate();
- this->SurfWinTransSolar.deallocate();
- this->SurfWinBmSolar.deallocate();
- this->SurfWinBmBmSolar.deallocate();
- this->SurfWinBmDifSolar.deallocate();
- this->SurfWinDifSolar.deallocate();
- this->SurfWinHeatGain.deallocate();
- this->SurfWinHeatGainRep.deallocate();
- this->SurfWinHeatLossRep.deallocate();
- this->SurfWinGainConvGlazToZoneRep.deallocate();
- this->SurfWinGainIRGlazToZoneRep.deallocate();
- this->SurfWinLossSWZoneToOutWinRep.deallocate();
- this->SurfWinGainFrameDividerToZoneRep.deallocate();
- this->SurfWinGainConvShadeToZoneRep.deallocate();
- this->SurfWinGainIRShadeToZoneRep.deallocate();
- this->SurfWinGapConvHtFlowRep.deallocate();
- this->SurfWinShadingAbsorbedSolar.deallocate();
- this->SurfWinSysSolTransmittance.deallocate();
- this->SurfWinSysSolReflectance.deallocate();
- this->SurfWinSysSolAbsorptance.deallocate();
- this->SurfWinTransSolarEnergy.deallocate();
- this->SurfWinBmSolarEnergy.deallocate();
- this->SurfWinBmBmSolarEnergy.deallocate();
- this->SurfWinBmDifSolarEnergy.deallocate();
- this->SurfWinDifSolarEnergy.deallocate();
- this->SurfWinHeatGainRepEnergy.deallocate();
- this->SurfWinHeatLossRepEnergy.deallocate();
- this->SurfWinShadingAbsorbedSolarEnergy.deallocate();
- this->SurfWinGapConvHtFlowRepEnergy.deallocate();
- this->SurfWinHeatTransferRepEnergy.deallocate();
- this->SurfWinIRfromParentZone.deallocate();
- this->SurfWinFrameQRadOutAbs.deallocate();
- this->SurfWinFrameQRadInAbs.deallocate();
- this->SurfWinDividerQRadOutAbs.deallocate();
- this->SurfWinDividerQRadInAbs.deallocate();
- this->SurfWinExtBeamAbsByShade.deallocate();
- this->SurfWinExtDiffAbsByShade.deallocate();
- this->SurfWinIntBeamAbsByShade.deallocate();
- this->SurfWinIntSWAbsByShade.deallocate();
- this->SurfWinInitialDifSolAbsByShade.deallocate();
- this->SurfWinIntLWAbsByShade.deallocate();
- this->SurfWinConvHeatFlowNatural.deallocate();
- this->SurfWinConvHeatGainToZoneAir.deallocate();
- this->SurfWinRetHeatGainToZoneAir.deallocate();
- this->SurfWinDividerHeatGain.deallocate();
- this->SurfWinBlTsolBmBm.deallocate();
- this->SurfWinBlTsolBmDif.deallocate();
- this->SurfWinBlTsolDifDif.deallocate();
- this->SurfWinBlGlSysTsolBmBm.deallocate();
- this->SurfWinBlGlSysTsolDifDif.deallocate();
- this->SurfWinScTsolBmBm.deallocate();
- this->SurfWinScTsolBmDif.deallocate();
- this->SurfWinScTsolDifDif.deallocate();
- this->SurfWinScGlSysTsolBmBm.deallocate();
- this->SurfWinScGlSysTsolDifDif.deallocate();
- this->SurfWinGlTsolBmBm.deallocate();
- this->SurfWinGlTsolBmDif.deallocate();
- this->SurfWinGlTsolDifDif.deallocate();
- this->SurfWinBmSolTransThruIntWinRep.deallocate();
- this->SurfWinBmSolAbsdOutsReveal.deallocate();
- this->SurfWinBmSolRefldOutsRevealReport.deallocate();
- this->SurfWinBmSolAbsdInsReveal.deallocate();
- this->SurfWinBmSolRefldInsReveal.deallocate();
- this->SurfWinBmSolRefldInsRevealReport.deallocate();
- this->SurfWinOutsRevealDiffOntoGlazing.deallocate();
- this->SurfWinInsRevealDiffOntoGlazing.deallocate();
- this->SurfWinInsRevealDiffIntoZone.deallocate();
- this->SurfWinOutsRevealDiffOntoFrame.deallocate();
- this->SurfWinInsRevealDiffOntoFrame.deallocate();
- this->SurfWinInsRevealDiffOntoGlazingReport.deallocate();
- this->SurfWinInsRevealDiffIntoZoneReport.deallocate();
- this->SurfWinInsRevealDiffOntoFrameReport.deallocate();
- this->SurfWinBmSolAbsdInsRevealReport.deallocate();
- this->SurfWinBmSolTransThruIntWinRepEnergy.deallocate();
- this->SurfWinBmSolRefldOutsRevealRepEnergy.deallocate();
- this->SurfWinBmSolRefldInsRevealRepEnergy.deallocate();
- this->SurfWinProfileAngHor.deallocate();
- this->SurfWinProfileAngVert.deallocate();
- this->SurfWinShadingFlag.deallocate();
- this->SurfWinShadingFlagEMSOn.deallocate();
- this->SurfWinShadingFlagEMSValue.deallocate();
- this->SurfWinStormWinFlag.deallocate();
- this->SurfWinStormWinFlagPrevDay.deallocate();
- this->SurfWinFracTimeShadingDeviceOn.deallocate();
- this->SurfWinExtIntShadePrevTS.deallocate();
- this->SurfWinHasShadeOrBlindLayer.deallocate();
- this->SurfWinSurfDayLightInit.deallocate();
- this->SurfWinDaylFacPoint.deallocate();
- this->SurfWinVisTransSelected.deallocate();
- this->SurfWinSwitchingFactor.deallocate();
- this->SurfWinTheta.deallocate();
- this->SurfWinPhi.deallocate();
- this->SurfWinRhoCeilingWall.deallocate();
- this->SurfWinRhoFloorWall.deallocate();
- this->SurfWinFractionUpgoing.deallocate();
- this->SurfWinVisTransRatio.deallocate();
- this->SurfWinFrameArea.deallocate();
- this->SurfWinFrameConductance.deallocate();
- this->SurfWinFrameSolAbsorp.deallocate();
- this->SurfWinFrameVisAbsorp.deallocate();
- this->SurfWinFrameEmis.deallocate();
- this->SurfWinFrEdgeToCenterGlCondRatio.deallocate();
- this->SurfWinFrameEdgeArea.deallocate();
- this->SurfWinFrameTempIn.deallocate();
- this->SurfWinFrameTempInOld.deallocate();
- this->SurfWinFrameTempSurfOut.deallocate();
- this->SurfWinProjCorrFrOut.deallocate();
- this->SurfWinProjCorrFrIn.deallocate();
- this->SurfWinDividerType.deallocate();
- this->SurfWinDividerArea.deallocate();
- this->SurfWinDividerConductance.deallocate();
- this->SurfWinDividerSolAbsorp.deallocate();
- this->SurfWinDividerVisAbsorp.deallocate();
- this->SurfWinDividerEmis.deallocate();
- this->SurfWinDivEdgeToCenterGlCondRatio.deallocate();
- this->SurfWinDividerEdgeArea.deallocate();
- this->SurfWinDividerTempIn.deallocate();
- this->SurfWinDividerTempInOld.deallocate();
- this->SurfWinDividerTempSurfOut.deallocate();
- this->SurfWinProjCorrDivOut.deallocate();
- this->SurfWinProjCorrDivIn.deallocate();
- this->SurfWinGlazedFrac.deallocate();
- this->SurfWinCenterGlArea.deallocate();
- this->SurfWinEdgeGlCorrFac.deallocate();
- this->SurfWinOriginalClass.deallocate();
- this->SurfWinShadeAbsFacFace1.deallocate();
- this->SurfWinShadeAbsFacFace2.deallocate();
- this->SurfWinConvCoeffWithShade.deallocate();
- this->SurfWinOtherConvHeatGain.deallocate();
- this->SurfWinBlindNumber.deallocate();
- this->SurfWinEffInsSurfTemp.deallocate();
- this->SurfWinMovableSlats.deallocate();
- this->SurfWinSlatAngThisTS.deallocate();
- this->SurfWinSlatAngThisTSDeg.deallocate();
- this->SurfWinSlatAngThisTSDegEMSon.deallocate();
- this->SurfWinSlatAngThisTSDegEMSValue.deallocate();
- this->SurfWinSlatsBlockBeam.deallocate();
- this->SurfWinSlatsAngIndex.deallocate();
- this->SurfWinSlatsAngInterpFac.deallocate();
- this->SurfWinProfileAng.deallocate();
- this->SurfWinProfAngIndex.deallocate();
- this->SurfWinProfAngInterpFac.deallocate();
- this->SurfWinBlindBmBmTrans.deallocate();
- this->SurfWinBlindAirFlowPermeability.deallocate();
- this->SurfWinTotGlazingThickness.deallocate();
- this->SurfWinTanProfileAngHor.deallocate();
- this->SurfWinTanProfileAngVert.deallocate();
- this->SurfWinInsideSillDepth.deallocate();
- this->SurfWinInsideReveal.deallocate();
- this->SurfWinInsideSillSolAbs.deallocate();
- this->SurfWinInsideRevealSolAbs.deallocate();
- this->SurfWinOutsideRevealSolAbs.deallocate();
- this->SurfWinScreenNumber.deallocate();
- this->SurfWinAirflowSource.deallocate();
- this->SurfWinAirflowDestination.deallocate();
- this->SurfWinAirflowReturnNodePtr.deallocate();
- this->SurfWinMaxAirflow.deallocate();
- this->SurfWinAirflowControlType.deallocate();
- this->SurfWinAirflowHasSchedule.deallocate();
- this->SurfWinAirflowSchedulePtr.deallocate();
- this->SurfWinAirflowThisTS.deallocate();
- this->SurfWinTAirflowGapOutlet.deallocate();
- this->SurfWinWindowCalcIterationsRep.deallocate();
- this->SurfWinVentingOpenFactorMultRep.deallocate();
- this->SurfWinInsideTempForVentingRep.deallocate();
- this->SurfWinVentingAvailabilityRep.deallocate();
- this->SurfWinSkyGndSolarInc.deallocate();
- this->SurfWinBmGndSolarInc.deallocate();
- this->SurfWinLightWellEff.deallocate();
- this->SurfWinSolarDiffusing.deallocate();
- this->SurfWinFrameHeatGain.deallocate();
- this->SurfWinFrameHeatLoss.deallocate();
- this->SurfWinDividerHeatLoss.deallocate();
- this->SurfWinTCLayerTemp.deallocate();
- this->SurfWinSpecTemp.deallocate();
- this->SurfWinWindowModelType.deallocate();
- this->SurfWinTDDPipeNum.deallocate();
- this->SurfWinStormWinConstr.deallocate();
- this->SurfActiveConstruction.deallocate();
- this->SurfWinActiveShadedConstruction.deallocate();
- this->AnyHeatBalanceInsideSourceTerm = false;
- this->AnyHeatBalanceOutsideSourceTerm = false;
- this->Surface.deallocate();
- this->SurfaceWindow.deallocate();
- this->FrameDivider.deallocate();
- this->StormWindow.deallocate();
- this->WindowShadingControl.deallocate();
- this->OSC.deallocate();
- this->OSCM.deallocate();
- this->userIntConvModels.deallocate();
- this->userExtConvModels.deallocate();
- this->ShadeV.deallocate();
- this->SurfIncSolSSG.deallocate();
- this->SurfIncSolMultiplier.deallocate();
- this->FenLayAbsSSG.deallocate();
- this->SurfLocalEnvironment.deallocate();
- this->SurroundingSurfsProperty.deallocate();
- this->IntMassObjects.deallocate();
- this->actualMaxSlatAngs = Material::MaxSlatAngs;
- this->GroundSurfsProperty.deallocate();
+ new (this) SurfacesData();
}
};
diff --git a/src/EnergyPlus/DaylightingManager.cc b/src/EnergyPlus/DaylightingManager.cc
index 175568e7a0b..df66f5166ad 100644
--- a/src/EnergyPlus/DaylightingManager.cc
+++ b/src/EnergyPlus/DaylightingManager.cc
@@ -54,9 +54,8 @@
// ObjexxFCL Headers
#include
#include
-#include
#include
-#include
+// #include
#include
#include
#include
@@ -173,27 +172,22 @@ void DayltgAveInteriorReflectance(EnergyPlusData &state, int const enclNum) // E
// REFERENCES:
// Based on DOE-2.1E subroutine DAVREF
- SurfaceClass IType; // Surface type/class
- Real64 AREA; // Inside surface area (m2)
- Real64 AInsTot; // Total inside surface area of an enclosure (m2)
- Real64 ARHTOT; // Sum over surfaces of AREA*(inside visible reflectance) (m2)
- int ITILT; // Surface tilt category (1 = floor, 2 = wall, 3 = ceiling)
- Real64 ATWL; // Opaque surface area (m2)
- Real64 ARHTWL; // ATWL times inside visible reflectance of surface (m2)
- Real64 ETA; // Ratio of floor-to-window-center height and average floor-to-ceiling height
+ Real64 AREA; // Inside surface area (m2)
+ Real64 ETA; // Ratio of floor-to-window-center height and average floor-to-ceiling height
// Total inside surface area, including windows
- AInsTot = 0.0;
+ Real64 AInsTot = 0.0;
// Sum of products of inside surface area * vis reflectance
- ARHTOT = 0.0;
+ Real64 ARHTOT = 0.0;
+
// Area sum and area * reflectance sum for different orientations
- state.dataDaylightingManager->AR = 0.0;
- state.dataDaylightingManager->ARH = 0.0;
+ std::array AR = {0.0, 0.0, 0.0};
+ std::array ARH = {0.0, 0.0, 0.0};
// Loop over surfaces in the zone's enclosure
auto &thisEnclosure(state.dataViewFactor->EnclSolInfo(enclNum));
for (int ISurf : thisEnclosure.SurfacePtr) {
- IType = state.dataSurface->Surface(ISurf).Class;
+ SurfaceClass IType = state.dataSurface->Surface(ISurf).Class;
// Error if window has multiplier > 1 since this causes incorrect illuminance calc
if (IType == SurfaceClass::Window && state.dataSurface->Surface(ISurf).Multiplier > 1.0) {
if (thisEnclosure.TotalEnclosureDaylRefPoints > 0) {
@@ -223,18 +217,17 @@ void DayltgAveInteriorReflectance(EnergyPlusData &state, int const enclNum) // E
(1.0 - state.dataSurface->SurfWinFrameSolAbsorp(ISurf)) +
state.dataSurface->SurfWinDividerArea(ISurf) * (1.0 + state.dataSurface->SurfWinProjCorrDivIn(ISurf)) *
(1.0 - state.dataSurface->SurfWinDividerSolAbsorp(ISurf));
- ITILT = 3; // Ceiling
- if (state.dataSurface->Surface(ISurf).Tilt > 10.0 && state.dataSurface->Surface(ISurf).Tilt < 170.0) ITILT = 2; // Wall
- if (state.dataSurface->Surface(ISurf).Tilt >= 170.0) ITILT = 1; // Floor
- state.dataDaylightingManager->AR(ITILT) +=
- AREA + state.dataSurface->SurfWinFrameArea(ISurf) * (1.0 + 0.5 * state.dataSurface->SurfWinProjCorrFrIn(ISurf)) +
- state.dataSurface->SurfWinDividerArea(ISurf) * (1.0 + state.dataSurface->SurfWinProjCorrDivIn(ISurf));
- state.dataDaylightingManager->ARH(ITILT) +=
- AREA * state.dataConstruction->Construct(state.dataSurface->Surface(ISurf).Construction).ReflectVisDiffBack +
- state.dataSurface->SurfWinFrameArea(ISurf) * (1.0 + 0.5 * state.dataSurface->SurfWinProjCorrFrIn(ISurf)) *
- (1.0 - state.dataSurface->SurfWinFrameSolAbsorp(ISurf)) +
- state.dataSurface->SurfWinDividerArea(ISurf) * (1.0 + state.dataSurface->SurfWinProjCorrDivIn(ISurf)) *
- (1.0 - state.dataSurface->SurfWinDividerSolAbsorp(ISurf));
+
+ FWC fwc = FWC::Ceiling; // Ceiling
+ if (state.dataSurface->Surface(ISurf).Tilt > 10.0 && state.dataSurface->Surface(ISurf).Tilt < 170.0) fwc = FWC::Wall; // Wall
+ if (state.dataSurface->Surface(ISurf).Tilt >= 170.0) fwc = FWC::Floor; // Floor
+ AR[(int)fwc] += AREA + state.dataSurface->SurfWinFrameArea(ISurf) * (1.0 + 0.5 * state.dataSurface->SurfWinProjCorrFrIn(ISurf)) +
+ state.dataSurface->SurfWinDividerArea(ISurf) * (1.0 + state.dataSurface->SurfWinProjCorrDivIn(ISurf));
+ ARH[(int)fwc] += AREA * state.dataConstruction->Construct(state.dataSurface->Surface(ISurf).Construction).ReflectVisDiffBack +
+ state.dataSurface->SurfWinFrameArea(ISurf) * (1.0 + 0.5 * state.dataSurface->SurfWinProjCorrFrIn(ISurf)) *
+ (1.0 - state.dataSurface->SurfWinFrameSolAbsorp(ISurf)) +
+ state.dataSurface->SurfWinDividerArea(ISurf) * (1.0 + state.dataSurface->SurfWinProjCorrDivIn(ISurf)) *
+ (1.0 - state.dataSurface->SurfWinDividerSolAbsorp(ISurf));
}
}
@@ -247,26 +240,26 @@ void DayltgAveInteriorReflectance(EnergyPlusData &state, int const enclNum) // E
// Total inside surface area of enclosure
state.dataDaylightingData->enclDaylight(enclNum).totInsSurfArea = AInsTot;
// Average floor visible reflectance
- state.dataDaylightingData->enclDaylight(enclNum).floorVisRefl =
- state.dataDaylightingManager->ARH(3) / (state.dataDaylightingManager->AR(3) + 1.e-6);
+ state.dataDaylightingData->enclDaylight(enclNum).floorVisRefl = ARH[(int)FWC::Ceiling] / (AR[(int)FWC::Ceiling] + 1.e-6);
for (int ISurf : thisEnclosure.SurfacePtr) {
auto const &surf = state.dataSurface->Surface(ISurf);
- IType = surf.Class;
+ SurfaceClass IType = surf.Class;
if (IType == SurfaceClass::Wall || IType == SurfaceClass::Floor || IType == SurfaceClass::Roof) {
// Remove this surface from the space inside surface area and area*reflectivity
// The resulting areas are AP(ITILT). The resulting area*reflectivity is ARHP(ITILT).
// Initialize gross area of surface (including subsurfaces)
- ATWL = surf.Area; // This is the surface area less subsurfaces
+ Real64 ATWL = surf.Area; // This is the surface area less subsurfaces
// Area * reflectance for this surface, excluding attached windows and doors
- ARHTWL = surf.Area * state.dataConstruction->Construct(surf.Construction).ReflectVisDiffBack;
- // Tilt index
+ Real64 ARHTWL = surf.Area * state.dataConstruction->Construct(surf.Construction).ReflectVisDiffBack;
+
+ FWC fwc;
if (surf.Tilt > 45.0 && surf.Tilt < 135.0) {
- ITILT = 2; // Wall
+ fwc = FWC::Wall; // Wall
} else if (surf.Tilt >= 135.0) {
- ITILT = 1; // Floor
+ fwc = FWC::Floor; // Floor
} else {
- ITILT = 3; // Ceiling
+ fwc = FWC::Ceiling; // Ceiling
}
// Loop over windows and doors on this wall
for (int IWinDr : thisEnclosure.SurfacePtr) {
@@ -284,18 +277,21 @@ void DayltgAveInteriorReflectance(EnergyPlusData &state, int const enclNum) // E
(1.0 - state.dataSurface->SurfWinDividerSolAbsorp(IWinDr));
}
}
+
+ std::array AP;
+ std::array ARHP;
// Inside surface area of floor, walls and ceilings, minus surface ISurf and its subsurfaces
- for (int IT = 1; IT <= 3; ++IT) {
- if (IT == ITILT) {
- state.dataDaylightingManager->AP(IT) = state.dataDaylightingManager->AR(IT) - ATWL;
- state.dataDaylightingManager->ARHP(IT) = state.dataDaylightingManager->ARH(IT) - ARHTWL;
+ for (int iFWC = (int)FWC::Floor; iFWC < (int)FWC::Num; ++iFWC) {
+ if (iFWC == (int)fwc) {
+ AP[iFWC] = AR[iFWC] - ATWL;
+ ARHP[iFWC] = ARH[iFWC] - ARHTWL;
} else {
- state.dataDaylightingManager->AP(IT) = state.dataDaylightingManager->AR(IT);
- state.dataDaylightingManager->ARHP(IT) = state.dataDaylightingManager->ARH(IT);
+ AP[iFWC] = AR[iFWC];
+ ARHP[iFWC] = ARH[iFWC];
}
}
- state.dataSurface->SurfaceWindow(ISurf).EnclAreaMinusThisSurf = state.dataDaylightingManager->AP;
- state.dataSurface->SurfaceWindow(ISurf).EnclAreaReflProdMinusThisSurf = state.dataDaylightingManager->ARHP;
+ state.dataSurface->SurfaceWindow(ISurf).EnclAreaMinusThisSurf = AP;
+ state.dataSurface->SurfaceWindow(ISurf).EnclAreaReflProdMinusThisSurf = ARHP;
}
} // End of loop over opaque surfaces in enclosure
@@ -308,15 +304,15 @@ void DayltgAveInteriorReflectance(EnergyPlusData &state, int const enclNum) // E
min(1.0,
(state.dataSurface->SurfaceWindow(IWin).WinCenter.z - state.dataHeatBal->Zone(zoneNum).OriginZ) *
state.dataHeatBal->Zone(zoneNum).FloorArea / state.dataHeatBal->Zone(zoneNum).Volume));
- state.dataDaylightingManager->AP = state.dataSurface->SurfaceWindow(ISurf).EnclAreaMinusThisSurf;
- state.dataDaylightingManager->ARHP = state.dataSurface->SurfaceWindow(ISurf).EnclAreaReflProdMinusThisSurf;
+
+ std::array AP = state.dataSurface->SurfaceWindow(ISurf).EnclAreaMinusThisSurf;
+ std::array ARHP = state.dataSurface->SurfaceWindow(ISurf).EnclAreaReflProdMinusThisSurf;
// Average reflectance seen by light moving up (RhoCeilingWall) and down (RhoFloorWall)
// across horizontal plane through center of window
state.dataSurface->SurfWinRhoCeilingWall(IWin) =
- (state.dataDaylightingManager->ARHP(2) * (1.0 - ETA) + state.dataDaylightingManager->ARHP(3)) /
- (state.dataDaylightingManager->AP(2) * (1.0 - ETA) + state.dataDaylightingManager->AP(3) + 1.0e-5);
- state.dataSurface->SurfWinRhoFloorWall(IWin) = (state.dataDaylightingManager->ARHP(2) * ETA + state.dataDaylightingManager->ARHP(1)) /
- (state.dataDaylightingManager->AP(2) * ETA + state.dataDaylightingManager->AP(1) + 1.e-9);
+ (ARHP[(int)FWC::Wall] * (1.0 - ETA) + ARHP[(int)FWC::Ceiling]) / (AP[(int)FWC::Wall] * (1.0 - ETA) + AP[(int)FWC::Ceiling] + 1.0e-5);
+ state.dataSurface->SurfWinRhoFloorWall(IWin) =
+ (ARHP[(int)FWC::Wall] * ETA + ARHP[(int)FWC::Floor]) / (AP[(int)FWC::Wall] * ETA + AP[(int)FWC::Floor] + 1.e-9);
// Angle factor for windows with diffusing shades. SurfaceWindow(IWin)%FractionUpgoing is
// fraction of light from the shade that goes up toward ceiling and upper part of walls.
@@ -819,20 +815,20 @@ void CalcDayltgCoeffsRefPoints(EnergyPlusData &state, int const daylightCtrlNum)
Real64 TVISIntWin; // Visible transmittance of int win at COSBIntWin for light from ext win
Real64 TVISIntWinDisk; // Visible transmittance of int win at COSBIntWin for sun
- auto &W2 = state.dataDaylightingManager->W2;
- auto &W3 = state.dataDaylightingManager->W3;
- auto &W21 = state.dataDaylightingManager->W21;
- auto &W23 = state.dataDaylightingManager->W23;
- auto &RREF2 = state.dataDaylightingManager->RREF2;
- auto &RWIN = state.dataDaylightingManager->RWIN;
- auto &RWIN2 = state.dataDaylightingManager->RWIN2;
- auto &Ray = state.dataDaylightingManager->Ray;
- auto &WNORM2 = state.dataDaylightingManager->WNORM2;
- auto &VIEWVC = state.dataDaylightingManager->VIEWVC;
- auto &U2 = state.dataDaylightingManager->U2;
- auto &U21 = state.dataDaylightingManager->U21;
- auto &U23 = state.dataDaylightingManager->U23;
- auto &VIEWVC2 = state.dataDaylightingManager->VIEWVC2;
+ Vector3 W2;
+ Vector3 W3;
+ Vector3 W21;
+ Vector3 W23;
+ Vector3 RREF2;
+ Vector3 RWIN;
+ Vector3 RWIN2;
+ Vector3 Ray;
+ Vector3 WNORM2;
+ Vector3 VIEWVC;
+ Vector3 U2;
+ Vector3 U21;
+ Vector3 U23;
+ Vector3 VIEWVC2;
int WinEl; // Current window element
@@ -856,9 +852,14 @@ void CalcDayltgCoeffsRefPoints(EnergyPlusData &state, int const daylightCtrlNum)
thisDaylightControl.GlareIndexAtRefPt = 0.0; // Glare index at reference points
thisDaylightControl.SolidAngAtRefPt = 0.0;
thisDaylightControl.SolidAngAtRefPtWtd = 0.0;
- thisDaylightControl.IllumFromWinAtRefPt = 0.0;
- thisDaylightControl.BackLumFromWinAtRefPt = 0.0;
- thisDaylightControl.SourceLumFromWinAtRefPt = 0.0;
+
+ for (int iExtWin = 1; iExtWin <= thisDaylightControl.TotalExtWindows; ++iExtWin) {
+ for (int iRefPt = 1; iRefPt <= thisDaylightControl.TotalDaylRefPoints; ++iRefPt) {
+ thisDaylightControl.IllumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ thisDaylightControl.BackLumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ thisDaylightControl.SourceLumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ }
+ }
int iHrBeg = state.dataSysVars->DetailedSolarTimestepIntegration ? state.dataGlobal->HourOfDay : 1;
int iHrEnd = state.dataSysVars->DetailedSolarTimestepIntegration ? state.dataGlobal->HourOfDay : Constant::HoursInDay;
@@ -889,7 +890,7 @@ void CalcDayltgCoeffsRefPoints(EnergyPlusData &state, int const daylightCtrlNum)
for (int IL = 1; IL <= NRF; ++IL) {
// Reference point in absolute coordinate system
- state.dataDaylightingManager->RREF = thisDaylightControl.DaylRefPtAbsCoord({1, 3}, IL); // ( x, y, z )
+ Vector3 RREF = thisDaylightControl.DaylRefPtAbsCoord(IL); // ( x, y, z )
// -------------
// ---------- WINDOW LOOP ----------
@@ -901,7 +902,7 @@ void CalcDayltgCoeffsRefPoints(EnergyPlusData &state, int const daylightCtrlNum)
IL,
loopwin,
CalledFor::RefPoint,
- state.dataDaylightingManager->RREF,
+ RREF,
VIEWVC,
IWin,
IWin2,
@@ -960,7 +961,7 @@ void CalcDayltgCoeffsRefPoints(EnergyPlusData &state, int const daylightCtrlNum)
W2,
W21,
W23,
- state.dataDaylightingManager->RREF,
+ RREF,
NWYlim,
VIEWVC2,
DWX,
@@ -1181,20 +1182,20 @@ void CalcDayltgCoeffsMapPoints(EnergyPlusData &state, int const mapNum)
Real64 TVISIntWinDisk; // Visible transmittance of int win at COSBIntWin for sun
int WinEl; // window elements counter
- auto &W2 = state.dataDaylightingManager->W2;
- auto &W3 = state.dataDaylightingManager->W3;
- auto &W21 = state.dataDaylightingManager->W21;
- auto &W23 = state.dataDaylightingManager->W23;
- auto &RREF2 = state.dataDaylightingManager->RREF2;
- auto &RWIN = state.dataDaylightingManager->RWIN;
- auto &RWIN2 = state.dataDaylightingManager->RWIN2;
- auto &Ray = state.dataDaylightingManager->Ray;
- auto &WNORM2 = state.dataDaylightingManager->WNORM2;
- auto &VIEWVC = state.dataDaylightingManager->VIEWVC;
- auto &U2 = state.dataDaylightingManager->U2;
- auto &U21 = state.dataDaylightingManager->U21;
- auto &U23 = state.dataDaylightingManager->U23;
- auto &VIEWVC2 = state.dataDaylightingManager->VIEWVC2;
+ Vector3 W2;
+ Vector3 W3;
+ Vector3 W21;
+ Vector3 W23;
+ Vector3 RREF2;
+ Vector3 RWIN;
+ Vector3 RWIN2;
+ Vector3 Ray;
+ Vector3 WNORM2;
+ Vector3 VIEWVC;
+ Vector3 U2;
+ Vector3 U21;
+ Vector3 U23;
+ Vector3 VIEWVC2;
if (state.dataDaylightingManager->mapFirstTime && (int)state.dataDaylightingData->IllumMap.size() > 0) {
IL = -999;
@@ -1220,7 +1221,12 @@ void CalcDayltgCoeffsMapPoints(EnergyPlusData &state, int const mapNum)
int numExtWins = thisEnclDaylight.NumOfDayltgExtWins;
illumMapCalc.DaylIllumAtMapPt = 0.0; // Daylight illuminance at reference points (lux)
- illumMapCalc.IllumFromWinAtMapPt = 0.0;
+
+ for (int iExtWin = 1; iExtWin <= (int)illumMapCalc.IllumFromWinAtMapPt.size1(); ++iExtWin) {
+ for (int iRefPt = 1; iRefPt <= (int)illumMapCalc.IllumFromWinAtMapPt.size2(); ++iRefPt) {
+ illumMapCalc.IllumFromWinAtMapPt(iExtWin, iRefPt) = {0.0, 0.0};
+ }
+ }
int iHrBeg = state.dataSysVars->DetailedSolarTimestepIntegration ? state.dataGlobal->HourOfDay : 1;
int iHrEnd = state.dataSysVars->DetailedSolarTimestepIntegration ? state.dataGlobal->HourOfDay : Constant::HoursInDay;
@@ -1239,7 +1245,7 @@ void CalcDayltgCoeffsMapPoints(EnergyPlusData &state, int const mapNum)
for (int IL = 1; IL <= numRefPts; ++IL) {
- state.dataDaylightingManager->RREF = illumMapCalc.MapRefPtAbsCoord({1, 3}, IL); // (x, y, z)
+ Vector3 RREF = illumMapCalc.MapRefPtAbsCoord(IL); // (x, y, z)
// -------------
// ---------- WINDOW LOOP ----------
@@ -1253,7 +1259,7 @@ void CalcDayltgCoeffsMapPoints(EnergyPlusData &state, int const mapNum)
IL,
loopwin,
CalledFor::MapPoint,
- state.dataDaylightingManager->RREF,
+ RREF,
VIEWVC,
IWin,
IWin2,
@@ -1313,7 +1319,7 @@ void CalcDayltgCoeffsMapPoints(EnergyPlusData &state, int const mapNum)
W2,
W21,
W23,
- state.dataDaylightingManager->RREF,
+ RREF,
NWYlim,
VIEWVC2,
DWX,
@@ -1526,6 +1532,9 @@ void FigureDayltgCoeffsAtPointsSetupForWindow(EnergyPlusData &state,
int zoneNum = 0; // zone number
int enclNum = 0; // enclosure number
+ Vector3 W1 = {0.0, 0.0, 0.0};
+ Vector3 WC = {0.0, 0.0, 0.0};
+
if (CalledFrom == CalledFor::RefPoint) {
state.dataDaylightingData->daylightControl(daylightCtrlNum).SolidAngAtRefPt(loopwin, iRefPoint) = 0.0;
state.dataDaylightingData->daylightControl(daylightCtrlNum).SolidAngAtRefPtWtd(loopwin, iRefPoint) = 0.0;
@@ -1583,11 +1592,11 @@ void FigureDayltgCoeffsAtPointsSetupForWindow(EnergyPlusData &state,
// upper left as viewed from outside.
W3 = state.dataSurface->Surface(IWin).Vertex(2);
W2 = state.dataSurface->Surface(IWin).Vertex(3);
- state.dataDaylightingManager->W1 = state.dataSurface->Surface(IWin).Vertex(4);
+ W1 = state.dataSurface->Surface(IWin).Vertex(4);
} else if (is_Triangle) {
W3 = state.dataSurface->Surface(IWin).Vertex(2);
W2 = state.dataSurface->Surface(IWin).Vertex(3);
- state.dataDaylightingManager->W1 = state.dataSurface->Surface(IWin).Vertex(1);
+ W1 = state.dataSurface->Surface(IWin).Vertex(1);
}
// Shade/blind calculation flag
@@ -1610,39 +1619,39 @@ void FigureDayltgCoeffsAtPointsSetupForWindow(EnergyPlusData &state,
// Unit vectors from window vertex 2 to 1 and 2 to 3,
// center point of window, and vector from ref pt to center of window
- W21 = state.dataDaylightingManager->W1 - W2;
+ W21 = W1 - W2;
W23 = W3 - W2;
HW = W21.magnitude();
WW = W23.magnitude();
if (is_Rectangle) {
- state.dataDaylightingManager->WC = W2 + (W23 + W21) / 2.0;
+ WC = W2 + (W23 + W21) / 2.0;
} else if (is_Triangle) {
- state.dataDaylightingManager->WC = W2 + (W23 + W21) / 3.0;
+ WC = W2 + (W23 + W21) / 3.0;
}
- state.dataSurface->SurfaceWindow(IWin).WinCenter = state.dataDaylightingManager->WC;
- state.dataDaylightingManager->REFWC = state.dataDaylightingManager->WC - RREF;
+ state.dataSurface->SurfaceWindow(IWin).WinCenter = WC;
+ Vector3 REFWC = WC - RREF;
// Unit vectors
W21 /= HW;
W23 /= WW;
// Unit vector normal to window (pointing away from room)
- state.dataDaylightingManager->WNORM = state.dataSurface->Surface(IWin).lcsz;
+ Vector3 WNORM = state.dataSurface->Surface(IWin).lcsz;
// Initialize number of window elements
NDIVX = 40;
NDIVY = 40;
// Distance from ref point to window plane
- ALF = std::abs(dot(state.dataDaylightingManager->WNORM, state.dataDaylightingManager->REFWC));
+ ALF = std::abs(dot(WNORM, REFWC));
if (CalledFrom == CalledFor::RefPoint) {
// Check if ref point to close to window due to input error (0.1524 m below is 0.5 ft)
if (ALF < 0.1524 && extWinType == ExtWinType::InZone) {
// Ref pt is close to window plane. Get vector from window
// origin to projection of ref pt on window plane.
- state.dataDaylightingManager->W2REF = RREF + ALF * state.dataDaylightingManager->WNORM - W2;
+ Vector3 W2REF = RREF + ALF * WNORM - W2;
- D1a = dot(state.dataDaylightingManager->W2REF, W23);
- D1b = dot(state.dataDaylightingManager->W2REF, W21);
+ D1a = dot(W2REF, W23);
+ D1b = dot(W2REF, W21);
// ! Error message if ref pt is too close to window.
if (D1a > 0.0 && D1b > 0.0 && D1b <= HW && D1a <= WW) {
@@ -1721,9 +1730,9 @@ void FigureDayltgCoeffsAtPointsSetupForWindow(EnergyPlusData &state,
DWY = HW / NWY;
// Azimuth and altitude of window normal
- state.dataSurface->SurfWinPhi(IWin) = std::asin(state.dataDaylightingManager->WNORM.z);
- if (std::abs(state.dataDaylightingManager->WNORM.x) > 1.0e-5 || std::abs(state.dataDaylightingManager->WNORM.y) > 1.0e-5) {
- state.dataSurface->SurfWinTheta(IWin) = std::atan2(state.dataDaylightingManager->WNORM.y, state.dataDaylightingManager->WNORM.x);
+ state.dataSurface->SurfWinPhi(IWin) = std::asin(WNORM.z);
+ if (std::abs(WNORM.x) > 1.0e-5 || std::abs(WNORM.y) > 1.0e-5) {
+ state.dataSurface->SurfWinTheta(IWin) = std::atan2(WNORM.y, WNORM.x);
} else {
state.dataSurface->SurfWinTheta(IWin) = 0.0;
}
@@ -1739,42 +1748,41 @@ void FigureDayltgCoeffsAtPointsSetupForWindow(EnergyPlusData &state,
// Calculate reference point coords relative to the diffuser coordinate system
// W21, W23, and WNORM are the unit vectors
- state.dataDaylightingManager->REFD.x = dot(state.dataDaylightingManager->REFWC, W21);
- state.dataDaylightingManager->REFD.y = dot(state.dataDaylightingManager->REFWC, W23);
- state.dataDaylightingManager->REFD.z = dot(state.dataDaylightingManager->REFWC, state.dataDaylightingManager->WNORM);
+ Vector3 REFD = {dot(REFWC, W21), dot(REFWC, W23), dot(REFWC, WNORM)};
// Calculate view vector coords relative to the diffuser coordinate system
- state.dataDaylightingManager->VIEWVD = {dot(VIEWVC, W21), dot(VIEWVC, W23), dot(VIEWVC, state.dataDaylightingManager->WNORM)};
+ Vector3 VIEWVD = {dot(VIEWVC, W21), dot(VIEWVC, W23), dot(VIEWVC, WNORM)};
- state.dataDaylightingManager->U3 = surf2.Vertex(2);
+ Vector3 U3 = surf2.Vertex(2);
U2 = surf2.Vertex(3);
+ Vector3 U1;
if (surf2.Sides == 4) {
// Vertices of window (numbered counter-clockwise starting
// at upper left as viewed from inside of room)
// Assumes original vertices are numbered counter-clockwise from
// upper left as viewed from outside.
- state.dataDaylightingManager->U3 = surf2.Vertex(2);
+ U3 = surf2.Vertex(2);
U2 = surf2.Vertex(3);
- state.dataDaylightingManager->U1 = surf2.Vertex(4);
+ U1 = surf2.Vertex(4);
} else if (surf2.Sides == 3) {
- state.dataDaylightingManager->U3 = surf2.Vertex(2);
+ U3 = surf2.Vertex(2);
U2 = surf2.Vertex(3);
- state.dataDaylightingManager->U1 = surf2.Vertex(1);
+ U1 = surf2.Vertex(1);
}
// Unit vectors from window vertex 2 to 1 and 2 to 3,
// center point of window, and vector from ref pt to center of window
- U21 = state.dataDaylightingManager->U1 - U2;
- U23 = state.dataDaylightingManager->U3 - U2;
+ U21 = U1 - U2;
+ U23 = U3 - U2;
HW = U21.magnitude();
WW = U23.magnitude();
if (surf2.Sides == 4) {
- state.dataDaylightingManager->WC = U2 + (U23 + U21) / 2.0;
+ WC = U2 + (U23 + U21) / 2.0;
} else if (surf2.Sides == 3) {
- state.dataDaylightingManager->WC = U2 + (U23 + U21) / 3.0;
+ WC = U2 + (U23 + U21) / 3.0;
}
- state.dataSurface->SurfaceWindow(IWin2).WinCenter = state.dataDaylightingManager->WC;
+ state.dataSurface->SurfaceWindow(IWin2).WinCenter = WC;
// Unit vectors
U21 /= HW;
U23 /= WW;
@@ -1795,13 +1803,11 @@ void FigureDayltgCoeffsAtPointsSetupForWindow(EnergyPlusData &state,
// Calculate new virtual reference point coords relative to dome coord system
// W21, W23, and WNORM2 are now the unit vectors for the dome coord system
- state.dataDaylightingManager->REFWC =
- state.dataDaylightingManager->REFD.x * U21 + state.dataDaylightingManager->REFD.y * U23 + state.dataDaylightingManager->REFD.z * WNORM2;
- RREF2 = state.dataDaylightingManager->WC - state.dataDaylightingManager->REFWC;
+ REFWC = REFD.x * U21 + REFD.y * U23 + REFD.z * WNORM2;
+ RREF2 = WC - REFWC;
// Calculate new virtual view vector coords relative to dome coord system
- VIEWVC2 = state.dataDaylightingManager->VIEWVD.x * U21 + state.dataDaylightingManager->VIEWVD.y * U23 +
- state.dataDaylightingManager->VIEWVD.z * WNORM2;
+ VIEWVC2 = VIEWVD.x * U21 + VIEWVD.y * U23 + VIEWVD.z * WNORM2;
// Copy several values from the diffuser so that DayltgInterReflectedIllum works correctly
// These are specific to the interior.
@@ -1813,7 +1819,7 @@ void FigureDayltgCoeffsAtPointsSetupForWindow(EnergyPlusData &state,
} else {
// This is not a TDD:DIFFUSER. Make sure nothing is messed up for a regular window.
IWin2 = IWin;
- WNORM2 = state.dataDaylightingManager->WNORM;
+ WNORM2 = WNORM;
RREF2 = RREF;
VIEWVC2 = VIEWVC;
@@ -2011,6 +2017,8 @@ void FigureDayltgCoeffsAtPointsForWindowElements(
TVISIntWinDisk = 0.0; // Init Value
TVISIntWin = 0.0;
+ Vector3 HitPtIntWin = {0.0, 0.0, 0.0};
+
if (state.dataSurface->SurfWinOriginalClass(IWin) == SurfaceClass::TDD_Diffuser) {
// Look up the TDD:DOME object
int PipeNum = state.dataSurface->SurfWinTDDPipeNum(IWin);
@@ -2044,7 +2052,8 @@ void FigureDayltgCoeffsAtPointsForWindowElements(
1) { // in develop this was Surface(IntWin).Class == SurfaceClass::Window && Surface(IntWin).ExtBoundCond >= 1
if (state.dataSurface->Surface(state.dataSurface->Surface(IntWin).ExtBoundCond).Zone ==
state.dataSurface->Surface(IWin).Zone) {
- PierceSurface(state, IntWin, RREF, Ray, state.dataDaylightingManager->HitPtIntWin, hitIntWin);
+
+ PierceSurface(state, IntWin, RREF, Ray, HitPtIntWin, hitIntWin);
if (hitIntWin) {
IntWinHitNum = IntWin;
COSBIntWin = dot(state.dataSurface->Surface(IntWin).OutNormVec, Ray);
@@ -2083,10 +2092,10 @@ void FigureDayltgCoeffsAtPointsForWindowElements(
if (extWinType == ExtWinType::AdjZone && IntWinHitNum > 0 && !hitIntObs) {
// Check for obstruction between ref point and interior window through which ray passes
- DayltgHitInteriorObstruction(state, IntWinHitNum, RREF, state.dataDaylightingManager->HitPtIntWin, hitIntObs);
+ DayltgHitInteriorObstruction(state, IntWinHitNum, RREF, HitPtIntWin, hitIntObs);
if (!hitIntObs) {
// Check for obstruction between intersection point on int window and ext win element
- DayltgHitBetWinObstruction(state, IntWinHitNum, IWin, state.dataDaylightingManager->HitPtIntWin, RWIN, hitIntObs);
+ DayltgHitBetWinObstruction(state, IntWinHitNum, IWin, HitPtIntWin, RWIN, hitIntObs);
}
}
if (CalledFrom == CalledFor::RefPoint) {
@@ -2138,9 +2147,9 @@ void FigureDayltgCoeffsAtPointsForWindowElements(
.IlluminanceMap(iRefPoint, MapNum)
.RefSurfIndex(ICplxFen, WinEl);
}
- state.dataDaylightingManager->RayVector = state.dataBSDFWindow->ComplexWind(IWin).Geom(CplxFenState).sInc(RayIndex);
+ Vector3 RayVector = state.dataBSDFWindow->ComplexWind(IWin).Geom(CplxFenState).sInc(RayIndex);
// It will get product of all transmittances
- DayltgHitObstruction(state, state.dataGlobal->HourOfDay, IWin, RWIN, state.dataDaylightingManager->RayVector, TransBeam);
+ DayltgHitObstruction(state, state.dataGlobal->HourOfDay, IWin, RWIN, RayVector, TransBeam);
// IF (TransBeam > 0.0d0) ObTrans = TransBeam
if (CalledFrom == CalledFor::RefPoint) {
state.dataBSDFWindow->ComplexWind(IWin).DaylghtGeom(CplxFenState).RefPoint(iRefPoint).TransOutSurf(ICplxFen, WinEl) =
@@ -2166,11 +2175,9 @@ void FigureDayltgCoeffsAtPointsForWindowElements(
Alfa = std::acos(-Ray.z);
Beta = std::atan2(Ray.y, Ray.x);
HorDis = (RWIN2.z - state.dataSurface->GroundLevelZ) * std::tan(Alfa);
- state.dataDaylightingManager->GroundHitPt = {
- RWIN2.x + HorDis * std::cos(Beta), RWIN2.y + HorDis * std::sin(Beta), state.dataSurface->GroundLevelZ};
+ Vector3 GroundHitPt = {RWIN2.x + HorDis * std::cos(Beta), RWIN2.y + HorDis * std::sin(Beta), state.dataSurface->GroundLevelZ};
- SkyObstructionMult = CalcObstrMultiplier(
- state, state.dataDaylightingManager->GroundHitPt, AltAngStepsForSolReflCalc, DataSurfaces::AzimAngStepsForSolReflCalc);
+ SkyObstructionMult = CalcObstrMultiplier(state, GroundHitPt, AltAngStepsForSolReflCalc, DataSurfaces::AzimAngStepsForSolReflCalc);
} // End of check if solar reflection calculation is in effect
} // End of check if COSB > 0
@@ -2201,12 +2208,12 @@ void InitializeCFSDaylighting(EnergyPlusData &state,
Real64 DWY; // Window element height
Real64 WinElArea; // Window element area
- auto &W1 = state.dataDaylightingManager->W1;
- auto &W2 = state.dataDaylightingManager->W2;
- auto &W3 = state.dataDaylightingManager->W3;
- auto &W21 = state.dataDaylightingManager->W21;
- auto &W23 = state.dataDaylightingManager->W23;
- auto &WNorm = state.dataDaylightingManager->WNorm; // unit vector from window (point towards outside)
+ Vector3 W1;
+ Vector3 W2;
+ Vector3 W3;
+ Vector3 W21;
+ Vector3 W23;
+ Vector3 WNorm;
// Position factor variables
Real64 AZVIEW; // Azimuth of view vector
@@ -2392,9 +2399,9 @@ void InitializeCFSStateData(EnergyPlusData &state,
Real64 TransRSurf;
int J;
- auto &RWin = state.dataDaylightingManager->RWin;
- auto &V = state.dataDaylightingManager->V;
- auto &GroundHitPt = state.dataDaylightingManager->GroundHitPt;
+ Vector3 RWin;
+ Vector3 V;
+ Vector3 GroundHitPt;
// temporary arrays for surfaces
// Each complex fenestration state can have different number of basis elements
@@ -2408,10 +2415,10 @@ void InitializeCFSStateData(EnergyPlusData &state,
Array2D TmpHSurfDSq(state.dataSurface->TotSurfaces, NBasis, 0.0); // Temporary HitSurfDSq
// Object Data
- Vector Centroid; // current window element centroid
- Vector HitPt; // surface hit point
- Array1D TmpGndPt(NBasis, Vector(0.0, 0.0, 0.0)); // Temporary ground intersection list
- Array2D TmpHitPt(state.dataSurface->TotSurfaces, NBasis, Vector(0.0, 0.0, 0.0)); // Temporary HitPt
+ Vector3 Centroid; // current window element centroid
+ Vector3 HitPt; // surface hit point
+ Array1D> TmpGndPt(NBasis, Vector3(0.0, 0.0, 0.0)); // Temporary ground intersection list
+ Array2D> TmpHitPt(state.dataSurface->TotSurfaces, NBasis, Vector3(0.0, 0.0, 0.0)); // Temporary HitPt
CFSRefPointPosFactor(state, RefPoint, StateRefPoint, iWin, CurFenState, NTrnBasis, AZVIEW);
@@ -2707,22 +2714,14 @@ void CFSRefPointSolidAngle(EnergyPlusData &state,
// PURPOSE OF THIS SUBROUTINE:
// Calculate position factor for given reference point.
- // SUBROUTINE LOCAL VARIABLES
- auto &Ray = state.dataDaylightingManager->Ray;
- auto &RayNorm = state.dataDaylightingManager->RayNorm;
- Real64 BestMatch;
- Real64 temp;
- Real64 Dist;
- Real64 CosB;
-
// calculate vector from center of window element to the current reference point
- Ray = RefPoint - RWin;
+ Vector3 Ray = RefPoint - RWin;
// figure out outgoing beam direction from current reference point
- BestMatch = 0.0;
+ Real64 BestMatch = 0.0;
for (int iTrnRay = 1; iTrnRay <= NTrnBasis; ++iTrnRay) {
- state.dataDaylightingManager->V = state.dataBSDFWindow->ComplexWind(iWin).Geom(CurFenState).sTrn(iTrnRay);
- temp = dot(Ray, state.dataDaylightingManager->V);
+ Vector3 const &V = state.dataBSDFWindow->ComplexWind(iWin).Geom(CurFenState).sTrn(iTrnRay);
+ Real64 temp = dot(Ray, V);
if (temp > BestMatch) {
BestMatch = temp;
RefPointMap.RefPointIndex(curWinEl) = iTrnRay;
@@ -2730,10 +2729,10 @@ void CFSRefPointSolidAngle(EnergyPlusData &state,
}
// calculate solid view angle
- Dist = Ray.magnitude();
- RayNorm = Ray / (-Dist);
+ Real64 Dist = Ray.magnitude();
+ Vector3 RayNorm = Ray / (-Dist);
RefPointGeomMap.SolidAngleVec(curWinEl) = RayNorm;
- CosB = dot(WNorm, RayNorm);
+ Real64 CosB = dot(WNorm, RayNorm);
RefPointGeomMap.SolidAngle(curWinEl) = WinElArea * CosB / (Dist * Dist);
}
@@ -2762,13 +2761,16 @@ void CFSRefPointPosFactor(EnergyPlusData &state,
auto const &sTrn = state.dataBSDFWindow->ComplexWind(iWin).Geom(CurFenState).sTrn;
for (int iTrnRay = 1; iTrnRay <= NTrnBasis; ++iTrnRay) {
- state.dataDaylightingManager->V = sTrn(iTrnRay);
- state.dataDaylightingManager->V.negate();
- PierceSurface(state, iWin, RefPoint, state.dataDaylightingManager->V, state.dataDaylightingManager->InterPoint, hit);
+ Vector3 V = sTrn(iTrnRay);
+ V.negate();
+
+ Vector3 InterPoint;
+
+ PierceSurface(state, iWin, RefPoint, V, InterPoint, hit);
if (hit) {
RefPointMap.RefPointIntersection(iTrnRay) = true;
- elPos = WindowComplexManager::DaylghtAltAndAzimuth(state.dataDaylightingManager->V);
+ elPos = WindowComplexManager::DaylghtAltAndAzimuth(V);
XR = std::tan(std::abs(Constant::PiOvr2 - AZVIEW - elPos.Azimuth) + 0.001);
YR = std::tan(elPos.Altitude + 0.001);
@@ -2811,14 +2813,13 @@ Real64 CalcObstrMultiplier(EnergyPlusData &state,
Real64 CPhi; // cos of Phi
Real64 Theta; // Azimuth angle of ray from a ground point (radians)
- Real64 CosIncAngURay; // Cosine of incidence angle of URay on ground plane
- Real64 dOmegaGnd; // Solid angle element of ray from ground point (steradians)
- Real64 IncAngSolidAngFac; // CosIncAngURay*dOmegaGnd/Pi
- bool hitObs; // True iff obstruction is hit
- auto &URay = state.dataDaylightingManager->URay; // Unit vector in (Phi,Theta) direction
- auto &ObsHitPt = state.dataDaylightingManager->ObsHitPt; // Unit vector in (Phi,Theta) direction
- auto &AltSteps_last = state.dataDaylightingManager->AltSteps_last; // Unit vector in (Phi,Theta) direction
- auto &AzimSteps_last = state.dataDaylightingManager->AzimSteps_last;
+ Real64 CosIncAngURay; // Cosine of incidence angle of URay on ground plane
+ Real64 dOmegaGnd; // Solid angle element of ray from ground point (steradians)
+ Real64 IncAngSolidAngFac; // CosIncAngURay*dOmegaGnd/Pi
+ bool hitObs; // True iff obstruction is hit
+
+ Vector3 URay; // Unit vector in (Phi,Theta) direction
+ Vector3 ObsHitPt; // Unit vector in (Phi,Theta) direction
assert(AzimSteps <= DataSurfaces::AzimAngStepsForSolReflCalc);
@@ -2828,22 +2829,22 @@ Real64 CalcObstrMultiplier(EnergyPlusData &state,
SkyGndUnObs = 0.0;
// Tuned Precompute Phi trig table
- if (AltSteps != AltSteps_last) {
+ if (AltSteps != state.dataDaylightingManager->AltSteps_last) {
for (int IPhi = 1, IPhi_end = (AltSteps / 2); IPhi <= IPhi_end; ++IPhi) {
Phi = (IPhi - 0.5) * DPhi;
state.dataDaylightingManager->cos_Phi(IPhi) = std::cos(Phi);
state.dataDaylightingManager->sin_Phi(IPhi) = std::sin(Phi);
}
- AltSteps_last = AltSteps;
+ state.dataDaylightingManager->AltSteps_last = AltSteps;
}
// Tuned Precompute Theta trig table
- if (AzimSteps != AzimSteps_last) {
+ if (AzimSteps != state.dataDaylightingManager->AzimSteps_last) {
for (int ITheta = 1; ITheta <= 2 * AzimSteps; ++ITheta) {
Theta = (ITheta - 0.5) * DTheta;
state.dataDaylightingManager->cos_Theta(ITheta) = std::cos(Theta);
state.dataDaylightingManager->sin_Theta(ITheta) = std::sin(Theta);
}
- AzimSteps_last = AzimSteps;
+ state.dataDaylightingManager->AzimSteps_last = AzimSteps;
}
// Altitude loop
@@ -2958,14 +2959,12 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
if (state.dataSurface->SurfSunCosHourly(iHour).z < DataEnvironment::SunIsUpValue) return;
// SUBROUTINE LOCAL VARIABLE DECLARATIONS:
- static Vector3 const RREF(0.0); // Location of a reference point in absolute coordinate system //Autodesk Was used uninitialized:
+ static const Vector3 RREF(0.0); // Location of a reference point in absolute coordinate system //Autodesk Was used uninitialized:
// Never set here // Made static for performance and const for now until issue addressed
- auto &XEDIRSK = state.dataDaylightingManager->XEDIRSK;
- auto &XAVWLSK = state.dataDaylightingManager->XAVWLSK;
- Real64 ProfAng; // Solar profile angle on a window (radians)
- Real64 POSFAC; // Position factor for a window element / ref point / view vector combination
- Real64 XR; // Horizontal displacement ratio
- Real64 YR; // Vertical displacement ratio
+ Real64 ProfAng; // Solar profile angle on a window (radians)
+ Real64 POSFAC; // Position factor for a window element / ref point / view vector combination
+ Real64 XR; // Horizontal displacement ratio
+ Real64 YR; // Vertical displacement ratio
Real64 ObTransDisk; // Product of solar transmittances of exterior obstructions hit by ray from reference point to sun
Real64 LumAtHitPtFrSun; // Luminance at hit point of obstruction by reflection of direct light from sun (cd/m2)
@@ -3045,9 +3044,9 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
if (COSB <= 0.0) return;
- XEDIRSK = Illums();
+ Illums XEDIRSK;
// XEDIRSU = 0.0; //Unused Set but never used
- XAVWLSK = Illums();
+ Illums XAVWLSK;
Real64 const Ray_3 = Ray.z;
Real64 const DOMEGA_Ray_3 = DOMEGA * Ray_3;
@@ -3067,8 +3066,8 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
// In the following hitIntObs == false ==> no interior obstructions hit, and
// hitExtObs == true ==> one or more exterior obstructions hit.
if (state.dataSurface->CalcSolRefl && !hitIntObs && hitExtObs) {
- int NearestHitSurfNum; // Surface number of nearest obstruction
- auto &NearestHitPt = state.dataDaylightingManager->NearestHitPt; // Hit point of ray on nearest obstruction
+ int NearestHitSurfNum; // Surface number of nearest obstruction
+ Vector3 NearestHitPt; // Hit point of ray on nearest obstruction
// One or more exterior obstructions was hit; get contribution of reflection
// from nearest obstruction.
// Find obstruction whose hit point is closest to this ray's window element
@@ -3158,8 +3157,8 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
state.dataDaylightingManager->AVWLSUdisk(iHour, 1) += state.dataDaylightingManager->WLUMSUdisk(iHour, 1);
if (PHRAY > 0.0) state.dataDaylightingManager->EDIRSU(iHour, 1) += state.dataDaylightingManager->WLUMSU(iHour, 1) * DOMEGA_Ray_3;
- } else { // Bare window
- auto &GroundHitPt = state.dataDaylightingManager->GroundHitPt; // Coordinates of point that ray hits ground (m)
+ } else { // Bare window
+ Vector3 GroundHitPt; // Coordinates of point that ray hits ground (m)
// Tuned Hoisted operations out of loop and linear indexing
if (state.dataSurface->CalcSolRefl) { // Coordinates of ground point hit by the ray
Alfa = std::acos(-Ray_3);
@@ -3213,7 +3212,7 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
if (state.dataSurface->CalcSolRefl) { // Coordinates of ground point hit by the ray
// Sun reaches ground point if vector from this point to the sun is unobstructed
hitObs = false;
- auto &ObsHitPt = state.dataDaylightingManager->ObsHitPt; // Coordinates of hit point on an obstruction (m)
+ Vector3 ObsHitPt; // Coordinates of hit point on an obstruction (m)
for (int ObsSurfNum : state.dataSurface->AllShadowPossObstrSurfaceList) {
PierceSurface(state, ObsSurfNum, GroundHitPt, SUNCOS_iHour, ObsHitPt, hitObs);
if (hitObs) break;
@@ -3230,11 +3229,11 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
// Illuminance from beam solar (without interior reflection)
// Just run this once on the last pass
if (iXelement == NWX && iYelement == NWY) { // Last pass
- auto &RAYCOS = state.dataDaylightingManager->RAYCOS;
// Beam solar reaching reference point directly without exterior reflection
// Unit vector from ref. pt. to sun
+ Vector3 RAYCOS;
RAYCOS.x = state.dataDaylightingManager->CPHSUN * std::cos(state.dataDaylightingManager->THSUN);
RAYCOS.y = state.dataDaylightingManager->CPHSUN * std::sin(state.dataDaylightingManager->THSUN);
RAYCOS.z = state.dataDaylightingManager->SPHSUN;
@@ -3243,7 +3242,7 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
COSI = dot(WNORM2, RAYCOS);
bool hit; // True if ray from ref point thru window element hits an obstruction
bool hitWin; // True if ray passes thru window
- auto &HP = state.dataDaylightingManager->HP;
+ Vector3 HP;
if (COSI > 0.0) {
// Does RAYCOS pass thru exterior window? HP is point that RAYCOS intersects window plane.
@@ -3265,7 +3264,7 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
// Surface number of int window intersected by ray betw ref pt and sun
int IntWinDiskHitNum;
// Intersection point on an interior window for ray from ref pt to sun (m)
- auto &HitPtIntWinDisk = state.dataDaylightingManager->HitPtIntWinDisk;
+ Vector3 HitPtIntWinDisk;
auto const &thisZone = state.dataHeatBal->Zone(zoneNum);
for (int const spaceNum : thisZone.spaceIndexes) {
auto const &thisSpace = state.dataHeatBal->space(spaceNum);
@@ -3352,8 +3351,8 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
state.dataDaylightingManager->EDIRSUdisk(iHour, 1) = RAYCOS.z * TVISS * ObTransDisk; // Bare window
- auto &TransBmBmMult = state.dataDaylightingManager->TransBmBmMult;
- TransBmBmMult = 0.0;
+ std::array transBmBmMult;
+ std::fill(transBmBmMult.begin(), transBmBmMult.end(), 0.0);
if (ANY_BLIND(ShType)) {
ProfileAngle(state, IWin, RAYCOS, state.dataMaterial->Blind(BlNum).SlatOrientation, ProfAng);
// Contribution of beam passing through slats and reaching reference point
@@ -3364,12 +3363,12 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
} else {
SlatAng = state.dataMaterial->Blind(BlNum).SlatAngle * Constant::DegToRadians;
}
- TransBmBmMult(JB) = WindowManager::BlindBeamBeamTrans(ProfAng,
+ transBmBmMult[JB] = WindowManager::BlindBeamBeamTrans(ProfAng,
SlatAng,
state.dataMaterial->Blind(BlNum).SlatWidth,
state.dataMaterial->Blind(BlNum).SlatSeparation,
state.dataMaterial->Blind(BlNum).SlatThickness);
- state.dataDaylightingManager->EDIRSUdisk(iHour, JB + 1) = RAYCOS.z * TVISS * TransBmBmMult(JB) * ObTransDisk;
+ state.dataDaylightingManager->EDIRSUdisk(iHour, JB + 1) = RAYCOS.z * TVISS * transBmBmMult[JB] * ObTransDisk;
// do this only once for fixed slat blinds
if (!state.dataSurface->SurfWinMovableSlats(IWin)) break;
@@ -3382,8 +3381,8 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
IWin,
(state.dataDaylightingManager->PHSUN - state.dataSurface->SurfWinPhi(IWin)),
(state.dataDaylightingManager->THSUN - state.dataSurface->SurfWinTheta(IWin)));
- TransBmBmMult(1) = state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).BmBmTrans;
- state.dataDaylightingManager->EDIRSUdisk(iHour, 2) = RAYCOS.z * TVISS * TransBmBmMult(1) * ObTransDisk;
+ transBmBmMult[1] = state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).BmBmTrans;
+ state.dataDaylightingManager->EDIRSUdisk(iHour, 2) = RAYCOS.z * TVISS * transBmBmMult[1] * ObTransDisk;
}
if (CalledFrom == CalledFor::RefPoint) {
@@ -3410,11 +3409,11 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
if (ANY_BLIND(ShType)) {
for (int JB = 1; JB <= Material::MaxSlatAngs; ++JB) {
// IF (.NOT. SurfaceWindow(IWin)%MovableSlats .AND. JB > 1) EXIT
- state.dataDaylightingManager->AVWLSUdisk(iHour, JB + 1) = XAVWL * TVISS * TransBmBmMult(JB) * ObTransDisk;
+ state.dataDaylightingManager->AVWLSUdisk(iHour, JB + 1) = XAVWL * TVISS * transBmBmMult[JB] * ObTransDisk;
if (!state.dataSurface->SurfWinMovableSlats(IWin)) break;
}
} else if (ShType == WinShadingType::ExtScreen) {
- state.dataDaylightingManager->AVWLSUdisk(iHour, 2) = XAVWL * TVISS * TransBmBmMult(1) * ObTransDisk;
+ state.dataDaylightingManager->AVWLSUdisk(iHour, 2) = XAVWL * TVISS * transBmBmMult[1] * ObTransDisk;
}
} // Position Factor
}
@@ -3430,11 +3429,11 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
int RecSurfNum = state.dataSurface->SurfShadowRecSurfNum(IWin2);
if (RecSurfNum > 0) { // interior windows do not apply
if (state.dataSolarReflectionManager->SolReflRecSurf(RecSurfNum).NumPossibleObs > 0) {
- bool hitRefl; // True iff ray hits reflecting surface
- auto &HitPtRefl = state.dataDaylightingManager->HitPtRefl; // Point that ray hits reflecting surface
- auto &SunVecMir = state.dataDaylightingManager->SunVecMir; // Sun ray mirrored in reflecting surface
- auto &ReflNorm = state.dataDaylightingManager->ReflNorm; // Normal vector to reflecting surface
- auto &TransBmBmMultRefl = state.dataDaylightingManager->TransBmBmMultRefl;
+ bool hitRefl; // True iff ray hits reflecting surface
+ Vector3 HitPtRefl; // Point that ray hits reflecting surface
+ Vector3 SunVecMir; // Sun ray mirrored in reflecting surface
+ Vector3 ReflNorm; // Normal vector to reflecting surface
+ Vector3 TransBmBmMultRefl;
// This window has associated obstructions that could reflect beam onto the window
for (int loop = 1, loop_end = state.dataSolarReflectionManager->SolReflRecSurf(RecSurfNum).NumPossibleObs; loop <= loop_end;
++loop) {
@@ -3472,7 +3471,7 @@ void FigureDayltgCoeffsAtPointsForSunPosition(
ReflDistance = std::sqrt(ReflDistanceSq);
// Is ray from ref. pt. to reflection point (HitPtRefl) obstructed?
bool hitObsRefl = false;
- auto &HitPtObs = state.dataDaylightingManager->HitPtObs; // Hit point on obstruction
+ Vector3 HitPtObs; // Hit point on obstruction
for (int loop2 = 1, loop2_end = state.dataSolarReflectionManager->SolReflRecSurf(RecSurfNum).NumPossibleObs;
loop2 <= loop2_end;
++loop2) {
@@ -3898,12 +3897,12 @@ void GetDaylightingParametersInput(EnergyPlusData &state)
surfWin.SolidAngAtRefPt = 0.0;
surfWin.SolidAngAtRefPtWtd.allocate(numEnclRefPoints);
surfWin.SolidAngAtRefPtWtd = 0.0;
- surfWin.IllumFromWinAtRefPt.allocate(2, numEnclRefPoints);
- surfWin.IllumFromWinAtRefPt = 0.0;
- surfWin.BackLumFromWinAtRefPt.allocate(2, numEnclRefPoints);
- surfWin.BackLumFromWinAtRefPt = 0.0;
- surfWin.SourceLumFromWinAtRefPt.allocate(2, numEnclRefPoints);
- surfWin.SourceLumFromWinAtRefPt = 0.0;
+ surfWin.IllumFromWinAtRefPt.allocate(numEnclRefPoints);
+ surfWin.IllumFromWinAtRefPt = {0.0, 0.0};
+ surfWin.BackLumFromWinAtRefPt.allocate(numEnclRefPoints);
+ surfWin.BackLumFromWinAtRefPt = {0.0, 0.0};
+ surfWin.SourceLumFromWinAtRefPt.allocate(numEnclRefPoints);
+ surfWin.SourceLumFromWinAtRefPt = {0.0, 0.0};
surfWin.IllumFromWinAtRefPtRep.allocate(numEnclRefPoints);
surfWin.IllumFromWinAtRefPtRep = 0.0;
surfWin.LumWinFromRefPtRep.allocate(numEnclRefPoints);
@@ -3921,12 +3920,12 @@ void GetDaylightingParametersInput(EnergyPlusData &state)
surfWin.SolidAngAtRefPt = 0.0;
surfWin.SolidAngAtRefPtWtd.allocate(numAdjEnclRefPoints);
surfWin.SolidAngAtRefPtWtd = 0.0;
- surfWin.IllumFromWinAtRefPt.allocate(2, numAdjEnclRefPoints);
- surfWin.IllumFromWinAtRefPt = 0.0;
- surfWin.BackLumFromWinAtRefPt.allocate(2, numAdjEnclRefPoints);
- surfWin.BackLumFromWinAtRefPt = 0.0;
- surfWin.SourceLumFromWinAtRefPt.allocate(2, numAdjEnclRefPoints);
- surfWin.SourceLumFromWinAtRefPt = 0.0;
+ surfWin.IllumFromWinAtRefPt.allocate(numAdjEnclRefPoints);
+ surfWin.IllumFromWinAtRefPt = {0.0, 0.0};
+ surfWin.BackLumFromWinAtRefPt.allocate(numAdjEnclRefPoints);
+ surfWin.BackLumFromWinAtRefPt = {0.0, 0.0};
+ surfWin.SourceLumFromWinAtRefPt.allocate(numAdjEnclRefPoints);
+ surfWin.SourceLumFromWinAtRefPt = {0.0, 0.0};
surfWin.IllumFromWinAtRefPtRep.allocate(numAdjEnclRefPoints);
surfWin.IllumFromWinAtRefPtRep = 0.0;
surfWin.LumWinFromRefPtRep.allocate(numAdjEnclRefPoints);
@@ -4365,8 +4364,8 @@ void GetInputIlluminanceMap(EnergyPlusData &state, bool &ErrorsFound)
// Add additional daylighting reference points for map
AddMapPoints = illumMap.Xnum * illumMap.Ynum;
illumMapCalc.TotalMapRefPoints = AddMapPoints;
- illumMapCalc.MapRefPtAbsCoord.allocate(3, AddMapPoints);
- illumMapCalc.MapRefPtAbsCoord = 0.0;
+ illumMapCalc.MapRefPtAbsCoord.allocate(AddMapPoints);
+ illumMapCalc.MapRefPtAbsCoord = Vector3(0.0);
illumMapCalc.MapRefPtInBounds.allocate(AddMapPoints);
illumMapCalc.MapRefPtInBounds = true;
illumMapCalc.DaylIllumAtMapPt.allocate(AddMapPoints);
@@ -4402,26 +4401,25 @@ void GetInputIlluminanceMap(EnergyPlusData &state, bool &ErrorsFound)
// Map points and increments are stored in AbsCoord and then that is operated on if relative coords entered.
for (int Y = 1; Y <= illumMap.Ynum; ++Y) {
for (int X = 1; X <= illumMap.Xnum; ++X) {
- illumMapCalc.MapRefPtAbsCoord(1, RefPt) = illumMap.Xmin + (X - 1) * illumMap.Xinc;
- illumMapCalc.MapRefPtAbsCoord(2, RefPt) = illumMap.Ymin + (Y - 1) * illumMap.Yinc;
- illumMapCalc.MapRefPtAbsCoord(3, RefPt) = illumMap.Z;
+ illumMapCalc.MapRefPtAbsCoord(RefPt) = {
+ illumMap.Xmin + (X - 1) * illumMap.Xinc, illumMap.Ymin + (Y - 1) * illumMap.Yinc, illumMap.Z};
++RefPt;
}
}
+
RefPt = 1;
for (int Y = 1; Y <= illumMap.Ynum; ++Y) {
for (int X = 1; X <= illumMap.Xnum; ++X) {
+ auto &mapRefPtAbsCoord = illumMapCalc.MapRefPtAbsCoord(RefPt);
if (!state.dataSurface->DaylRefWorldCoordSystem) {
- Xb = illumMapCalc.MapRefPtAbsCoord(1, RefPt) * CosZoneRelNorth -
- illumMapCalc.MapRefPtAbsCoord(2, RefPt) * SinZoneRelNorth + zone.OriginX;
- Yb = illumMapCalc.MapRefPtAbsCoord(1, RefPt) * SinZoneRelNorth +
- illumMapCalc.MapRefPtAbsCoord(2, RefPt) * CosZoneRelNorth + zone.OriginY;
- illumMapCalc.MapRefPtAbsCoord(1, RefPt) = Xb * CosBldgRelNorth - Yb * SinBldgRelNorth;
- illumMapCalc.MapRefPtAbsCoord(2, RefPt) = Xb * SinBldgRelNorth + Yb * CosBldgRelNorth;
- illumMapCalc.MapRefPtAbsCoord(3, RefPt) += zone.OriginZ;
+ Xb = mapRefPtAbsCoord.x * CosZoneRelNorth - mapRefPtAbsCoord.y * SinZoneRelNorth + zone.OriginX;
+ Yb = mapRefPtAbsCoord.x * SinZoneRelNorth + mapRefPtAbsCoord.y * CosZoneRelNorth + zone.OriginY;
+ mapRefPtAbsCoord.x = Xb * CosBldgRelNorth - Yb * SinBldgRelNorth;
+ mapRefPtAbsCoord.y = Xb * SinBldgRelNorth + Yb * CosBldgRelNorth;
+ mapRefPtAbsCoord.z += zone.OriginZ;
if (doTransform) {
- Xo = illumMapCalc.MapRefPtAbsCoord(1, RefPt); // world coordinates.... shifted by relative north angle...
- Yo = illumMapCalc.MapRefPtAbsCoord(2, RefPt);
+ Xo = mapRefPtAbsCoord.x; // world coordinates.... shifted by relative north angle...
+ Yo = mapRefPtAbsCoord.y;
// next derotate the building
XnoRot = Xo * CosBldgRelNorth + Yo * SinBldgRelNorth;
YnoRot = Yo * CosBldgRelNorth - Xo * SinBldgRelNorth;
@@ -4429,45 +4427,39 @@ void GetInputIlluminanceMap(EnergyPlusData &state, bool &ErrorsFound)
Xtrans = XnoRot * std::sqrt(NewAspectRatio / OldAspectRatio);
Ytrans = YnoRot * std::sqrt(OldAspectRatio / NewAspectRatio);
// rerotate
- illumMapCalc.MapRefPtAbsCoord(1, RefPt) = Xtrans * CosBldgRelNorth - Ytrans * SinBldgRelNorth;
+ mapRefPtAbsCoord.x = Xtrans * CosBldgRelNorth - Ytrans * SinBldgRelNorth;
- illumMapCalc.MapRefPtAbsCoord(2, RefPt) = Xtrans * SinBldgRelNorth + Ytrans * CosBldgRelNorth;
+ mapRefPtAbsCoord.y = Xtrans * SinBldgRelNorth + Ytrans * CosBldgRelNorth;
}
} else {
- Xb = illumMapCalc.MapRefPtAbsCoord(1, RefPt);
- Yb = illumMapCalc.MapRefPtAbsCoord(2, RefPt);
- illumMapCalc.MapRefPtAbsCoord(1, RefPt) = Xb * CosBldgRotAppGonly - Yb * SinBldgRotAppGonly;
- illumMapCalc.MapRefPtAbsCoord(2, RefPt) = Xb * SinBldgRotAppGonly + Yb * CosBldgRotAppGonly;
+ Xb = mapRefPtAbsCoord.x;
+ Yb = mapRefPtAbsCoord.y;
+ mapRefPtAbsCoord.x = Xb * CosBldgRotAppGonly - Yb * SinBldgRotAppGonly;
+ mapRefPtAbsCoord.y = Xb * SinBldgRotAppGonly + Yb * CosBldgRotAppGonly;
}
if (RefPt == 1) {
- illumMap.Xmin = illumMapCalc.MapRefPtAbsCoord(1, RefPt);
- illumMap.Ymin = illumMapCalc.MapRefPtAbsCoord(2, RefPt);
- illumMap.Xmax = illumMapCalc.MapRefPtAbsCoord(1, RefPt);
- illumMap.Ymax = illumMapCalc.MapRefPtAbsCoord(2, RefPt);
- illumMap.Z = illumMapCalc.MapRefPtAbsCoord(3, RefPt);
+ illumMap.Xmin = mapRefPtAbsCoord.x;
+ illumMap.Ymin = mapRefPtAbsCoord.y;
+ illumMap.Xmax = mapRefPtAbsCoord.x;
+ illumMap.Ymax = mapRefPtAbsCoord.y;
+ illumMap.Z = mapRefPtAbsCoord.z;
}
- illumMap.Xmin = min(illumMap.Xmin, illumMapCalc.MapRefPtAbsCoord(1, RefPt));
- illumMap.Ymin = min(illumMap.Ymin, illumMapCalc.MapRefPtAbsCoord(2, RefPt));
- illumMap.Xmax = max(illumMap.Xmax, illumMapCalc.MapRefPtAbsCoord(1, RefPt));
- illumMap.Ymax = max(illumMap.Ymax, illumMapCalc.MapRefPtAbsCoord(2, RefPt));
- if ((illumMapCalc.MapRefPtAbsCoord(1, RefPt) < zone.MinimumX &&
- (zone.MinimumX - illumMapCalc.MapRefPtAbsCoord(1, RefPt)) > 0.001) ||
- (illumMapCalc.MapRefPtAbsCoord(1, RefPt) > zone.MaximumX &&
- (illumMapCalc.MapRefPtAbsCoord(1, RefPt) - zone.MaximumX) > 0.001) ||
- (illumMapCalc.MapRefPtAbsCoord(2, RefPt) < zone.MinimumY &&
- (zone.MinimumY - illumMapCalc.MapRefPtAbsCoord(2, RefPt)) > 0.001) ||
- (illumMapCalc.MapRefPtAbsCoord(2, RefPt) > zone.MaximumY &&
- (illumMapCalc.MapRefPtAbsCoord(2, RefPt) - zone.MaximumY) > 0.001) ||
- (illumMapCalc.MapRefPtAbsCoord(3, RefPt) < zone.MinimumZ &&
- (zone.MinimumZ - illumMapCalc.MapRefPtAbsCoord(3, RefPt)) > 0.001) ||
- (illumMapCalc.MapRefPtAbsCoord(3, RefPt) > zone.MaximumZ &&
- (illumMapCalc.MapRefPtAbsCoord(3, RefPt) - zone.MaximumZ) > 0.001)) {
+ illumMap.Xmin = min(illumMap.Xmin, mapRefPtAbsCoord.x);
+ illumMap.Ymin = min(illumMap.Ymin, mapRefPtAbsCoord.y);
+ illumMap.Xmax = max(illumMap.Xmax, mapRefPtAbsCoord.x);
+ illumMap.Ymax = max(illumMap.Ymax, mapRefPtAbsCoord.y);
+ if ((mapRefPtAbsCoord.x < zone.MinimumX && (zone.MinimumX - mapRefPtAbsCoord.x) > 0.001) ||
+ (mapRefPtAbsCoord.x > zone.MaximumX && (mapRefPtAbsCoord.x - zone.MaximumX) > 0.001) ||
+ (mapRefPtAbsCoord.y < zone.MinimumY && (zone.MinimumY - mapRefPtAbsCoord.y) > 0.001) ||
+ (mapRefPtAbsCoord.y > zone.MaximumY && (mapRefPtAbsCoord.y - zone.MaximumY) > 0.001) ||
+ (mapRefPtAbsCoord.z < zone.MinimumZ && (zone.MinimumZ - mapRefPtAbsCoord.z) > 0.001) ||
+ (mapRefPtAbsCoord.z > zone.MaximumZ && (mapRefPtAbsCoord.z - zone.MaximumZ) > 0.001)) {
illumMapCalc.MapRefPtInBounds(RefPt) = false;
}
// Test extremes of Map Points against Zone Min/Max
if (RefPt == 1 || RefPt == illumMapCalc.TotalMapRefPoints) {
- if ((illumMapCalc.MapRefPtAbsCoord(1, RefPt) < zone.MinimumX ||
- illumMapCalc.MapRefPtAbsCoord(1, RefPt) > zone.MaximumX) &&
+ auto const &mapRefPtAbsCoord2 = illumMapCalc.MapRefPtAbsCoord(RefPt);
+ if ((mapRefPtAbsCoord2.x < zone.MinimumX || mapRefPtAbsCoord2.x > zone.MaximumX) &&
!illumMapCalc.MapRefPtInBounds(RefPt)) {
ShowWarningError(state,
format("GetInputIlluminanceMap: Reference Map point #[{}], X Value outside Zone Min/Max X, Zone={}",
@@ -4475,21 +4467,18 @@ void GetInputIlluminanceMap(EnergyPlusData &state, bool &ErrorsFound)
zone.Name));
ShowContinueError(state,
format("...X Reference Point= {:.2R}, Zone Minimum X= {:.2R}, Zone Maximum X= {:.2R}",
- illumMapCalc.MapRefPtAbsCoord(1, RefPt),
+ mapRefPtAbsCoord2.x,
zone.MinimumX,
zone.MaximumX));
- if (illumMapCalc.MapRefPtAbsCoord(1, RefPt) < zone.MinimumX) {
- ShowContinueError(state,
- format("...X Reference Distance Outside MinimumX= {:.4R} m.",
- zone.MinimumX - illumMapCalc.MapRefPtAbsCoord(1, RefPt)));
+ if (mapRefPtAbsCoord2.x < zone.MinimumX) {
+ ShowContinueError(
+ state, format("...X Reference Distance Outside MinimumX= {:.4R} m.", zone.MinimumX - mapRefPtAbsCoord2.x));
} else {
- ShowContinueError(state,
- format("...X Reference Distance Outside MaximumX= {:.4R} m.",
- illumMapCalc.MapRefPtAbsCoord(1, RefPt) - zone.MaximumX));
+ ShowContinueError(
+ state, format("...X Reference Distance Outside MaximumX= {:.4R} m.", mapRefPtAbsCoord2.x - zone.MaximumX));
}
}
- if ((illumMapCalc.MapRefPtAbsCoord(2, RefPt) < zone.MinimumY ||
- illumMapCalc.MapRefPtAbsCoord(2, RefPt) > zone.MaximumY) &&
+ if ((mapRefPtAbsCoord2.y < zone.MinimumY || mapRefPtAbsCoord2.y > zone.MaximumY) &&
!illumMapCalc.MapRefPtInBounds(RefPt)) {
ShowWarningError(state,
format("GetInputIlluminanceMap: Reference Map point #[{}], Y Value outside Zone Min/Max Y, Zone={}",
@@ -4497,21 +4486,18 @@ void GetInputIlluminanceMap(EnergyPlusData &state, bool &ErrorsFound)
zone.Name));
ShowContinueError(state,
format("...Y Reference Point= {:.2R}, Zone Minimum Y= {:.2R}, Zone Maximum Y= {:.2R}",
- illumMapCalc.MapRefPtAbsCoord(2, RefPt),
+ mapRefPtAbsCoord2.y,
zone.MinimumY,
zone.MaximumY));
- if (illumMapCalc.MapRefPtAbsCoord(2, RefPt) < zone.MinimumY) {
- ShowContinueError(state,
- format("...Y Reference Distance Outside MinimumY= {:.4R} m.",
- zone.MinimumY - illumMapCalc.MapRefPtAbsCoord(2, RefPt)));
+ if (mapRefPtAbsCoord2.y < zone.MinimumY) {
+ ShowContinueError(
+ state, format("...Y Reference Distance Outside MinimumY= {:.4R} m.", zone.MinimumY - mapRefPtAbsCoord2.y));
} else {
- ShowContinueError(state,
- format("...Y Reference Distance Outside MaximumY= {:.4R} m.",
- illumMapCalc.MapRefPtAbsCoord(2, RefPt) - zone.MaximumY));
+ ShowContinueError(
+ state, format("...Y Reference Distance Outside MaximumY= {:.4R} m.", mapRefPtAbsCoord2.y - zone.MaximumY));
}
}
- if ((illumMapCalc.MapRefPtAbsCoord(3, RefPt) < zone.MinimumZ ||
- illumMapCalc.MapRefPtAbsCoord(3, RefPt) > zone.MaximumZ) &&
+ if ((mapRefPtAbsCoord2.z < zone.MinimumZ || mapRefPtAbsCoord2.z > zone.MaximumZ) &&
!illumMapCalc.MapRefPtInBounds(RefPt)) {
ShowWarningError(state,
format("GetInputIlluminanceMap: Reference Map point #[{}], Z Value outside Zone Min/Max Z, Zone={}",
@@ -4519,17 +4505,15 @@ void GetInputIlluminanceMap(EnergyPlusData &state, bool &ErrorsFound)
zone.Name));
ShowContinueError(state,
format("...Z Reference Point= {:.2R}, Zone Minimum Z= {:.2R}, Zone Maximum Z= {:.2R}",
- illumMapCalc.MapRefPtAbsCoord(3, RefPt),
+ mapRefPtAbsCoord2.z,
zone.MinimumZ,
zone.MaximumZ));
- if (illumMapCalc.MapRefPtAbsCoord(3, RefPt) < zone.MinimumZ) {
- ShowContinueError(state,
- format("...Z Reference Distance Outside MinimumZ= {:.4R} m.",
- zone.MinimumZ - illumMapCalc.MapRefPtAbsCoord(3, RefPt)));
+ if (mapRefPtAbsCoord2.z < zone.MinimumZ) {
+ ShowContinueError(
+ state, format("...Z Reference Distance Outside MinimumZ= {:.4R} m.", zone.MinimumZ - mapRefPtAbsCoord2.z));
} else {
- ShowContinueError(state,
- format("...Z Reference Distance Outside MaximumZ= {:.4R} m.",
- illumMapCalc.MapRefPtAbsCoord(3, RefPt) - zone.MaximumZ));
+ ShowContinueError(
+ state, format("...Z Reference Distance Outside MaximumZ= {:.4R} m.", mapRefPtAbsCoord2.z - zone.MaximumZ));
}
}
}
@@ -4539,6 +4523,7 @@ void GetInputIlluminanceMap(EnergyPlusData &state, bool &ErrorsFound)
}
}
} // MapNum
+
ZoneMsgDone.dimension(state.dataGlobal->NumOfZones, false);
for (int MapNum = 1; MapNum <= TotIllumMaps; ++MapNum) {
auto const &illumMap = state.dataDaylightingData->IllumMap(MapNum);
@@ -4788,7 +4773,7 @@ void GetDaylightingControls(EnergyPlusData &state, bool &ErrorsFound)
daylightControl.IllumSetPoint.allocate(curTotalDaylRefPts);
daylightControl.DaylIllumAtRefPt.allocate(curTotalDaylRefPts);
daylightControl.GlareIndexAtRefPt.allocate(curTotalDaylRefPts);
- daylightControl.DaylRefPtAbsCoord.allocate(3, curTotalDaylRefPts);
+ daylightControl.DaylRefPtAbsCoord.allocate(curTotalDaylRefPts);
daylightControl.DaylRefPtInBounds.allocate(curTotalDaylRefPts);
daylightControl.RefPtPowerReductionFactor.allocate(curTotalDaylRefPts);
daylightControl.BacLum.allocate(curTotalDaylRefPts);
@@ -4806,9 +4791,7 @@ void GetDaylightingControls(EnergyPlusData &state, bool &ErrorsFound)
daylightControl.BacLum(refPt) = 0.0;
daylightControl.TimeExceedingGlareIndexSPAtRefPt(refPt) = 0.0;
daylightControl.TimeExceedingDaylightIlluminanceSPAtRefPt(refPt) = 0.0;
- for (int coord = 1; coord <= 3; ++coord) {
- daylightControl.DaylRefPtAbsCoord(coord, refPt) = 0.0;
- }
+ daylightControl.DaylRefPtAbsCoord(refPt) = {0.0, 0.0, 0.0};
}
int countRefPts = 0;
@@ -4958,20 +4941,20 @@ void GeometryTransformForDaylighting(EnergyPlusData &state)
curRefPt.indexToFracAndIllum = refPtNum; // back reference to the index to the ZoneDaylight structure arrays related to reference points
if (state.dataSurface->DaylRefWorldCoordSystem) {
// transform only by appendix G rotation
- daylCntrl.DaylRefPtAbsCoord(1, refPtNum) = curRefPt.x * CosBldgRotAppGonly - curRefPt.y * SinBldgRotAppGonly;
- daylCntrl.DaylRefPtAbsCoord(2, refPtNum) = curRefPt.x * SinBldgRotAppGonly + curRefPt.y * CosBldgRotAppGonly;
- daylCntrl.DaylRefPtAbsCoord(3, refPtNum) = curRefPt.z;
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).x = curRefPt.x * CosBldgRotAppGonly - curRefPt.y * SinBldgRotAppGonly;
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).y = curRefPt.x * SinBldgRotAppGonly + curRefPt.y * CosBldgRotAppGonly;
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).z = curRefPt.z;
} else {
// Transform reference point coordinates into building coordinate system
Xb = curRefPt.x * CosZoneRelNorth - curRefPt.y * SinZoneRelNorth + zone.OriginX;
Yb = curRefPt.x * SinZoneRelNorth + curRefPt.y * CosZoneRelNorth + zone.OriginY;
// Transform into World Coordinate System
- daylCntrl.DaylRefPtAbsCoord(1, refPtNum) = Xb * CosBldgRelNorth - Yb * SinBldgRelNorth;
- daylCntrl.DaylRefPtAbsCoord(2, refPtNum) = Xb * SinBldgRelNorth + Yb * CosBldgRelNorth;
- daylCntrl.DaylRefPtAbsCoord(3, refPtNum) = curRefPt.z + zone.OriginZ;
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).x = Xb * CosBldgRelNorth - Yb * SinBldgRelNorth;
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).y = Xb * SinBldgRelNorth + Yb * CosBldgRelNorth;
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).z = curRefPt.z + zone.OriginZ;
if (doTransform) {
- Xo = daylCntrl.DaylRefPtAbsCoord(1, refPtNum); // world coordinates.... shifted by relative north angle...
- Yo = daylCntrl.DaylRefPtAbsCoord(2, refPtNum);
+ Xo = daylCntrl.DaylRefPtAbsCoord(refPtNum).x; // world coordinates.... shifted by relative north angle...
+ Yo = daylCntrl.DaylRefPtAbsCoord(refPtNum).y;
// next derotate the building
XnoRot = Xo * CosBldgRelNorth + Yo * SinBldgRelNorth;
YnoRot = Yo * CosBldgRelNorth - Xo * SinBldgRelNorth;
@@ -4979,8 +4962,8 @@ void GeometryTransformForDaylighting(EnergyPlusData &state)
Xtrans = XnoRot * std::sqrt(NewAspectRatio / OldAspectRatio);
Ytrans = YnoRot * std::sqrt(OldAspectRatio / NewAspectRatio);
// rerotate
- daylCntrl.DaylRefPtAbsCoord(1, refPtNum) = Xtrans * CosBldgRelNorth - Ytrans * SinBldgRelNorth;
- daylCntrl.DaylRefPtAbsCoord(2, refPtNum) = Xtrans * SinBldgRelNorth + Ytrans * CosBldgRelNorth;
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).x = Xtrans * CosBldgRelNorth - Ytrans * SinBldgRelNorth;
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).y = Xtrans * SinBldgRelNorth + Ytrans * CosBldgRelNorth;
}
}
refName = curRefPt.Name;
@@ -5004,61 +4987,61 @@ void GeometryTransformForDaylighting(EnergyPlusData &state)
OutputReportPredefined::PreDefTableEntry(
state, state.dataOutRptPredefined->pdchDyLtWCtrl, refName, rLightLevel * daylCntrl.FracZoneDaylit(refPtNum));
- if (daylCntrl.DaylRefPtAbsCoord(1, refPtNum) < zone.MinimumX || daylCntrl.DaylRefPtAbsCoord(1, refPtNum) > zone.MaximumX) {
+ if (daylCntrl.DaylRefPtAbsCoord(refPtNum).x < zone.MinimumX || daylCntrl.DaylRefPtAbsCoord(refPtNum).x > zone.MaximumX) {
daylCntrl.DaylRefPtInBounds(refPtNum) = false;
ShowWarningError(state,
format("GeometryTransformForDaylighting: Reference point X Value outside Zone Min/Max X, Zone={}", zone.Name));
ShowContinueError(state,
format("...X Reference Point= {:.2R}, Zone Minimum X= {:.2R}, Zone Maximum X= {:.2R}",
- daylCntrl.DaylRefPtAbsCoord(1, refPtNum),
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).x,
zone.MinimumX,
zone.MaximumX));
- if (daylCntrl.DaylRefPtAbsCoord(1, refPtNum) < zone.MinimumX) {
+ if (daylCntrl.DaylRefPtAbsCoord(refPtNum).x < zone.MinimumX) {
ShowContinueError(
state,
- format("...X Reference Distance Outside MinimumX= {:.4R} m.", zone.MinimumX - daylCntrl.DaylRefPtAbsCoord(1, refPtNum)));
+ format("...X Reference Distance Outside MinimumX= {:.4R} m.", zone.MinimumX - daylCntrl.DaylRefPtAbsCoord(refPtNum).x));
} else {
ShowContinueError(
state,
- format("...X Reference Distance Outside MaximumX= {:.4R} m.", daylCntrl.DaylRefPtAbsCoord(1, refPtNum) - zone.MaximumX));
+ format("...X Reference Distance Outside MaximumX= {:.4R} m.", daylCntrl.DaylRefPtAbsCoord(refPtNum).x - zone.MaximumX));
}
}
- if (daylCntrl.DaylRefPtAbsCoord(2, refPtNum) < zone.MinimumY || daylCntrl.DaylRefPtAbsCoord(2, refPtNum) > zone.MaximumY) {
+ if (daylCntrl.DaylRefPtAbsCoord(refPtNum).y < zone.MinimumY || daylCntrl.DaylRefPtAbsCoord(refPtNum).y > zone.MaximumY) {
daylCntrl.DaylRefPtInBounds(refPtNum) = false;
ShowWarningError(state,
format("GeometryTransformForDaylighting: Reference point Y Value outside Zone Min/Max Y, Zone={}", zone.Name));
ShowContinueError(state,
format("...Y Reference Point= {:.2R}, Zone Minimum Y= {:.2R}, Zone Maximum Y= {:.2R}",
- daylCntrl.DaylRefPtAbsCoord(2, refPtNum),
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).x,
zone.MinimumY,
zone.MaximumY));
- if (daylCntrl.DaylRefPtAbsCoord(2, refPtNum) < zone.MinimumY) {
+ if (daylCntrl.DaylRefPtAbsCoord(refPtNum).y < zone.MinimumY) {
ShowContinueError(
state,
- format("...Y Reference Distance Outside MinimumY= {:.4R} m.", zone.MinimumY - daylCntrl.DaylRefPtAbsCoord(2, refPtNum)));
+ format("...Y Reference Distance Outside MinimumY= {:.4R} m.", zone.MinimumY - daylCntrl.DaylRefPtAbsCoord(refPtNum).y));
} else {
ShowContinueError(
state,
- format("...Y Reference Distance Outside MaximumY= {:.4R} m.", daylCntrl.DaylRefPtAbsCoord(2, refPtNum) - zone.MaximumY));
+ format("...Y Reference Distance Outside MaximumY= {:.4R} m.", daylCntrl.DaylRefPtAbsCoord(refPtNum).y - zone.MaximumY));
}
}
- if (daylCntrl.DaylRefPtAbsCoord(3, refPtNum) < zone.MinimumZ || daylCntrl.DaylRefPtAbsCoord(3, refPtNum) > zone.MaximumZ) {
+ if (daylCntrl.DaylRefPtAbsCoord(refPtNum).z < zone.MinimumZ || daylCntrl.DaylRefPtAbsCoord(refPtNum).z > zone.MaximumZ) {
daylCntrl.DaylRefPtInBounds(refPtNum) = false;
ShowWarningError(state,
format("GeometryTransformForDaylighting: Reference point Z Value outside Zone Min/Max Z, Zone={}", zone.Name));
ShowContinueError(state,
format("...Z Reference Point= {:.2R}, Zone Minimum Z= {:.2R}, Zone Maximum Z= {:.2R}",
- daylCntrl.DaylRefPtAbsCoord(3, refPtNum),
+ daylCntrl.DaylRefPtAbsCoord(refPtNum).z,
zone.MinimumZ,
zone.MaximumZ));
- if (daylCntrl.DaylRefPtAbsCoord(3, refPtNum) < zone.MinimumZ) {
+ if (daylCntrl.DaylRefPtAbsCoord(refPtNum).z < zone.MinimumZ) {
ShowContinueError(
state,
- format("...Z Reference Distance Outside MinimumZ= {:.4R} m.", zone.MinimumZ - daylCntrl.DaylRefPtAbsCoord(3, refPtNum)));
+ format("...Z Reference Distance Outside MinimumZ= {:.4R} m.", zone.MinimumZ - daylCntrl.DaylRefPtAbsCoord(refPtNum).z));
} else {
ShowContinueError(
state,
- format("...Z Reference Distance Outside MaximumZ= {:.4R} m.", daylCntrl.DaylRefPtAbsCoord(3, refPtNum) - zone.MaximumZ));
+ format("...Z Reference Distance Outside MaximumZ= {:.4R} m.", daylCntrl.DaylRefPtAbsCoord(refPtNum).z - zone.MaximumZ));
}
}
} // for (refPtNum) reference point
@@ -5354,10 +5337,10 @@ void DayltgGlare(EnergyPlusData &state,
int WinShadingIndex = findWinShadingStatus(state, IWin);
// Conversion from ft-L to cd/m2, with cd/m2 = 0.2936 ft-L, gives the 0.4794 factor
// below, which is (0.2936)**0.6
- Real64 GTOT1 = 0.4794 * (std::pow(thisDaylightControl.SourceLumFromWinAtRefPt(loop, WinShadingIndex, IL), 1.6)) *
+ Real64 GTOT1 = 0.4794 * (std::pow(thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[WinShadingIndex - 1], 1.6)) *
std::pow(thisDaylightControl.SolidAngAtRefPtWtd(loop, IL), 0.8);
Real64 GTOT2 = BLUM + 0.07 * (std::sqrt(thisDaylightControl.SolidAngAtRefPt(loop, IL))) *
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, WinShadingIndex, IL);
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[WinShadingIndex - 1];
GTOT += GTOT1 / (GTOT2 + 0.000001);
}
@@ -5407,10 +5390,10 @@ void DayltgGlareWithIntWins(EnergyPlusData &state,
int WinShadingIndex = findWinShadingStatus(state, IWin);
// Conversion from ft-L to cd/m2, with cd/m2 = 0.2936 ft-L, gives the 0.4794 factor
// below, which is (0.2936)**0.6
- Real64 GTOT1 = 0.4794 * (std::pow(thisDaylightControl.SourceLumFromWinAtRefPt(loop, WinShadingIndex, IL), 1.6)) *
+ Real64 GTOT1 = 0.4794 * (std::pow(thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[WinShadingIndex - 1], 1.6)) *
std::pow(thisDaylightControl.SolidAngAtRefPtWtd(loop, IL), 0.8);
Real64 GTOT2 = BackgroundLum + 0.07 * (std::sqrt(thisDaylightControl.SolidAngAtRefPt(loop, IL))) *
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, WinShadingIndex, IL);
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[WinShadingIndex - 1];
GTOT += GTOT1 / (GTOT2 + 0.000001);
}
@@ -5455,12 +5438,12 @@ void DayltgExtHorizIllum(EnergyPlusData &state,
// Init
if (state.dataDaylightingManager->DayltgExtHorizIllum_firstTime) {
for (int IPH = 1; IPH <= NPH; ++IPH) {
- state.dataDaylightingManager->PH(IPH) = (IPH - 0.5) * DPH;
- state.dataDaylightingManager->SPHCPH(IPH) =
- std::sin(state.dataDaylightingManager->PH(IPH)) * std::cos(state.dataDaylightingManager->PH(IPH)); // DA = COS(PH)*DTH*DPH
+ state.dataDaylightingManager->PH[IPH] = (IPH - 0.5) * DPH;
+ state.dataDaylightingManager->SPHCPH[IPH] =
+ std::sin(state.dataDaylightingManager->PH[IPH]) * std::cos(state.dataDaylightingManager->PH[IPH]); // DA = COS(PH)*DTH*DPH
}
for (int ITH = 1; ITH <= NTH; ++ITH) {
- state.dataDaylightingManager->TH(ITH) = (ITH - 0.5) * DTH;
+ state.dataDaylightingManager->TH[ITH] = (ITH - 0.5) * DTH;
}
state.dataDaylightingManager->DayltgExtHorizIllum_firstTime = false;
}
@@ -5469,10 +5452,10 @@ void DayltgExtHorizIllum(EnergyPlusData &state,
// Sky integration
for (int IPH = 1; IPH <= NPH; ++IPH) {
- Real64 const PH_IPH(state.dataDaylightingManager->PH(IPH));
- Real64 const SPHCPH_IPH(state.dataDaylightingManager->SPHCPH(IPH));
+ Real64 const PH_IPH = state.dataDaylightingManager->PH[IPH];
+ Real64 const SPHCPH_IPH = state.dataDaylightingManager->SPHCPH[IPH];
for (int ITH = 1; ITH <= NTH; ++ITH) {
- Real64 const TH_ITH(state.dataDaylightingManager->TH(ITH));
+ Real64 const TH_ITH = state.dataDaylightingManager->TH[ITH];
for (int iSky = (int)SkyType::Clear; iSky < (int)SkyType::Num; ++iSky) {
HISK.sky[iSky] += DayltgSkyLuminance(state, static_cast(iSky), TH_ITH, PH_IPH) * SPHCPH_IPH;
}
@@ -5525,6 +5508,7 @@ void DayltgHitObstruction(EnergyPlusData &state,
auto const &window(state.dataSurface->Surface(IWin));
int const window_iBaseSurf(window.BaseSurf);
+ Vector3 DayltgHitObstructionHP;
// Loop over potentially obstructing surfaces, which can be building elements, like walls, or shadowing surfaces, like overhangs
// Building elements are assumed to be opaque
// A shadowing surface is opaque unless its transmittance schedule value is non-zero
@@ -5534,13 +5518,13 @@ void DayltgHitObstruction(EnergyPlusData &state,
auto const &surface = state.dataSurface->Surface(ISurf);
SurfaceClass IType = surface.Class;
if ((IType == SurfaceClass::Wall || IType == SurfaceClass::Roof || IType == SurfaceClass::Floor) && (ISurf != window_iBaseSurf)) {
- PierceSurface(state, ISurf, R1, RN, state.dataDaylightingManager->DayltgHitObstructionHP, hit);
+ PierceSurface(state, ISurf, R1, RN, DayltgHitObstructionHP, hit);
if (hit) { // Building element is hit (assumed opaque)
ObTrans = 0.0;
break;
}
} else if (surface.IsShadowing) {
- PierceSurface(state, ISurf, R1, RN, state.dataDaylightingManager->DayltgHitObstructionHP, hit);
+ PierceSurface(state, ISurf, R1, RN, DayltgHitObstructionHP, hit);
if (hit) { // Shading surface is hit
// Get solar transmittance of the shading surface
Real64 const Trans(
@@ -5564,14 +5548,15 @@ void DayltgHitObstruction(EnergyPlusData &state,
auto solarTransmittance = [=, &state, &R1, &RN, &hit, &ObTrans](SurfaceData const &surface) -> bool {
if (!surface.IsShadowPossibleObstruction) return false; // Do Consider separate octree without filtered surfaces
DataSurfaces::SurfaceClass const sClass(surface.Class);
+ Vector3 HP;
if ((sClass == SurfaceClass::Wall || sClass == SurfaceClass::Roof || sClass == SurfaceClass::Floor) && (&surface != window_base_p)) {
- PierceSurface(surface, R1, RN, state.dataDaylightingManager->DayltgHitObstructionHP, hit);
+ PierceSurface(surface, R1, RN, HP, hit);
if (hit) { // Building element is hit (assumed opaque)
ObTrans = 0.0;
return true;
}
} else if (surface.IsShadowing) {
- PierceSurface(surface, R1, RN, state.dataDaylightingManager->DayltgHitObstructionHP, hit);
+ PierceSurface(surface, R1, RN, HP, hit);
if (hit) { // Shading surface is hit
// Get solar transmittance of the shading surface
Real64 const Trans(
@@ -5613,11 +5598,9 @@ void DayltgHitInteriorObstruction(EnergyPlusData &state,
// Preconditions
assert(magnitude(R2 - R1) > 0.0); // Protect normalize() from divide by zero
- auto &RN = state.dataDaylightingManager->RN; // Unit vector along ray
-
hit = false;
- RN = (R2 - R1).normalize(); // Make unit vector
- Real64 const d12(distance(R1, R2)); // Distance between R1 and R2
+ Vector3 RN = (R2 - R1).normalize(); // Make unit vector
+ Real64 const d12(distance(R1, R2)); // Distance between R1 and R2
auto const &window(state.dataSurface->Surface(IWin));
int const window_Enclosure(window.SolarEnclIndex);
@@ -5628,7 +5611,7 @@ void DayltgHitInteriorObstruction(EnergyPlusData &state,
// Loop over potentially obstructing surfaces, which can be building elements, like walls, or shadowing surfaces, like overhangs
if (state.dataSurface->TotSurfaces < octreeCrossover) { // Linear search through surfaces
// Hit coordinates, if ray hits an obstruction
- auto &DayltgHitInteriorObstructionHP = state.dataDaylightingManager->DayltgHitInteriorObstructionHP;
+ Vector3 DayltgHitInteriorObstructionHP;
for (int ISurf = 1; ISurf <= state.dataSurface->TotSurfaces; ++ISurf) {
auto const &surface = state.dataSurface->Surface(ISurf);
@@ -5650,19 +5633,15 @@ void DayltgHitInteriorObstruction(EnergyPlusData &state,
auto const *window_base_adjacent_p(&window_base_adjacent);
// Lambda function for the octree to test for surface hit
- auto surfaceHit = [=, &R1, &hit, &state](SurfaceData const &surface) -> bool {
+ auto surfaceHit = [=, &R1, &hit](SurfaceData const &surface) -> bool {
DataSurfaces::SurfaceClass const sClass(surface.Class);
+ Vector3 HP; // Hit point
if ((surface.IsShadowing) || // Shadowing surface
((surface.SolarEnclIndex == window_Enclosure) && // Surface is in same zone as window
(sClass == SurfaceClass::Wall || sClass == SurfaceClass::Roof || sClass == SurfaceClass::Floor) && // Wall, ceiling/roof, or floor
(&surface != window_base_p) && (&surface != window_base_adjacent_p))) // Exclude window's base or base-adjacent surfaces
{
- PierceSurface(surface,
- R1,
- RN,
- d12,
- state.dataDaylightingManager->DayltgHitInteriorObstructionHP,
- hit); // Check if R2-R1 segment pierces surface
+ PierceSurface(surface, R1, RN, d12, HP, hit); // Check if R2-R1 segment pierces surface
return hit;
} else {
return false;
@@ -5699,8 +5678,9 @@ void DayltgHitBetWinObstruction(EnergyPlusData &state,
SurfaceClass IType; // Surface type/class
hit = false;
- state.dataDaylightingManager->DayltgHitBetWinObstructionRN = (R2 - R1).normalize(); // Unit vector
- Real64 const d12(distance(R1, R2)); // Distance between R1 and R2 (m)
+ Vector3 RN = (R2 - R1).normalize(); // Unit vector
+
+ Real64 const d12(distance(R1, R2)); // Distance between R1 and R2 (m)
auto const &window1(state.dataSurface->Surface(IWin1));
int const window1_iBaseSurf(window1.BaseSurf);
@@ -5729,14 +5709,9 @@ void DayltgHitBetWinObstruction(EnergyPlusData &state,
(ISurf != window1_iBaseSurf) && (ISurf != window2_iBaseSurf) && // Exclude windows' base surfaces
(ISurf != window1_base_iExtBoundCond) && (ISurf != window2_base_iExtBoundCond))) // Exclude windows' base-adjacent surfaces
{
- PierceSurface(state,
- ISurf,
- R1,
- state.dataDaylightingManager->DayltgHitBetWinObstructionRN,
- d12,
- state.dataDaylightingManager->DayltgHitBetWinObstructionHP,
- hit); // Check if R2-R1 segment pierces surface
- if (hit) break; // Segment pierces surface: Don't check the rest
+ Vector3 HP;
+ PierceSurface(state, ISurf, R1, RN, d12, HP, hit); // Check if R2-R1 segment pierces surface
+ if (hit) break; // Segment pierces surface: Don't check the rest
}
}
@@ -5751,19 +5726,16 @@ void DayltgHitBetWinObstruction(EnergyPlusData &state,
auto const *window2_base_adjacent_p(&window2_base_adjacent);
// Lambda function for the octree to test for surface hit
- auto surfaceHit = [=, &R1, &hit, &state](SurfaceData const &surface) -> bool {
+ auto surfaceHit = [=, &R1, &RN, &hit](SurfaceData const &surface) -> bool {
DataSurfaces::SurfaceClass const sClass(surface.Class);
+ Vector3 HP;
if ((surface.IsShadowing) || // Shadowing surface
((surface.SolarEnclIndex == window2_Enclosure) && // Surface is in same zone as window
(sClass == SurfaceClass::Wall || sClass == SurfaceClass::Roof || sClass == SurfaceClass::Floor) && // Wall, ceiling/roof, or floor
(&surface != window1_base_p) && (&surface != window2_base_p) && // Exclude windows' base surfaces
(&surface != window1_base_adjacent_p) && (&surface != window2_base_adjacent_p))) // Exclude windows' base-adjacent surfaces
{
- PierceSurface(surface,
- R1,
- state.dataDaylightingManager->DayltgHitBetWinObstructionRN,
- d12,
- state.dataDaylightingManager->DayltgHitBetWinObstructionHP,
+ PierceSurface(surface, R1, RN, d12, HP,
hit); // Check if R2-R1 segment pierces surface
return hit;
} else {
@@ -5819,10 +5791,10 @@ void initDaylighting(EnergyPlusData &state, bool const initSurfaceHeatBalancefir
auto &thisEnclDaylight = state.dataDaylightingData->enclDaylight(enclNum);
for (int extWinNum = 1; extWinNum <= thisEnclDaylight.NumOfDayltgExtWins; ++extWinNum) {
int IWin = thisEnclDaylight.DayltgExtWinSurfNums(extWinNum);
- int IS = 1;
+ WinCover winCover = WinCover::Bare;
if (state.dataSurface->SurfWinWindowModelType(IWin) != WindowModel::BSDF &&
(IS_SHADED(state.dataSurface->SurfWinShadingFlag(IWin)) || state.dataSurface->SurfWinSolarDiffusing(IWin))) {
- IS = 2;
+ winCover = WinCover::Shaded;
}
int refPtCount = 0;
for (int controlNum : state.dataDaylightingData->enclDaylight(enclNum).daylightControlIndexes) {
@@ -5831,9 +5803,9 @@ void initDaylighting(EnergyPlusData &state, bool const initSurfaceHeatBalancefir
for (int refPtNum = 1; refPtNum <= thisControl.TotalDaylRefPoints; ++refPtNum) {
++refPtCount; // Count reference points across each daylighting control in the same enclosure
state.dataSurface->SurfaceWindow(IWin).IllumFromWinAtRefPtRep(refPtCount) =
- thisControl.IllumFromWinAtRefPt(extWinNum, IS, refPtNum);
+ thisControl.IllumFromWinAtRefPt(extWinNum, refPtNum)[(int)winCover];
state.dataSurface->SurfaceWindow(IWin).LumWinFromRefPtRep(refPtCount) =
- thisControl.SourceLumFromWinAtRefPt(extWinNum, IS, refPtNum);
+ thisControl.SourceLumFromWinAtRefPt(extWinNum, refPtNum)[(int)winCover];
}
}
}
@@ -6088,9 +6060,9 @@ void DayltgInteriorIllum(EnergyPlusData &state,
if (state.dataDaylightingManager->DayltgInteriorIllum_firstTime) {
int const d1(max(maxval(state.dataHeatBal->Zone, &DataHeatBalance::ZoneData::NumSubSurfaces),
maxval(state.dataDaylightingData->enclDaylight, &EnclDaylightCalc::NumOfDayltgExtWins)));
- tmpIllumFromWinAtRefPt.allocate(d1, 2, state.dataDaylightingManager->maxNumRefPtInAnyDaylCtrl);
- tmpBackLumFromWinAtRefPt.allocate(d1, 2, state.dataDaylightingManager->maxNumRefPtInAnyDaylCtrl);
- tmpSourceLumFromWinAtRefPt.allocate(d1, 2, state.dataDaylightingManager->maxNumRefPtInAnyDaylCtrl);
+ tmpIllumFromWinAtRefPt.allocate(d1, state.dataDaylightingManager->maxNumRefPtInAnyDaylCtrl);
+ tmpBackLumFromWinAtRefPt.allocate(d1, state.dataDaylightingManager->maxNumRefPtInAnyDaylCtrl);
+ tmpSourceLumFromWinAtRefPt.allocate(d1, state.dataDaylightingManager->maxNumRefPtInAnyDaylCtrl);
SetPnt.allocate(state.dataDaylightingManager->maxNumRefPtInAnyDaylCtrl);
state.dataDaylightingManager->DaylIllum.allocate(state.dataDaylightingManager->maxNumRefPtInAnyDaylCtrl);
@@ -6099,9 +6071,14 @@ void DayltgInteriorIllum(EnergyPlusData &state,
state.dataDaylightingManager->DayltgInteriorIllum_firstTime = false;
}
- tmpIllumFromWinAtRefPt = 0.0;
- tmpBackLumFromWinAtRefPt = 0.0;
- tmpSourceLumFromWinAtRefPt = 0.0;
+
+ for (int iExtWin = 1; iExtWin <= (int)tmpIllumFromWinAtRefPt.size1(); ++iExtWin) {
+ for (int iRefPt = 1; iRefPt <= (int)tmpIllumFromWinAtRefPt.size2(); ++iRefPt) {
+ tmpIllumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ tmpBackLumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ tmpSourceLumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ }
+ }
// Initialize reference point illuminance and window background luminance
for (int IL = 1; IL <= NREFPT; ++IL) {
@@ -6159,23 +6136,23 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// Daylight factors for current sun position
auto const &illSkyCurr = thisDaylightControl.DaylIllFacSky(state.dataGlobal->HourOfDay, loop, IL, 1);
auto const &illSkyPrev = thisDaylightControl.DaylIllFacSky(state.dataGlobal->PreviousHour, loop, IL, 1);
- auto &dfskhr = state.dataDaylightingManager->DFSKHR(1);
+ auto &dfskhr = state.dataDaylightingManager->DFSKHR[(int)WinCover::Bare];
auto const &backSkyCurr = thisDaylightControl.DaylBackFacSky(state.dataGlobal->HourOfDay, loop, IL, 1);
auto const &backSkyPrev = thisDaylightControl.DaylBackFacSky(state.dataGlobal->PreviousHour, loop, IL, 1);
- auto &bfskhr = state.dataDaylightingManager->BFSKHR(1);
+ auto &bfskhr = state.dataDaylightingManager->BFSKHR[(int)WinCover::Bare];
auto const &sourceSkyCurr = thisDaylightControl.DaylSourceFacSky(state.dataGlobal->HourOfDay, loop, IL, 1);
auto const &sourceSkyPrev = thisDaylightControl.DaylSourceFacSky(state.dataGlobal->PreviousHour, loop, IL, 1);
- auto &sfskhr = state.dataDaylightingManager->SFSKHR(1);
+ auto &sfskhr = state.dataDaylightingManager->SFSKHR[(int)WinCover::Bare];
auto const &ill2SkyCurr = thisDaylightControl.DaylIllFacSky(state.dataGlobal->HourOfDay, loop, IL, 2);
auto const &ill2SkyPrev = thisDaylightControl.DaylIllFacSky(state.dataGlobal->PreviousHour, loop, IL, 2);
- auto &dfskhr2 = state.dataDaylightingManager->DFSKHR(2);
+ auto &dfskhr2 = state.dataDaylightingManager->DFSKHR[(int)WinCover::Shaded];
auto const &back2SkyCurr = thisDaylightControl.DaylBackFacSky(state.dataGlobal->HourOfDay, loop, IL, 2);
auto const &back2SkyPrev = thisDaylightControl.DaylBackFacSky(state.dataGlobal->PreviousHour, loop, IL, 2);
- auto &bfskhr2 = state.dataDaylightingManager->BFSKHR(2);
+ auto &bfskhr2 = state.dataDaylightingManager->BFSKHR[(int)WinCover::Shaded];
auto const &source2SkyCurr = thisDaylightControl.DaylSourceFacSky(state.dataGlobal->HourOfDay, loop, IL, 2);
auto const &source2SkyPrev = thisDaylightControl.DaylSourceFacSky(state.dataGlobal->PreviousHour, loop, IL, 2);
- auto &sfskhr2 = state.dataDaylightingManager->SFSKHR(2);
+ auto &sfskhr2 = state.dataDaylightingManager->SFSKHR[(int)WinCover::Shaded];
int SurfWinSlatsAngIndex = state.dataSurface->SurfWinSlatsAngIndex(IWin);
int slatAngLo = SurfWinSlatsAngIndex + 1;
@@ -6232,21 +6209,21 @@ void DayltgInteriorIllum(EnergyPlusData &state,
} // for (iSky)
// Sun daylight factor for bare/shaded window
- state.dataDaylightingManager->DFSUHR(1) =
+ state.dataDaylightingManager->DFSUHR[(int)WinCover::Bare] =
VTRatio * (wgtCurrHr * (thisDaylightControl.DaylIllFacSun(state.dataGlobal->HourOfDay, loop, IL, 1) +
thisDaylightControl.DaylIllFacSunDisk(state.dataGlobal->HourOfDay, loop, IL, 1)) +
wgtPrevHr * (thisDaylightControl.DaylIllFacSun(state.dataGlobal->PreviousHour, loop, IL, 1) +
thisDaylightControl.DaylIllFacSunDisk(state.dataGlobal->PreviousHour, loop, IL, 1)));
// Sun background luminance factor for bare/shaded window
- state.dataDaylightingManager->BFSUHR(1) =
+ state.dataDaylightingManager->BFSUHR[(int)WinCover::Bare] =
VTRatio * (wgtCurrHr * (thisDaylightControl.DaylBackFacSun(state.dataGlobal->HourOfDay, loop, IL, 1) +
thisDaylightControl.DaylBackFacSunDisk(state.dataGlobal->HourOfDay, loop, IL, 1)) +
wgtPrevHr * (thisDaylightControl.DaylBackFacSun(state.dataGlobal->PreviousHour, loop, IL, 1) +
thisDaylightControl.DaylBackFacSunDisk(state.dataGlobal->PreviousHour, loop, IL, 1)));
// Sun source luminance factor for bare/shaded window
- state.dataDaylightingManager->SFSUHR(1) =
+ state.dataDaylightingManager->SFSUHR[(int)WinCover::Bare] =
VTRatio * (wgtCurrHr * (thisDaylightControl.DaylSourceFacSun(state.dataGlobal->HourOfDay, loop, IL, 1) +
thisDaylightControl.DaylSourceFacSunDisk(state.dataGlobal->HourOfDay, loop, IL, 1)) +
wgtPrevHr * (thisDaylightControl.DaylSourceFacSun(state.dataGlobal->PreviousHour, loop, IL, 1) +
@@ -6257,28 +6234,28 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// ===Shaded window or window with diffusing glass===
if (!state.dataSurface->SurfWinMovableSlats(IWin)) {
// Shade, screen, blind with fixed slats, or diffusing glass
- state.dataDaylightingManager->DFSUHR(2) =
+ state.dataDaylightingManager->DFSUHR[(int)WinCover::Shaded] =
VTRatio * (wgtCurrHr * thisDaylightControl.DaylIllFacSun(state.dataGlobal->HourOfDay, loop, IL, 2) +
wgtPrevHr * thisDaylightControl.DaylIllFacSun(state.dataGlobal->PreviousHour, loop, IL, 2));
- state.dataDaylightingManager->BFSUHR(2) =
+ state.dataDaylightingManager->BFSUHR[(int)WinCover::Shaded] =
VTRatio * (wgtCurrHr * thisDaylightControl.DaylBackFacSun(state.dataGlobal->HourOfDay, loop, IL, 2) +
wgtPrevHr * thisDaylightControl.DaylBackFacSun(state.dataGlobal->PreviousHour, loop, IL, 2));
- state.dataDaylightingManager->SFSUHR(2) =
+ state.dataDaylightingManager->SFSUHR[(int)WinCover::Shaded] =
VTRatio * (wgtCurrHr * thisDaylightControl.DaylSourceFacSun(state.dataGlobal->HourOfDay, loop, IL, 2) +
wgtPrevHr * thisDaylightControl.DaylSourceFacSun(state.dataGlobal->PreviousHour, loop, IL, 2));
if (!state.dataSurface->SurfWinSlatsBlockBeam(IWin)) {
- state.dataDaylightingManager->DFSUHR(2) +=
+ state.dataDaylightingManager->DFSUHR[(int)WinCover::Shaded] +=
VTRatio * (wgtCurrHr * thisDaylightControl.DaylIllFacSunDisk(state.dataGlobal->HourOfDay, loop, IL, 2) +
wgtPrevHr * thisDaylightControl.DaylIllFacSunDisk(state.dataGlobal->PreviousHour, loop, IL, 2));
- state.dataDaylightingManager->BFSUHR(2) +=
+ state.dataDaylightingManager->BFSUHR[(int)WinCover::Shaded] +=
VTRatio * (wgtCurrHr * thisDaylightControl.DaylBackFacSunDisk(state.dataGlobal->HourOfDay, loop, IL, 2) +
wgtPrevHr * thisDaylightControl.DaylBackFacSunDisk(state.dataGlobal->PreviousHour, loop, IL, 2));
- state.dataDaylightingManager->SFSUHR(2) +=
+ state.dataDaylightingManager->SFSUHR[(int)WinCover::Shaded] +=
VTRatio * (wgtCurrHr * thisDaylightControl.DaylSourceFacSunDisk(state.dataGlobal->HourOfDay, loop, IL, 2) +
wgtPrevHr * thisDaylightControl.DaylSourceFacSunDisk(state.dataGlobal->PreviousHour, loop, IL, 2));
}
@@ -6310,9 +6287,12 @@ void DayltgInteriorIllum(EnergyPlusData &state,
General::Interp(thisDaylightControl.DaylSourceFacSun(state.dataGlobal->PreviousHour, loop, IL, slatAngLo),
thisDaylightControl.DaylSourceFacSun(state.dataGlobal->PreviousHour, loop, IL, slatAngHi),
SurfWinSlatsAngInterpFac);
- state.dataDaylightingManager->DFSUHR(2) = VTRatio * (wgtCurrHr * DaylIllFacSunNow + wgtPrevHr * DaylIllFacSunPrev);
- state.dataDaylightingManager->BFSUHR(2) = VTRatio * (wgtCurrHr * DaylBackFacSunNow + wgtPrevHr * DaylBackFacSunPrev);
- state.dataDaylightingManager->SFSUHR(2) = VTRatio * (wgtCurrHr * DaylSourceFacSunNow + wgtPrevHr * DaylSourceFacSunPrev);
+ state.dataDaylightingManager->DFSUHR[(int)WinCover::Shaded] =
+ VTRatio * (wgtCurrHr * DaylIllFacSunNow + wgtPrevHr * DaylIllFacSunPrev);
+ state.dataDaylightingManager->BFSUHR[(int)WinCover::Shaded] =
+ VTRatio * (wgtCurrHr * DaylBackFacSunNow + wgtPrevHr * DaylBackFacSunPrev);
+ state.dataDaylightingManager->SFSUHR[(int)WinCover::Shaded] =
+ VTRatio * (wgtCurrHr * DaylSourceFacSunNow + wgtPrevHr * DaylSourceFacSunPrev);
// We add the contribution from the solar disk if slats do not block beam solar
// TH CR 8010, DaylIllFacSunDisk needs to be interpolated
@@ -6341,9 +6321,11 @@ void DayltgInteriorIllum(EnergyPlusData &state,
General::Interp(thisDaylightControl.DaylSourceFacSunDisk(state.dataGlobal->PreviousHour, loop, IL, slatAngLo),
thisDaylightControl.DaylSourceFacSunDisk(state.dataGlobal->PreviousHour, loop, IL, slatAngHi),
SurfWinSlatsAngInterpFac);
- state.dataDaylightingManager->DFSUHR(2) += VTRatio * (wgtCurrHr * DaylIllFacSunDiskNow + wgtPrevHr * DaylIllFacSunDiskPrev);
- state.dataDaylightingManager->BFSUHR(2) += VTRatio * (wgtCurrHr * DaylBackFacSunDiskNow + wgtPrevHr * DaylBackFacSunDiskPrev);
- state.dataDaylightingManager->SFSUHR(2) +=
+ state.dataDaylightingManager->DFSUHR[(int)WinCover::Shaded] +=
+ VTRatio * (wgtCurrHr * DaylIllFacSunDiskNow + wgtPrevHr * DaylIllFacSunDiskPrev);
+ state.dataDaylightingManager->BFSUHR[(int)WinCover::Shaded] +=
+ VTRatio * (wgtCurrHr * DaylBackFacSunDiskNow + wgtPrevHr * DaylBackFacSunDiskPrev);
+ state.dataDaylightingManager->SFSUHR[(int)WinCover::Shaded] +=
VTRatio * (wgtCurrHr * DaylSourceFacSunDiskNow + wgtPrevHr * DaylSourceFacSunDiskPrev);
}
} // End of check if window has blind with movable slats
@@ -6372,32 +6354,34 @@ void DayltgInteriorIllum(EnergyPlusData &state,
HorIllSkyFac = state.dataEnvrn->HISKF / ((1 - SkyWeight) * horIllSky2 + SkyWeight * horIllSky1);
- for (int IS = 1; IS <= 2; ++IS) {
- auto const &dfskhr = state.dataDaylightingManager->DFSKHR(IS);
- auto const &bfskhr = state.dataDaylightingManager->BFSKHR(IS);
- auto const &sfskhr = state.dataDaylightingManager->SFSKHR(IS);
+ for (int iWinCover = 0; iWinCover < (int)WinCover::Num; ++iWinCover) {
+ auto const &dfskhr = state.dataDaylightingManager->DFSKHR[iWinCover];
+ auto const &bfskhr = state.dataDaylightingManager->BFSKHR[iWinCover];
+ auto const &sfskhr = state.dataDaylightingManager->SFSKHR[iWinCover];
- if (IS == 2 && !ShadedOrDiffusingGlassWin) break;
+ // What is this?
+ if (iWinCover == (int)WinCover::Shaded && !ShadedOrDiffusingGlassWin) break;
- thisDaylightControl.IllumFromWinAtRefPt(loop, IS, IL) =
- state.dataDaylightingManager->DFSUHR(IS) * state.dataEnvrn->HISUNF +
+ thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[iWinCover] =
+ state.dataDaylightingManager->DFSUHR[iWinCover] * state.dataEnvrn->HISUNF +
HorIllSkyFac * (dfskhr.sky[iSky1] * SkyWeight * horIllSky1 + dfskhr.sky[iSky2] * (1.0 - SkyWeight) * horIllSky2);
- thisDaylightControl.BackLumFromWinAtRefPt(loop, IS, IL) =
- state.dataDaylightingManager->BFSUHR(IS) * state.dataEnvrn->HISUNF +
+ thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[iWinCover] =
+ state.dataDaylightingManager->BFSUHR[iWinCover] * state.dataEnvrn->HISUNF +
HorIllSkyFac * (bfskhr.sky[iSky1] * SkyWeight * horIllSky1 + bfskhr.sky[iSky2] * (1.0 - SkyWeight) * horIllSky2);
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, IS, IL) =
- state.dataDaylightingManager->SFSUHR(IS) * state.dataEnvrn->HISUNF +
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[iWinCover] =
+ state.dataDaylightingManager->SFSUHR[iWinCover] * state.dataEnvrn->HISUNF +
HorIllSkyFac * (sfskhr.sky[iSky1] * SkyWeight * horIllSky1 + sfskhr.sky[iSky2] * (1.0 - SkyWeight) * horIllSky2);
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, IS, IL) = max(thisDaylightControl.SourceLumFromWinAtRefPt(loop, IS, IL), 0.0);
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[iWinCover] =
+ max(thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[iWinCover], 0.0);
// Added TH 1/21/2010 - save the original clear and dark (fully switched) states'
// zone daylighting values, needed for switachable glazings
- tmpIllumFromWinAtRefPt(loop, IS, IL) = thisDaylightControl.IllumFromWinAtRefPt(loop, IS, IL);
- tmpBackLumFromWinAtRefPt(loop, IS, IL) = thisDaylightControl.BackLumFromWinAtRefPt(loop, IS, IL);
- tmpSourceLumFromWinAtRefPt(loop, IS, IL) = thisDaylightControl.SourceLumFromWinAtRefPt(loop, IS, IL);
- } // IS
+ tmpIllumFromWinAtRefPt(loop, IL)[iWinCover] = thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[iWinCover];
+ tmpBackLumFromWinAtRefPt(loop, IL)[iWinCover] = thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[iWinCover];
+ tmpSourceLumFromWinAtRefPt(loop, IL)[iWinCover] = thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[iWinCover];
+ } // for for (iWinCover)
} // End of reference point loop, IL
} // End of first loop over exterior windows associated with this zone
@@ -6429,8 +6413,8 @@ void DayltgInteriorIllum(EnergyPlusData &state,
int IS = findWinShadingStatus(state, IWin);
for (int IL = 1; IL <= NREFPT; ++IL) {
- state.dataDaylightingManager->DaylIllum(IL) += thisDaylightControl.IllumFromWinAtRefPt(loop, IS, IL);
- thisDaylightControl.BacLum(IL) += thisDaylightControl.BackLumFromWinAtRefPt(loop, IS, IL);
+ state.dataDaylightingManager->DaylIllum(IL) += thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[IS - 1];
+ thisDaylightControl.BacLum(IL) += thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[IS - 1];
}
} // End of second window loop over exterior windows associated with this zone
@@ -6470,13 +6454,14 @@ void DayltgInteriorIllum(EnergyPlusData &state,
if (state.dataSurface->SurfWinShadingFlag(IWin) == WinShadingType::GlassConditionallyLightened &&
state.dataSurface->WindowShadingControl(ICtrl).shadingControlType == WindowShadingControlType::MeetDaylIlumSetp &&
!previously_shaded(loop)) {
- DILLSW(igroup) += thisDaylightControl.IllumFromWinAtRefPt(loop, IS, 1);
+ DILLSW(igroup) += thisDaylightControl.IllumFromWinAtRefPt(loop, 1)[IS - 1];
previously_shaded(loop) = true;
} else {
if (!previously_shaded(loop)) {
- DILLUN(igroup) += thisDaylightControl.IllumFromWinAtRefPt(loop, IS, 1);
+ DILLUN(igroup) += thisDaylightControl.IllumFromWinAtRefPt(loop, 1)[IS - 1];
} else {
- DILLUN(igroup) += thisDaylightControl.IllumFromWinAtRefPt(loop, 2, 1); // use the shaded state if previously shaded
+ DILLUN(igroup) += thisDaylightControl.IllumFromWinAtRefPt(
+ loop, 1)[(int)WinCover::Shaded]; // use the shaded state if previously shaded
}
}
}
@@ -6557,16 +6542,16 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// and need to adjusted for intermediate switched state at VisTransSelected: IS = 2
int IS = 1;
VTRAT = state.dataSurface->SurfWinVisTransSelected(IWin) / (thisTVIS1 + 0.000001);
- state.dataDaylightingManager->DaylIllum(IL) += (VTRAT - 1.0) * thisDaylightControl.IllumFromWinAtRefPt(loop, IS, IL);
- thisDaylightControl.BacLum(IL) += (VTRAT - 1.0) * thisDaylightControl.BackLumFromWinAtRefPt(loop, IS, IL);
+ state.dataDaylightingManager->DaylIllum(IL) += (VTRAT - 1.0) * thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[IS - 1];
+ thisDaylightControl.BacLum(IL) += (VTRAT - 1.0) * thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[IS - 1];
// Adjust illum, background illum and source luminance for this window in intermediate switched state
// for later use in the DayltgGlare calc because SurfaceWindow(IWin)%ShadingFlag = WinShadingType::SwitchableGlazing = 2
IS = 2;
VTRAT = state.dataSurface->SurfWinVisTransSelected(IWin) / (thisTVIS2 + 0.000001);
- thisDaylightControl.IllumFromWinAtRefPt(loop, IS, IL) = VTRAT * tmpIllumFromWinAtRefPt(loop, IS, IL);
- thisDaylightControl.BackLumFromWinAtRefPt(loop, IS, IL) = VTRAT * tmpBackLumFromWinAtRefPt(loop, IS, IL);
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, IS, IL) = VTRAT * tmpSourceLumFromWinAtRefPt(loop, IS, IL);
+ thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[IS - 1] = VTRAT * tmpIllumFromWinAtRefPt(loop, IL)[IS - 1];
+ thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[IS - 1] = VTRAT * tmpBackLumFromWinAtRefPt(loop, IL)[IS - 1];
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[IS - 1] = VTRAT * tmpSourceLumFromWinAtRefPt(loop, IL)[IS - 1];
} // IL
} // ASETIL < 1
}
@@ -6602,15 +6587,16 @@ void DayltgInteriorIllum(EnergyPlusData &state,
(currentFlag == WinShadingType::ExtShadeConditionallyOff) || (currentFlag == WinShadingType::IntBlindConditionallyOff) ||
(currentFlag == WinShadingType::ExtBlindConditionallyOff) || (currentFlag == WinShadingType::BGShadeConditionallyOff) ||
(currentFlag == WinShadingType::BGBlindConditionallyOff)) {
- if (thisDaylightControl.SourceLumFromWinAtRefPt(loop, 1, 1) > state.dataSurface->WindowShadingControl(ICtrl).SetPoint2) {
+ if (thisDaylightControl.SourceLumFromWinAtRefPt(loop, 1)[(int)WinCover::Bare] >
+ state.dataSurface->WindowShadingControl(ICtrl).SetPoint2) {
// shade on if luminance of this window is above setpoint
state.dataSurface->SurfWinShadingFlag(IWin) = ShType;
// update total illuminance and background luminance
for (int IL = 1; IL <= NREFPT; ++IL) {
- state.dataDaylightingManager->DaylIllum(IL) +=
- thisDaylightControl.IllumFromWinAtRefPt(loop, 2, IL) - thisDaylightControl.IllumFromWinAtRefPt(loop, 1, IL);
- thisDaylightControl.BacLum(IL) +=
- thisDaylightControl.BackLumFromWinAtRefPt(loop, 2, IL) - thisDaylightControl.BackLumFromWinAtRefPt(loop, 1, IL);
+ state.dataDaylightingManager->DaylIllum(IL) += thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] -
+ thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[(int)WinCover::Bare];
+ thisDaylightControl.BacLum(IL) += thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] -
+ thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Bare];
}
} else {
// shade off if luminance is below setpoint
@@ -6642,9 +6628,9 @@ void DayltgInteriorIllum(EnergyPlusData &state,
}
if (GlareFlag) {
- bool &blnCycle = state.dataDaylightingManager->blnCycle;
- bool &GlareOK = state.dataDaylightingManager->GlareOK;
- Real64 &tmpMult = state.dataDaylightingManager->tmpMult;
+ bool blnCycle;
+ bool GlareOK;
+ Real64 tmpMult;
// Glare is too high at a ref pt. Loop through windows.
count = 0;
@@ -6684,9 +6670,11 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// window without shading (IS=1) and with shading (IS=2) for each ref pt
// For switchable windows, this may be partially switched rather than fully dark
for (int IL = 1; IL <= NREFPT; ++IL) {
- for (int IS = 1; IS <= 2; ++IS) {
- state.dataDaylightingManager->WDAYIL(IS, IL, igroup) = thisDaylightControl.IllumFromWinAtRefPt(loop, IS, IL);
- state.dataDaylightingManager->WBACLU(IS, IL, igroup) = thisDaylightControl.BackLumFromWinAtRefPt(loop, IS, IL);
+ for (int iWinCover = 0; iWinCover < (int)WinCover::Num; ++iWinCover) {
+ state.dataDaylightingManager->WDAYIL(IL, igroup)[iWinCover] =
+ thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[iWinCover];
+ state.dataDaylightingManager->WBACLU(IL, igroup)[iWinCover] =
+ thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[iWinCover];
}
}
@@ -6696,20 +6684,22 @@ void DayltgInteriorIllum(EnergyPlusData &state,
if (state.dataSurface->SurfWinShadingFlag(IWin) != WinShadingType::SwitchableGlazing) {
// for non switchable glazings or switchable glazings not switched yet (still in clear state)
// SurfaceWindow(IWin)%ShadingFlag = WinShadingFlag::GlassConditionallyLightened
- state.dataDaylightingManager->RDAYIL(IL, igroup) = state.dataDaylightingManager->DaylIllum(IL) -
- state.dataDaylightingManager->WDAYIL(1, IL, igroup) +
- state.dataDaylightingManager->WDAYIL(2, IL, igroup);
- state.dataDaylightingManager->RBACLU(IL, igroup) = thisDaylightControl.BacLum(IL) -
- state.dataDaylightingManager->WBACLU(1, IL, igroup) +
- state.dataDaylightingManager->WBACLU(2, IL, igroup);
+ state.dataDaylightingManager->RDAYIL(IL, igroup) =
+ state.dataDaylightingManager->DaylIllum(IL) -
+ state.dataDaylightingManager->WDAYIL(IL, igroup)[(int)WinCover::Bare] +
+ state.dataDaylightingManager->WDAYIL(IL, igroup)[(int)WinCover::Shaded];
+ state.dataDaylightingManager->RBACLU(IL, igroup) =
+ thisDaylightControl.BacLum(IL) - state.dataDaylightingManager->WBACLU(IL, igroup)[(int)WinCover::Bare] +
+ state.dataDaylightingManager->WBACLU(IL, igroup)[(int)WinCover::Shaded];
} else {
// switchable glazings already in partially switched state when calc the RDAYIL(IL) & RBACLU(IL)
- state.dataDaylightingManager->RDAYIL(IL, igroup) = state.dataDaylightingManager->DaylIllum(IL) -
- state.dataDaylightingManager->WDAYIL(2, IL, igroup) +
- tmpIllumFromWinAtRefPt(loop, 2, IL);
- state.dataDaylightingManager->RBACLU(IL, igroup) = thisDaylightControl.BacLum(IL) -
- state.dataDaylightingManager->WBACLU(2, IL, igroup) +
- tmpBackLumFromWinAtRefPt(loop, 2, IL);
+ state.dataDaylightingManager->RDAYIL(IL, igroup) =
+ state.dataDaylightingManager->DaylIllum(IL) -
+ state.dataDaylightingManager->WDAYIL(IL, igroup)[(int)WinCover::Shaded] +
+ tmpIllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ state.dataDaylightingManager->RBACLU(IL, igroup) =
+ thisDaylightControl.BacLum(IL) - state.dataDaylightingManager->WBACLU(IL, igroup)[(int)WinCover::Shaded] +
+ tmpBackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
}
}
@@ -6732,9 +6722,12 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// update ZoneDaylight(ZoneNum)%SourceLumFromWinAtRefPt(IL,2,loop) for use in DayltgGlare
if (state.dataSurface->SurfWinShadingFlag(IWin) == WinShadingType::SwitchableGlazing) {
for (int IL = 1; IL <= NREFPT; ++IL) {
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, 2, IL) = tmpSourceLumFromWinAtRefPt(loop, 2, IL);
- thisDaylightControl.IllumFromWinAtRefPt(loop, 2, IL) = tmpIllumFromWinAtRefPt(loop, 2, IL);
- thisDaylightControl.BackLumFromWinAtRefPt(loop, 2, IL) = tmpBackLumFromWinAtRefPt(loop, 2, IL);
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpSourceLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpIllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpBackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
}
int const IConst = state.dataSurface->SurfActiveConstruction(IWin);
@@ -6824,9 +6817,12 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// RESET properties for fully dark state
for (int IL = 1; IL <= NREFPT; ++IL) {
- thisDaylightControl.IllumFromWinAtRefPt(loop, 2, IL) = tmpIllumFromWinAtRefPt(loop, 2, IL);
- thisDaylightControl.BackLumFromWinAtRefPt(loop, 2, IL) = tmpBackLumFromWinAtRefPt(loop, 2, IL);
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, 2, IL) = tmpSourceLumFromWinAtRefPt(loop, 2, IL);
+ thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpIllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpBackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpSourceLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
}
}
@@ -6860,11 +6856,16 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// restore fully dark values
for (int IL = 1; IL <= NREFPT; ++IL) {
- state.dataDaylightingManager->WDAYIL(2, IL, igroup) = tmpIllumFromWinAtRefPt(loop, 2, IL);
- state.dataDaylightingManager->WBACLU(2, IL, igroup) = tmpBackLumFromWinAtRefPt(loop, 2, IL);
- thisDaylightControl.IllumFromWinAtRefPt(loop, 2, IL) = tmpIllumFromWinAtRefPt(loop, 2, IL);
- thisDaylightControl.BackLumFromWinAtRefPt(loop, 2, IL) = tmpBackLumFromWinAtRefPt(loop, 2, IL);
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, 2, IL) = tmpSourceLumFromWinAtRefPt(loop, 2, IL);
+ state.dataDaylightingManager->WDAYIL(IL, igroup)[(int)WinCover::Shaded] =
+ tmpIllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ state.dataDaylightingManager->WBACLU(IL, igroup)[(int)WinCover::Shaded] =
+ tmpBackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpIllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpBackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpSourceLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded];
}
}
@@ -6879,9 +6880,6 @@ void DayltgInteriorIllum(EnergyPlusData &state,
if (GlareOK) {
if (state.dataSurface->SurfWinShadingFlag(IWin) == WinShadingType::SwitchableGlazing &&
state.dataSurface->WindowShadingControl(ICtrl).shadingControlType == WindowShadingControlType::MeetDaylIlumSetp) {
- Real64 &tmpSWSL1 = state.dataDaylightingManager->tmpSWSL1;
- Real64 &tmpSWSL2 = state.dataDaylightingManager->tmpSWSL2;
- Real64 &tmpSWFactor = state.dataDaylightingManager->tmpSWFactor;
// Added TH 1/14/2010
// Only for switchable glazings with MeetDaylightIlluminanceSetpoint control
// The glazing is in fully dark state, it might lighten a bit to provide more daylight
@@ -6889,30 +6887,32 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// Iteration to find the right switching factor meeting the glare index
// get fully dark state values
- tmpSWSL1 = tmpSourceLumFromWinAtRefPt(loop, 2, 1);
- if (NREFPT > 1) tmpSWSL2 = tmpSourceLumFromWinAtRefPt(loop, 2, 2);
+ Real64 tmpSWSL1 = tmpSourceLumFromWinAtRefPt(loop, 1)[(int)WinCover::Shaded];
+ Real64 tmpSWSL2 = (NREFPT > 1) ? tmpSourceLumFromWinAtRefPt(loop, 2)[(int)WinCover::Shaded] : 0.0;
// use simple fixed step search in iteraction, can be improved in future
- tmpSWFactor = 1.0 - tmpSWIterStep;
+ Real64 tmpSWFactor = 1.0 - tmpSWIterStep;
while (tmpSWFactor > 0) {
// calc new glare at new switching state
for (int IL = 1; IL <= NREFPT; ++IL) {
state.dataDaylightingManager->RDAYIL(IL, igroup) =
- state.dataDaylightingManager->DaylIllum(IL) + (state.dataDaylightingManager->WDAYIL(1, IL, igroup) -
- state.dataDaylightingManager->WDAYIL(2, IL, igroup)) *
- (1.0 - tmpSWFactor);
+ state.dataDaylightingManager->DaylIllum(IL) +
+ (state.dataDaylightingManager->WDAYIL(IL, igroup)[(int)WinCover::Bare] -
+ state.dataDaylightingManager->WDAYIL(IL, igroup)[(int)WinCover::Shaded]) *
+ (1.0 - tmpSWFactor);
state.dataDaylightingManager->RBACLU(IL, igroup) =
- thisDaylightControl.BacLum(IL) + (state.dataDaylightingManager->WBACLU(1, IL, igroup) -
- state.dataDaylightingManager->WBACLU(2, IL, igroup)) *
- (1.0 - tmpSWFactor);
+ thisDaylightControl.BacLum(IL) +
+ (state.dataDaylightingManager->WBACLU(IL, igroup)[(int)WinCover::Bare] -
+ state.dataDaylightingManager->WBACLU(IL, igroup)[(int)WinCover::Shaded]) *
+ (1.0 - tmpSWFactor);
BACL = max(SetPnt(IL) * state.dataDaylightingData->enclDaylight(enclNum).aveVisDiffReflect / Constant::Pi,
state.dataDaylightingManager->RBACLU(IL, igroup));
// needs to update SourceLumFromWinAtRefPt(IL,2,loop) before re-calc DayltgGlare
tmpMult = (thisTVIS1 - (thisTVIS1 - thisTVIS2) * tmpSWFactor) / thisTVIS2;
if (IL == 1) {
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, 2, IL) = tmpSWSL1 * tmpMult;
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] = tmpSWSL1 * tmpMult;
} else {
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, 2, IL) = tmpSWSL2 * tmpMult;
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] = tmpSWSL2 * tmpMult;
}
// Calc new glare
DayltgGlare(state, IL, BACL, GLRNEW(IL), daylightCtrlNum);
@@ -6950,22 +6950,24 @@ void DayltgInteriorIllum(EnergyPlusData &state,
// Glare too high, use previous state and re-calc
for (int IL = 1; IL <= NREFPT; ++IL) {
state.dataDaylightingManager->RDAYIL(IL, igroup) =
- state.dataDaylightingManager->DaylIllum(IL) + (state.dataDaylightingManager->WDAYIL(1, IL, igroup) -
- state.dataDaylightingManager->WDAYIL(2, IL, igroup)) *
- (1.0 - tmpSWFactor);
+ state.dataDaylightingManager->DaylIllum(IL) +
+ (state.dataDaylightingManager->WDAYIL(IL, igroup)[(int)WinCover::Bare] -
+ state.dataDaylightingManager->WDAYIL(IL, igroup)[(int)WinCover::Shaded]) *
+ (1.0 - tmpSWFactor);
state.dataDaylightingManager->RBACLU(IL, igroup) =
- thisDaylightControl.BacLum(IL) + (state.dataDaylightingManager->WBACLU(1, IL, igroup) -
- state.dataDaylightingManager->WBACLU(2, IL, igroup)) *
- (1.0 - tmpSWFactor);
+ thisDaylightControl.BacLum(IL) +
+ (state.dataDaylightingManager->WBACLU(IL, igroup)[(int)WinCover::Bare] -
+ state.dataDaylightingManager->WBACLU(IL, igroup)[(int)WinCover::Shaded]) *
+ (1.0 - tmpSWFactor);
BACL = max(SetPnt(IL) * state.dataDaylightingData->enclDaylight(enclNum).aveVisDiffReflect / Constant::Pi,
state.dataDaylightingManager->RBACLU(IL, igroup));
// needs to update SourceLumFromWinAtRefPt(IL,2,IWin) before re-calc DayltgGlare
tmpMult = (thisTVIS1 - (thisTVIS1 - thisTVIS2) * tmpSWFactor) / thisTVIS2;
if (IL == 1) {
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, 2, 1) = tmpSWSL1 * tmpMult;
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, 1)[(int)WinCover::Shaded] = tmpSWSL1 * tmpMult;
} else {
- thisDaylightControl.SourceLumFromWinAtRefPt(loop, 2, 2) = tmpSWSL2 * tmpMult;
+ thisDaylightControl.SourceLumFromWinAtRefPt(loop, 2)[(int)WinCover::Shaded] = tmpSWSL2 * tmpMult;
}
DayltgGlare(state, IL, BACL, GLRNEW(IL), daylightCtrlNum);
}
@@ -6979,8 +6981,10 @@ void DayltgInteriorIllum(EnergyPlusData &state,
tmpMult = (thisTVIS1 - (thisTVIS1 - thisTVIS2) * tmpSWFactor) / thisTVIS2;
// update report variables
- thisDaylightControl.IllumFromWinAtRefPt(loop, 2, IL) = tmpIllumFromWinAtRefPt(loop, 2, IL) * tmpMult;
- thisDaylightControl.BackLumFromWinAtRefPt(loop, 2, IL) = tmpBackLumFromWinAtRefPt(loop, 2, IL) * tmpMult;
+ thisDaylightControl.IllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpIllumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] * tmpMult;
+ thisDaylightControl.BackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] =
+ tmpBackLumFromWinAtRefPt(loop, IL)[(int)WinCover::Shaded] * tmpMult;
}
state.dataSurface->SurfWinSwitchingFactor(IWin) = tmpSWFactor;
state.dataSurface->SurfWinVisTransSelected(IWin) = thisTVIS1 - (thisTVIS1 - thisTVIS2) * tmpSWFactor;
@@ -7358,18 +7362,18 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
// I = sky type;
// J = 1 for bare window, 2 and above for window with shade or blind.
auto &ZSK = state.dataDaylightingManager->ZSK;
- auto &U = state.dataDaylightingManager->U;
- auto &DayltgInterReflectedIllumNearestHitPt = state.dataDaylightingManager->DayltgInterReflectedIllumNearestHitPt;
- auto &DayltgInterReflectedIllumObsHitPt = state.dataDaylightingManager->DayltgInterReflectedIllumObsHitPt;
- auto &DayltgInterReflectedIllumGroundHitPt = state.dataDaylightingManager->DayltgInterReflectedIllumGroundHitPt;
+ Vector3 U; // Unit vector in (PH,TH) direction
+ Vector3 nearestHitPt; // Hit point of ray on nearest obstruction (m)
+ Vector3 obsHitPt; // Coordinates of hit point on an obstruction (m)
+ Vector3 groundHitPt; // Coordinates of point that ray from window center hits the ground (m)
auto &SkyObstructionMult = state.dataDaylightingManager->SkyObstructionMult;
auto &FLFWSK = state.dataDaylightingManager->FLFWSK;
auto &FLFWSU = state.dataDaylightingManager->FLFWSU;
auto &FLFWSUdisk = state.dataDaylightingManager->FLFWSUdisk;
auto &FLCWSK = state.dataDaylightingManager->FLCWSK;
auto &FLCWSU = state.dataDaylightingManager->FLCWSU;
- auto &TransMult = state.dataDaylightingManager->TransMult;
- auto &DayltgInterReflectedIllumTransBmBmMult = state.dataDaylightingManager->DayltgInterReflectedIllumTransBmBmMult;
+ std::array transMult;
+ std::array transBmBmMult;
auto &ObTransM = state.dataDaylightingManager->ObTransM;
// 3=intermediate, 4=overcast
@@ -7582,8 +7586,8 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
// Determine net transmittance of obstructions that the ray hits. ObTrans will be 1.0
// if no obstructions are hit.
DayltgHitObstruction(state, IHR, IWin, state.dataSurface->SurfaceWindow(IWin).WinCenter, U, ObTrans);
- ObTransM(IPH, ITH) = ObTrans;
- SkyObstructionMult(IPH, ITH) = 1.0;
+ ObTransM[IPH][ITH] = ObTrans;
+ SkyObstructionMult[IPH][ITH] = 1.0;
}
// SKY AND GROUND RADIATION ON WINDOW
@@ -7594,10 +7598,10 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
if (PH > 0.0) { // Contribution is from sky
for (int iSky = (int)SkyType::Clear; iSky < (int)SkyType::Num; ++iSky) {
- ZSK.sky[iSky] = DayltgSkyLuminance(state, static_cast(iSky), TH, PH) * COSB * DA * ObTransM(IPH, ITH);
+ ZSK.sky[iSky] = DayltgSkyLuminance(state, static_cast(iSky), TH, PH) * COSB * DA * ObTransM[IPH][ITH];
}
} else { // PH <= 0.0; contribution is from ground
- if (state.dataSurface->CalcSolRefl && ObTransM(IPH, ITH) > 1.e-6 && ISunPos == 1) {
+ if (state.dataSurface->CalcSolRefl && ObTransM[IPH][ITH] > 1.e-6 && ISunPos == 1) {
// Calculate effect of obstructions on shading of sky diffuse reaching the ground point hit
// by the ray. This effect is given by the ratio SkyObstructionMult =
// (obstructed sky diffuse at ground point)/(unobstructed sky diffuse at ground point).
@@ -7606,48 +7610,47 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
Alfa = std::acos(-U.z);
Beta = std::atan2(U.y, U.x);
HorDis = (state.dataSurface->SurfaceWindow(IWin).WinCenter.z - state.dataSurface->GroundLevelZ) * std::tan(Alfa);
- DayltgInterReflectedIllumGroundHitPt.z = state.dataSurface->GroundLevelZ;
- DayltgInterReflectedIllumGroundHitPt.x = state.dataSurface->SurfaceWindow(IWin).WinCenter.x + HorDis * std::cos(Beta);
- DayltgInterReflectedIllumGroundHitPt.y = state.dataSurface->SurfaceWindow(IWin).WinCenter.y + HorDis * std::sin(Beta);
+ groundHitPt.z = state.dataSurface->GroundLevelZ;
+ groundHitPt.x = state.dataSurface->SurfaceWindow(IWin).WinCenter.x + HorDis * std::cos(Beta);
+ groundHitPt.y = state.dataSurface->SurfaceWindow(IWin).WinCenter.y + HorDis * std::sin(Beta);
- SkyObstructionMult(IPH, ITH) = CalcObstrMultiplier(
- state, DayltgInterReflectedIllumGroundHitPt, AltAngStepsForSolReflCalc, DataSurfaces::AzimAngStepsForSolReflCalc);
+ SkyObstructionMult[IPH][ITH] =
+ CalcObstrMultiplier(state, groundHitPt, AltAngStepsForSolReflCalc, DataSurfaces::AzimAngStepsForSolReflCalc);
} // End of check if solar reflection calc is in effect
auto const &gilsk = state.dataDaylightingManager->GILSK(IHR);
for (int iSky = (int)SkyType::Clear; iSky < (int)SkyType::Num; ++iSky) {
// Below, luminance of ground in cd/m2 is illuminance on ground in lumens/m2
// times ground reflectance, divided by pi, times obstruction multiplier.
- ZSK.sky[iSky] = (gilsk.sky[iSky] * state.dataEnvrn->GndReflectanceForDayltg / Constant::Pi) * COSB * DA * ObTransM(IPH, ITH) *
- SkyObstructionMult(IPH, ITH);
+ ZSK.sky[iSky] = (gilsk.sky[iSky] * state.dataEnvrn->GndReflectanceForDayltg / Constant::Pi) * COSB * DA * ObTransM[IPH][ITH] *
+ SkyObstructionMult[IPH][ITH];
}
// Determine if sun illuminates the point that ray hits the ground. If the solar reflection
// calculation has been requested (CalcSolRefl = .TRUE.) shading by obstructions, including
// the building itself, is considered in determining whether sun hits the ground point.
// Otherwise this shading is ignored and the sun always hits the ground point.
SunObstructionMult = 1.0;
- if (state.dataSurface->CalcSolRefl && ObTransM(IPH, ITH) > 1.e-6) {
+ if (state.dataSurface->CalcSolRefl && ObTransM[IPH][ITH] > 1.e-6 && ISunPos == 1) {
// Sun reaches ground point if vector from this point to the sun is unobstructed
hitObs = false;
for (int ObsSurfNum : state.dataSurface->AllShadowPossObstrSurfaceList) {
- PierceSurface(state, ObsSurfNum, DayltgInterReflectedIllumGroundHitPt, SUNCOS_IHR, DayltgInterReflectedIllumObsHitPt, hitObs);
+ PierceSurface(state, ObsSurfNum, groundHitPt, SUNCOS_IHR, obsHitPt, hitObs);
if (hitObs) break;
}
if (hitObs) SunObstructionMult = 0.0;
}
ZSU = (state.dataDaylightingManager->GILSU(IHR) * state.dataEnvrn->GndReflectanceForDayltg / Constant::Pi) * COSB * DA *
- ObTransM(IPH, ITH) * SunObstructionMult;
+ ObTransM[IPH][ITH] * SunObstructionMult;
}
// BEAM SOLAR AND SKY SOLAR REFLECTED FROM NEAREST OBSTRUCTION
- if (state.dataSurface->CalcSolRefl && ObTransM(IPH, ITH) < 1.0) {
+ if (state.dataSurface->CalcSolRefl && ObTransM[IPH][ITH] < 1.0) {
// Find obstruction whose hit point is closest to the center of the window
- DayltgClosestObstruction(
- state, state.dataSurface->SurfaceWindow(IWin).WinCenter, U, NearestHitSurfNum, DayltgInterReflectedIllumNearestHitPt);
+ DayltgClosestObstruction(state, state.dataSurface->SurfaceWindow(IWin).WinCenter, U, NearestHitSurfNum, nearestHitPt);
if (NearestHitSurfNum > 0) {
// Beam solar reflected from nearest obstruction.
- DayltgSurfaceLumFromSun(state, IHR, U, NearestHitSurfNum, DayltgInterReflectedIllumNearestHitPt, LumAtHitPtFrSun);
+ DayltgSurfaceLumFromSun(state, IHR, U, NearestHitSurfNum, nearestHitPt, LumAtHitPtFrSun);
ZSUObsRefl = LumAtHitPtFrSun * COSB * DA;
ZSU += ZSUObsRefl;
@@ -7761,12 +7764,7 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
for (int IntWinLoop = 1; IntWinLoop <= thisEnclDaylight.IntWinAdjEnclExtWin(IntWinAdjZoneExtWinNum).NumOfIntWindows;
++IntWinLoop) {
IntWinNum = thisEnclDaylight.IntWinAdjEnclExtWin(IntWinAdjZoneExtWinNum).IntWinNum(IntWinLoop);
- PierceSurface(state,
- IntWinNum,
- state.dataSurface->SurfaceWindow(IntWinNum).WinCenter,
- SUNCOS_IHR,
- DayltgInterReflectedIllumObsHitPt,
- hitObs);
+ PierceSurface(state, IntWinNum, state.dataSurface->SurfaceWindow(IntWinNum).WinCenter, SUNCOS_IHR, obsHitPt, hitObs);
if (hitObs) { // disk passes thru
// cosine of incidence angle of light from sky or ground element for
COSBintWin = SPH * std::sin(state.dataSurface->SurfWinPhi(IntWinNum)) +
@@ -7841,16 +7839,16 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
if (state.dataSurface->SurfWinSolarDiffusing(IWin)) IConstShaded = state.dataSurface->Surface(IWin).Construction;
// Transmittance of window including shade, screen or blind
- DayltgInterReflectedIllumTransBmBmMult = 0.0;
- TransMult = 0.0;
+ std::fill(transBmBmMult.begin(), transBmBmMult.end(), 0.0);
+ std::fill(transMult.begin(), transMult.end(), 0.0);
if (ShadeOn) { // Shade
if (state.dataSurface->SurfWinOriginalClass(IWin) == SurfaceClass::TDD_Dome) {
// Shaded visible transmittance of TDD for a single ray from sky/ground element
- TransMult(1) = TransTDD(state, PipeNum, COSB, RadType::VisibleBeam) * state.dataSurface->SurfWinGlazedFrac(IWin);
+ transMult[1] = TransTDD(state, PipeNum, COSB, RadType::VisibleBeam) * state.dataSurface->SurfWinGlazedFrac(IWin);
} else { // Shade only, no TDD
// Calculate transmittance of the combined window and shading device for this sky/ground element
- TransMult(1) = General::POLYF(COSB, state.dataConstruction->Construct(IConstShaded).TransVisBeamCoef) *
+ transMult[1] = General::POLYF(COSB, state.dataConstruction->Construct(IConstShaded).TransVisBeamCoef) *
state.dataSurface->SurfWinGlazedFrac(IWin) * state.dataSurface->SurfWinLightWellEff(IWin);
}
@@ -7860,11 +7858,10 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
ReflGlDiffDiffFront = state.dataConstruction->Construct(IConst).ReflectVisDiffFront;
ReflScDiffDiffBack = state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).DifReflectVis;
TransScBmDiffFront = state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).BmDifTransVis;
- TransMult(1) = TransScBmDiffFront * state.dataSurface->SurfWinGlazedFrac(IWin) *
+ transMult[1] = TransScBmDiffFront * state.dataSurface->SurfWinGlazedFrac(IWin) *
state.dataConstruction->Construct(IConst).TransDiffVis / (1 - ReflGlDiffDiffFront * ReflScDiffDiffBack) *
state.dataSurface->SurfWinLightWellEff(IWin);
- DayltgInterReflectedIllumTransBmBmMult(1) =
- state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).BmBmTransVis;
+ transBmBmMult[1] = state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).BmBmTransVis;
} else if (BlindOn) { // Blind: get beam-diffuse and beam-beam vis trans of blind+glazing system
// PETER: As long as only interior blinds are allowed for TDDs, no need to change TransMult calculation
@@ -7884,13 +7881,13 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
WindowManager::InterpProfAng(ProfAng, state.dataMaterial->Blind(BlNum).VisFrontBeamDiffRefl(JB, {1, 37}));
ReflBlDiffDiffFront = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffRefl(JB);
TransBlDiffDiffFront = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffTrans(JB);
- TransMult(JB) = TVISBR * (TransBlBmDiffFront + ReflBlBmDiffFront * ReflGlDiffDiffBack * TransBlDiffDiffFront /
+ transMult[JB] = TVISBR * (TransBlBmDiffFront + ReflBlBmDiffFront * ReflGlDiffDiffBack * TransBlDiffDiffFront /
(1.0 - ReflBlDiffDiffFront * ReflGlDiffDiffBack));
} else if (ShType == WinShadingType::ExtBlind) { // Exterior blind
ReflGlDiffDiffFront = state.dataConstruction->Construct(IConst).ReflectVisDiffFront;
ReflBlDiffDiffBack = state.dataMaterial->Blind(BlNum).VisBackDiffDiffRefl(JB);
- TransMult(JB) = TransBlBmDiffFront * state.dataSurface->SurfWinGlazedFrac(IWin) *
+ transMult[JB] = TransBlBmDiffFront * state.dataSurface->SurfWinGlazedFrac(IWin) *
state.dataConstruction->Construct(IConst).TransDiffVis /
(1.0 - ReflGlDiffDiffFront * ReflBlDiffDiffBack) * state.dataSurface->SurfWinLightWellEff(IWin);
@@ -7904,14 +7901,14 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
rfshB = WindowManager::InterpProfAng(ProfAng, state.dataMaterial->Blind(BlNum).VisFrontBeamDiffRefl(JB, {1, 37}));
rbshd = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffRefl(JB);
if (state.dataConstruction->Construct(IConst).TotGlassLayers == 2) { // 2 glass layers
- TransMult(JB) =
+ transMult[JB] =
t1 * (tfshBd * (1.0 + rfd2 * rbshd) + rfshB * rbd1 * tfshd) * td2 * state.dataSurface->SurfWinLightWellEff(IWin);
} else { // 3 glass layers; blind between layers 2 and 3
t2 = General::POLYF(COSB, state.dataConstruction->Construct(IConst).tBareVisCoef(2));
td3 = state.dataConstruction->Construct(IConst).tBareVisDiff(3);
rfd3 = state.dataConstruction->Construct(IConst).rfBareVisDiff(3);
rbd2 = state.dataConstruction->Construct(IConst).rbBareVisDiff(2);
- TransMult(JB) = t1 * t2 * (tfshBd * (1.0 + rfd3 * rbshd) + rfshB * (rbd2 * tfshd + td2 * rbd1 * td2 * tfshd)) * td3 *
+ transMult[JB] = t1 * t2 * (tfshBd * (1.0 + rfd3 * rbshd) + rfshB * (rbd2 * tfshd + td2 * rbd1 * td2 * tfshd)) * td3 *
state.dataSurface->SurfWinLightWellEff(IWin);
}
}
@@ -7921,27 +7918,26 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
} else {
SlatAng = state.dataMaterial->Blind(BlNum).SlatAngle * Constant::DegToRadians;
}
- DayltgInterReflectedIllumTransBmBmMult(JB) =
- TVISBR * WindowManager::BlindBeamBeamTrans(ProfAng,
- SlatAng,
- state.dataMaterial->Blind(BlNum).SlatWidth,
- state.dataMaterial->Blind(BlNum).SlatSeparation,
- state.dataMaterial->Blind(BlNum).SlatThickness);
+ transBmBmMult[JB] = TVISBR * WindowManager::BlindBeamBeamTrans(ProfAng,
+ SlatAng,
+ state.dataMaterial->Blind(BlNum).SlatWidth,
+ state.dataMaterial->Blind(BlNum).SlatSeparation,
+ state.dataMaterial->Blind(BlNum).SlatThickness);
} // End of loop over slat angles
} else { // Diffusing glass
- TransMult(1) = General::POLYF(COSB, state.dataConstruction->Construct(IConstShaded).TransVisBeamCoef) *
+ transMult[1] = General::POLYF(COSB, state.dataConstruction->Construct(IConstShaded).TransVisBeamCoef) *
state.dataSurface->SurfWinGlazedFrac(IWin) * state.dataSurface->SurfWinLightWellEff(IWin);
} // End of check if shade, blind or diffusing glass
if (state.dataSurface->SurfWinOriginalClass(IWin) == SurfaceClass::TDD_Dome) {
// No beam is transmitted. This takes care of all types of screens and blinds.
- DayltgInterReflectedIllumTransBmBmMult = 0.0;
+ std::fill(transBmBmMult.begin(), transBmBmMult.end(), 0.0);
}
// Daylighting shelf simplification: No beam makes it past end of shelf, all light is diffuse
- if (InShelfSurf > 0) { // Inside daylighting shelf
- DayltgInterReflectedIllumTransBmBmMult = 0.0; // No beam, diffuse only
+ if (InShelfSurf > 0) { // Inside daylighting shelf
+ std::fill(transBmBmMult.begin(), transBmBmMult.end(), 0.0);
}
// DayltgInterReflectedIllumTransBmBmMult is used in the following for windows with blinds or screens to get contribution from light
@@ -7957,27 +7953,27 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
for (int iSky = (int)SkyType::Clear; iSky < (int)SkyType::Num; ++iSky) {
- wlumsk.sky[iSky] += ZSK.sky[iSky] * TransMult(JB) / Constant::Pi;
- flfwsk.sky[iSky] += ZSK.sky[iSky] * TransMult(JB) * (1.0 - state.dataSurface->SurfWinFractionUpgoing(IWin));
- flcwsk.sky[iSky] += ZSK.sky[iSky] * TransMult(JB) * state.dataSurface->SurfWinFractionUpgoing(IWin);
+ wlumsk.sky[iSky] += ZSK.sky[iSky] * transMult[JB] / Constant::Pi;
+ flfwsk.sky[iSky] += ZSK.sky[iSky] * transMult[JB] * (1.0 - state.dataSurface->SurfWinFractionUpgoing(IWin));
+ flcwsk.sky[iSky] += ZSK.sky[iSky] * transMult[JB] * state.dataSurface->SurfWinFractionUpgoing(IWin);
if (BlindOn || ScreenOn) {
if (PH > 0.0) {
- flfwsk.sky[iSky] += ZSK.sky[iSky] * DayltgInterReflectedIllumTransBmBmMult(JB);
+ flfwsk.sky[iSky] += ZSK.sky[iSky] * transBmBmMult[JB];
} else {
- flcwsk.sky[iSky] += ZSK.sky[iSky] * DayltgInterReflectedIllumTransBmBmMult(JB);
+ flcwsk.sky[iSky] += ZSK.sky[iSky] * transBmBmMult[JB];
}
}
}
- state.dataDaylightingManager->WLUMSU(IHR, JB + 1) += ZSU * TransMult(JB) / Constant::Pi;
- FLFWSU(JB + 1) += ZSU * TransMult(JB) * (1.0 - state.dataSurface->SurfWinFractionUpgoing(IWin));
- FLCWSU(JB + 1) += ZSU * TransMult(JB) * state.dataSurface->SurfWinFractionUpgoing(IWin);
+ state.dataDaylightingManager->WLUMSU(IHR, JB + 1) += ZSU * transMult[JB] / Constant::Pi;
+ FLFWSU(JB + 1) += ZSU * transMult[JB] * (1.0 - state.dataSurface->SurfWinFractionUpgoing(IWin));
+ FLCWSU(JB + 1) += ZSU * transMult[JB] * state.dataSurface->SurfWinFractionUpgoing(IWin);
if (BlindOn || ScreenOn) {
if (PH > 0.0) {
- FLFWSU(JB + 1) += ZSU * DayltgInterReflectedIllumTransBmBmMult(JB);
+ FLFWSU(JB + 1) += ZSU * transBmBmMult[JB];
} else {
- FLCWSU(JB + 1) += ZSU * DayltgInterReflectedIllumTransBmBmMult(JB);
+ FLCWSU(JB + 1) += ZSU * transBmBmMult[JB];
}
}
}
@@ -8082,8 +8078,8 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
// -- Window with shade, screen, blind or diffusing glass
if (ShadeOn || BlindOn || ScreenOn || state.dataSurface->SurfWinSolarDiffusing(IWin)) {
- DayltgInterReflectedIllumTransBmBmMult = 0.0;
- TransMult = 0.0;
+ std::fill(transBmBmMult.begin(), transBmBmMult.end(), 0.0);
+ std::fill(transMult.begin(), transMult.end(), 0.0);
// TH 7/7/2010 moved from inside the loop: DO JB = 1,MaxSlatAngs
if (BlindOn)
@@ -8095,15 +8091,15 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
if (ShadeOn || ScreenOn || state.dataSurface->SurfWinSolarDiffusing(IWin)) { // Shade or screen on or diffusing glass
if (state.dataSurface->SurfWinOriginalClass(IWin) == SurfaceClass::TDD_Dome) {
// Shaded visible transmittance of TDD for collimated beam from the sun
- TransMult(1) = TransTDD(state, PipeNum, COSBSun, RadType::VisibleBeam) * state.dataSurface->SurfWinGlazedFrac(IWin);
+ transMult[1] = TransTDD(state, PipeNum, COSBSun, RadType::VisibleBeam) * state.dataSurface->SurfWinGlazedFrac(IWin);
} else {
if (ScreenOn) {
- TransMult(1) = state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).BmBmTransVis *
+ transMult[1] = state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).BmBmTransVis *
state.dataSurface->SurfWinGlazedFrac(IWin) * state.dataSurface->SurfWinLightWellEff(IWin);
} else {
int IConstShaded = state.dataSurface->SurfWinActiveShadedConstruction(IWin);
if (state.dataSurface->SurfWinSolarDiffusing(IWin)) IConstShaded = state.dataSurface->Surface(IWin).Construction;
- TransMult(1) = General::POLYF(COSBSun, state.dataConstruction->Construct(IConstShaded).TransVisBeamCoef) *
+ transMult[1] = General::POLYF(COSBSun, state.dataConstruction->Construct(IConstShaded).TransVisBeamCoef) *
state.dataSurface->SurfWinGlazedFrac(IWin) * state.dataSurface->SurfWinLightWellEff(IWin);
}
}
@@ -8126,11 +8122,11 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
ReflBlDiffDiffFront = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffRefl(JB);
TransBlDiffDiffFront = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffTrans(JB);
- TransMult(JB) = TVISBSun * (TransBlBmDiffFront + ReflBlBmDiffFront * ReflGlDiffDiffBack * TransBlDiffDiffFront /
+ transMult[JB] = TVISBSun * (TransBlBmDiffFront + ReflBlBmDiffFront * ReflGlDiffDiffBack * TransBlDiffDiffFront /
(1.0 - ReflBlDiffDiffFront * ReflGlDiffDiffBack));
} else if (ShType == WinShadingType::ExtBlind) { // Exterior blind
- TransMult(JB) = TransBlBmDiffFront *
+ transMult[JB] = TransBlBmDiffFront *
(state.dataConstruction->Construct(IConst).TransDiffVis /
(1.0 - ReflGlDiffDiffFront * state.dataMaterial->Blind(BlNum).VisBackDiffDiffRefl(JB))) *
state.dataSurface->SurfWinGlazedFrac(IWin) * state.dataSurface->SurfWinLightWellEff(IWin);
@@ -8140,11 +8136,11 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
tfshBd = WindowManager::InterpProfAng(ProfAng, state.dataMaterial->Blind(BlNum).VisFrontBeamDiffTrans(JB, {1, 37}));
rfshB = WindowManager::InterpProfAng(ProfAng, state.dataMaterial->Blind(BlNum).VisFrontBeamDiffRefl(JB, {1, 37}));
if (state.dataConstruction->Construct(IConst).TotGlassLayers == 2) { // 2 glass layers
- TransMult(JB) =
+ transMult[JB] =
t1 * (tfshBd * (1.0 + rfd2 * rbshd) + rfshB * rbd1 * tfshd) * td2 * state.dataSurface->SurfWinLightWellEff(IWin);
} else { // 3 glass layers; blind between layers 2 and 3
t2 = General::POLYF(COSBSun, state.dataConstruction->Construct(IConst).tBareVisCoef(2));
- TransMult(JB) = t1 * t2 * (tfshBd * (1.0 + rfd3 * rbshd) + rfshB * (rbd2 * tfshd + td2 * rbd1 * td2 * tfshd)) * td3 *
+ transMult[JB] = t1 * t2 * (tfshBd * (1.0 + rfd3 * rbshd) + rfshB * (rbd2 * tfshd + td2 * rbd1 * td2 * tfshd)) * td3 *
state.dataSurface->SurfWinLightWellEff(IWin);
}
}
@@ -8153,29 +8149,29 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
} else {
SlatAng = state.dataMaterial->Blind(BlNum).SlatAngle * Constant::DegToRadians;
}
- DayltgInterReflectedIllumTransBmBmMult(JB) =
- TVISBSun * WindowManager::BlindBeamBeamTrans(ProfAng,
- SlatAng,
- state.dataMaterial->Blind(BlNum).SlatWidth,
- state.dataMaterial->Blind(BlNum).SlatSeparation,
- state.dataMaterial->Blind(BlNum).SlatThickness);
+ transBmBmMult[JB] = TVISBSun * WindowManager::BlindBeamBeamTrans(ProfAng,
+ SlatAng,
+ state.dataMaterial->Blind(BlNum).SlatWidth,
+ state.dataMaterial->Blind(BlNum).SlatSeparation,
+ state.dataMaterial->Blind(BlNum).SlatThickness);
} // ShadeOn/ScreenOn/BlindOn/Diffusing glass
if (state.dataSurface->SurfWinOriginalClass(IWin) == SurfaceClass::TDD_Dome) {
- DayltgInterReflectedIllumTransBmBmMult = 0.0; // No beam, diffuse only
+ std::fill(transBmBmMult.begin(), transBmBmMult.end(), 0.0); // No beam, diffuse only
}
// Daylighting shelf simplification: No beam makes it past end of shelf, all light is diffuse
- if (InShelfSurf > 0) { // Inside daylighting shelf
- DayltgInterReflectedIllumTransBmBmMult = 0.0; // No beam, diffuse only (Not sure if this really works)
- // SurfaceWindow(IWin)%FractionUpgoing is already set to 1.0 earlier
+ if (InShelfSurf > 0) { // Inside daylighting shelf
+ std::fill(
+ transBmBmMult.begin(), transBmBmMult.end(), 0.0); // No beam, diffuse only
+ // SurfaceWindow(IWin)%FractionUpgoing is already set to 1.0 earlier
}
- state.dataDaylightingManager->WLUMSU(IHR, JB + 1) += ZSU1 * TransMult(JB) / Constant::Pi;
- state.dataDaylightingManager->WLUMSUdisk(IHR, JB + 1) = ZSU1 * DayltgInterReflectedIllumTransBmBmMult(JB) / Constant::Pi;
- FLFWSU(JB + 1) += ZSU1 * TransMult(JB) * (1.0 - state.dataSurface->SurfWinFractionUpgoing(IWin));
- FLFWSUdisk(JB + 1) = ZSU1 * DayltgInterReflectedIllumTransBmBmMult(JB);
- FLCWSU(JB + 1) += ZSU1 * TransMult(JB) * state.dataSurface->SurfWinFractionUpgoing(IWin);
+ state.dataDaylightingManager->WLUMSU(IHR, JB + 1) += ZSU1 * transMult[JB] / Constant::Pi;
+ state.dataDaylightingManager->WLUMSUdisk(IHR, JB + 1) = ZSU1 * transBmBmMult[JB] / Constant::Pi;
+ FLFWSU(JB + 1) += ZSU1 * transMult[JB] * (1.0 - state.dataSurface->SurfWinFractionUpgoing(IWin));
+ FLFWSUdisk(JB + 1) = ZSU1 * transBmBmMult[JB];
+ FLCWSU(JB + 1) += ZSU1 * transMult[JB] * state.dataSurface->SurfWinFractionUpgoing(IWin);
} // End of loop over slat angles
} // End of window with shade or blind
} // COSBSun > 0
@@ -8206,8 +8202,8 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
// -- Window with shade, blind or diffusing glass
if (ShadeOn || BlindOn || ScreenOn || state.dataSurface->SurfWinSolarDiffusing(IWin)) {
- DayltgInterReflectedIllumTransBmBmMult = 0.0;
- TransMult = 0.0;
+ std::fill(transBmBmMult.begin(), transBmBmMult.end(), 0.0);
+ std::fill(transMult.begin(), transMult.end(), 0.0);
for (int JB = 1; JB <= Material::MaxSlatAngs; ++JB) {
if (!state.dataSurface->SurfWinMovableSlats(IWin) && JB > 1) break;
@@ -8215,12 +8211,12 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
if (ShadeOn || state.dataSurface->SurfWinSolarDiffusing(IWin)) { // Shade on or diffusing glass
int IConstShaded = state.dataSurface->SurfWinActiveShadedConstruction(IWin);
if (state.dataSurface->SurfWinSolarDiffusing(IWin)) IConstShaded = state.dataSurface->Surface(IWin).Construction;
- TransMult(1) = state.dataConstruction->Construct(IConstShaded).TransDiffVis * state.dataSurface->SurfWinGlazedFrac(IWin) *
+ transMult[1] = state.dataConstruction->Construct(IConstShaded).TransDiffVis * state.dataSurface->SurfWinGlazedFrac(IWin) *
state.dataSurface->SurfWinLightWellEff(IWin);
} else if (ScreenOn) { // Exterior screen on
TransScDiffDiffFront = state.dataMaterial->Screens(state.dataSurface->SurfWinScreenNumber(IWin)).DifDifTransVis;
- TransMult(1) = TransScDiffDiffFront *
+ transMult[1] = TransScDiffDiffFront *
(state.dataConstruction->Construct(IConst).TransDiffVis / (1.0 - ReflGlDiffDiffFront * ReflScDiffDiffBack)) *
state.dataSurface->SurfWinGlazedFrac(IWin) * state.dataSurface->SurfWinLightWellEff(IWin);
@@ -8228,11 +8224,11 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
TransBlDiffDiffFront = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffTrans(JB);
if (ShType == WinShadingType::IntBlind) { // Interior blind
ReflBlDiffDiffFront = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffRefl(JB);
- TransMult(JB) = TVisSunRefl * (TransBlDiffDiffFront + ReflBlDiffDiffFront * ReflGlDiffDiffBack * TransBlDiffDiffFront /
+ transMult[JB] = TVisSunRefl * (TransBlDiffDiffFront + ReflBlDiffDiffFront * ReflGlDiffDiffBack * TransBlDiffDiffFront /
(1.0 - ReflBlDiffDiffFront * ReflGlDiffDiffBack));
} else if (ShType == WinShadingType::ExtBlind) { // Exterior blind
- TransMult(JB) = TransBlDiffDiffFront *
+ transMult[JB] = TransBlDiffDiffFront *
(state.dataConstruction->Construct(IConst).TransDiffVis /
(1.0 - ReflGlDiffDiffFront * state.dataMaterial->Blind(BlNum).VisBackDiffDiffRefl(JB))) *
state.dataSurface->SurfWinGlazedFrac(IWin) * state.dataSurface->SurfWinLightWellEff(IWin);
@@ -8242,19 +8238,19 @@ void DayltgInterReflectedIllum(EnergyPlusData &state,
tfshBd = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffTrans(JB);
rfshB = state.dataMaterial->Blind(BlNum).VisFrontDiffDiffRefl(JB);
if (state.dataConstruction->Construct(IConst).TotGlassLayers == 2) { // 2 glass layers
- TransMult(JB) =
+ transMult[JB] =
t1 * (tfshBd * (1.0 + rfd2 * rbshd) + rfshB * rbd1 * tfshd) * td2 * state.dataSurface->SurfWinLightWellEff(IWin);
} else { // 3 glass layers; blind between layers 2 and 3
t2 = state.dataConstruction->Construct(IConst).tBareVisDiff(2);
- TransMult(JB) = t1 * t2 * (tfshBd * (1.0 + rfd3 * rbshd) + rfshB * (rbd2 * tfshd + td2 * rbd1 * td2 * tfshd)) * td3 *
+ transMult[JB] = t1 * t2 * (tfshBd * (1.0 + rfd3 * rbshd) + rfshB * (rbd2 * tfshd + td2 * rbd1 * td2 * tfshd)) * td3 *
state.dataSurface->SurfWinLightWellEff(IWin);
}
} // End of check of interior/exterior/between-glass blind
} // ShadeOn/BlindOn
- state.dataDaylightingManager->WLUMSU(IHR, JB + 1) += ZSU1refl * TransMult(JB) / Constant::Pi;
- FLFWSU(JB + 1) += ZSU1refl * TransMult(JB) * (1.0 - state.dataSurface->SurfWinFractionUpgoing(IWin));
- FLCWSU(JB + 1) += ZSU1refl * TransMult(JB) * state.dataSurface->SurfWinFractionUpgoing(IWin);
+ state.dataDaylightingManager->WLUMSU(IHR, JB + 1) += ZSU1refl * transMult[JB] / Constant::Pi;
+ FLFWSU(JB + 1) += ZSU1refl * transMult[JB] * (1.0 - state.dataSurface->SurfWinFractionUpgoing(IWin));
+ FLCWSU(JB + 1) += ZSU1refl * transMult[JB] * state.dataSurface->SurfWinFractionUpgoing(IWin);
} // End of loop over slat angles
} // End of check if window has shade, blind or diffusing glass
} // End of check if ZSU1refl > 0.0
@@ -8297,11 +8293,8 @@ void ComplexFenestrationLuminances(EnergyPlusData &state,
// AUTHOR Simon Vidanovic
// DATE WRITTEN June 2013
- auto &ComplexFenestrationLuminancesObsHitPt =
- state.dataDaylightingManager->ComplexFenestrationLuminancesObsHitPt; // Coordinates of hit point on an obstruction (m)
- auto &ComplexFenestrationLuminancesGroundHitPt =
- state.dataDaylightingManager
- ->ComplexFenestrationLuminancesGroundHitPt; // Coordinates of point that ray from window center hits the ground (m)
+ Vector3 obsHitPt; // Coordinates of hit point on an obstruction (m)
+ Vector3 groundHitPt; // Coordinates of point that ray from window center hits the ground (m)
int CurCplxFenState = state.dataSurface->SurfaceWindow(IWin).ComplexFen.CurrentState;
auto &complexWinGeom = state.dataBSDFWindow->ComplexWind(IWin).Geom(CurCplxFenState);
@@ -8382,10 +8375,9 @@ void ComplexFenestrationLuminances(EnergyPlusData &state,
if (state.dataSurface->CalcSolRefl) {
// Sun reaches ground point if vector from this point to the sun is unobstructed
for (int ObsSurfNum : state.dataSurface->AllShadowPossObstrSurfaceList) {
- ComplexFenestrationLuminancesGroundHitPt = complexWinRefPoint.GndPt(iGndElem, WinEl);
+ groundHitPt = complexWinRefPoint.GndPt(iGndElem, WinEl);
bool hitObs = false;
- PierceSurface(
- state, ObsSurfNum, ComplexFenestrationLuminancesGroundHitPt, SUNCOS_IHR, ComplexFenestrationLuminancesObsHitPt, hitObs);
+ PierceSurface(state, ObsSurfNum, groundHitPt, SUNCOS_IHR, obsHitPt, hitObs);
if (hitObs) {
SunObstrMultiplier = 0.0;
break;
@@ -8430,11 +8422,10 @@ void ComplexFenestrationLuminances(EnergyPlusData &state,
if (state.dataSurface->CalcSolRefl) {
// Sun reaches ground point if vector from this point to the sun is unobstructed
for (int ObsSurfNum : state.dataSurface->AllShadowPossObstrSurfaceList) {
- ComplexFenestrationLuminancesGroundHitPt = complexWinIllumMap.GndPt(iGndElem, WinEl);
+ groundHitPt = complexWinIllumMap.GndPt(iGndElem, WinEl);
bool hitObs = false;
- PierceSurface(
- state, ObsSurfNum, ComplexFenestrationLuminancesGroundHitPt, SUNCOS_IHR, ComplexFenestrationLuminancesObsHitPt, hitObs);
+ PierceSurface(state, ObsSurfNum, groundHitPt, SUNCOS_IHR, obsHitPt, hitObs);
if (hitObs) {
SunObstrMultiplier = 0.0;
break;
@@ -8790,20 +8781,11 @@ void DayltgDirectSunDiskComplexFenestration(EnergyPlusData &state,
}
LambdaTrn = state.dataBSDFWindow->ComplexWind(iWin).Geom(CurCplxFenState).Trn.Lamda(iTrnElem);
- state.dataDaylightingManager->DayltgDirectSunDiskComplexFenestrationV =
- state.dataBSDFWindow->ComplexWind(iWin).Geom(CurCplxFenState).sTrn(iTrnElem);
- state.dataDaylightingManager->DayltgDirectSunDiskComplexFenestrationV =
- -state.dataDaylightingManager->DayltgDirectSunDiskComplexFenestrationV;
-
+ Vector3 V = -state.dataBSDFWindow->ComplexWind(iWin).Geom(CurCplxFenState).sTrn(iTrnElem);
// Window center
- state.dataDaylightingManager->DayltgDirectSunDiskComplexFenestrationRWin = state.dataSurface->Surface(iWin).Centroid;
+ Vector3 RWin = state.dataSurface->Surface(iWin).Centroid;
- DayltgHitObstruction(state,
- iHour,
- iWin,
- state.dataDaylightingManager->DayltgDirectSunDiskComplexFenestrationRWin,
- state.dataDaylightingManager->DayltgDirectSunDiskComplexFenestrationV,
- TransBeam);
+ DayltgHitObstruction(state, iHour, iWin, RWin, V, TransBeam);
WinLumSunDisk += (14700.0 * std::sqrt(0.000068 * PosFac) * double(NumEl) / std::pow(WindowSolidAngleDaylightPoint, 0.8)) * dirTrans *
LambdaTrn * TransBeam;
@@ -8943,15 +8925,15 @@ void ProfileAngle(EnergyPlusData &state,
if (std::abs(ElevWin) < 0.1) { // Near-vertical window
ProfileAng = AzimWin - AzimSun; // CR7952 allow sign changes.
} else {
- auto &WinNorm = state.dataDaylightingManager->WinNorm; // Window outward normal unit vector
- auto &SunPrime = state.dataDaylightingManager->SunPrime; // Projection of sun vector onto plane (perpendicular to window plane) determined
- // by WinNorm and vector along baseline of window
- auto &WinNormCrossBase = state.dataDaylightingManager->WinNormCrossBase; // Cross product of WinNorm and vector along window baseline
- WinNorm = state.dataSurface->Surface(SurfNum).OutNormVec;
+
+ Vector3 WinNorm = state.dataSurface->Surface(SurfNum).OutNormVec; // Window outward normal unit vector
ThWin = AzimWin - Constant::PiOvr2;
- Real64 const sin_ElevWin(std::sin(ElevWin));
- WinNormCrossBase = {-sin_ElevWin * std::cos(ThWin), sin_ElevWin * std::sin(ThWin), std::cos(ElevWin)};
- SunPrime = CosDirSun - WinNormCrossBase * dot(CosDirSun, WinNormCrossBase);
+ Real64 const sin_ElevWin = std::sin(ElevWin);
+ // Cross product of WinNorm and vector along window baseline
+ Vector3 WinNormCrossBase = {-sin_ElevWin * std::cos(ThWin), sin_ElevWin * std::sin(ThWin), std::cos(ElevWin)};
+ // Projection of sun vector onto plane (perpendicular to window plane) determined
+ // by WinNorm and vector along baseline of window
+ Vector3 SunPrime = CosDirSun - WinNormCrossBase * dot(CosDirSun, WinNormCrossBase);
ProfileAng = std::abs(std::acos(dot(WinNorm, SunPrime) / SunPrime.magnitude()));
// CR7952 correct sign of result for vertical slats
if ((AzimWin - AzimSun) < 0.0) ProfileAng = -1.0 * ProfileAng;
@@ -8982,8 +8964,8 @@ void DayltgClosestObstruction(EnergyPlusData &state,
// = 0 if no obstruction is hit.
// SUBROUTINE LOCAL VARIABLE DECLARATIONS:
- auto &HitPt = state.dataDaylightingManager->HitPt; // Hit point on an obstruction (m)
- bool hit; // True iff obstruction is hit
+ Vector3 HitPt; // Hit point on an obstruction (m)
+ bool hit; // True iff obstruction is hit
NearestHitSurfNum = 0;
Real64 NearestHitDistance_sq(std::numeric_limits::max()); // Distance squared from receiving point to nearest hit point for a ray (m^2)
@@ -9019,9 +9001,10 @@ void DayltgClosestObstruction(EnergyPlusData &state,
// Lambda function for the octree to test for surface hit
auto surfaceHit = [=, &state, &RecPt, &RayVec, &hit, &NearestHitDistance_sq, &nearestHitSurface, &NearestHitPt](SurfaceData const &surface) {
if (surface.IsShadowPossibleObstruction) {
+ Vector3 HitPt;
// Determine if this ray hits the surface and, if so, get the distance from the receiving point to the hit
- PierceSurface(surface, RecPt, RayVec, state.dataDaylightingManager->HitPt, hit); // Check if ray pierces surface
- if (hit) { // Ray pierces surface
+ PierceSurface(surface, RecPt, RayVec, HitPt, hit); // Check if ray pierces surface
+ if (hit) { // Ray pierces surface
// If obstruction is a window and its base surface is the nearest obstruction hit so far set nearestHitSurface to this window
// Note that in this case NearestHitDistance_sq has already been calculated, so does not have to be recalculated
if ((surface.Class == SurfaceClass::Window) && (surface.BaseSurf > 0) &&
@@ -9077,25 +9060,25 @@ void DayltgSurfaceLumFromSun(EnergyPlusData &state,
// beam normal illuminance (cd/m2)
// SUBROUTINE LOCAL VARIABLE DECLARATIONS:
- auto &DayltgSurfaceLumFromSunReflNorm = state.dataDaylightingManager->DayltgSurfaceLumFromSunReflNorm; // Unit normal to reflecting surface (m)
- auto &DayltgSurfaceLumFromSunObsHitPt = state.dataDaylightingManager->DayltgSurfaceLumFromSunObsHitPt; // Hit point on obstruction (m)
- bool hitObs; // True iff obstruction is hit
- Real64 CosIncAngAtHitPt; // Cosine of angle of incidence of sun at HitPt
- Real64 DiffVisRefl; // Diffuse visible reflectance of ReflSurfNum
+ Vector3 SurfaceLumFromSunReflNorm; // Unit normal to reflecting surface (m)
+ Vector3 SurfaceLumFromSunObsHitPt; // Hit point on obstruction (m)
+ bool hitObs; // True iff obstruction is hit
+ Real64 CosIncAngAtHitPt; // Cosine of angle of incidence of sun at HitPt
+ Real64 DiffVisRefl; // Diffuse visible reflectance of ReflSurfNum
LumAtReflHitPtFrSun = 0.0;
// Skip daylighting shelves since reflection from these is separately calculated
if (state.dataSurface->SurfDaylightingShelfInd(ReflSurfNum) > 0) return;
// Normal to reflecting surface in hemisphere containing window element
- DayltgSurfaceLumFromSunReflNorm = state.dataSurface->Surface(ReflSurfNum).OutNormVec;
+ SurfaceLumFromSunReflNorm = state.dataSurface->Surface(ReflSurfNum).OutNormVec;
if (state.dataSurface->Surface(ReflSurfNum).IsShadowing) {
- if (dot(DayltgSurfaceLumFromSunReflNorm, Ray) > 0.0) {
- DayltgSurfaceLumFromSunReflNorm *= -1.0;
+ if (dot(SurfaceLumFromSunReflNorm, Ray) > 0.0) {
+ SurfaceLumFromSunReflNorm *= -1.0;
}
}
// Cosine of angle of incidence of sun at HitPt if sun were to reach HitPt
Vector3 const SUNCOS_IHR(state.dataSurface->SurfSunCosHourly(IHR));
- CosIncAngAtHitPt = dot(DayltgSurfaceLumFromSunReflNorm, SUNCOS_IHR);
+ CosIncAngAtHitPt = dot(SurfaceLumFromSunReflNorm, SUNCOS_IHR);
// Require that the sun be in front of this surface relative to window element
if (CosIncAngAtHitPt <= 0.0) return; // Sun is in back of reflecting surface
// Sun reaches ReflHitPt if vector from ReflHitPt to sun is unobstructed
@@ -9103,7 +9086,7 @@ void DayltgSurfaceLumFromSun(EnergyPlusData &state,
for (int ObsSurfNum : state.dataSurface->AllShadowPossObstrSurfaceList) {
// Exclude as a possible obstructor ReflSurfNum and its base surface (if it has one)
if (ObsSurfNum == ReflSurfNum || ObsSurfNum == state.dataSurface->Surface(ReflSurfNum).BaseSurf) continue;
- PierceSurface(state, ObsSurfNum, ReflHitPt, SUNCOS_IHR, DayltgSurfaceLumFromSunObsHitPt, hitObs);
+ PierceSurface(state, ObsSurfNum, ReflHitPt, SUNCOS_IHR, SurfaceLumFromSunObsHitPt, hitObs);
if (hitObs) break;
}
if (hitObs) return; // Obstruction was hit, blocking s auto surfaceHit = [&state, &GroundHitPtun
@@ -9232,8 +9215,8 @@ void DayltgInteriorMapIllum(EnergyPlusData &state)
Real64 wgtThisHr = state.dataGlobal->WeightNow;
Real64 wgtPrevHr = state.dataGlobal->WeightPreviousHour;
- auto &dfskhr = DFSKHR(1);
- auto &dfskhr2 = DFSKHR(2);
+ auto &dfskhr = DFSKHR[(int)WinCover::Bare];
+ auto &dfskhr2 = DFSKHR[(int)WinCover::Shaded];
int SurfWinSlatsAngIndex = state.dataSurface->SurfWinSlatsAngIndex(IWin);
int slatAngLo = SurfWinSlatsAngIndex + 1;
@@ -9275,10 +9258,11 @@ void DayltgInteriorMapIllum(EnergyPlusData &state)
} // End of check if window is shaded or has diffusing glass
} // for (iSky)
- DayltgInteriorMapIllumDFSUHR(1) = VTRatio * (wgtThisHr * (thisMap.DaylIllFacSun(state.dataGlobal->HourOfDay, loop, ILB, 1) +
- thisMap.DaylIllFacSunDisk(state.dataGlobal->HourOfDay, loop, ILB, 1)) +
- wgtPrevHr * (thisMap.DaylIllFacSun(state.dataGlobal->PreviousHour, loop, ILB, 1) +
- thisMap.DaylIllFacSunDisk(state.dataGlobal->PreviousHour, loop, ILB, 1)));
+ DayltgInteriorMapIllumDFSUHR[(int)WinCover::Bare] =
+ VTRatio * (wgtThisHr * (thisMap.DaylIllFacSun(state.dataGlobal->HourOfDay, loop, ILB, 1) +
+ thisMap.DaylIllFacSunDisk(state.dataGlobal->HourOfDay, loop, ILB, 1)) +
+ wgtPrevHr * (thisMap.DaylIllFacSun(state.dataGlobal->PreviousHour, loop, ILB, 1) +
+ thisMap.DaylIllFacSunDisk(state.dataGlobal->PreviousHour, loop, ILB, 1)));
if ((state.dataSurface->SurfWinWindowModelType(IWin) != WindowModel::BSDF) &&
(IS_SHADED(state.dataSurface->SurfWinShadingFlag(IWin)) || state.dataSurface->SurfWinSolarDiffusing(IWin))) {
@@ -9286,11 +9270,12 @@ void DayltgInteriorMapIllum(EnergyPlusData &state)
// ===Shaded window===
if (!state.dataSurface->SurfWinMovableSlats(IWin)) {
// Shade, screen, blind with fixed slats, or diffusing glass
- DayltgInteriorMapIllumDFSUHR(2) = VTRatio * (wgtThisHr * thisMap.DaylIllFacSun(state.dataGlobal->HourOfDay, loop, ILB, 2) +
- wgtPrevHr * thisMap.DaylIllFacSun(state.dataGlobal->PreviousHour, loop, ILB, 2));
+ DayltgInteriorMapIllumDFSUHR[(int)WinCover::Shaded] =
+ VTRatio * (wgtThisHr * thisMap.DaylIllFacSun(state.dataGlobal->HourOfDay, loop, ILB, 2) +
+ wgtPrevHr * thisMap.DaylIllFacSun(state.dataGlobal->PreviousHour, loop, ILB, 2));
if (!state.dataSurface->SurfWinSlatsBlockBeam(IWin)) {
- DayltgInteriorMapIllumDFSUHR(2) +=
+ DayltgInteriorMapIllumDFSUHR[(int)WinCover::Shaded] +=
VTRatio * (wgtThisHr * thisMap.DaylIllFacSunDisk(state.dataGlobal->HourOfDay, loop, ILB, 2) +
wgtPrevHr * thisMap.DaylIllFacSunDisk(state.dataGlobal->PreviousHour, loop, ILB, 2));
}
@@ -9306,7 +9291,7 @@ void DayltgInteriorMapIllum(EnergyPlusData &state)
Real64 DaylIllFacSunPrev = General::Interp(thisMap.DaylIllFacSun(state.dataGlobal->PreviousHour, loop, ILB, slatAngLo),
thisMap.DaylIllFacSun(state.dataGlobal->PreviousHour, loop, ILB, slatAngHi),
SurfWinSlatsAngInterpFac);
- DFSUHR(2) = VTRatio * (wgtThisHr * DaylIllFacSunNow + wgtPrevHr * DaylIllFacSunPrev);
+ DFSUHR[(int)WinCover::Shaded] = VTRatio * (wgtThisHr * DaylIllFacSunNow + wgtPrevHr * DaylIllFacSunPrev);
// We add the contribution from the solar disk if slats do not block beam solar
// TH CR 8010, DaylIllFacSunDisk needs to be interpolated
@@ -9319,7 +9304,7 @@ void DayltgInteriorMapIllum(EnergyPlusData &state)
General::Interp(thisMap.DaylIllFacSunDisk(state.dataGlobal->PreviousHour, loop, ILB, slatAngLo),
thisMap.DaylIllFacSunDisk(state.dataGlobal->PreviousHour, loop, ILB, slatAngHi),
SurfWinSlatsAngInterpFac);
- DFSUHR(2) += VTRatio * (wgtThisHr * DaylIllFacSunDiskNow + wgtPrevHr * DaylIllFacSunDiskPrev);
+ DFSUHR[(int)WinCover::Shaded] += VTRatio * (wgtThisHr * DaylIllFacSunDiskNow + wgtPrevHr * DaylIllFacSunDiskPrev);
}
} // End of check if window has blind with movable slats
} // End of check if window is shaded or has diffusing glass
@@ -9341,13 +9326,15 @@ void DayltgInteriorMapIllum(EnergyPlusData &state)
HorIllSkyFac = state.dataEnvrn->HISKF / ((1.0 - SkyWeight) * DayltgInteriorMapIllumHorIllSky.sky[iSky2] +
SkyWeight * DayltgInteriorMapIllumHorIllSky.sky[iSky1]);
- for (int IS = 1; IS <= 2; ++IS) {
- if (IS == 2 && state.dataSurface->SurfWinWindowModelType(IWin) == WindowModel::BSDF) break;
- if (IS == 2 && NOT_SHADED(state.dataSurface->SurfWinShadingFlag(IWin)) && !state.dataSurface->SurfWinSolarDiffusing(IWin)) break;
- auto const &dfskhr = DFSKHR(IS);
+ for (int iWinCover = 0; iWinCover < (int)WinCover::Num; ++iWinCover) {
+ if (iWinCover == (int)WinCover::Shaded) {
+ if (state.dataSurface->SurfWinWindowModelType(IWin) == WindowModel::BSDF) break;
+ if (NOT_SHADED(state.dataSurface->SurfWinShadingFlag(IWin)) && !state.dataSurface->SurfWinSolarDiffusing(IWin)) break;
+ }
+ auto const &dfskhr = DFSKHR[iWinCover];
- thisMap.IllumFromWinAtMapPt(loop, IS, ILB) =
- DayltgInteriorMapIllumDFSUHR(IS) * state.dataEnvrn->HISUNF +
+ thisMap.IllumFromWinAtMapPt(loop, ILB)[iWinCover] =
+ DayltgInteriorMapIllumDFSUHR[iWinCover] * state.dataEnvrn->HISUNF +
HorIllSkyFac * (dfskhr.sky[iSky1] * SkyWeight * DayltgInteriorMapIllumHorIllSky.sky[iSky1] +
dfskhr.sky[iSky2] * (1.0 - SkyWeight) * DayltgInteriorMapIllumHorIllSky.sky[iSky2]);
}
@@ -9384,7 +9371,7 @@ void DayltgInteriorMapIllum(EnergyPlusData &state)
for (int IL = 1; IL <= NREFPT; ++IL) {
// Determine if illuminance contribution is from bare or shaded window
- daylight_illum(IL) += VTMULT * thisMap.IllumFromWinAtMapPt(loop, IS, IL);
+ daylight_illum(IL) += VTMULT * thisMap.IllumFromWinAtMapPt(loop, IL)[IS - 1];
}
} // End of second window loop
@@ -9460,9 +9447,9 @@ void ReportIllumMap(EnergyPlusData &state, int const MapNum)
++rCount;
illumMap.pointsHeader += format(" RefPt{}=({:.2R}:{:.2R}:{:.2R}),",
rCount,
- thisDaylightControl.DaylRefPtAbsCoord(1, R),
- thisDaylightControl.DaylRefPtAbsCoord(2, R),
- thisDaylightControl.DaylRefPtAbsCoord(3, R));
+ thisDaylightControl.DaylRefPtAbsCoord(R).x,
+ thisDaylightControl.DaylRefPtAbsCoord(R).y,
+ thisDaylightControl.DaylRefPtAbsCoord(R).z);
}
}
}
@@ -9489,8 +9476,8 @@ void ReportIllumMap(EnergyPlusData &state, int const MapNum)
for (int X = 1; X <= illumMap.Xnum; ++X) {
const std::string AddXorYString = format("{}({:.2R};{:.2R})=",
state.dataDaylightingData->MapColSep,
- state.dataDaylightingData->IllumMapCalc(MapNum).MapRefPtAbsCoord(1, RefPt),
- state.dataDaylightingData->IllumMapCalc(MapNum).MapRefPtAbsCoord(2, RefPt));
+ state.dataDaylightingData->IllumMapCalc(MapNum).MapRefPtAbsCoord(RefPt).x,
+ state.dataDaylightingData->IllumMapCalc(MapNum).MapRefPtAbsCoord(RefPt).y);
if (illumMap.HeaderXLineLengthNeeded) linelen += int(len(AddXorYString));
mapLine += AddXorYString;
++RefPt;
@@ -9513,7 +9500,7 @@ void ReportIllumMap(EnergyPlusData &state, int const MapNum)
// Write Y scale prefix and illuminance values
RefPt = 1;
for (int Y = 1; Y <= illumMap.Ynum; ++Y) {
- mapLine = format("({:.2R};{:.2R})=", illumMapCalc.MapRefPtAbsCoord(1, RefPt), illumMapCalc.MapRefPtAbsCoord(2, RefPt));
+ mapLine = format("({:.2R};{:.2R})=", illumMapCalc.MapRefPtAbsCoord(RefPt).x, illumMapCalc.MapRefPtAbsCoord(RefPt).y);
for (int R = RefPt; R <= RefPt + illumMap.Xnum - 1; ++R) {
int IllumOut = nint(illumMapCalc.DaylIllumAtMapPtHr(R));
std::string String;
@@ -9855,12 +9842,16 @@ void DayltgSetupAdjZoneListsAndPointers(EnergyPlusData &state)
thisDaylightControl.SolidAngAtRefPt = 0.0;
thisDaylightControl.SolidAngAtRefPtWtd.allocate(enclExtWin(enclNum), thisDaylightControl.TotalDaylRefPoints);
thisDaylightControl.SolidAngAtRefPtWtd = 0.0;
- thisDaylightControl.IllumFromWinAtRefPt.allocate(enclExtWin(enclNum), 2, thisDaylightControl.TotalDaylRefPoints);
- thisDaylightControl.IllumFromWinAtRefPt = 0.0;
- thisDaylightControl.BackLumFromWinAtRefPt.allocate(enclExtWin(enclNum), 2, thisDaylightControl.TotalDaylRefPoints);
- thisDaylightControl.BackLumFromWinAtRefPt = 0.0;
- thisDaylightControl.SourceLumFromWinAtRefPt.allocate(enclExtWin(enclNum), 2, thisDaylightControl.TotalDaylRefPoints);
- thisDaylightControl.SourceLumFromWinAtRefPt = 0.0;
+ thisDaylightControl.IllumFromWinAtRefPt.allocate(enclExtWin(enclNum), thisDaylightControl.TotalDaylRefPoints);
+ thisDaylightControl.BackLumFromWinAtRefPt.allocate(enclExtWin(enclNum), thisDaylightControl.TotalDaylRefPoints);
+ thisDaylightControl.SourceLumFromWinAtRefPt.allocate(enclExtWin(enclNum), thisDaylightControl.TotalDaylRefPoints);
+ for (int iExtWin = 1; iExtWin <= enclExtWin(enclNum); ++iExtWin) {
+ for (int iRefPt = 1; iRefPt <= thisDaylightControl.TotalDaylRefPoints; ++iRefPt) {
+ thisDaylightControl.IllumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ thisDaylightControl.BackLumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ thisDaylightControl.SourceLumFromWinAtRefPt(iExtWin, iRefPt) = {0.0, 0.0};
+ }
+ }
}
int enclExtWinCtr = 0;
@@ -9887,20 +9878,23 @@ void DayltgSetupAdjZoneListsAndPointers(EnergyPlusData &state)
thisEnclDaylight.DayltgExtWinSurfNums(enclExtWinCtr) = SurfNumAdj;
// If no daylighting in the adjacent enclosure, set up variables anyway:
- if (state.dataViewFactor->EnclSolInfo(adjEnclNum).TotalEnclosureDaylRefPoints == 0) {
- if (!state.dataSurface->SurfWinSurfDayLightInit(SurfNumAdj)) {
- state.dataSurface->SurfaceWindow(SurfNumAdj).SolidAngAtRefPt.allocate(thisEnclNumRefPoints);
- state.dataSurface->SurfaceWindow(SurfNumAdj).SolidAngAtRefPt = 0.0;
- state.dataSurface->SurfaceWindow(SurfNumAdj).SolidAngAtRefPtWtd.allocate(thisEnclNumRefPoints);
- state.dataSurface->SurfaceWindow(SurfNumAdj).SolidAngAtRefPtWtd = 0.0;
- state.dataSurface->SurfaceWindow(SurfNumAdj).IllumFromWinAtRefPt.allocate(2, thisEnclNumRefPoints);
- state.dataSurface->SurfaceWindow(SurfNumAdj).IllumFromWinAtRefPt = 0.0;
- state.dataSurface->SurfaceWindow(SurfNumAdj).BackLumFromWinAtRefPt.allocate(2, thisEnclNumRefPoints);
- state.dataSurface->SurfaceWindow(SurfNumAdj).BackLumFromWinAtRefPt = 0.0;
- state.dataSurface->SurfaceWindow(SurfNumAdj).SourceLumFromWinAtRefPt.allocate(2, thisEnclNumRefPoints);
- state.dataSurface->SurfaceWindow(SurfNumAdj).SourceLumFromWinAtRefPt = 0.0;
- state.dataSurface->SurfWinSurfDayLightInit(SurfNumAdj) = true;
+ if (state.dataViewFactor->EnclSolInfo(adjEnclNum).TotalEnclosureDaylRefPoints == 0 &&
+ !state.dataSurface->SurfWinSurfDayLightInit(SurfNumAdj)) {
+ auto &surfWinAdj = state.dataSurface->SurfaceWindow(SurfNumAdj);
+ surfWinAdj.SolidAngAtRefPt.allocate(thisEnclNumRefPoints);
+ surfWinAdj.SolidAngAtRefPt = 0.0;
+ surfWinAdj.SolidAngAtRefPtWtd.allocate(thisEnclNumRefPoints);
+ surfWinAdj.SolidAngAtRefPtWtd = 0.0;
+ surfWinAdj.IllumFromWinAtRefPt.allocate(thisEnclNumRefPoints);
+ surfWinAdj.BackLumFromWinAtRefPt.allocate(thisEnclNumRefPoints);
+ surfWinAdj.SourceLumFromWinAtRefPt.allocate(thisEnclNumRefPoints);
+
+ for (int iRefPt = 1; iRefPt < (int)surfWinAdj.IllumFromWinAtRefPt.size(); ++iRefPt) {
+ surfWinAdj.IllumFromWinAtRefPt(iRefPt) = {0.0, 0.0};
+ surfWinAdj.BackLumFromWinAtRefPt(iRefPt) = {0.0, 0.0};
+ surfWinAdj.SourceLumFromWinAtRefPt(iRefPt) = {0.0, 0.0};
}
+ state.dataSurface->SurfWinSurfDayLightInit(SurfNumAdj) = true;
}
}
}
@@ -9934,8 +9928,8 @@ void DayltgSetupAdjZoneListsAndPointers(EnergyPlusData &state)
// size these for the maximum of the shade deployment order
state.dataDaylightingManager->DILLSW.allocate(maxShadeDeployOrderExtWinsSize);
state.dataDaylightingManager->DILLUN.allocate(maxShadeDeployOrderExtWinsSize);
- state.dataDaylightingManager->WDAYIL.allocate(2, state.dataDaylightingData->maxRefPointsPerControl, maxShadeDeployOrderExtWinsSize);
- state.dataDaylightingManager->WBACLU.allocate(2, state.dataDaylightingData->maxRefPointsPerControl, maxShadeDeployOrderExtWinsSize);
+ state.dataDaylightingManager->WDAYIL.allocate(state.dataDaylightingData->maxRefPointsPerControl, maxShadeDeployOrderExtWinsSize);
+ state.dataDaylightingManager->WBACLU.allocate(state.dataDaylightingData->maxRefPointsPerControl, maxShadeDeployOrderExtWinsSize);
state.dataDaylightingManager->RDAYIL.allocate(state.dataDaylightingData->maxRefPointsPerControl, maxShadeDeployOrderExtWinsSize);
state.dataDaylightingManager->RBACLU.allocate(state.dataDaylightingData->maxRefPointsPerControl, maxShadeDeployOrderExtWinsSize);
@@ -9961,8 +9955,12 @@ void DayltgSetupAdjZoneListsAndPointers(EnergyPlusData &state)
int numMapRefPts = illumMapCalc.TotalMapRefPoints;
if (numMapRefPts > 0) {
- illumMapCalc.IllumFromWinAtMapPt.allocate(numExtWin, 2, numMapRefPts);
- illumMapCalc.IllumFromWinAtMapPt = 0.0;
+ illumMapCalc.IllumFromWinAtMapPt.allocate(numExtWin, numMapRefPts);
+ for (int iExtWin = 1; iExtWin <= numExtWin; ++iExtWin) {
+ for (int iRefPt = 1; iRefPt <= numMapRefPts; ++iRefPt) {
+ illumMapCalc.IllumFromWinAtMapPt(iExtWin, iRefPt) = {0.0, 0.0};
+ }
+ }
illumMapCalc.DaylIllFacSky.allocate(Constant::HoursInDay, numExtWin, numMapRefPts, numSlatAngs);
illumMapCalc.DaylIllFacSun.allocate(Constant::HoursInDay, numExtWin, numMapRefPts, numSlatAngs);
@@ -9985,10 +9983,6 @@ void DayltgSetupAdjZoneListsAndPointers(EnergyPlusData &state)
state.dataDaylightingManager->FLFWSU.dimension(numSlatAngs);
state.dataDaylightingManager->FLFWSUdisk.dimension(numSlatAngs);
state.dataDaylightingManager->FLCWSU.dimension(numSlatAngs);
- state.dataDaylightingManager->TransMult.dimension(state.dataSurface->actualMaxSlatAngs);
- state.dataDaylightingManager->DayltgInterReflectedIllumTransBmBmMult.dimension(state.dataSurface->actualMaxSlatAngs);
- state.dataDaylightingManager->TransBmBmMult.dimension(state.dataSurface->actualMaxSlatAngs);
- state.dataDaylightingManager->TransBmBmMultRefl.dimension(state.dataSurface->actualMaxSlatAngs);
state.dataDaylightingManager->FLCWSK.dimension(numSlatAngs, Illums());
state.dataDaylightingManager->FLFWSK.dimension(numSlatAngs, Illums());
@@ -10188,27 +10182,6 @@ void CalcMinIntWinSolidAngs(EnergyPlusData &state)
// For each Daylighting:Detailed zone finds the minimum solid angle subtended
// by interior windows through which daylight can pass from adjacent zones with
// exterior windows.
-
- bool is_Triangle; // True if window is a triangle
- bool is_Rectangle; // True if window is a rectangle
- Real64 IntWinSolidAng; // Approximation to solid angle subtended by an interior window
- // from a point a distance SQRT(zone floor area) away.
- auto &W1 = state.dataDaylightingManager->CalcMinIntWinSolidAngsW1; // Window vertices
- auto &W2 = state.dataDaylightingManager->CalcMinIntWinSolidAngsW2;
- auto &W3 = state.dataDaylightingManager->CalcMinIntWinSolidAngsW3;
- auto &WC = state.dataDaylightingManager->CalcMinIntWinSolidAngsWC; // Center point of window
- auto &W21 = state.dataDaylightingManager->CalcMinIntWinSolidAngsW21; // Unit vectors from window vertex 2 to 1 and 2 to 3
- auto &W23 = state.dataDaylightingManager->CalcMinIntWinSolidAngsW23;
- auto &RREF = state.dataDaylightingManager->CalcMinIntWinSolidAngsRREF; // Location of a reference point in absolute coordinate system
- auto &Ray = state.dataDaylightingManager->CalcMinIntWinSolidAngsRay; // Unit vector along ray from reference point to window center
- auto &REFWC = state.dataDaylightingManager->CalcMinIntWinSolidAngsREFWC; // Vector from reference point to center of window
- auto &WNORM = state.dataDaylightingManager->CalcMinIntWinSolidAngsWNORM; // Unit vector normal to window (pointing away from room)
- Real64 HW; // Window height and width (m)
- Real64 WW;
- Real64 DIS; // Distance from ref point to window center (m)
- Real64 COSB; // Cosine of angle between ray from ref pt to center of window
- // and window outward normal
-
for (int enclNum = 1; enclNum <= state.dataViewFactor->NumOfSolarEnclosures; ++enclNum) {
auto &thisEnclDaylight = state.dataDaylightingData->enclDaylight(enclNum);
thisEnclDaylight.MinIntWinSolidAng = 2.0 * Constant::Pi;
@@ -10236,9 +10209,11 @@ void CalcMinIntWinSolidAngs(EnergyPlusData &state)
auto &thisDaylightControl = state.dataDaylightingData->daylightControl(controlNum);
for (int IL = 1; IL <= thisDaylightControl.TotalDaylRefPoints; ++IL) {
// Reference point in absolute coordinate system
- RREF = thisDaylightControl.DaylRefPtAbsCoord({1, 3}, IL);
- is_Triangle = (surf.Sides == 3);
- is_Rectangle = (surf.Sides == 4);
+ Vector3 RREF = thisDaylightControl.DaylRefPtAbsCoord(IL);
+ bool is_Triangle = (surf.Sides == 3);
+ bool is_Rectangle = (surf.Sides == 4);
+
+ Vector3 W1, W2, W3;
if (is_Rectangle) {
// Vertices of window numbered counter-clockwise starting at upper left as viewed
// from inside of room. Assumes original vertices are numbered counter-clockwise from
@@ -10253,31 +10228,29 @@ void CalcMinIntWinSolidAngs(EnergyPlusData &state)
}
// Unit vectors from window vertex 2 to 1 and 2 to 3, center point of window,
// and vector from ref pt to center of window
- W21 = W1 - W2;
- W23 = W3 - W2;
- HW = W21.magnitude();
- WW = W23.magnitude();
- if (is_Rectangle) {
- WC = W2 + (W23 + W21) / 2.0;
- } else if (is_Triangle) {
- WC = W2 + (W23 + W21) / 3.0;
- }
+ Vector3 W21 = W1 - W2;
+ Vector3 W23 = W3 - W2;
+ Real64 HW = W21.magnitude();
+ Real64 WW = W23.magnitude();
+ Vector3 WC =
+ (is_Rectangle) ? (W2 + (W23 + W21) / 2.0) : (is_Triangle ? (W2 + (W23 + W21) / 3.0) : (W2 + (W23 + W21) / 3.0));
+
// Vector from ref point to center of window
- REFWC = WC - RREF;
+ Vector3 REFWC = WC - RREF;
W21 /= HW;
W23 /= WW;
// Unit vector normal to window (pointing away from room)
- WNORM = surf.OutNormVec;
+ Vector3 WNORM = surf.OutNormVec;
// Distance from ref point to center of window
- DIS = REFWC.magnitude();
+ Real64 DIS = REFWC.magnitude();
// Unit vector from ref point to center of window
- Ray = REFWC / DIS;
+ Vector3 Ray = REFWC / DIS;
// Cosine of angle between ray from ref pt to center of window and window outward normal
- COSB = dot(WNORM, Ray);
+ Real64 COSB = dot(WNORM, Ray);
if (COSB > 0.01765) { // 0 <= B < 89 deg
// Above test avoids case where ref point cannot receive daylight directly from the
// interior window
- IntWinSolidAng = COSB * surf.Area / (pow_2(DIS) + 0.001);
+ Real64 IntWinSolidAng = COSB * surf.Area / (pow_2(DIS) + 0.001);
thisEnclDaylight.MinIntWinSolidAng = min(thisEnclDaylight.MinIntWinSolidAng, IntWinSolidAng);
}
} // for (IL)
diff --git a/src/EnergyPlus/DaylightingManager.hh b/src/EnergyPlus/DaylightingManager.hh
index 748dc2cdb60..9cf95022c8b 100644
--- a/src/EnergyPlus/DaylightingManager.hh
+++ b/src/EnergyPlus/DaylightingManager.hh
@@ -82,8 +82,10 @@ namespace Dayltg {
constexpr int octreeCrossover(100); // Octree surface count crossover
constexpr int NTH(18); // Number of azimuth steps for sky integration
constexpr int NPH(8); // Number of altitude steps for sky integration
- constexpr int NPHMAX(10); // Number of sky/ground integration steps in altitude
- constexpr int NTHMAX(16); // Number of sky/ground integration steps in azimuth
+
+ // It's crazy having both NPH and NPHMAX
+ constexpr int NPHMAX(10); // Number of sky/ground integration steps in altitude
+ constexpr int NTHMAX(16); // Number of sky/ground integration steps in azimuth
void DayltgAveInteriorReflectance(EnergyPlusData &state, int const enclNum); // Enclosure number
@@ -539,57 +541,6 @@ struct DaylightingManagerData : BaseGlobalStruct
bool MySunIsUpFlag = false;
bool CalcDayltgCoeffsMapPointsMySunIsUpFlag = false;
-
- // static variables extracted from functions
- Vector3 AR; // Inside surface area sum for floor/wall/ceiling (m2)
- Vector3 ARH; // Inside surface area*reflectance sum for floor/wall/ceiling (m2)
- Vector3 AP; // Zone inside surface floor/wall/ceiling area without a selected floor/wall/ceiling (m2)
- Vector3 ARHP; // Zone inside surface floor/wall/ceiling area*reflectance without a selected floor/wall/ceiling (m2)
- Vector3 W2; // Second vertex of window
- Vector3 W3; // Third vertex of window
- Vector3 W21; // Vector from window vertex 2 to window vertex 1
- Vector3 W23; // Vector from window vertex 2 to window vertex 3
- Vector3 RREF; // Location of a reference point in absolute coordinate system
- Vector3 RREF2; // Location of virtual reference point in absolute coordinate system
- Vector3 RWIN; // Center of a window element in absolute coordinate system
- Vector3 RWIN2; // Center of a window element for TDD:DOME (if exists) in abs coord sys
- Vector3 Ray; // Unit vector along ray from reference point to window element
- Vector3 WNORM2; // Unit vector normal to TDD:DOME (if exists)
- Vector3 VIEWVC; // View vector in absolute coordinate system
- Vector3 U2; // Second vertex of window for TDD:DOME (if exists)
- Vector3 U21; // Vector from window vertex 2 to window vertex 1 for TDD:DOME (if exists)
- Vector3 U23; // Vector from window vertex 2 to window vertex 3 for TDD:DOME (if exists)
- Vector3 VIEWVC2; // Virtual view vector in absolute coordinate system
-
- Vector3 W1; // First vertex of window (where vertices are numbered
- Vector3 WC; // Center point of window
- Vector3 REFWC; // Vector from reference point to center of window
- Vector3 WNORM; // Unit vector normal to window (pointing away from room)
- Vector3 W2REF; // Vector from window origin to project of ref. pt. on window plane
- Vector3 REFD; // Vector from ref pt to center of win in TDD:DIFFUSER coord sys (if exists)
- Vector3 VIEWVD; // Virtual view vector in TDD:DIFFUSER coord sys (if exists)
- Vector3 U1; // First vertex of window for TDD:DOME (if exists)
- Vector3 U3; // Third vertex of window for TDD:DOME (if exists)
- Vector3 RayVector;
-
- Vector3 HitPtIntWin; // Intersection point on an interior window for ray from ref pt to ext win (m)
- Vector3 GroundHitPt; // Coordinates of point that ray hits ground (m)
- Vector3 URay; // Unit vector in (Phi,Theta) direction
- Vector3 ObsHitPt; // Coordinates of hit point on an obstruction (m)
-
- Vector3 WNorm; // unit vector from window (point towards outside)
- Vector3 RayNorm; // unit vector along ray from window to reference point
- Vector3 InterPoint; // Intersection point
- Vector3 RWin; // window element center point (same as centroid)
- Vector3 V; // vector array
-
- Vector3 NearestHitPt; // Hit point of ray on nearest obstruction
- Vector3 ReflNorm; // Normal vector to reflecting surface
- Vector3 SunVecMir; // Sun ray mirrored in reflecting surface
- Vector3