US20200218208A1 - Building management system with efficient model generation for system identification - Google Patents
Building management system with efficient model generation for system identification Download PDFInfo
- Publication number
- US20200218208A1 US20200218208A1 US16/240,028 US201916240028A US2020218208A1 US 20200218208 A1 US20200218208 A1 US 20200218208A1 US 201916240028 A US201916240028 A US 201916240028A US 2020218208 A1 US2020218208 A1 US 2020218208A1
- Authority
- US
- United States
- Prior art keywords
- parameters
- values
- building
- prediction error
- initial
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000000034 method Methods 0.000 claims abstract description 139
- 230000008569 process Effects 0.000 claims abstract description 87
- 238000012549 training Methods 0.000 claims abstract description 81
- 238000005457 optimization Methods 0.000 claims abstract description 20
- 239000011159 matrix material Substances 0.000 claims description 22
- 230000004044 response Effects 0.000 claims description 22
- 238000005293 physical law Methods 0.000 claims description 9
- 230000006870 function Effects 0.000 description 108
- 238000013459 approach Methods 0.000 description 29
- 238000010586 diagram Methods 0.000 description 15
- 239000013598 vector Substances 0.000 description 15
- 239000012530 fluid Substances 0.000 description 14
- 238000012545 processing Methods 0.000 description 14
- 238000012546 transfer Methods 0.000 description 14
- 238000001816 cooling Methods 0.000 description 12
- 238000010438 heat treatment Methods 0.000 description 12
- 238000002474 experimental method Methods 0.000 description 11
- 230000006399 behavior Effects 0.000 description 9
- 238000004891 communication Methods 0.000 description 9
- 230000008859 change Effects 0.000 description 7
- 238000004088 simulation Methods 0.000 description 7
- 239000003990 capacitor Substances 0.000 description 6
- 230000003190 augmentative effect Effects 0.000 description 5
- 230000005284 excitation Effects 0.000 description 5
- 238000009529 body temperature measurement Methods 0.000 description 4
- 230000006872 improvement Effects 0.000 description 4
- 239000007787 solid Substances 0.000 description 4
- 238000012800 visualization Methods 0.000 description 4
- 238000001514 detection method Methods 0.000 description 3
- 230000000977 initiatory effect Effects 0.000 description 3
- 239000000463 material Substances 0.000 description 3
- 238000005259 measurement Methods 0.000 description 3
- 238000012986 modification Methods 0.000 description 3
- 230000004048 modification Effects 0.000 description 3
- 238000005070 sampling Methods 0.000 description 3
- LYCAIKOWRPUZTN-UHFFFAOYSA-N Ethylene glycol Chemical compound OCCO LYCAIKOWRPUZTN-UHFFFAOYSA-N 0.000 description 2
- 238000003491 array Methods 0.000 description 2
- 238000004364 calculation method Methods 0.000 description 2
- 238000009472 formulation Methods 0.000 description 2
- 238000009413 insulation Methods 0.000 description 2
- VNWKTOKETHGBQD-UHFFFAOYSA-N methane Chemical compound C VNWKTOKETHGBQD-UHFFFAOYSA-N 0.000 description 2
- 239000000203 mixture Substances 0.000 description 2
- 230000001052 transient effect Effects 0.000 description 2
- 101100129500 Caenorhabditis elegans max-2 gene Proteins 0.000 description 1
- 241001465754 Metazoa Species 0.000 description 1
- 101150071746 Pbsn gene Proteins 0.000 description 1
- 230000004931 aggregating effect Effects 0.000 description 1
- 230000004888 barrier function Effects 0.000 description 1
- 239000003086 colorant Substances 0.000 description 1
- 238000010276 construction Methods 0.000 description 1
- 230000003247 decreasing effect Effects 0.000 description 1
- 238000013461 design Methods 0.000 description 1
- 230000009977 dual effect Effects 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005485 electric heating Methods 0.000 description 1
- 238000005265 energy consumption Methods 0.000 description 1
- 238000004146 energy storage Methods 0.000 description 1
- WGCNASOHLSPBMP-UHFFFAOYSA-N hydroxyacetaldehyde Natural products OCC=O WGCNASOHLSPBMP-UHFFFAOYSA-N 0.000 description 1
- 238000013178 mathematical model Methods 0.000 description 1
- 239000003345 natural gas Substances 0.000 description 1
- 230000003287 optical effect Effects 0.000 description 1
- 230000002093 peripheral effect Effects 0.000 description 1
- 239000003507 refrigerant Substances 0.000 description 1
- 238000006467 substitution reaction Methods 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 238000009423 ventilation Methods 0.000 description 1
- XLYOFNOQVPJJNP-UHFFFAOYSA-N water Substances O XLYOFNOQVPJJNP-UHFFFAOYSA-N 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B15/00—Systems controlled by a computer
- G05B15/02—Systems controlled by a computer electric
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B13/00—Adaptive control systems, i.e. systems automatically adjusting themselves to have a performance which is optimum according to some preassigned criterion
- G05B13/02—Adaptive control systems, i.e. systems automatically adjusting themselves to have a performance which is optimum according to some preassigned criterion electric
- G05B13/04—Adaptive control systems, i.e. systems automatically adjusting themselves to have a performance which is optimum according to some preassigned criterion electric involving the use of models or simulators
- G05B13/048—Adaptive control systems, i.e. systems automatically adjusting themselves to have a performance which is optimum according to some preassigned criterion electric involving the use of models or simulators using a predictor
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B23/00—Testing or monitoring of control systems or parts thereof
- G05B23/02—Electric testing or monitoring
- G05B23/0205—Electric testing or monitoring by means of a monitoring system capable of detecting and responding to faults
- G05B23/0218—Electric testing or monitoring by means of a monitoring system capable of detecting and responding to faults characterised by the fault detection method dealing with either existing or incipient faults
- G05B23/0224—Process history based detection method, e.g. whereby history implies the availability of large amounts of data
- G05B23/0227—Qualitative history assessment, whereby the type of data acted upon, e.g. waveforms, images or patterns, is not relevant, e.g. rule based assessment; if-then decisions
- G05B23/0235—Qualitative history assessment, whereby the type of data acted upon, e.g. waveforms, images or patterns, is not relevant, e.g. rule based assessment; if-then decisions based on a comparison with predetermined threshold or range, e.g. "classical methods", carried out during normal operation; threshold adaptation or choice; when or how to compare with the threshold
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q10/00—Administration; Management
- G06Q10/04—Forecasting or optimisation specially adapted for administrative or management purposes, e.g. linear programming or "cutting stock problem"
-
- G—PHYSICS
- G05—CONTROLLING; REGULATING
- G05B—CONTROL OR REGULATING SYSTEMS IN GENERAL; FUNCTIONAL ELEMENTS OF SUCH SYSTEMS; MONITORING OR TESTING ARRANGEMENTS FOR SUCH SYSTEMS OR ELEMENTS
- G05B2219/00—Program-control systems
- G05B2219/20—Pc systems
- G05B2219/26—Pc applications
- G05B2219/2642—Domotique, domestic, home control, automation, smart house
Definitions
- the present disclosure relates generally to control systems for HVAC equipment, and more particularly to system identification for controlling HVAC equipment.
- System identification refers to the process of generating a model of a system (e.g., a building served by an HVAC equipment) that can be used to control the HVAC equipment, for example in a model predictive control system. Because the physical phenomena that govern such systems are often complex, nonlinear, and poorly understood, system identification requires the determination of model parameters based on measured and recorded data from the real system in order to generate an accurate predictive model.
- the building management system includes building equipment operable to heat or cool a building and generate training data relating to behavior of a building system and a controller configured to perform a system identification process to identify one or more parameters of a system model that predicts the behavior of the building system.
- the one or more parameters includes at least one of one or more model parameters or one or more Kalman gain parameters.
- the system identification process includes generating a prediction error function based on the training data and the system model, generating a plurality of initial guesses of the one or more parameters, for each initial guess, running an optimization problem of the prediction error function for a first group of iterations, discarding, after the first group of iterations, a portion of the initial guesses based on one or more criteria and ranking a remaining portion of the initial guesses, running the optimization problem of the prediction error function for a top-ranked initial guess of the remaining portion to local optimality or for a second group of iterations to identify a first set of values of the one or more parameters, determining whether the first set of values of the one or more parameters satisfies a condition, and, in response to a determination that the first set of values satisfies the condition, identifying the one or more parameters as having the first set of values.
- the controller is configured to operate the building equipment to heat or cool the building by performing a predictive control process that uses the system model with the one or more parameters identified by the
- the controller is further configured to, in response to determining that the first set of values does not satisfy the condition, discard the top-ranked initial guess, run the optimization problem for a new top-ranked initial guess to local optimality or for the second group of iterations to identify a second set of values of the one or more parameters, determine whether the second set of values satisfies the condition, and, in response to a determination that the second set of values satisfies the condition, select the second set of values for the one or more parameters.
- the controller is configured to discard initial guesses that violate physical laws relating to the one or more parameters. In some embodiments, determining that the first set of values satisfies the condition includes determining that the first set of values conforms with the physical laws relating to the one or more parameters.
- the controller is configured to discard the portion of the initial guesses based on one or more criteria by determining that a first initial guess and a second initial guess lead toward a same local optimum after the first group of iterations and, in response, discarding first initial guess.
- the controller is configured to discard the portion of the initial guesses based on one or more criteria by discarding initial guesses that lead to an unstable, uncontrollable, or unobservable system after the first group of iterations.
- the controller is configured to discard the portion of the initial guesses based on one or more criteria by discarding initial guesses that lead to a matrix with a condition number greater than a threshold number.
- each of the plurality of initial guesses provides a stable system.
- the controller is configured to detect and remove saturation data from the training data.
- the prediction error function includes a multi-step ahead prediction error function.
- Another implementation of the present disclosure is a method for generating a system model for a building system and controlling building equipment in accordance with the system model.
- the method includes operating the building equipment to generate training data relating to behavior of the building system, defining a prediction error function based on the training data and the system model, and identifying values for one or more parameters of the system model by optimizing the prediction error function.
- Optimizing the prediction error function includes generating a plurality of initial guesses of the one or more parameters, running, for each initial guess, an optimization problem of the prediction error function for a first group of iterations, discarding, after the first group of iterations, a portion of the initial guesses based on one or more criteria and ranking a remaining portion of the initial guesses, running the optimization problem of the prediction error function for a top-ranked initial guess of the remaining portion to local optimality or for a second group of iterations to identify a first set of values of the one or more parameters, determining whether the first set of values of the one or more parameters satisfies a condition, and, in response to a determination that the first set of values satisfies the condition, defining the one or more parameters as having the first set of values.
- the method also includes operating the building equipment to heat or cool the building system by applying the system model in a predictive controller to generate control inputs for the building equipment.
- the method also includes, in response to determining that the first set of values does not satisfy the condition, discarding the top-ranked initial guess, running the optimization problem of the prediction error function for a new top-ranked initial guess to local optimality or for the second group of iterations to identify a second set of values of the one or more parameters, determining whether the second set of values satisfies the condition, and, in response to a determination that the second set of values satisfies the condition, selecting the second set of values for the one or more parameters.
- the method includes discarding initial guesses that violate physical laws relating to the one or more parameters and the behavior of the building system. In some embodiments, determining that the first set of values satisfies the condition includes determining that the first set of values conforms with the physical laws.
- discarding the portion of the initial guesses based on one or more criteria includes determining that a first initial guess and a second initial guess lead toward a same local optimum after the first group of iterations and, in response, discarding the first initial guess.
- discarding the portion of the initial guesses based on one or more criteria includes discarding initial guesses that lead to a matrix with a condition number greater than a threshold number after the first group of iterations.
- each of the plurality of initial guesses provides a stable system.
- the method includes detecting and removing saturation data from the training data.
- the prediction error function includes a multi-step ahead prediction error function.
- Another implementation of the present disclosure is a method for generating a system model for a building and controlling building equipment in accordance with the system model.
- the method includes operating the building equipment to generate training data relating to behavior of the building system, and defining a prediction error function based on the training data and the system model.
- the method also includes identifying values for one or more parameters of the system model based on the prediction error function by generating a plurality of initial guesses of the one or more parameters, for each initial guess, performing a first group of iterations using the prediction error function, after the first group of iterations, discarding a portion of the initial guesses based on one or more criteria and ranking a remaining portion of the initial guesses, performing a second group of iterations using the prediction error function for a top-ranked initial guess of the remaining portion to identify a first set of values of the one or more parameters, determining whether the first set of values of the one or more parameters satisfies a condition; and in response to a determination that the first set of values satisfies the condition, defining the one or more parameters as having the first set of values.
- the method also includes operating the building equipment to heat or cool the building system by applying the system model in a predictive controller to generate control inputs for the building equipment.
- FIG. 1 is a drawing of a building equipped with a HVAC system, according to an exemplary embodiment.
- FIG. 2 is a block diagram of the building and HVAC system of FIG. 1 , according to an exemplary embodiment.
- FIG. 3 is a circuit-style diagram of a model of the building and HVAC system of FIG. 1 , according to an exemplary embodiment.
- FIG. 4 is a block diagram of a controller for use with the HVAC system of FIG. 1 , according to an exemplary embodiment.
- FIG. 5 is a detailed block diagram of a model identifier of the controller of FIG. 4 , according to an exemplary embodiment.
- FIG. 6 is flowchart of a process for system identification, according to an exemplary embodiment.
- FIG. 7 is a flowchart of a multi-step ahead prediction error method for use in system identification, according to an exemplary embodiment.
- FIG. 8 is a visualization useful in illustrating the multi-step ahead prediction error method of FIG. 7 , according to an exemplary embodiment.
- FIG. 9 is a flowchart a first process for efficient model generation which can be performed by the model identifier of FIG. 5 , according to an exemplary embodiment.
- FIG. 10 is a flowchart of a second process for efficient model generation which can be performed by the model identifier of FIG. 5 , according to an exemplary embodiment.
- FIG. 11 is a visualization that facilitates explanation of the processes of FIGS. 9 and 10 , according to an exemplary embodiment.
- FIG. 12 is a graphical representation of experimental results obtained using the processes of FIGS. 9 and 10 , according to an exemplary embodiment.
- FIG. 13 is a graphical representation of experiment results obtained without using the processes of FIGS. 9 and 10 , for sake of comparison to FIG. 12 .
- FIG. 14 is a flowchart of a process for generating a system model for a building system and controlling building equipment in accordance with the system model, according to an exemplary embodiment.
- FIGURES systems and methods for system identification using a multi-step ahead prediction error approach for use in controlling plant equipment are shown and described.
- the systems and method described herein provide improved system models and therefore improved control of plant equipment for heating and cooling buildings or for other plant functions.
- a BMS is, in general, a system of devices configured to control, monitor, and manage equipment in or around a building or building area.
- a BMS can include, for example, a HVAC system, a security system, a lighting system, a fire alerting system, any other system that is capable of managing building functions or devices, or any combination
- HVAC system 100 can include a plurality of HVAC devices (e.g., heaters, chillers, air handling units, pumps, fans, thermal energy storage, etc.) configured to provide heating, cooling, ventilation, or other services for building 10 .
- HVAC system 100 is shown to include a waterside system 120 and an airside system 130 .
- Waterside system 120 may provide a heated or chilled fluid to an air handling unit of airside system 130 .
- Airside system 130 may use the heated or chilled fluid to heat or cool an airflow provided to building 10 .
- HVAC system 100 is shown to include a chiller 102 , a boiler 104 , and a rooftop air handling unit (AHU) 106 .
- Waterside system 120 may use boiler 104 and chiller 102 to heat or cool a working fluid (e.g., water, glycol, etc.) and may circulate the working fluid to AHU 106 .
- the HVAC devices of waterside system 120 can be located in or around building 10 (as shown in FIG. 1 ) or at an offsite location such as a central plant (e.g., a chiller plant, a steam plant, a heat plant, etc.).
- the working fluid can be heated in boiler 104 or cooled in chiller 102 , depending on whether heating or cooling is required in building 10 .
- Boiler 104 may add heat to the circulated fluid, for example, by burning a combustible material (e.g., natural gas) or using an electric heating element.
- Chiller 102 may place the circulated fluid in a heat exchange relationship with another fluid (e.g., a refrigerant) in a heat exchanger (e.g., an evaporator) to absorb heat from the circulated fluid.
- the working fluid from chiller 102 and/or boiler 104 can be transported to AHU 106 via piping 108 .
- AHU 106 may place the working fluid in a heat exchange relationship with an airflow passing through AHU 106 (e.g., via one or more stages of cooling coils and/or heating coils).
- the airflow can be, for example, outside air, return air from within building 10 , or a combination of both.
- AHU 106 may transfer heat between the airflow and the working fluid to provide heating or cooling for the airflow.
- AHU 106 can include one or more fans or blowers configured to pass the airflow over or through a heat exchanger containing the working fluid. The working fluid may then return to chiller 102 or boiler 104 via piping 110 .
- Airside system 130 may deliver the airflow supplied by AHU 106 (i.e., the supply airflow) to building 10 via air supply ducts 112 and may provide return air from building 10 to AHU 106 via air return ducts 114 .
- airside system 130 includes multiple variable air volume (VAV) units 116 .
- VAV variable air volume
- airside system 130 is shown to include a separate VAV unit 116 on each floor or zone of building 10 .
- VAV units 116 can include dampers or other flow control elements that can be operated to control an amount of the supply airflow provided to individual zones of building 10 .
- airside system 130 delivers the supply airflow into one or more zones of building 10 (e.g., via supply ducts 112 ) without using intermediate VAV units 116 or other flow control elements.
- AHU 106 can include various sensors (e.g., temperature sensors, pressure sensors, etc.) configured to measure attributes of the supply airflow.
- AHU 106 may receive input from sensors located within AHU 106 and/or within the building zone and may adjust the flow rate, temperature, or other attributes of the supply airflow through AHU 106 to achieve setpoint conditions for the building zone.
- HVAC system 100 thereby provides heating and cooling to the building 10 .
- the building 10 also includes other sources of heat transfer that the indoor air temperature in the building 10 .
- the building mass e.g., walls, floors, furniture
- People, electronic devices, other appliances, etc. (“heat load”) also contribute heat to the building 10 through body heat, electrical resistance, etc.
- the outside air temperature impacts the temperature in the building 10 by providing heat to or drawing heat from the building 10 .
- FIG. 2 a block diagram of the HVAC system 100 with building 10 is shown, according to an exemplary embodiment. More particularly, FIG. 2 illustrates the variety of heat transfers that affect the indoor air temperature T ia of the indoor air 201 in zone 200 of building 10 .
- Zone 200 is a room, floor, area, etc. of building 10 .
- the primary goal of the HVAC system 100 is to maintain the indoor air temperature T ia in the zone 200 at or around a desired temperature to facilitate the comfort of occupants of the zone 200 or to meet other needs of the zone 200 .
- the indoor air temperature T ia of the zone 200 has a thermal capacitance C i1 .
- the indoor air temperature T ia is affected by a variety of heat transfers ⁇ dot over (Q) ⁇ into the zone 200 , as described in detail below. It should be understood that although all heat transfers ⁇ dot over (Q) ⁇ are shown in FIG. 2 as directed into the zone 200 , the value of one or more of the heat transfers ⁇ dot over (Q) ⁇ may be negative, such that heat flows out of the zone 200 .
- the heat load 202 contributes other heat transfer ⁇ dot over (Q) ⁇ other to the zone 200 .
- the heat load 202 includes the heat added to the zone by occupants (e.g., people, animals) that give off body heat in the zone 200 .
- the heat load 202 also includes computers, lighting, and other electronic devices in the zone 200 that generate heat through electrical resistance, as well as solar irradiance.
- the building mass 204 contributes building mass heat transfer ⁇ dot over (Q) ⁇ m to the zone 200 .
- the building mass 204 includes the physical structures in the building, such as walls, floors, ceilings, furniture, etc., all of which can absorb or give off heat.
- the building mass 204 has a temperature T m and a lumped mass thermal capacitance C m .
- the resistance of the building mass 204 to exchange heat with the indoor air 201 may be characterized as mass thermal resistance R mi .
- the outdoor air 206 contributes outside air heat transfer ⁇ dot over (Q) ⁇ oa to the zone 200 .
- the outdoor air 206 is the air outside of the building 10 with outdoor air temperature T oa .
- the outdoor air temperature T oa fluctuates with the weather and climate.
- Barriers between the outdoor air 206 and the indoor air 201 e.g., walls, closed windows, insulation) create an outdoor-indoor thermal resistance R oi to heat exchange between the outdoor air 206 and the indoor air 201 .
- the HVAC system 100 also contributes heat to the zone 200 , denoted as ⁇ dot over (Q) ⁇ HVAC .
- the HVAC system 100 includes HVAC equipment 210 , controller 212 , an indoor air temperature sensor 214 and an outdoor air temperature sensor 216 .
- the HVAC equipment 210 may include the waterside system 120 and airside system 130 of FIG. 1 , or other suitable equipment for controllably supplying heating and/or cooling to the zone 200 .
- HVAC equipment 210 is controlled by a controller 212 to provide heating (e.g., positive value of ⁇ dot over (Q) ⁇ HVAC ) or cooling (e.g., a negative value of ⁇ dot over (Q) ⁇ HVAC ) to the zone 200 .
- the indoor air temperature sensor 214 is located in the zone 200 , measures the indoor air temperature T ia , and provides the measurement of T ia the controller 212 .
- the outdoor air temperature sensor 216 is located outside of the building 10 , measures the outdoor air temperature T oa , and provides the measurement of T oa to the controller 212 .
- the controller 212 receives the temperature measurements T oa and T ia , generates a control signal for the HVAC equipment 210 , and transmits the control signal to the HVAC equipment 210 .
- the operation of the controller 212 is discussed in detail below.
- the controller 212 considers the effects of the heat load 202 , building mass 204 , and outdoor air 206 on the indoor air 201 in controlling the HVAC equipment 210 to provide a suitable level of ⁇ dot over (Q) ⁇ HVAC .
- a model of this system for use by the controller 212 is described with reference to FIG. 3 .
- the control signal provide to the HVAC equipment 210 by the controller 110 indicates a temperature setpoint T sp for the zone 200 .
- the controller 212 assumes that the relationship between the indoor air temperature T ia and the temperature setpoint T sp follows a proportional-integral control law with saturation, represented as:
- j ⁇ ⁇ clg, hlg ⁇ is the index that is used to denote either heating or cooling mode.
- K p,j and K I,j are needed for the heating and cooling mode.
- the controller 212 uses this model in generating a control signal for the HVAC equipment 210 .
- FIG. 3 a circuit-style diagram 300 corresponding to the zone 200 and the various heat transfers ⁇ dot over (Q) ⁇ of FIG. 2 is shown, according to an exemplary embodiment.
- the diagram 300 models the zone 200 as a two thermal resistance, two thermal capacitance, control-oriented thermal mass system.
- This model can be characterized by the following system of linear differential equations, described with reference to FIG. 3 below:
- Indoor air node 302 corresponds to the indoor air temperature T ia . From indoor air node 302 , the model branches in several directions, including down to a ground 304 via a capacitor 306 with a capacitance C ia .
- the capacitor 306 models the ability of the indoor air to absorb or release heat and is associated with the rate of change of the indoor heat transfer ⁇ dot over (T) ⁇ ia . Accordingly, the capacitor 306 enters Eq. C on the left side of the equation as C ia ⁇ dot over (T) ⁇ ia .
- the diagram 300 From indoor air node 302 , the diagram 300 also branches left to building mass node 310 , which corresponds to the thermal mass temperature T m .
- a resistor 312 with mass thermal resistance R mi separates the indoor air node 302 and the building mass node 310 , modeling the heat transfer ⁇ dot over (Q) ⁇ m from the building mass 204 to the indoor air 201 as
- the diagram 300 also branches up from indoor air node 302 to outdoor air node 314 .
- a resistor 316 with outdoor-indoor thermal resistance R oi separates the indoor air node 302 and the outdoor air node 314 , modeling the flow heat from the outdoor air 206 to the indoor air 201 as
- the diagram 300 branches right to two ⁇ dot over (Q) ⁇ sources, namely ⁇ dot over (Q) ⁇ HVAC and ⁇ dot over (Q) ⁇ other .
- ⁇ dot over (Q) ⁇ other corresponds to heat load 202 and to a variety of sources of energy that contribute to the changes in the indoor air temperature T ia .
- ⁇ dot over (Q) ⁇ other is not measured or controlled by the HVAC system 100 , yet contributes to the rate of change of the indoor air temperature ⁇ dot over (T) ⁇ ia .
- ⁇ dot over (Q) ⁇ HVAC is generated and controlled by the HVAC system 100 to manage the indoor air temperature T ia . Accordingly, ⁇ dot over (Q) ⁇ HVAC and ⁇ dot over (Q) ⁇ other are included on the right side of Eq. C above.
- the second nonlinear differential equation (Eq. D) above focuses on the rate of change ⁇ dot over (T) ⁇ m in the building mass temperature T.
- the capacity of the building mass to receive or give off heat is modelled by capacitor 318 .
- Capacitor 318 has lumped mass thermal capacitance C m and is positioned between a ground 304 and the building mass node 310 and regulates the rate of change in the building mass temperature T m . Accordingly, the capacitance C m is included on left side of Eq. D.
- resistor 312 leading to indoor air node 302 branching from the building mass node 310 is resistor 312 leading to indoor air node 302 . As mentioned above, this branch accounts for heat transfer ⁇ dot over (Q) ⁇ m between the building mass 204 and the indoor air 201 . Accordingly, the term
- the model represented by diagram 300 is used by the controller 212 in generating a control signal for the HVAC equipment 210 . More particularly, the controller 212 uses a state-space representation of the model shown in diagram 300 .
- the state-space representation used by the controller 212 can be derived by incorporating Eq. A and B with Eq. C and D, and writing the resulting system of equations as a linear system of differential equations to get:
- [ T . i ⁇ a T . m I . ] [ 1 C ia ⁇ ( K p , j - 1 R m ⁇ i ⁇ 1 R oi ) ⁇ 1 C ia ⁇ R mi K I , j C i ⁇ a 1 C m ⁇ R mi - 1 C m ⁇ R mi 0 - 1 0 0 ] [ ⁇ T i ⁇ a T m I ] + ⁇ ⁇ [ ⁇ - K p , j C ia 1 C ia ⁇ R oi 0 0 1 0 ] ⁇ [ T s ⁇ p ⁇ j T o ⁇ a ] + [ 0 1 C ia 0 ] ⁇ Q .
- I represents the integral term ⁇ 0 t ⁇ sp (s)ds from Eq. A.
- the resulting linear system has three states (T ia , T m , I), two inputs (T sp, j , T oa ), two outputs (T ia , ⁇ dot over (Q) ⁇ HVAC ), and one disturbance ⁇ dot over (Q) ⁇ other .
- the controller 212 models the disturbance ⁇ dot over (Q) ⁇ other using an input disturbance model that adds a forth state d to the state space representation.
- this linear system of differential equations can be written as:
- a c ⁇ ( ⁇ ) [ - ( ⁇ 1 + ⁇ 2 + ⁇ 3 ⁇ ⁇ 4 ) ⁇ 2 ⁇ 3 ⁇ ⁇ 4 ⁇ ⁇ 5 ⁇ 6 - ⁇ 6 0 - 1 0 0 ] ⁇
- ⁇ B c ⁇ ( ⁇ ) [ ⁇ 3 ⁇ ⁇ 4 ⁇ 1 0 0 1 0 ]
- ⁇ C c ⁇ ( ⁇ ) [ 1 0 0 - ⁇ 4 0 ⁇ 5 ⁇ ⁇ 4 ]
- ⁇ ⁇ D c ⁇ ( ⁇ ) [ 0 0 ⁇ 4 0 ] ;
- ⁇ 1 1 C i ⁇ a ⁇ R o ⁇ i ;
- ⁇ 2 1 C i ⁇ a ⁇ R ⁇ i ;
- ⁇ 3 1 C i ⁇ a ;
- ⁇ 4 K p ;
- ⁇ 5 1 ⁇ ; ⁇
- the controller 212 uses a two-step process to parameterize the system.
- the disturbance state d is then introduced into the model and an Kalman estimator gain is added, such that in the second step the controller 212 identifies the Kalman gain parameters K.
- variable refers to an item/quantity capable of varying in value over time or with respect to change in some other variable.
- a “value” as used herein is an instance of that variable at a particular time. A value may be measured or predicted.
- T sp is a variable that changes over time
- T sp (3) is a value that denotes the setpoint at time step 3 (e.g., 68 degrees Fahrenheit).
- predicted value as used herein describes a quantity for a particular time step that may vary as a function of one or more parameters.
- the controller 212 includes a processing circuit 400 and a communication interface 402 .
- the communication interface 402 is structured to facilitate the exchange of communications (e.g., data, control signals) between the processing circuit 400 and other components of HVAC system 100 .
- the communication interface 402 facilitates communication between the processing circuit 400 and the outdoor air temperature sensor 216 and the indoor air temperature sensor 214 to all temperature measurements T oa and T ia to be received by the processing circuit 400 .
- the communication interface 402 also facilitates communication between the processing circuit 400 and the HVAC equipment 210 that allows a control signal (indicated as temperature setpoint T sp ) to be transmitted from the processing circuit 400 to the HVAC equipment 210 .
- the processing circuit 400 is structured to carry out the functions of the controller described herein.
- the processing circuit 400 includes a processor 404 and a memory 406 .
- the processor 404 may be implemented as a general-purpose processor, an application-specific integrated circuit, one or more field programmable gate arrays, a digital signal processor, a group of processing components, or other suitable electronic processing components.
- the memory 406 described in detail below, includes one or more memory devices (e.g., RAM, ROM, NVRAM, Flash Memory, hard disk storage) that store data and/or computer code for facilitating at least some of the processes described herein.
- the memory 406 stores programming logic that, when executed by the processor 404 , controls the operation of the controller 212 .
- the memory 406 includes a training data generator 408 , a training data database 410 , a model identifier 412 , a model predictive controller 414 , and an equipment controller 416 .
- the various generators, databases, identifiers, controllers, optimizers, etc. of memory 406 may be implemented as any combination of hardware components and machine-readable media included with memory 406 .
- the equipment controller 416 is configured to generate a temperature setpoint T sp that serves as a control signal for the HVAC equipment 210 .
- the equipment controller receives inputs of the indoor air temperature T ia from the indoor air temperature sensor 214 via the communication interface 402 and ⁇ dot over (Q) ⁇ HVAC from the model predictive controller 414 (during normal operation) and the training data generator 408 (during a training data generation phase described in detail below).
- the equipment controller uses T ia and ⁇ dot over (Q) ⁇ HVAC to generate T sp by solving Eq. A and Eq. B above for T sp .
- the equipment controller 416 then provides the control signal T sp to the HVAC equipment 210 via the communication interface 402 .
- the model predictive controller 414 determines ⁇ dot over (Q) ⁇ HVAC based on an identified model and the temperature measurements T ia , T oa , and provides ⁇ dot over (Q) ⁇ HVAC to the equipment controller 416 .
- the model predictive controller 414 follows a model predictive control (MPC) approach.
- the MPC approach involves predicting future system states based on a model of the system, and using those predictions to determine the controllable input to the system (here, ⁇ dot over (Q) ⁇ HVAC ) that bests achieves a control goal (e.g., to maintain the indoor air temperature near a desired temperature).
- a more accurate model allows the MPC to provide better control based on more accurate predictions.
- the model predictive controller 414 uses a model identified through a system identification process facilitated by the training data generator 408 , the training data database 410 , and the model identifier 412 , described in detail below.
- System identification as facilitated by the training data generator 408 , the training data database 410 , and the model identifier 412 , is a process of constructing mathematical models of dynamic systems.
- System identification provides a suitable alternative to first-principles-derived model when first principles models are unavailable or too complex for on-line MPC computations.
- System identification captures the important and relevant system dynamics based on actual input/output data (training data) of the system, in particular by determining model parameters particular to a building or zone to tune the model to the behavior of the building/zone.
- the training data generator 408 , the training data database 410 , and the model identifier 412 each contribute to system identification by the controller 212 .
- the training data generator 408 is configured to generate training data by providing an excitation signal to the system. That is, the training data generator provides various ⁇ dot over (Q) ⁇ HVAC values to the equipment controller 416 for a number N of time steps k, and receives the measured output response of the indoor air temperature T ia at each time step k from the air temperature sensor 214 .
- the various ⁇ dot over (Q) ⁇ HVAC values may be chosen by the training data generator 408 to explore the system dynamics as much as possible (e.g., across a full range of possible ⁇ dot over (Q) ⁇ HVAC values, different patterns of ⁇ dot over (Q) ⁇ HVAC values, etc.).
- the equipment controller 416 receives the various ⁇ dot over (Q) ⁇ HVAC values and generates various control inputs T sp in response.
- the temperature setpoint T sp for each time step k is provided to the HVAC equipment 210 , which operates accordingly to heat or cool the zone 200 (i.e., to influence T ia ).
- the temperature setpoints T sp may also be provided to the training data generator 408 to be included in the training data.
- the training data generator receives an updated measurement of the indoor air temperature T ia for each time step k and may also receive the outdoor air temperature T oa for each time step k.
- the training data generator 408 thereby causes the states, inputs, and outputs of the system to vary across the time steps k and generates data corresponding to the inputs and outputs.
- the inputs and outputs generated by the training data generator 408 are provided to the training data database 410 . More particularly, in the nomenclature of the model of Eq. E and Eq. F above, the training data generator 408 provides inputs T sp and T oa and outputs ⁇ dot over (Q) ⁇ HVAC and T ia for each time step k to the training data database 410 .
- the training data database 410 stores the inputs and outputs for each time step k provided by the training data generator 408 . Each input and output is tagged with a time step identifier, so that data for the same time step can be associated together.
- This data is grouped together in the training data database 410 in a set of training data Z N .
- Z N [y(1), u(1), y(2), u(2), . . . , y(N), u(N)].
- the training data is refined using a saturation detection and removal process.
- System and methods for saturation detection and removal suitable for use to refine the training data Z N are described in U.S. patent application Ser. No. 15/900,459, filed Feb. 20, 2018, incorporated by reference herein in its entirety.
- the training data may be filtered by determining whether the operating capacity is in a non-transient region for a threshold amount of a time period upon determining that an error for the building zone exists for the time period, and in response to a determination that the operating capacity is in the non-transient region for at least the threshold amount of the time period, indicating the time period as a saturation period. Data from the saturation period can then be removed from the training data.
- the model identifier 412 accesses the training data database 410 to retrieve the training data Z N and uses the training data Z N to identify a model of the system.
- the model identifier 412 includes a system parameter identifier 418 and a gain parameter identifier 420 .
- the system parameter identifier 418 carries out a first step of system identification, namely identifying the model parameters
- the gain parameter identifier 420 carries out the second step, namely determining a Kalman gain estimator.
- the model parameters and the Kalman gain estimator are included in an identified model of the system, and that model is provided to the model predictive controller 414 .
- the model predictive controller can thus facilitate the control of the HVAC equipment 210 as described above.
- the model identifier 412 includes the system parameter identifier 418 and the gain parameter identifier 420 .
- the system parameter identifier 418 includes a model framework identifier 422 , a prediction error function generator 424 , and an optimizer 426 .
- the model framework identifier 422 identifies that the model of the system, denoted as ( ⁇ ), corresponds to the form described above in Eqs. G and H, i.e.,
- the model framework identifier 422 thereby determines that the system parameter identifier 418 has the goal of determining a parameter vector ⁇ circumflex over ( ⁇ ) ⁇ N from the set of ⁇ ⁇ ⁇ d , where is the set of admissible model parameter values.
- the goal of the system parameter identifier 418 is to select a parameter vector ⁇ circumflex over ( ⁇ ) ⁇ N from among possible values of ⁇ that best matches the model to the physical system (i.e., the vector ⁇ is a list of variables and the vector ⁇ circumflex over ( ⁇ ) ⁇ N is a list of values), thereby defining matrices A, B, C, and D.
- the prediction error function generator 424 applies a prediction error method to determine the optimal parameter vector ⁇ circumflex over ( ⁇ ) ⁇ N .
- prediction error methods determine the optimal parameter vector ⁇ circumflex over ( ⁇ ) ⁇ N by minimizing some prediction performance function V N ( ⁇ , Z N ) that is based in some way on the difference between predicted outputs and the observed/measured outputs included in the training data Z N . That is, the parameter estimation ⁇ N is determined as:
- the prediction error function generator 424 use one or more of several possible prediction error approaches to generate a prediction performance function V N ( ⁇ , Z N ). In the embodiment shown, the prediction error function generator applies a simulation approach. In the simulation approach, the prediction error function generator 424 uses the model ( ⁇ ), the input trajectory [u(1),u(2), . . . , u(N)], and an initial state x(0) to produce predicted outputs in terms of ⁇ . That is, the prediction error function generator 424 predicts:
- 0, ⁇ ) denotes the predicted output at time step k given the training data from time 0 and the model ( ⁇ ).
- the prediction error function generator 424 then squares the two-norm of each prediction error ⁇ (k, ⁇ ) and sums the results to determine the prediction performance function, which can be written as:
- the prediction error function generator 424 applies a one-step-ahead prediction error method to generate the prediction performance function V N ( ⁇ , Z N ).
- the prediction error function generator 424 uses past input-output data and the model ( ⁇ ) the model to predict the output one step ahead in terms of ⁇ . That is, in the one-step ahead prediction error method, the prediction error function generator 424 generates one-step ahead predictions ⁇ (k
- the prediction error function generator 424 then squares the two-norm of the prediction errors for each k and sums the results, generating a prediction performance function that can be expressed in a condensed form as:
- the prediction error function generator 424 uses a multi-step ahead prediction error approach to generate the prediction performance function.
- the multi-step ahead prediction error approach is described in detail below with reference to the gain parameter identifier 420 and FIGS. 7-8 .
- the multi-step ahead prediction error approach is also described in detail in U.S. patent application Ser. No. 15/953,324, filed Apr. 13, 2018, incorporated by reference herein in its entirety.
- the prediction error function generator 424 then provides the performance function V N ( ⁇ , Z N ) (i.e., from Eq. I or Eq. J in various embodiments) to the optimizer 426 .
- the optimizer 426 receives the prediction error function generated by the prediction error function generator 424 and optimizes the prediction error function in ⁇ to determine ⁇ circumflex over ( ⁇ ) ⁇ N . More specifically, the optimizer 426 finds the minimum value of the prediction error function V N ( ⁇ , Z N ) as ⁇ is varied throughout the allowable values of ⁇ ⁇ . That is, the optimizer 426 determines ⁇ circumflex over ( ⁇ ) ⁇ N based on:
- the optimizer 426 then uses ⁇ circumflex over ( ⁇ ) ⁇ N to calculate the matrices A, B, C, and D.
- the system parameter identifier 418 then provides the identified matrices A, B, C, D to the gain parameter identifier 420 .
- the gain parameter identifier 420 receives the model with the matrices A, B, C, D (i.e., the model parameters) from system parameter identifier 418 , as well as the training data Z N from the training data database 410 , and uses that information to identify the gain parameters.
- the gain parameter identifier 420 includes an estimator creator 428 , a prediction error function generator 430 , and an optimizer 432 .
- the estimator creator 428 adds a disturbance model and introduces a Kalman estimator gain to account for thermal dynamics of the system, for example for the influence of ⁇ dot over (Q) ⁇ other on the system.
- the estimator creator 428 generates an augmented model with disturbance state d, given by:
- parameters A c , B c , C c , and D c are the matrices A, B, C, D received from the system parameter identifier 418 and the disturbance model is selected with
- the estimator creator 428 then converts the model to a discrete time model, for example using 5-minute sampling periods, resulting in the matrices A dis , B dis , C dis , D dis and the disturbance model discrete time matrix B d dis .
- the estimator creator 428 then adds a parameterized estimator gain, resulting in the following model:
- the matrix K( ⁇ ) is the estimator gain parameterized with the parameter vector ⁇ where:
- t) is an estimate of the state at time t+1 obtained using the Kalman filter and made utilizing information at sampling time t. For example, with a sampling time of five minutes, ⁇ circumflex over (x) ⁇ (t+1
- the goal of the gain parameter identifier is to identify parameters ⁇ circumflex over ( ⁇ ) ⁇ N (i.e., a vector of for each of ⁇ 1 . . . ⁇ 8 ) that make the model best match the physical system.
- the estimator creator 428 then provides the discrete time model with estimator gain (i.e., Eqs. K-L) to the prediction error function generator 430 .
- the prediction error function generator receives the model from the estimator creator 428 as well as the training data Z N from the training data database 410 , and uses the model (with the estimator gain) and the training data Z N to generate a prediction performance function.
- the prediction error function generator 430 follows a multi-step ahead prediction error method to generate a predication performance function V N ( ⁇ , Z N ).
- the multi-step ahead prediction error method is illustrated in FIGS. 7-8 and described in detail with reference thereto.
- the prediction error function generator 430 uses past input-output data and the model ( ⁇ ) the model to predict the output multiple step ahead in terms of ⁇ . That is, in the multi-step ahead prediction error method, the prediction error function generator 430 generates multi-step ahead predictions ⁇ (k+h
- the prediction error function generator 430 then squares the two-norm of the prediction errors for each k and sums the results, in some embodiments using an weighting function w(h).
- the prediction error function generator 430 thereby generates a prediction performance function that can be expressed in a condensed form as:
- the multi-step ahead prediction error method is described in more detail below with reference to FIGS. 7-8 .
- the prediction error function generator 430 follows the simulation approach or the one-step ahead prediction error approach discussed above with reference to the prediction error function generator 424 .
- the prediction error function generator 430 then provides the prediction performance function (i.e., Eq. M) to the optimizer 432 .
- the optimizer 432 receives the prediction error function V N ( ⁇ , Z N ) generated by the prediction error function generator 430 and optimizes the prediction error function in ⁇ to determine ⁇ circumflex over ( ⁇ ) ⁇ N . More specifically, the optimizer 426 finds the minimum value of the prediction error function V N ( ⁇ , Z N ) as ⁇ is varied throughout the allowable values of ⁇ . In some cases, all real values of ⁇ are allowable. That is, the optimizer 426 determines ⁇ circumflex over ( ⁇ ) ⁇ N based on:
- the optimizer 432 uses ⁇ circumflex over ( ⁇ ) ⁇ N to calculate the matrices K x ( ⁇ ) and K d ( ⁇ ), resulting in a fully identified model.
- the gain parameter identifier 420 provides the identified model to the model predictive controller 414 .
- the prediction error function generator 430 reconfigures the multi-step ahead prediction problem by defining augmented vectors that allow the multi-step ahead prediction performance function (Eq. M) to be recast in an identical structure to the single-step ahead prediction performance function (Eq. J).
- Existing software toolboxes and programs e.g., Matlab system identification toolbox
- Matlab system identification toolbox e.g., Matlab system identification toolbox
- k ) A ⁇ circumflex over (x) ⁇ ( k
- k ⁇ 1) C ⁇ circumflex over (x) ⁇ ( k
- the one-step prediction (with the prediction error function generator 430 given x0) is given by the equation:
- 0) A ⁇ circumflex over (x) ⁇ (1
- 0)+ Bu (1) A ( Ax 0+ Bu (0)+ K ( y (0) ⁇ Cx 0 ⁇ Du (0)))+ Bu (1); ⁇ (1
- 0) C ⁇ circumflex over (x) ⁇ (1
- 0)+ Du (1) C ( Ax 0+ Bu (0)+ K ( y (0) ⁇ Cx 0 ⁇ Du (0)))+ Du (1).
- the prediction of the third step is the prediction of the prediction of the third step.
- the forth step prediction is
- the pattern needed to cast the multi-step prediction problem as a 1-step prediction is revealed.
- the pattern revealed is:
- 0) Ax 0 +Bu (0)+ K ( y (0) ⁇ Cx 0 ⁇ Du (0)); ⁇ circumflex over (x) ⁇ (2
- 0) ( A 2 ⁇ AKC ) x 0+( AB ⁇ AKD ) u (0)+ Bu (1)+ AKy (0); ⁇ circumflex over (x) ⁇ (3
- 0) ( A 3 ⁇ A 2 KC ) x 0+( A 2 B ⁇ A 2 KD ) u (0)+ ABu (1)+ Bu (2)+ A 2 Ky (0); ⁇ circumflex over (x) ⁇ (4
- 0) ( CA ⁇ CKC ) x 0+( CB ⁇ CKD
- the prediction error function generator 430 defines the following vectors:
- u ⁇ ⁇ ( 0 ) [ u ⁇ ( 0 ) u ⁇ ( 1 ) u ⁇ ( 2 ) u ⁇ ( 3 ) y ⁇ ( 0 ) ]
- y ⁇ ⁇ ⁇ ( 0 ) [ y ⁇ ⁇ ( 0 ) y ⁇ ⁇ ( 1
- y ⁇ ⁇ ( 0 ) [ y ⁇ ( 0 ) y ⁇ ( 1 ) y ⁇ ( 2 ) y ⁇ ( 3 ) ] ,
- the new system that has the 4-step prediction casted into a one-step prediction which can be analyzed by the prediction error function generator 430 using an existing system identification software product as:
- this four-step example can be extrapolated to define the general augmented input and output vectors as:
- k ) A ⁇ circumflex over (x) ⁇ ( k
- the prediction error function generator 430 generates a function of the form:
- the multi-step ahead prediction performance function can be reconfigured into the following one-step ahead prediction performance function by the prediction error function generator 430 :
- the prediction error function generator 430 uses this reconfigured format of the prediction performance function with existing software toolboxes suited for the one-step ahead prediction error approach.
- the prediction error function generator 430 may include machine-readable media storing computer code executable to apply such software.
- FIG. 6 a flowchart of a process 600 for system identification is shown, according to an exemplary embodiment.
- the process 600 can be carried out by the controller 212 of FIGS. 2 and 4 .
- the controller 212 applies an excitation signal to the HVAC equipment 210 .
- the training data generator 408 may vary the ⁇ dot over (Q) ⁇ HVAC values supplied to the equipment controller 416 , causing an excitation signal to be generated in the temperature setpoint T sp inputs provided to the HVAC equipment 210 .
- the excitation signal is designed to test the system in a way to provide robust data for use in system identification.
- training data is collected and stored by the controller 212 .
- the training data therefore includes inputs u(k) and the outputs y(k) for the time period.
- the training data is received from temperature sensors 214 , 216 , training data generator 408 , and/or equipment controller 416 and stored in training data database 410 .
- the controller 212 identifies the model parameters for the system. That is, as discussed in detail above, the controller 212 determines the matrices A( ⁇ ), B( ⁇ ), C( ⁇ ), and D( ⁇ ) that minimize a prediction performance function V N (Z N , ⁇ ) for the model:
- model parameters are determined at step 606 using a multi-step ahead prediction error method, described in detail with reference to FIGS. 7-8 .
- the controller 212 identifies the gain estimator parameters. That is, the controller 212 determines the matrices K x and K d of Eq. K above. In preferred embodiments, the controller 212 uses the multi-step ahead prediction error method to find the matrices K x and K d .
- the multi-step ahead prediction error method is described in detail below with reference to FIGS. 7-8 . In alternative embodiments, a simulation approach or a one-step-ahead prediction error approach is followed to find the matrices K x and K d .
- the identified model is validated by the controller 212 .
- the controller 212 uses the identified model to generate control signal inputs T sp for the HVAC equipment 210 using model predictive control.
- the controller then monitors the temperature measurements T oa and T ia from temperature sensors 214 , 216 , the input T sp , and the value ⁇ dot over (Q) ⁇ HVAC to determine how well the model matches system behavior in normal operation.
- the training data database 410 may collect and store an addition set of training data that can be used by the model identifier 412 to validate the model. If some discrepancy is determined, the identified model may be updated. The identified model can thereby by dynamically adjusted to adjust for changes in the physical system.
- FIGS. 7-8 the multi-step ahead prediction error approach for use in system identification is illustrated, according to an exemplary embodiment.
- FIG. 7 a flowchart of a process 700 for identifying system parameters using the multi-step ahead prediction error approach is shown, according to an exemplary embodiment.
- FIG. 8 shows an example visualization useful in explaining process 700 .
- Process 700 can be carried out by the system parameter identifier 418 and/or the gain parameter identifier 420 of FIG. 5 . In the embodiment described herein, the process 700 is implemented with the gain parameter identifier 420 .
- N is the number of samples in the training data.
- the gain parameter identifier 420 also receives the system model from the system parameter identifier 418 .
- the prediction error function generator 430 uses the training data for a time step k to predict outputs ⁇ for each subsequent time step up to k+h max .
- the prediction horizon may be any integer greater than one, for example four or eight.
- the prediction horizon can be tuned experimentally, to determine an ideal prediction horizon. For example, too long of a prediction horizon may lead to poor prediction while too short of a prediction horizon may suffer the same limitations as the one-step ahead prediction error method mentioned above. In some cases, a prediction horizon of eight is preferred.
- k ⁇ 1)] are predicted based on the past training data (i.e., through step k ⁇ 1), denoted as Z k ⁇ 1 , along with future inputs [u(k), u(k+1) . . . u(k+h max )]. These predictions are made using the model ( ⁇ ), such that predicted outputs ⁇ depend on ⁇ .
- FIG. 8 shows a simplified visualization in which y(k) and ⁇ (k) are depicted as scalar values for the sake of simplified explanation.
- the solid circles 802 represent measured outputs y(t) from the training data.
- the unfilled boxes 804 represent predicted outputs ⁇ (t
- 0), that is, the outputs predicted for each time step based on the input/output data available at time t 0 (e.g., y(0)).
- the dashed lines represent the propagation of the predictions; for example, graph 800 includes three unfilled boxes 804 connected by a dashed line to the solid circle 802 corresponding to y(0). This shows that the predictions ⁇ (t
- the prediction error function generator 430 compares the predicted outputs ⁇ to the measured outputs y for each future step up to k+h max (i.e., for all predicted outputs ⁇ generated at step 704 ). More specifically, an error term for each step may be defined as y(k+h) ⁇ (k+h
- step 706 can be understood as measuring the distance between, for example, each unfilled box 804 and the corresponding solid circle 802 (i.e., the unfilled box 804 and the solid circle 802 at the same time t).
- step 706 includes calculating three error terms.
- the error terms are weighted based on a weighting function w(h).
- the weighting function w(h) allows the prediction errors to be given more or less weight depending on how many steps ahead the prediction is.
- step 704 corresponds to generating the predictions represented by the unfilled circles 808 and the unfilled triangles 810 .
- 1), for t 2, 3, 4.
- 2), for t 3, 4, 5.
- the prediction error function generator 430 again compares the predicted outputs ⁇ for the new value of k to the measured outputs y for each future step up to k+h max to define the error term ⁇ y(k+h) ⁇ (k+h
- the terms are again weighted by the weighting function w(h).
- the weighting function w(h) may be the same for each k.
- each iteration of steps 704 - 708 thus corresponds to steps necessary to generate the values used by the inner (right) summation indexed in h, while repetition of the steps 704 - 708 corresponds to the iteration through k represented in the outer (left) summation.
- these summations are executed.
- the system identification circuit 108 sums the weighted error terms generated by steps 704 - 708 to generate a prediction performance function as:
- the prediction performance function is a function of the input data Z N and the parameter variable ⁇ .
- the input data Z N is given (i.e., received by the model identifier 412 and used in the calculation of error terms as described above).
- the prediction performance function is primarily a function of ⁇ .
- the result of step 712 is a vector ⁇ circumflex over ( ⁇ ) ⁇ N of identified model parameters that tune the model ( ⁇ circumflex over ( ⁇ ) ⁇ N ) to accurately predict system evolution multiple steps ahead.
- the model identifier 412 provides the identified system model (i.e., ( ⁇ circumflex over ( ⁇ ) ⁇ N )) to the model predictive controller 414 for use in generating control inputs for the HVAC equipment 210 .
- process 700 is run once at set-up to establish the system model, run periodically to update the system model, or run repeatedly/continuously to dynamically update the system model in real time.
- FIG. 9 a flowchart showing a process 900 for optimizing the prediction performance function (cost function) to identify model parameters is shown, according to an exemplary embodiment.
- the optimizer 426 of the system parameter identifier 418 of FIG. 5 may be configured to executed the process 900 , and reference is made thereto in the following description of process 900 .
- the process 900 is included in step 712 of the process 700 of FIG. 7 .
- the optimizer 426 generates a number N of initial guesses of the system parameters ⁇ , where the matrix A( ⁇ ) is stable.
- the optimizer 426 may ensure that the matrix A is stable by initiating all six parameters to be positive and checking that each eigenvalue of the resulting A matrix has a negative real part.
- the optimizer 426 may ensure that the matrix A is stable by initiating the fifth parameter to zero
- circuit-style diagram 300 shown in FIG. 3 as a passive circuit.
- the optimizer 426 discards initial guesses for which
- the optimizer 426 checks that the indoor air-thermal mass thermal resistance is larger than the indoor air-outdoor air thermal resistance and that the lump mass thermal capacitance value is larger than the indoor air thermal capacitance, and discards initial guesses that violate these physical requirements. The optimizer 426 thereby ensures that the remaining initial guesses conform with requirements from the basic physics of the system.
- the optimizer 426 runs a system identification problem for each remaining initial guess for a small number of iterations M.
- the small number M may be substantially lower than the number of iterations needed to reach local optimality for the system identification problem given an initial guess.
- the process 900 limits the computation required at step 906 (e.g., computation time, computing resources used) relative to other possible approaches.
- the optimizer 426 records (e.g., stores, saves) the value of the cost function and the system parameter values after the M iterations.
- the optimizer 426 discards initial guesses that lead to an unstable A matrix and/or an A matrix with a very high condition number after M iterations (i.e., as recorded at step 908 ). That is, the optimizer 426 may check whether each A matrix recorded at step 908 is stable, and keep only the initial guesses corresponding to a stable A matrix. The optimizer 426 may also determine the condition number of the A matrix and only keep the corresponding initial guess if the condition number is less than a very high threshold number.
- the optimizer 426 determines groups of initial guesses that converge towards the same local optimal solution (i.e., a similar cost function value and similar parameter values).
- the optimizer 426 discards all but one initial guess from each group.
- FIG. 11 is included to illustrate steps 912 and 914 (depicted with a single parameter variable ⁇ for the sake of clarity).
- FIG. 11 shows a graph 1100 of a cost function V( ⁇ ) with the value of the cost function V( ⁇ ) on the vertical axis and the parameter value ⁇ on the horizontal axis. The region of the cost function V( ⁇ ) shown in FIG.
- first local optimum 1102 and a second local optimum 1104 that have similar cost function values (i.e., positions on the vertical axis as illustrated by dotted line 1106 ) but different parameter values. Also illustrated in FIG. 11 is a first group of multiple initial guesses 1108 illustrated as trending towards either the first local optimum 1102 and a second group of multiple initial guesses 1110 illustrated as trending towards the second local optimum 1104 .
- all but one of the first group of initial guesses 1108 and all but one of the second group of initial guesses 1110 can be discarded to avoid duplication, triplication, etc. of computations in later phases of process 900 .
- one of the local optima may also be a global optimum.
- the optimizer 426 ranks the remaining initial guesses in order of cost function value from lowest value to highest value after the M iterations.
- a lower cost function value corresponds to a higher accuracy of the predictive model, such that a top-ranked initial guess (i.e., having the lowest cost function value) may be understood as corresponding to the most accurate set of parameter values after the M iterations.
- the optimizer 426 chooses the top-ranked initial guess and runs the system identification problem for the top-ranked initial guess to local optimality or for a large number of iterations P.
- the optimizer 426 thereby generates a set of parameters characterized by the A, B, C, and D matrices defined above based on the top-ranked initial guess.
- the optimizer 426 checks whether the A matrix is stable, controllable and observable. The optimizer 426 also checks whether the condition number of the A matrix is less than a threshold number L. If the A matrix is unstable, uncontrollable, unobservable, or has a condition number greater than L, then the process 900 proceeds to step 922 where the corresponding initial guess is discarded. If the A matrix is stable, controllable, observable, and has a condition number less than the threshold number, then the process 900 proceeds to step 924 .
- the optimizer 426 checks whether the obtained model (i.e., after P iterations) satisfies the physics-based inequalities
- step 922 the process 900 proceeds to step 922 where the corresponding initial guess is discarded.
- the process 900 then returns to step 918 , where the system optimization problem is run for the top-ranked remaining initial guess to local optimality or for a large number of iterations P.
- the process 900 thereby repeats steps 918 - 922 until an A matrix is obtained that satisfies the conditions of steps 920 and 924 (i.e., a model is identified for which A is stable, controllable, and observable, has a condition number less than the threshold number, and satisfies
- step 926 the system model parameters are identified in accordance with the obtained model that satisfies the conditions of steps 920 and 924 .
- the system model parameters e.g., the obtained A, B, C, and D matrices
- the gain parameter identifier 420 may be output from the optimizer 426 to the gain parameter identifier 420 as shown in FIG. 5 .
- process 900 avoids running poor initial guesses all the way to local optimality (i.e., for a large number of iterations).
- Process 900 also avoids running multiple initial guesses to the same local optimum.
- the process 900 is therefore substantially more efficient than other approaches for example generating many initial guesses, running all to local optimality, checking the quality of all models to choose the best result as the obtained model, and repeating the entire process if the obtained model is not satisfactory (e.g., does not satisfy the criteria in steps 920 and 924 ). Experimental results showing this improvement are described below with reference to FIGS. 12-13 .
- FIG. 10 a flowchart of a process 1000 for identifying Kalman gain parameters as part of a system identification process is shown, according to an exemplary embodiment.
- the process 1000 may be executed by the optimizer 432 of the gain parameter identifier 420 of FIG. 5 .
- the process 1000 may be included in step 608 of FIG. 6 .
- the optimizer 432 may use the system model parameters identified via process 900 as an input to process 1000 .
- the optimizer 432 generates Ninitial guesses of the Kalman gain parameters, with each initial guess having a stable observer system A ⁇ KC, i.e., for which all eigenvalues of A ⁇ KC are in the unit circuit.
- the optimizer 432 ensures that the initial guess have a stable observer system A ⁇ KC using pole placement in which an observer gain is calculated in such a way that places the eigenvalues of A ⁇ KC in any desired location provided that the system is observable.
- the optimizer 432 runs a system identification problem for each initial guess for a small number of iterations M. After the M iterations, at step 1006 the optimizer 432 records the cost function and the Kalman gain parameter values that were reached for each initial guess.
- the optimizer 432 discards initial guesses that lead to an unstable A ⁇ KC observer system. That is, for each initial guess, the optimizer 432 may check whether A ⁇ KC is stable after M iterations and only keeps the corresponding guess if the optimizer 432 determines that A ⁇ KC is stable.
- the optimizer 432 discards initial guesses that lead to an A ⁇ KC observer system with a very high condition number (e.g., higher than a threshold number). That is, for each initial guess, the optimizer 432 determines the condition number of A ⁇ KC and only keeps the corresponding initial guess if the condition number is less than a very high threshold number.
- the optimizer 432 determines groups of initial guesses that converge towards the same local optimal solution (e.g., with similar Kalman gain parameter values and cost function values).
- the optimizer 432 discards all but one initial guess from each group of initial guesses that converge towards the same local optimal solution. Step 1012 and step 1014 may be explained with reference to FIG. 11 in a similar manner as for steps 912 and steps 914 above and not repeated here for the sake of brevity.
- the optimizer 432 thereby avoids running multiple initial guesses of the Kalman gain parameters through many iterations of the system identification problem and/or all of the way to local optimality.
- the optimizer 432 ranks the initial guesses in order of cost function value from lowest value to highest value after the M iterations, i.e., such that the top-ranked initial guess corresponds to the lowest cost function value after the small number M of iterations.
- the optimizer 432 runs the system identification problem for the top-ranked initial guess to local optimality or for a large number of iterations P. The optimizer 432 thereby generates values for the Kalman gain parameters based on the top-ranked initial guess.
- the optimizer 432 checks whether the A ⁇ KC observer system is stable, controllable, and observable with a condition number less than a threshold number L. If those criteria are not met (i.e., if the A ⁇ KC observer system is unstable, uncontrollable, unobservable, or has a condition number higher than L), the process 1000 proceeds to step 1022 where the corresponding initial guess is discard. The process 1000 then returns to step 1018 where the system identification problem is run for the top-ranked remaining initial guess to local optimality or for a large number of iterations, the result of which is checked against the criteria described above at step 1020 . Steps 1018 , 1020 and 1022 may thereby be repeated until an initial guess leads to an A ⁇ KC observer system that is stable, controllable, and observable with a condition number less than the threshold number L.
- the resulting obtained system model is output, for example from the optimizer 432 to the model predictive controller 414 of FIG. 4 .
- the process 1000 combines with the A, B, C, and D matrices identified in process 900 , the process 1000 thereby provides identified Kalman gain K.
- the resulting identified model may be applied in a model predictive control approach as described in detail above to control the building equipment based on the identified model.
- process 100 avoids running poor initial guesses all the way to local optimality (i.e., for a large number of iterations).
- Process 1000 also avoids running multiple initial guesses to the same local optimum. The process 1000 is therefore substantially more efficient than other approaches for example generating many initial guesses, running all to local optimality, checking the quality of all models to choose the best result as the obtained model, and repeating the entire process if the obtained model is not satisfactory (e.g., does not satisfy the criteria in step 1020 ). Experimental results showing this improvement are described below with reference to FIGS. 12-13 .
- FIGS. 12-13 graphical representations of experimental results demonstrating the advantages of process 900 and process 1000 are shown, according to an exemplary embodiment.
- FIG. 12 shows experimental results obtained using processes 900 and 1000 , and illustrate the improved prediction accuracy achieved using processes 900 and 1000 .
- FIG. 13 shows experimental results obtained using an alternative approach of many initial guesses, running all to local optimality, checking the quality of all models to choose the best result as the obtained model, and repeating the entire process if the obtained model is not satisfactory.
- the graphical representations shown are described in further detail below.
- the total computation time required for the system identification process to yield an identified system model was 307 CPU seconds.
- FIG. 12 includes a first graph 1200 that shows zone temperature plotted over time and a second graph 1202 that shows Q HVAC plotted over time. Both graphs include a measured line 1204 that represents actual/measured data and a predicted line 1206 that shows the predictions made using the model generated as described above. In both the first graph 1200 and the second graph 1202 , the predicted line 1206 closely tracks the measured line 1204 .
- the 2-norm of the one-step prediction error in the outputs of the two days was 1.6175 for the zone temperature and 16.6594 for ⁇ dot over (Q) ⁇ HVAC .
- FIG. 13 shows a third graph 1300 that shows zone temperature plotted over time and a fourth graph 1302 that shows ⁇ dot over (Q) ⁇ HVAC plotted over time.
- Both graphs 1300 , 1302 include a measured line 1304 that represents actual/measured data and a predicted line 1306 that shows the predictions made using the model generated as described above.
- the predicted line 1306 roughly follows the measured line 1304 , but with noticeably less accuracy than the predicted line 1206 of FIG. 12 .
- the 2-norm of the one-step prediction error of the outputs for the two days was 7.8597 for the zone temperature and 94.4387 for ⁇ dot over (Q) ⁇ HVAC , i.e., substantially worse than as stated above for the first experiment.
- Process 1400 may be carried out by the controller 212 of FIG. 4 and may correspond to various steps of process 600 of FIG. 6 . Various steps of process 1400 may also correspond to various steps of process 900 and process 1000 .
- building equipment e.g., HVAC equipment 210
- building equipment e.g., HVAC equipment 210
- an excitation signal may be provided and the inputs and outputs of the system recorded as described above with reference to FIGS. 4 and 6 .
- a prediction error function (cost function) is defined based on the training data and a system model.
- the prediction error function may be based on a one-step ahead prediction error approach, a simulation prediction error approach, and/or a multi-step ahead prediction error approach.
- the prediction error function is a function of the parameters of the system model, for example as shown above in Eq. M above.
- multiple initial guesses are generated for the parameters of the system model.
- the initial guesses may be selected as described with reference to steps 902 - 904 and step 1002 above.
- an optimization problem is run for each initial guess for a first group of iterations (e.g., a small number of iterations as described with reference to steps 906 and 1004 ).
- the resulting parameters and prediction error functions may be recorded.
- a portion of the initial guesses are discarded based on one or more criteria, for example as described with reference to steps 910 - 914 and steps 1008 - 1014 .
- the one or more criteria include stability, observability, and controllability of a matrix of the system model.
- the one or more criteria relate to a condition number of a matrix of the system model.
- discarding a portion of the initial guesses based on one or more criteria includes determining that a first initial guess and a second initial guess lead toward a same local optimum after the first group of iterations and, in response, discarding the first initial guess. Many other criteria are contemplated by the present disclosure.
- a remaining initial guess is selected and the optimization problem is run for the selected initial guess for a second group of iterations and/or to local optimality.
- the remaining initial guess may be selected as the initial guess corresponding to the lowest value of the of the prediction error function after the first group of iterations.
- the second group of iterations may include a large number of iterations (e.g., a larger number of iterations than included in the first group of iterations of step 1408 ). It should be understood that, in some cases, local optimality is also global optimality.
- the parameters resulting from step 1412 and/or the system model having the parameters resulting from step 1412 are checked against one or more conditions.
- the one or more conditions may require one or more matrices of the system model to be observable, controllable, and stable.
- the one or more conditions may require one or more matrices of the system model to have a condition number less than a threshold condition number.
- the one or more conditions may require that the parameters are consistent with one or more physical laws that constrain the behavior of the system.
- process 1400 returns to step 1412 where a different remaining initial guess is selected and the optimization problem is run for the different remaining initial guess for the second group of iterations or to local optimality.
- the resulting parameters and/or system model is then checked against the one or more conditions at step 1414 . Steps 1412 and 1414 may be repeated until the one or more conditions are satisfied.
- the system model is identified as having the parameters resulting from the latest instance of step 1412 .
- building equipment e.g., HVAC equipment 210
- the controller may use the system model to generate control inputs for the building equipment, for example to minimize the utility cost associated with operating the building equipment over an optimization period.
- the predictive controller may be a model predictive controller or another type of controller in various embodiments. Process 1400 thereby provides for improved operation of building equipment with the improved performance described with reference to the experimental results of FIGS. 12-13 .
- circuit may include hardware structured to execute the functions described herein.
- each respective “circuit” may include machine-readable media for configuring the hardware to execute the functions described herein.
- the circuit may be embodied as one or more circuitry components including, but not limited to, processing circuitry, network interfaces, peripheral devices, input devices, output devices, sensors, etc.
- a circuit may take the form of one or more analog circuits, electronic circuits (e.g., integrated circuits (IC), discrete circuits, system on a chip (SOCs) circuits, etc.), telecommunication circuits, hybrid circuits, and any other type of “circuit.”
- the “circuit” may include any type of component for accomplishing or facilitating achievement of the operations described herein.
- a circuit as described herein may include one or more transistors, logic gates (e.g., NAND, AND, NOR, OR, XOR, NOT, XNOR, etc.), resistors, multiplexers, registers, capacitors, inductors, diodes, wiring, and so on).
- the “circuit” may also include one or more processors communicably coupled to one or more memory or memory devices.
- the one or more processors may execute instructions stored in the memory or may execute instructions otherwise accessible to the one or more processors.
- the one or more processors may be embodied in various ways.
- the one or more processors may be constructed in a manner sufficient to perform at least the operations described herein.
- the one or more processors may be shared by multiple circuits (e.g., circuit A and circuit B may include or otherwise share the same processor which, in some example embodiments, may execute instructions stored, or otherwise accessed, via different areas of memory).
- the one or more processors may be structured to perform or otherwise execute certain operations independent of one or more co-processors.
- two or more processors may be coupled via a bus to enable independent, parallel, pipelined, or multi-threaded instruction execution.
- Each processor may be implemented as one or more general-purpose processors, application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs), digital signal processors (DSPs), or other suitable electronic data processing components structured to execute instructions provided by memory.
- the one or more processors may take the form of a single core processor, multi-core processor (e.g., a dual core processor, triple core processor, quad core processor, etc.), microprocessor, etc.
- the one or more processors may be external to the apparatus, for example the one or more processors may be a remote processor (e.g., a cloud based processor). Alternatively or additionally, the one or more processors may be internal and/or local to the apparatus. In this regard, a given circuit or components thereof may be disposed locally (e.g., as part of a local server, a local computing system, etc.) or remotely (e.g., as part of a remote server such as a cloud based server). To that end, a “circuit” as described herein may include components that are distributed across one or more locations. The present disclosure contemplates methods, systems and program products on any machine-readable media for accomplishing various operations.
- Embodiments of the present disclosure can be implemented using existing computer processors, or by a special purpose computer processor for an appropriate system, incorporated for this or another purpose, or by a hardwired system.
- Embodiments within the scope of the present disclosure include program products comprising machine-readable media for carrying or having machine-executable instructions or data structures stored thereon.
- Such machine-readable media can be any available media that can be accessed by a general purpose or special purpose computer or other machine with a processor.
- machine-readable media can comprise RAM, ROM, EPROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code in the form of machine-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer or other machine with a processor. Combinations of the above are also included within the scope of machine-readable media.
- Machine-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing machines to perform a certain function or group of functions.
Landscapes
- Engineering & Computer Science (AREA)
- Business, Economics & Management (AREA)
- General Physics & Mathematics (AREA)
- Physics & Mathematics (AREA)
- Strategic Management (AREA)
- Human Resources & Organizations (AREA)
- Economics (AREA)
- Automation & Control Theory (AREA)
- Marketing (AREA)
- Tourism & Hospitality (AREA)
- Theoretical Computer Science (AREA)
- General Business, Economics & Management (AREA)
- Development Economics (AREA)
- Quality & Reliability (AREA)
- Game Theory and Decision Science (AREA)
- Operations Research (AREA)
- Entrepreneurship & Innovation (AREA)
- General Engineering & Computer Science (AREA)
- Artificial Intelligence (AREA)
- Health & Medical Sciences (AREA)
- Computer Vision & Pattern Recognition (AREA)
- Evolutionary Computation (AREA)
- Software Systems (AREA)
- Medical Informatics (AREA)
- Air Conditioning Control Device (AREA)
Abstract
Description
- The present disclosure relates generally to control systems for HVAC equipment, and more particularly to system identification for controlling HVAC equipment. System identification refers to the process of generating a model of a system (e.g., a building served by an HVAC equipment) that can be used to control the HVAC equipment, for example in a model predictive control system. Because the physical phenomena that govern such systems are often complex, nonlinear, and poorly understood, system identification requires the determination of model parameters based on measured and recorded data from the real system in order to generate an accurate predictive model.
- One implementation of the present disclosure is a building management system. The building management system includes building equipment operable to heat or cool a building and generate training data relating to behavior of a building system and a controller configured to perform a system identification process to identify one or more parameters of a system model that predicts the behavior of the building system. The one or more parameters includes at least one of one or more model parameters or one or more Kalman gain parameters. The system identification process includes generating a prediction error function based on the training data and the system model, generating a plurality of initial guesses of the one or more parameters, for each initial guess, running an optimization problem of the prediction error function for a first group of iterations, discarding, after the first group of iterations, a portion of the initial guesses based on one or more criteria and ranking a remaining portion of the initial guesses, running the optimization problem of the prediction error function for a top-ranked initial guess of the remaining portion to local optimality or for a second group of iterations to identify a first set of values of the one or more parameters, determining whether the first set of values of the one or more parameters satisfies a condition, and, in response to a determination that the first set of values satisfies the condition, identifying the one or more parameters as having the first set of values. The controller is configured to operate the building equipment to heat or cool the building by performing a predictive control process that uses the system model with the one or more parameters identified by the system identification process.
- In some embodiments, the controller is further configured to, in response to determining that the first set of values does not satisfy the condition, discard the top-ranked initial guess, run the optimization problem for a new top-ranked initial guess to local optimality or for the second group of iterations to identify a second set of values of the one or more parameters, determine whether the second set of values satisfies the condition, and, in response to a determination that the second set of values satisfies the condition, select the second set of values for the one or more parameters.
- In some embodiments, the controller is configured to discard initial guesses that violate physical laws relating to the one or more parameters. In some embodiments, determining that the first set of values satisfies the condition includes determining that the first set of values conforms with the physical laws relating to the one or more parameters.
- In some embodiments, the controller is configured to discard the portion of the initial guesses based on one or more criteria by determining that a first initial guess and a second initial guess lead toward a same local optimum after the first group of iterations and, in response, discarding first initial guess.
- In some embodiments, the controller is configured to discard the portion of the initial guesses based on one or more criteria by discarding initial guesses that lead to an unstable, uncontrollable, or unobservable system after the first group of iterations.
- In some embodiments, the controller is configured to discard the portion of the initial guesses based on one or more criteria by discarding initial guesses that lead to a matrix with a condition number greater than a threshold number.
- In some embodiments, each of the plurality of initial guesses provides a stable system. In some embodiments, the controller is configured to detect and remove saturation data from the training data. In some embodiments, the prediction error function includes a multi-step ahead prediction error function.
- Another implementation of the present disclosure is a method for generating a system model for a building system and controlling building equipment in accordance with the system model. The method includes operating the building equipment to generate training data relating to behavior of the building system, defining a prediction error function based on the training data and the system model, and identifying values for one or more parameters of the system model by optimizing the prediction error function. Optimizing the prediction error function includes generating a plurality of initial guesses of the one or more parameters, running, for each initial guess, an optimization problem of the prediction error function for a first group of iterations, discarding, after the first group of iterations, a portion of the initial guesses based on one or more criteria and ranking a remaining portion of the initial guesses, running the optimization problem of the prediction error function for a top-ranked initial guess of the remaining portion to local optimality or for a second group of iterations to identify a first set of values of the one or more parameters, determining whether the first set of values of the one or more parameters satisfies a condition, and, in response to a determination that the first set of values satisfies the condition, defining the one or more parameters as having the first set of values. The method also includes operating the building equipment to heat or cool the building system by applying the system model in a predictive controller to generate control inputs for the building equipment.
- In some embodiments, the method also includes, in response to determining that the first set of values does not satisfy the condition, discarding the top-ranked initial guess, running the optimization problem of the prediction error function for a new top-ranked initial guess to local optimality or for the second group of iterations to identify a second set of values of the one or more parameters, determining whether the second set of values satisfies the condition, and, in response to a determination that the second set of values satisfies the condition, selecting the second set of values for the one or more parameters.
- In some embodiments, the method includes discarding initial guesses that violate physical laws relating to the one or more parameters and the behavior of the building system. In some embodiments, determining that the first set of values satisfies the condition includes determining that the first set of values conforms with the physical laws.
- In some embodiments, discarding the portion of the initial guesses based on one or more criteria includes determining that a first initial guess and a second initial guess lead toward a same local optimum after the first group of iterations and, in response, discarding the first initial guess.
- In some embodiments, discarding the portion of the initial guesses based on one or more criteria includes discarding initial guesses that lead to a matrix with a condition number greater than a threshold number after the first group of iterations. In some embodiments, each of the plurality of initial guesses provides a stable system. In some embodiments, the method includes detecting and removing saturation data from the training data. In some embodiments, the prediction error function includes a multi-step ahead prediction error function.
- Another implementation of the present disclosure is a method for generating a system model for a building and controlling building equipment in accordance with the system model. The method includes operating the building equipment to generate training data relating to behavior of the building system, and defining a prediction error function based on the training data and the system model. The method also includes identifying values for one or more parameters of the system model based on the prediction error function by generating a plurality of initial guesses of the one or more parameters, for each initial guess, performing a first group of iterations using the prediction error function, after the first group of iterations, discarding a portion of the initial guesses based on one or more criteria and ranking a remaining portion of the initial guesses, performing a second group of iterations using the prediction error function for a top-ranked initial guess of the remaining portion to identify a first set of values of the one or more parameters, determining whether the first set of values of the one or more parameters satisfies a condition; and in response to a determination that the first set of values satisfies the condition, defining the one or more parameters as having the first set of values. The method also includes operating the building equipment to heat or cool the building system by applying the system model in a predictive controller to generate control inputs for the building equipment.
- Various objects, aspects, features, and advantages of the disclosure will become more apparent and better understood by referring to the detailed description taken in conjunction with the accompanying drawings, in which like reference characters identify corresponding elements throughout. In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements.
-
FIG. 1 is a drawing of a building equipped with a HVAC system, according to an exemplary embodiment. -
FIG. 2 is a block diagram of the building and HVAC system ofFIG. 1 , according to an exemplary embodiment. -
FIG. 3 is a circuit-style diagram of a model of the building and HVAC system ofFIG. 1 , according to an exemplary embodiment. -
FIG. 4 is a block diagram of a controller for use with the HVAC system ofFIG. 1 , according to an exemplary embodiment. -
FIG. 5 is a detailed block diagram of a model identifier of the controller ofFIG. 4 , according to an exemplary embodiment. -
FIG. 6 is flowchart of a process for system identification, according to an exemplary embodiment. -
FIG. 7 is a flowchart of a multi-step ahead prediction error method for use in system identification, according to an exemplary embodiment. -
FIG. 8 is a visualization useful in illustrating the multi-step ahead prediction error method ofFIG. 7 , according to an exemplary embodiment. -
FIG. 9 is a flowchart a first process for efficient model generation which can be performed by the model identifier ofFIG. 5 , according to an exemplary embodiment. -
FIG. 10 is a flowchart of a second process for efficient model generation which can be performed by the model identifier ofFIG. 5 , according to an exemplary embodiment. -
FIG. 11 is a visualization that facilitates explanation of the processes ofFIGS. 9 and 10 , according to an exemplary embodiment. -
FIG. 12 is a graphical representation of experimental results obtained using the processes ofFIGS. 9 and 10 , according to an exemplary embodiment. -
FIG. 13 is a graphical representation of experiment results obtained without using the processes ofFIGS. 9 and 10 , for sake of comparison toFIG. 12 . -
FIG. 14 is a flowchart of a process for generating a system model for a building system and controlling building equipment in accordance with the system model, according to an exemplary embodiment. - Referring generally to the FIGURES, systems and methods for system identification using a multi-step ahead prediction error approach for use in controlling plant equipment are shown and described. The systems and method described herein provide improved system models and therefore improved control of plant equipment for heating and cooling buildings or for other plant functions.
- Referring to
FIG. 1 , a perspective view of abuilding 10 is shown.Building 10 is served by a building management system (BMS). A BMS is, in general, a system of devices configured to control, monitor, and manage equipment in or around a building or building area. A BMS can include, for example, a HVAC system, a security system, a lighting system, a fire alerting system, any other system that is capable of managing building functions or devices, or any combination - The BMS that serves building 10 includes a
HVAC system 100.HVAC system 100 can include a plurality of HVAC devices (e.g., heaters, chillers, air handling units, pumps, fans, thermal energy storage, etc.) configured to provide heating, cooling, ventilation, or other services for building 10. For example,HVAC system 100 is shown to include awaterside system 120 and anairside system 130.Waterside system 120 may provide a heated or chilled fluid to an air handling unit ofairside system 130.Airside system 130 may use the heated or chilled fluid to heat or cool an airflow provided to building 10. -
HVAC system 100 is shown to include achiller 102, aboiler 104, and a rooftop air handling unit (AHU) 106.Waterside system 120 may useboiler 104 andchiller 102 to heat or cool a working fluid (e.g., water, glycol, etc.) and may circulate the working fluid toAHU 106. In various embodiments, the HVAC devices ofwaterside system 120 can be located in or around building 10 (as shown inFIG. 1 ) or at an offsite location such as a central plant (e.g., a chiller plant, a steam plant, a heat plant, etc.). The working fluid can be heated inboiler 104 or cooled inchiller 102, depending on whether heating or cooling is required in building 10.Boiler 104 may add heat to the circulated fluid, for example, by burning a combustible material (e.g., natural gas) or using an electric heating element.Chiller 102 may place the circulated fluid in a heat exchange relationship with another fluid (e.g., a refrigerant) in a heat exchanger (e.g., an evaporator) to absorb heat from the circulated fluid. The working fluid fromchiller 102 and/orboiler 104 can be transported toAHU 106 viapiping 108. -
AHU 106 may place the working fluid in a heat exchange relationship with an airflow passing through AHU 106 (e.g., via one or more stages of cooling coils and/or heating coils). The airflow can be, for example, outside air, return air from within building 10, or a combination of both.AHU 106 may transfer heat between the airflow and the working fluid to provide heating or cooling for the airflow. For example,AHU 106 can include one or more fans or blowers configured to pass the airflow over or through a heat exchanger containing the working fluid. The working fluid may then return tochiller 102 orboiler 104 viapiping 110. -
Airside system 130 may deliver the airflow supplied by AHU 106 (i.e., the supply airflow) to building 10 viaair supply ducts 112 and may provide return air from building 10 toAHU 106 viaair return ducts 114. In some embodiments,airside system 130 includes multiple variable air volume (VAV)units 116. For example,airside system 130 is shown to include aseparate VAV unit 116 on each floor or zone of building 10.VAV units 116 can include dampers or other flow control elements that can be operated to control an amount of the supply airflow provided to individual zones of building 10. In other embodiments,airside system 130 delivers the supply airflow into one or more zones of building 10 (e.g., via supply ducts 112) without usingintermediate VAV units 116 or other flow control elements.AHU 106 can include various sensors (e.g., temperature sensors, pressure sensors, etc.) configured to measure attributes of the supply airflow.AHU 106 may receive input from sensors located withinAHU 106 and/or within the building zone and may adjust the flow rate, temperature, or other attributes of the supply airflow throughAHU 106 to achieve setpoint conditions for the building zone. -
HVAC system 100 thereby provides heating and cooling to thebuilding 10. Thebuilding 10 also includes other sources of heat transfer that the indoor air temperature in thebuilding 10. The building mass (e.g., walls, floors, furniture) influences the indoor air temperature in building 10 by storing or transferring heat (e.g., if the indoor air temperature is less than the temperature of the building mass, heat transfers from the building mass to the indoor air). People, electronic devices, other appliances, etc. (“heat load”) also contribute heat to thebuilding 10 through body heat, electrical resistance, etc. Additionally, the outside air temperature impacts the temperature in thebuilding 10 by providing heat to or drawing heat from thebuilding 10. - Referring now to
FIG. 2 , a block diagram of theHVAC system 100 with building 10 is shown, according to an exemplary embodiment. More particularly,FIG. 2 illustrates the variety of heat transfers that affect the indoor air temperature Tia of the indoor air 201 inzone 200 of building 10.Zone 200 is a room, floor, area, etc. of building 10. In general, the primary goal of theHVAC system 100 is to maintain the indoor air temperature Tia in thezone 200 at or around a desired temperature to facilitate the comfort of occupants of thezone 200 or to meet other needs of thezone 200. - As shown in
FIG. 2 , the indoor air temperature Tia of thezone 200 has a thermal capacitance Ci1. The indoor air temperature Tia is affected by a variety of heat transfers {dot over (Q)} into thezone 200, as described in detail below. It should be understood that although all heat transfers {dot over (Q)} are shown inFIG. 2 as directed into thezone 200, the value of one or more of the heat transfers {dot over (Q)} may be negative, such that heat flows out of thezone 200. - The
heat load 202 contributes other heat transfer {dot over (Q)}other to thezone 200. Theheat load 202 includes the heat added to the zone by occupants (e.g., people, animals) that give off body heat in thezone 200. Theheat load 202 also includes computers, lighting, and other electronic devices in thezone 200 that generate heat through electrical resistance, as well as solar irradiance. - The
building mass 204 contributes building mass heat transfer {dot over (Q)}m to thezone 200. Thebuilding mass 204 includes the physical structures in the building, such as walls, floors, ceilings, furniture, etc., all of which can absorb or give off heat. Thebuilding mass 204 has a temperature Tm and a lumped mass thermal capacitance Cm. The resistance of thebuilding mass 204 to exchange heat with the indoor air 201 (e.g., due to insulation, thickness/layers of materials, etc.) may be characterized as mass thermal resistance Rmi. - The
outdoor air 206 contributes outside air heat transfer {dot over (Q)}oa to thezone 200. Theoutdoor air 206 is the air outside of thebuilding 10 with outdoor air temperature Toa. The outdoor air temperature Toa fluctuates with the weather and climate. Barriers between theoutdoor air 206 and the indoor air 201 (e.g., walls, closed windows, insulation) create an outdoor-indoor thermal resistance Roi to heat exchange between theoutdoor air 206 and the indoor air 201. - The
HVAC system 100 also contributes heat to thezone 200, denoted as {dot over (Q)}HVAC. TheHVAC system 100 includesHVAC equipment 210,controller 212, an indoorair temperature sensor 214 and an outdoorair temperature sensor 216. TheHVAC equipment 210 may include thewaterside system 120 andairside system 130 ofFIG. 1 , or other suitable equipment for controllably supplying heating and/or cooling to thezone 200. In general,HVAC equipment 210 is controlled by acontroller 212 to provide heating (e.g., positive value of {dot over (Q)}HVAC) or cooling (e.g., a negative value of {dot over (Q)}HVAC) to thezone 200. - The indoor
air temperature sensor 214 is located in thezone 200, measures the indoor air temperature Tia, and provides the measurement of Tia thecontroller 212. The outdoorair temperature sensor 216 is located outside of thebuilding 10, measures the outdoor air temperature Toa, and provides the measurement of Toa to thecontroller 212. - The
controller 212 receives the temperature measurements Toa and Tia, generates a control signal for theHVAC equipment 210, and transmits the control signal to theHVAC equipment 210. The operation of thecontroller 212 is discussed in detail below. In general, thecontroller 212 considers the effects of theheat load 202, buildingmass 204, andoutdoor air 206 on the indoor air 201 in controlling theHVAC equipment 210 to provide a suitable level of {dot over (Q)}HVAC. A model of this system for use by thecontroller 212 is described with reference toFIG. 3 . - In the embodiments described herein, the control signal provide to the
HVAC equipment 210 by thecontroller 110 indicates a temperature setpoint Tsp for thezone 200. To determine the temperature setpoint Tsp, thecontroller 212 assumes that the relationship between the indoor air temperature Tia and the temperature setpoint Tsp follows a proportional-integral control law with saturation, represented as: -
{dot over (Q)} HVAC,j =K p,jϵsp +K I,j∫0 tϵsp(s)ds (Eq. A) -
ϵsp =T sp,j −T ia (Eq. B) - where j ∈ {clg, hlg} is the index that is used to denote either heating or cooling mode. Different parameters Kp,j and KI,j are needed for the heating and cooling mode. Moreover, the heating and cooling load is constrained to the following set: {dot over (Q)}HVAC,j∈[0, {dot over (Q)}clg,max] for cooling mode (j=clg) and {dot over (Q)}HVAC,j∈[−{dot over (Q)}htg,max,0] for heating mode (j=htg). As discussed in detail below with reference to
FIG. 4 , thecontroller 212 uses this model in generating a control signal for theHVAC equipment 210. - Referring now to
FIG. 3 , a circuit-style diagram 300 corresponding to thezone 200 and the various heat transfers {dot over (Q)} ofFIG. 2 is shown, according to an exemplary embodiment. In general, the diagram 300 models thezone 200 as a two thermal resistance, two thermal capacitance, control-oriented thermal mass system. This model can be characterized by the following system of linear differential equations, described with reference toFIG. 3 below: -
- where the first line (Eq. C) focuses on the indoor air temperature Tia, and each term in Eq. C corresponds to a branch of diagram 300 as explained below:
-
Indoor air node 302 corresponds to the indoor air temperature Tia. Fromindoor air node 302, the model branches in several directions, including down to aground 304 via acapacitor 306 with a capacitance Cia. Thecapacitor 306 models the ability of the indoor air to absorb or release heat and is associated with the rate of change of the indoor heat transfer {dot over (T)}ia. Accordingly, thecapacitor 306 enters Eq. C on the left side of the equation as Cia{dot over (T)}ia. - From
indoor air node 302, the diagram 300 also branches left to buildingmass node 310, which corresponds to the thermal mass temperature Tm. A resistor 312 with mass thermal resistance Rmi separates theindoor air node 302 and thebuilding mass node 310, modeling the heat transfer {dot over (Q)}m from thebuilding mass 204 to the indoor air 201 as -
- This term is included on the right side of Eq. C above as contributing to the rate of change of the indoor air temperature {dot over (T)}ia.
- The diagram 300 also branches up from
indoor air node 302 tooutdoor air node 314. A resistor 316 with outdoor-indoor thermal resistance Roi separates theindoor air node 302 and theoutdoor air node 314, modeling the flow heat from theoutdoor air 206 to the indoor air 201 as -
- This term is also included on the right side of Eq. C above as contributing to the rate of change of the indoor air temperature {dot over (T)}ia.
- Also from
indoor air node 302, the diagram 300 branches right to two {dot over (Q)} sources, namely {dot over (Q)}HVAC and {dot over (Q)}other. As mentioned above, {dot over (Q)}other corresponds to heatload 202 and to a variety of sources of energy that contribute to the changes in the indoor air temperature Tia. {dot over (Q)}other is not measured or controlled by theHVAC system 100, yet contributes to the rate of change of the indoor air temperature {dot over (T)}ia. {dot over (Q)}HVAC is generated and controlled by theHVAC system 100 to manage the indoor air temperature Tia. Accordingly, {dot over (Q)}HVAC and {dot over (Q)}other are included on the right side of Eq. C above. - The second nonlinear differential equation (Eq. D) above focuses on the rate of change {dot over (T)}m in the building mass temperature T. The capacity of the building mass to receive or give off heat is modelled by
capacitor 318.Capacitor 318 has lumped mass thermal capacitance Cm and is positioned between aground 304 and thebuilding mass node 310 and regulates the rate of change in the building mass temperature Tm. Accordingly, the capacitance Cm is included on left side of Eq. D. Also branching from thebuilding mass node 310 isresistor 312 leading toindoor air node 302. As mentioned above, this branch accounts for heat transfer {dot over (Q)}m between thebuilding mass 204 and the indoor air 201. Accordingly, the term -
- is included on the right side of Eq. D.
- As described in detail below, the model represented by diagram 300 is used by the
controller 212 in generating a control signal for theHVAC equipment 210. More particularly, thecontroller 212 uses a state-space representation of the model shown in diagram 300. The state-space representation used by thecontroller 212 can be derived by incorporating Eq. A and B with Eq. C and D, and writing the resulting system of equations as a linear system of differential equations to get: -
- where I represents the integral term ∫0 tϵsp(s)ds from Eq. A. The resulting linear system has three states (Tia, Tm, I), two inputs (Tsp, j, Toa), two outputs (Tia, {dot over (Q)}HVAC), and one disturbance {dot over (Q)}other. Because {dot over (Q)}other is not measured or controlled, the
controller 212 models the disturbance {dot over (Q)}other using an input disturbance model that adds a forth state d to the state space representation. In a more compact form, this linear system of differential equations can be written as: -
{dot over (x)}(t)=A c(θ)x(t)+B c(θ)u(t); (Eq. G) -
y(t)=C c(θ)x(t)+D c(θ)u(t); (Eq. H) - where
-
- As described in detail below, the
controller 212 uses a two-step process to parameterize the system. In the first step, thecontroller 212 identifies the system parameters θ={θ1, θ2, θ3, θ4, θ5, θ6} (i.e., the values of Cia, Cm, Rmi, Roi, Kp,j, Ki,j). The disturbance state d is then introduced into the model and an Kalman estimator gain is added, such that in the second step thecontroller 212 identifies the Kalman gain parameters K. - As used herein, the term ‘variable’ refers to an item/quantity capable of varying in value over time or with respect to change in some other variable. A “value” as used herein is an instance of that variable at a particular time. A value may be measured or predicted. For example, the temperature setpoint Tsp is a variable that changes over time, while Tsp(3) is a value that denotes the setpoint at time step 3 (e.g., 68 degrees Fahrenheit). The term “predicted value” as used herein describes a quantity for a particular time step that may vary as a function of one or more parameters.
- Controller for HVAC Equipment with System Identification
- Referring now to
FIG. 4 , a detailed diagram of thecontroller 212 is shown, according to an exemplary embodiment. Thecontroller 212 includes aprocessing circuit 400 and acommunication interface 402. Thecommunication interface 402 is structured to facilitate the exchange of communications (e.g., data, control signals) between theprocessing circuit 400 and other components ofHVAC system 100. As shown inFIG. 4 , thecommunication interface 402 facilitates communication between theprocessing circuit 400 and the outdoorair temperature sensor 216 and the indoorair temperature sensor 214 to all temperature measurements Toa and Tia to be received by theprocessing circuit 400. Thecommunication interface 402 also facilitates communication between theprocessing circuit 400 and theHVAC equipment 210 that allows a control signal (indicated as temperature setpoint Tsp) to be transmitted from theprocessing circuit 400 to theHVAC equipment 210. - The
processing circuit 400 is structured to carry out the functions of the controller described herein. Theprocessing circuit 400 includes aprocessor 404 and amemory 406. Theprocessor 404 may be implemented as a general-purpose processor, an application-specific integrated circuit, one or more field programmable gate arrays, a digital signal processor, a group of processing components, or other suitable electronic processing components. Thememory 406, described in detail below, includes one or more memory devices (e.g., RAM, ROM, NVRAM, Flash Memory, hard disk storage) that store data and/or computer code for facilitating at least some of the processes described herein. For example, thememory 406 stores programming logic that, when executed by theprocessor 404, controls the operation of thecontroller 212. More particularly, thememory 406 includes atraining data generator 408, atraining data database 410, amodel identifier 412, a modelpredictive controller 414, and anequipment controller 416. The various generators, databases, identifiers, controllers, optimizers, etc. ofmemory 406 may be implemented as any combination of hardware components and machine-readable media included withmemory 406. - The
equipment controller 416 is configured to generate a temperature setpoint Tsp that serves as a control signal for theHVAC equipment 210. The equipment controller receives inputs of the indoor air temperature Tia from the indoorair temperature sensor 214 via thecommunication interface 402 and {dot over (Q)}HVAC from the model predictive controller 414 (during normal operation) and the training data generator 408 (during a training data generation phase described in detail below). The equipment controller uses Tia and {dot over (Q)}HVAC to generate Tsp by solving Eq. A and Eq. B above for Tsp. Theequipment controller 416 then provides the control signal Tsp to theHVAC equipment 210 via thecommunication interface 402. - The model
predictive controller 414 determines {dot over (Q)}HVAC based on an identified model and the temperature measurements Tia, Toa, and provides {dot over (Q)}HVAC to theequipment controller 416. The modelpredictive controller 414 follows a model predictive control (MPC) approach. The MPC approach involves predicting future system states based on a model of the system, and using those predictions to determine the controllable input to the system (here, {dot over (Q)}HVAC) that bests achieves a control goal (e.g., to maintain the indoor air temperature near a desired temperature). A more accurate model allows the MPC to provide better control based on more accurate predictions. Because the physical phenomena that define the behavior of the system (i.e., of the indoor air 201 in the building 10) are complex, nonlinear, and/or poorly understood, a perfect model derived from first-principles is generally unachievable or unworkable. Thus, the modelpredictive controller 414 uses a model identified through a system identification process facilitated by thetraining data generator 408, thetraining data database 410, and themodel identifier 412, described in detail below. - System identification, as facilitated by the
training data generator 408, thetraining data database 410, and themodel identifier 412, is a process of constructing mathematical models of dynamic systems. System identification provides a suitable alternative to first-principles-derived model when first principles models are unavailable or too complex for on-line MPC computations. System identification captures the important and relevant system dynamics based on actual input/output data (training data) of the system, in particular by determining model parameters particular to a building or zone to tune the model to the behavior of the building/zone. As described in detail below, thetraining data generator 408, thetraining data database 410, and themodel identifier 412 each contribute to system identification by thecontroller 212. - The
training data generator 408 is configured to generate training data by providing an excitation signal to the system. That is, the training data generator provides various {dot over (Q)}HVAC values to theequipment controller 416 for a number N of time steps k, and receives the measured output response of the indoor air temperature Tia at each time step k from theair temperature sensor 214. The various {dot over (Q)}HVAC values may be chosen by thetraining data generator 408 to explore the system dynamics as much as possible (e.g., across a full range of possible {dot over (Q)}HVAC values, different patterns of {dot over (Q)}HVAC values, etc.). - The
equipment controller 416 receives the various {dot over (Q)}HVAC values and generates various control inputs Tsp in response. The temperature setpoint Tsp for each time step k is provided to theHVAC equipment 210, which operates accordingly to heat or cool the zone 200 (i.e., to influence Tia). The temperature setpoints Tsp may also be provided to thetraining data generator 408 to be included in the training data. The training data generator receives an updated measurement of the indoor air temperature Tia for each time step k and may also receive the outdoor air temperature Toa for each time step k. Thetraining data generator 408 thereby causes the states, inputs, and outputs of the system to vary across the time steps k and generates data corresponding to the inputs and outputs. - The inputs and outputs generated by the
training data generator 408 are provided to thetraining data database 410. More particularly, in the nomenclature of the model of Eq. E and Eq. F above, thetraining data generator 408 provides inputs Tsp and Toa and outputs {dot over (Q)}HVAC and Tia for each time step k to thetraining data database 410. - The
training data database 410 stores the inputs and outputs for each time step k provided by thetraining data generator 408. Each input and output is tagged with a time step identifier, so that data for the same time step can be associated together. Thetraining data database 410 thereby collects and stores input and output data for each time step k, k=0, . . . , N, or, more specifically, Tsp(k), Toa(k), Tia(k), and {dot over (Q)}HVAC(k), for k, k=0, . . . , N. This data is grouped together in thetraining data database 410 in a set of training data ZN. In the notation of Eq. G and Eq. H, ZN=[y(1), u(1), y(2), u(2), . . . , y(N), u(N)]. - In some embodiments, the training data is refined using a saturation detection and removal process. System and methods for saturation detection and removal suitable for use to refine the training data ZN are described in U.S. patent application Ser. No. 15/900,459, filed Feb. 20, 2018, incorporated by reference herein in its entirety. For example, as described in detail therein, the training data may be filtered by determining whether the operating capacity is in a non-transient region for a threshold amount of a time period upon determining that an error for the building zone exists for the time period, and in response to a determination that the operating capacity is in the non-transient region for at least the threshold amount of the time period, indicating the time period as a saturation period. Data from the saturation period can then be removed from the training data.
- The
model identifier 412 accesses thetraining data database 410 to retrieve the training data ZN and uses the training data ZN to identify a model of the system. Themodel identifier 412 includes asystem parameter identifier 418 and again parameter identifier 420. As shown in detail inFIG. 5 and discussed in detail with reference thereto, thesystem parameter identifier 418 carries out a first step of system identification, namely identifying the model parameters, while thegain parameter identifier 420 carries out the second step, namely determining a Kalman gain estimator. The model parameters and the Kalman gain estimator are included in an identified model of the system, and that model is provided to the modelpredictive controller 414. The model predictive controller can thus facilitate the control of theHVAC equipment 210 as described above. - Referring now to
FIG. 5 , a detailed view of themodel identifier 412 is shown, according to an exemplary embodiment. As mentioned above, themodel identifier 412 includes thesystem parameter identifier 418 and thegain parameter identifier 420. Thesystem parameter identifier 418 is structured to identify the matrices A, B, C, D of Eqs. G and H, i.e., the values of θ={θ1, θ2, θ3, θ4, θ5, θ6}. In the embodiment described herein, this corresponds to finding the values of Cia, Cm, Rmi, Roi, Kp,j, and Ki,j. -
-
{dot over (x)}(t)=A c(θ)x(t)+B c(θ)u(t); (Eq. G) -
y(t)=C c(θ)x(t)+D c(θ)u(t); (Eq. H). - The
model framework identifier 422 thereby determines that thesystem parameter identifier 418 has the goal of determining a parameter vector {circumflex over (θ)}N from the set of θ ∈ ⊂ d, where is the set of admissible model parameter values. The resulting possible models are given by the set: M={(θ), θ ∈ }. The goal of thesystem parameter identifier 418 is to select a parameter vector {circumflex over (θ)}N from among possible values of θ that best matches the model to the physical system (i.e., the vector θ is a list of variables and the vector {circumflex over (θ)}N is a list of values), thereby defining matrices A, B, C, and D. Themodel framework identifier 422 also receives training data ZN and sorts the training data (i.e., Tsp(k), Toa(k), Tia(k), and {dot over (Q)}HVAC(k), for k, k=0, . . . , N) into the notation of Eq. G-H as input/output data ZN=[y(1), u(1), y(2), u(2), . . . , y(N), u(N)]. - The prediction
error function generator 424 receives the model framework M={(θ), θ ∈ } and the training data ZN from themodel framework identifier 422. The predictionerror function generator 424 applies a prediction error method to determine the optimal parameter vector {circumflex over (θ)}N. In general, prediction error methods determine the optimal parameter vector {circumflex over (θ)}N by minimizing some prediction performance function VN(θ, ZN) that is based in some way on the difference between predicted outputs and the observed/measured outputs included in the training data ZN. That is, the parameter estimation θN is determined as: - The prediction
error function generator 424 use one or more of several possible prediction error approaches to generate a prediction performance function VN(θ, ZN). In the embodiment shown, the prediction error function generator applies a simulation approach. In the simulation approach, the predictionerror function generator 424 uses the model (θ), the input trajectory [u(1),u(2), . . . , u(N)], and an initial state x(0) to produce predicted outputs in terms of θ. That is, the predictionerror function generator 424 predicts: -
[ŷ(1|0, θ), ŷ(2|0, θ) . . . ŷ(k|0, θ) . . . , ŷ(N|0, θ)], - where ŷ(k|0, θ) denotes the predicted output at time step k given the training data from
time 0 and the model (θ). The predictionerror function generator 424 then calculates a prediction error at each time step k is given by ϵ(k, θ) :=y(k)−ŷ(k|0, θ). The predictionerror function generator 424 then squares the two-norm of each prediction error ϵ(k, θ) and sums the results to determine the prediction performance function, which can be written as: -
V N(θ,Z N)=Σk=1 N ∥y(k)−ŷ(k|0, θ)∥2 2 (Eq.I). - In an alternative embodiment, the prediction
error function generator 424 applies a one-step-ahead prediction error method to generate the prediction performance function VN(θ, ZN). In the one-step-ahead prediction error method, the predictionerror function generator 424 uses past input-output data and the model (θ) the model to predict the output one step ahead in terms of θ. That is, in the one-step ahead prediction error method, the predictionerror function generator 424 generates one-step ahead predictions ŷ(k|k−1, θ), which denotes the predicted output at time step k given the past input-output sequence Zk−1 and using parameters θ. The one-step ahead prediction ŷ(k|k−1, θ) is then compared to the measured output y(k) by the predictionerror function generator 424 to determine the prediction error at k, defined as ϵ(k, θ):=y(k)−ŷ(k|k−1, θ). The predictionerror function generator 424 then squares the two-norm of the prediction errors for each k and sums the results, generating a prediction performance function that can be expressed in a condensed form as: -
- In other alternative embodiments, the prediction
error function generator 424 uses a multi-step ahead prediction error approach to generate the prediction performance function. The multi-step ahead prediction error approach is described in detail below with reference to thegain parameter identifier 420 andFIGS. 7-8 . The multi-step ahead prediction error approach is also described in detail in U.S. patent application Ser. No. 15/953,324, filed Apr. 13, 2018, incorporated by reference herein in its entirety. - The prediction
error function generator 424 then provides the performance function VN(θ, ZN) (i.e., from Eq. I or Eq. J in various embodiments) to theoptimizer 426. - The
optimizer 426 receives the prediction error function generated by the predictionerror function generator 424 and optimizes the prediction error function in θ to determine {circumflex over (θ)}N. More specifically, theoptimizer 426 finds the minimum value of the prediction error function VN(θ, ZN) as θ is varied throughout the allowable values of θ ∈ . That is, theoptimizer 426 determines {circumflex over (θ)}N based on: - The
optimizer 426 then uses {circumflex over (θ)}N to calculate the matrices A, B, C, and D. Thesystem parameter identifier 418 then provides the identified matrices A, B, C, D to thegain parameter identifier 420. - The
gain parameter identifier 420 receives the model with the matrices A, B, C, D (i.e., the model parameters) fromsystem parameter identifier 418, as well as the training data ZN from thetraining data database 410, and uses that information to identify the gain parameters. Thegain parameter identifier 420 includes anestimator creator 428, a predictionerror function generator 430, and anoptimizer 432. - The
estimator creator 428 adds a disturbance model and introduces a Kalman estimator gain to account for thermal dynamics of the system, for example for the influence of {dot over (Q)}other on the system. Theestimator creator 428 generates an augmented model with disturbance state d, given by: -
- where the parameters Ac, Bc, Cc, and Dc are the matrices A, B, C, D received from the
system parameter identifier 418 and the disturbance model is selected with -
- The
estimator creator 428 then converts the model to a discrete time model, for example using 5-minute sampling periods, resulting in the matrices Adis, Bdis, Cdis, Ddis and the disturbance model discrete time matrix Bddis . Theestimator creator 428 then adds a parameterized estimator gain, resulting in the following model: -
- The matrix K(ϕ) is the estimator gain parameterized with the parameter vector ϕ where:
-
- In this notation, {circumflex over (x)}(t+1|t) is an estimate of the state at time t+1 obtained using the Kalman filter and made utilizing information at sampling time t. For example, with a sampling time of five minutes, {circumflex over (x)}(t+1|t) is an estimate of the state five minutes after the collection of the data that the estimate is based on. The goal of the gain parameter identifier is to identify parameters {circumflex over (ϕ)}N (i.e., a vector of for each of ϕ1 . . . ϕ8) that make the model best match the physical system.
- The
estimator creator 428 then provides the discrete time model with estimator gain (i.e., Eqs. K-L) to the predictionerror function generator 430. The prediction error function generator receives the model from theestimator creator 428 as well as the training data ZN from thetraining data database 410, and uses the model (with the estimator gain) and the training data ZN to generate a prediction performance function. - The prediction
error function generator 430 follows a multi-step ahead prediction error method to generate a predication performance function VN(ϕ, ZN). The multi-step ahead prediction error method is illustrated inFIGS. 7-8 and described in detail with reference thereto. As an overview, in the multi-step-ahead prediction error method, the predictionerror function generator 430 uses past input-output data and the model (θ) the model to predict the output multiple step ahead in terms of ϕ. That is, in the multi-step ahead prediction error method, the predictionerror function generator 430 generates multi-step ahead predictions ŷ(k+h|k−1, ϕ), which denotes the predicted output at time step k+h given the past input-output sequence Zk−1 and using parameters ϕ. The index h corresponds the number of steps ahead the prediction is made, and for each time step k predictions are made for h=0, . . . , hmax (i.e., when h=2, the prediction is three steps ahead because h is indexed from zero). - Each multiple multi-step ahead prediction ŷ(k+h|k−1, ϕ) is then compared to the corresponding measured output y(k) by the prediction
error function generator 430 to determine the prediction error at k, defined as ϵ(k, θ) :=y(k)−ŷ(k+h|k−1, ϕ). The predictionerror function generator 430 then squares the two-norm of the prediction errors for each k and sums the results, in some embodiments using an weighting function w(h). The predictionerror function generator 430 thereby generates a prediction performance function that can be expressed in a condensed form as: -
- The multi-step ahead prediction error method is described in more detail below with reference to
FIGS. 7-8 . In alternative embodiments, the predictionerror function generator 430 follows the simulation approach or the one-step ahead prediction error approach discussed above with reference to the predictionerror function generator 424. - The prediction
error function generator 430 then provides the prediction performance function (i.e., Eq. M) to theoptimizer 432. Theoptimizer 432 receives the prediction error function VN(ϕ, ZN) generated by the predictionerror function generator 430 and optimizes the prediction error function in ϕ to determine {circumflex over (ϕ)}N. More specifically, theoptimizer 426 finds the minimum value of the prediction error function VN(ϕ, ZN) as ϕ is varied throughout the allowable values of ϕ. In some cases, all real values of ϕ are allowable. That is, theoptimizer 426 determines {circumflex over (ϕ)}N based on: -
{circumflex over (ϕ)}N={circumflex over (ϕ)}N(Z N)=arg minϕ V N(ϕ, Z N). - The
optimizer 432 then uses {circumflex over (ϕ)}N to calculate the matrices Kx(ϕ) and Kd(ϕ), resulting in a fully identified model. Thegain parameter identifier 420 provides the identified model to the modelpredictive controller 414. - In some embodiments, the prediction
error function generator 430 reconfigures the multi-step ahead prediction problem by defining augmented vectors that allow the multi-step ahead prediction performance function (Eq. M) to be recast in an identical structure to the single-step ahead prediction performance function (Eq. J). Existing software toolboxes and programs (e.g., Matlab system identification toolbox) configured to handle the single-step ahead prediction error approach can then be used to carry out the multi-step ahead prediction error approach. To reconfigure the problem for that purpose, the predictionerror function generator 430 considers, the system model of the form: -
x(k+1)=Ax(k)+Bu(k); y(k)=Cx(k)+Du(k). - where the one-step prediction of {circumflex over (x)}(k+1|k) using a steady-state Kalman gain is:
-
{circumflex over (x)}(k+1|k)=A{circumflex over (x)}(k|k−1)+Bi(k)+K(y(k)−C{circumflex over (x)}(k|k−1)−Du(k)); ŷ(k|k−1)=C{circumflex over (x)}(k|k−1)+Du(k). - In the multi-step prediction Kalman gain system identification problem, the complete pattern of the algebraic manipulations is shown by the 4-step prediction. The prediction
error function generator 430 considers a case with four input data points and four output data-points starting from time h=0 to time h=3, so that hmax=3. The one-step prediction (with the predictionerror function generator 430 given x0) is given by the equation: - {circumflex over (x)}(1|0)=Ax0+Bu(0)+K(y(0)−Cx0−Du(0)); ŷ(0|0)=Cx0+Du(0).
- The prediction of the second step is
- {circumflex over (x)}(2|0)=A{circumflex over (x)}(1|0)+Bu(1)=A(Ax0+Bu(0)+K(y(0)−Cx0−Du(0)))+Bu(1); ŷ(1|0)=C{circumflex over (x)}(1|0)+Du(1)=C(Ax0+Bu(0)+K(y(0)−Cx0−Du(0)))+Du(1).
- The prediction of the third step is
-
- The forth step prediction is
-
- With these 4-step predictions, the pattern needed to cast the multi-step prediction problem as a 1-step prediction is revealed. By aggregating the matrices multiplying x0, y(0), u(0), u(1), u(2), and u(3), the pattern revealed is:
-
{circumflex over (x)}(1|0)=Ax0+Bu(0)+K(y(0)−Cx0−Du(0)); {circumflex over (x)}(2|0)=(A 2 −AKC)x0+(AB−AKD)u(0)+Bu(1)+AKy(0); {circumflex over (x)}(3|0)=(A 3 −A 2 KC)x0+(A 2 B−A 2 KD)u(0)+ABu(1)+Bu(2)+A 2 Ky(0); {circumflex over (x)}(4|0)=(A 4 −A 3 KC)x0+(A 3 B−A 3 KD)u(0)+A 2 Bu(1)ABu(2)+Bu(3)+A 3 Ky(0); ŷ(0)=Cx0+Du(0); ŷ(1|0)=(CA−CKC)x0+(CB−CKD)u(0)+Du(1)+CKy(0); ŷ(2|0)=(CA 2 −CAKC)x0+(CAB−CAKD)u(0)+CBu(1)+DU(2)+CAKy(0); ŷ(3|0)=(CA 3 −CA 2 KC)x0+(CA 2 B−CA 2 KD)u(0)+CABu(1)+CBu(2)+Du(3)+CA 2 Ky(0). - Based on that pattern, the prediction
error function generator 430 defines the following vectors: -
- {circumflex over (x)}(1|0) and x0 remain unchanged.
- The new system that has the 4-step prediction casted into a one-step prediction which can be analyzed by the prediction
error function generator 430 using an existing system identification software product as: -
- In order to have the general formulation at time k for predicting hmax step ahead in time, this four-step example can be extrapolated to define the general augmented input and output vectors as:
-
- With these definition, the general formulation at time k for predicting hmax steps ahead in time is:
-
{circumflex over (x)}(k+1|k)=A{circumflex over (x)}(k|k−1)+[B0 . . . 0]ũ(k)+[K0 . . . 0]({tilde over (y)}(k)−{circumflex over ({tilde over (y)})}(k). - As described above, in the multi-step ahead prediction error method the prediction
error function generator 430 generates a function of the form: -
- If w(h)≡1 for all h, and using the augmented input and output vectors defined above, the multi-step ahead prediction performance function can be reconfigured into the following one-step ahead prediction performance function by the prediction error function generator 430:
-
- The prediction
error function generator 430 then uses this reconfigured format of the prediction performance function with existing software toolboxes suited for the one-step ahead prediction error approach. The predictionerror function generator 430 may include machine-readable media storing computer code executable to apply such software. - Referring now to
FIG. 6 , a flowchart of aprocess 600 for system identification is shown, according to an exemplary embodiment. Theprocess 600 can be carried out by thecontroller 212 ofFIGS. 2 and 4 . - At
step 602, thecontroller 212 applies an excitation signal to theHVAC equipment 210. For example, thetraining data generator 408 may vary the {dot over (Q)}HVAC values supplied to theequipment controller 416, causing an excitation signal to be generated in the temperature setpoint Tsp inputs provided to theHVAC equipment 210. In general, the excitation signal is designed to test the system in a way to provide robust data for use in system identification. - At
step 604, training data is collected and stored by thecontroller 212. Training data includes measureable temperature readings, i.e., Toa and Tia, controller-determined values {dot over (Q)}HVAC and Tsp for each of a plurality of time steps k, k=0, . . . , N. The training data therefore includes inputs u(k) and the outputs y(k) for the time period. The training data is received fromtemperature sensors training data generator 408, and/orequipment controller 416 and stored intraining data database 410. - At
step 606, thecontroller 212 identifies the model parameters for the system. That is, as discussed in detail above, thecontroller 212 determines the matrices A(θ), B(θ), C(θ), and D(θ) that minimize a prediction performance function VN(ZN, θ) for the model: -
{dot over (x)}(t)=A c(θ)x(t)+B c(θ)u(t); (Eq. G) -
y(t)=C c(θ)x(t)+D c(θ)u(t); (Eq. H). - In identifying the model parameters, a simulation approach or a one-step-ahead prediction error approach is followed in some embodiments. These approaches are described in detail above with reference to the prediction
error function generator 424 ofFIG. 5 . In other embodiments, the model parameters are determined atstep 606 using a multi-step ahead prediction error method, described in detail with reference toFIGS. 7-8 . - At
step 608, thecontroller 212 identifies the gain estimator parameters. That is, thecontroller 212 determines the matrices Kx and Kd of Eq. K above. In preferred embodiments, thecontroller 212 uses the multi-step ahead prediction error method to find the matrices Kx and Kd. The multi-step ahead prediction error method is described in detail below with reference toFIGS. 7-8 . In alternative embodiments, a simulation approach or a one-step-ahead prediction error approach is followed to find the matrices Kx and Kd. - At step 610, the identified model is validated by the
controller 212. Thecontroller 212 uses the identified model to generate control signal inputs Tsp for theHVAC equipment 210 using model predictive control. The controller then monitors the temperature measurements Toa and Tia fromtemperature sensors training data database 410 may collect and store an addition set of training data that can be used by themodel identifier 412 to validate the model. If some discrepancy is determined, the identified model may be updated. The identified model can thereby by dynamically adjusted to adjust for changes in the physical system. - Referring now to
FIGS. 7-8 the multi-step ahead prediction error approach for use in system identification is illustrated, according to an exemplary embodiment. InFIG. 7 , a flowchart of aprocess 700 for identifying system parameters using the multi-step ahead prediction error approach is shown, according to an exemplary embodiment.FIG. 8 shows an example visualization useful in explainingprocess 700.Process 700 can be carried out by thesystem parameter identifier 418 and/or thegain parameter identifier 420 ofFIG. 5 . In the embodiment described herein, theprocess 700 is implemented with thegain parameter identifier 420. -
Process 700 begins atstep 702, where thegain parameter identifier 420 receives training data ZN=[y(1), u(1), y(2), u(2), . . . , y(N), u(N)] from thetraining data database 410. The training data includes measured outputs y(k) (i.e., Tia(k) and {dot over (Q)}HVAC(k)) and inputs u(k) (i.e., Toa(k) and Tsp(k)) for each time step k, k=1, . . . , N. N is the number of samples in the training data. Thegain parameter identifier 420 also receives the system model from thesystem parameter identifier 418. - At step 704, the prediction
error function generator 430 uses the training data for a time step k to predict outputs ŷ for each subsequent time step up to k+hmax. The value hmax corresponds to the number of steps ahead the predictions are made, referred to herein as the prediction horizon. Because hmax is indexed from zero in Eq. M above, the prediction horizon is one more than the value of hmax. For example, in the case shown inFIG. 8 and described below, predictions are made three steps ahead, corresponding to hmax=2 in the notation of Eq. D and a prediction horizon of three. The prediction horizon may be any integer greater than one, for example four or eight. The prediction horizon can be tuned experimentally, to determine an ideal prediction horizon. For example, too long of a prediction horizon may lead to poor prediction while too short of a prediction horizon may suffer the same limitations as the one-step ahead prediction error method mentioned above. In some cases, a prediction horizon of eight is preferred. - More specifically, at each step 704 the predicted outputs [ŷ(k|k−1), ŷ(k+1|k−1), . . . ŷ(k+hmax|k−1)] are predicted based on the past training data (i.e., through step k−1), denoted as Zk−1, along with future inputs [u(k), u(k+1) . . . u(k+hmax)]. These predictions are made using the model (ϕ), such that predicted outputs ŷ depend on ϕ.
- To illustrate the predictions of step 704,
FIG. 8 shows a simplified visualization in which y(k) and ŷ(k) are depicted as scalar values for the sake of simplified explanation. InFIG. 8 , thegraph 800 plots the values of y and ŷ over time t for five time steps past a starting time t=0. Thesolid circles 802 represent measured outputs y(t) from the training data. Theunfilled boxes 804 represent predicted outputs ŷ(t|0), that is, the outputs predicted for each time step based on the input/output data available at time t=0 (e.g., y(0)). The dashed lines represent the propagation of the predictions; for example,graph 800 includes threeunfilled boxes 804 connected by a dashed line to thesolid circle 802 corresponding to y(0). This shows that the predictions ŷ(t|0), 1≤t≤3, represented by theunfilled boxes 804 were based on the measured value of y(0). - At
step 706, the predictionerror function generator 430 compares the predicted outputs ŷ to the measured outputs y for each future step up to k+hmax (i.e., for all predicted outputs ŷ generated at step 704). More specifically, an error term for each step may be defined as y(k+h)−ŷ(k+h|k−1, ϕ). Because y and ŷ are vectors, the two-norm of this error term may be taken and squared to facilitate comparison between prediction errors as scalars, such that the error term becomes ∥y(k+h)−ŷ(k+h|k−1, ϕ)∥2 2. This term appears in Eq. M above. - As shown in
FIG. 8 , step 706 can be understood as measuring the distance between, for example, eachunfilled box 804 and the corresponding solid circle 802 (i.e., theunfilled box 804 and thesolid circle 802 at the same time t). Thus, in the example ofFIG. 8 ,step 706 includes calculating three error terms. - At
step 708, the error terms are weighted based on a weighting function w(h). The weighting function w(h) allows the prediction errors to be given more or less weight depending on how many steps ahead the prediction is. The weighting function w(h) is preferably a monotonically decreasing function of h, so that farther-out-in-time predictions have less influence on the prediction error. In some embodiments, the weighting function w(h)=1. Step 708 thereby corresponds the w(h) term in Eq. M above. - The
process 700 then returns to step 704 to repeat steps 704-706 for each value of k, k=1, N−hmax. As illustrated inFIG. 8 , repeating step 704 corresponds to generating the predictions represented by theunfilled circles 808 and theunfilled triangles 810. Theunfilled circles 808 chart the predictions based on the output data available at time t=1, i.e., ŷ(t|1), for t=2, 3, 4. The unfilled triangles chart the predictions based on the output data available at time t=2, i.e., ŷ(t|2), for t=3, 4, 5.Process 700 therefore involves making multiple predictions for most time steps: for example,FIG. 8 shows three separate predictions for time t=3. - At
step 706, the predictionerror function generator 430 again compares the predicted outputs ŷ for the new value of k to the measured outputs y for each future step up to k+hmax to define the error term ∥y(k+h)−ŷ(k+h|k−1, θ)∥2 2 as included in Eq. M. Atstep 708, the terms are again weighted by the weighting function w(h). The weighting function w(h) may be the same for each k. - In the notation of Eq. M, each iteration of steps 704-708 thus corresponds to steps necessary to generate the values used by the inner (right) summation indexed in h, while repetition of the steps 704-708 corresponds to the iteration through k represented in the outer (left) summation. At
step 710, then, these summations are executed. In other words, thesystem identification circuit 108 sums the weighted error terms generated by steps 704-708 to generate a prediction performance function as: -
- The prediction performance function is a function of the input data ZN and the parameter variable ϕ. Typically, the input data ZN is given (i.e., received by the
model identifier 412 and used in the calculation of error terms as described above). Thus, the prediction performance function is primarily a function of ϕ. - At
step 712, the prediction performance function VN(ϕ, ZN) is minimized to find an optimal parameter vector {circumflex over (θ)}N=argVN(ϕ, ZN). Any minimization procedure may be followed. The result ofstep 712 is a vector {circumflex over (ϕ)}N of identified model parameters that tune the model ({circumflex over (ϕ)}N) to accurately predict system evolution multiple steps ahead. At step 714, the model identifier 412 provides the identified system model (i.e., ({circumflex over (ϕ)}N)) to the modelpredictive controller 414 for use in generating control inputs for theHVAC equipment 210. - According to various embodiments,
process 700 is run once at set-up to establish the system model, run periodically to update the system model, or run repeatedly/continuously to dynamically update the system model in real time. - Referring now to
FIG. 9 , a flowchart showing aprocess 900 for optimizing the prediction performance function (cost function) to identify model parameters is shown, according to an exemplary embodiment. Theoptimizer 426 of thesystem parameter identifier 418 ofFIG. 5 may be configured to executed theprocess 900, and reference is made thereto in the following description ofprocess 900. In some embodiments, theprocess 900 is included instep 712 of theprocess 700 ofFIG. 7 . - At
step 902, theoptimizer 426 generates a number N of initial guesses of the system parameters θ, where the matrix A(θ) is stable. In some embodiments, theoptimizer 426 may ensure that the matrix A is stable by initiating all six parameters to be positive and checking that each eigenvalue of the resulting A matrix has a negative real part. In some embodiments, theoptimizer 426 may ensure that the matrix A is stable by initiating the fifth parameter to zero -
- and initiating the remaining five parameters to positive values, which establishes the circuit-style diagram 300 shown in
FIG. 3 as a passive circuit. - At
step 904, theoptimizer 426 discards initial guesses for which -
- That is, the
optimizer 426 checks that the indoor air-thermal mass thermal resistance is larger than the indoor air-outdoor air thermal resistance and that the lump mass thermal capacitance value is larger than the indoor air thermal capacitance, and discards initial guesses that violate these physical requirements. Theoptimizer 426 thereby ensures that the remaining initial guesses conform with requirements from the basic physics of the system. - At
step 906, theoptimizer 426 runs a system identification problem for each remaining initial guess for a small number of iterations M. The small number M may be substantially lower than the number of iterations needed to reach local optimality for the system identification problem given an initial guess. By only running M iterations, theprocess 900 limits the computation required at step 906 (e.g., computation time, computing resources used) relative to other possible approaches. Atstep 908, for each remaining initial guess, theoptimizer 426 records (e.g., stores, saves) the value of the cost function and the system parameter values after the M iterations. - At
step 910, theoptimizer 426 discards initial guesses that lead to an unstable A matrix and/or an A matrix with a very high condition number after M iterations (i.e., as recorded at step 908). That is, theoptimizer 426 may check whether each A matrix recorded atstep 908 is stable, and keep only the initial guesses corresponding to a stable A matrix. Theoptimizer 426 may also determine the condition number of the A matrix and only keep the corresponding initial guess if the condition number is less than a very high threshold number. - At
step 912, theoptimizer 426 determines groups of initial guesses that converge towards the same local optimal solution (i.e., a similar cost function value and similar parameter values). Atstep 914, theoptimizer 426 discards all but one initial guess from each group.FIG. 11 is included to illustratesteps 912 and 914 (depicted with a single parameter variable θ for the sake of clarity).FIG. 11 shows agraph 1100 of a cost function V(θ) with the value of the cost function V(θ) on the vertical axis and the parameter value θ on the horizontal axis. The region of the cost function V(θ) shown inFIG. 11 has a firstlocal optimum 1102 and a secondlocal optimum 1104 that have similar cost function values (i.e., positions on the vertical axis as illustrated by dotted line 1106) but different parameter values. Also illustrated inFIG. 11 is a first group of multipleinitial guesses 1108 illustrated as trending towards either the firstlocal optimum 1102 and a second group of multipleinitial guesses 1110 illustrated as trending towards the secondlocal optimum 1104. - Because all of the
initial guesses 1108 trending towards the firstlocal optimum 1102 will eventually converge to the firstlocal optimum 1102, only oneinitial guess 1108 of the first group ofinitial guesses 1108 needs to be kept in order to have an initial guess that leads the system identification problem to the firstlocal optimum 1102 after a large number of iterations. Similarly, because all of theinitial guesses 1110 trending towards the secondlocal optimum 1104 will eventually converge to the secondlocal optimum 1104, only one initial guess of the second group ofinitial guesses 1110 needs to be kept in order to have an initial guess that leads the system identification problem to the secondlocal optimum 1104 after a large number of iterations. Accordingly, all but one of the first group ofinitial guesses 1108 and all but one of the second group ofinitial guesses 1110 can be discarded to avoid duplication, triplication, etc. of computations in later phases ofprocess 900. It should be understood that one of the local optima may also be a global optimum. - Still referring to
FIG. 9 , atstep 916 theoptimizer 426 ranks the remaining initial guesses in order of cost function value from lowest value to highest value after the M iterations. A lower cost function value corresponds to a higher accuracy of the predictive model, such that a top-ranked initial guess (i.e., having the lowest cost function value) may be understood as corresponding to the most accurate set of parameter values after the M iterations. - At
step 918, theoptimizer 426 chooses the top-ranked initial guess and runs the system identification problem for the top-ranked initial guess to local optimality or for a large number of iterations P. Theoptimizer 426 thereby generates a set of parameters characterized by the A, B, C, and D matrices defined above based on the top-ranked initial guess. - At
step 920, theoptimizer 426 checks whether the A matrix is stable, controllable and observable. Theoptimizer 426 also checks whether the condition number of the A matrix is less than a threshold number L. If the A matrix is unstable, uncontrollable, unobservable, or has a condition number greater than L, then theprocess 900 proceeds to step 922 where the corresponding initial guess is discarded. If the A matrix is stable, controllable, observable, and has a condition number less than the threshold number, then theprocess 900 proceeds to step 924. - At
step 924, theoptimizer 426 checks whether the obtained model (i.e., after P iterations) satisfies the physics-based inequalities -
- which describe limits from the physics of the system. These inequalities are the same as those used in
step 904 and described in detail above. If the inequalities are not satisfied (i.e., if -
- the
process 900 proceeds to step 922 where the corresponding initial guess is discarded. Theprocess 900 then returns to step 918, where the system optimization problem is run for the top-ranked remaining initial guess to local optimality or for a large number of iterations P. Theprocess 900 thereby repeats steps 918-922 until an A matrix is obtained that satisfies the conditions ofsteps 920 and 924 (i.e., a model is identified for which A is stable, controllable, and observable, has a condition number less than the threshold number, and satisfies -
- The
process 900 then proceeds to step 926 where the system model parameters are identified in accordance with the obtained model that satisfies the conditions ofsteps step 926, the system model parameters (e.g., the obtained A, B, C, and D matrices) may be output from theoptimizer 426 to thegain parameter identifier 420 as shown inFIG. 5 . - Notably,
process 900 avoids running poor initial guesses all the way to local optimality (i.e., for a large number of iterations).Process 900 also avoids running multiple initial guesses to the same local optimum. Theprocess 900 is therefore substantially more efficient than other approaches for example generating many initial guesses, running all to local optimality, checking the quality of all models to choose the best result as the obtained model, and repeating the entire process if the obtained model is not satisfactory (e.g., does not satisfy the criteria insteps 920 and 924). Experimental results showing this improvement are described below with reference toFIGS. 12-13 . - Referring now to
FIG. 10 , a flowchart of aprocess 1000 for identifying Kalman gain parameters as part of a system identification process is shown, according to an exemplary embodiment. Theprocess 1000 may be executed by theoptimizer 432 of thegain parameter identifier 420 ofFIG. 5 . Theprocess 1000 may be included instep 608 ofFIG. 6 . Theoptimizer 432 may use the system model parameters identified viaprocess 900 as an input toprocess 1000. - At
step 1002, theoptimizer 432 generates Ninitial guesses of the Kalman gain parameters, with each initial guess having a stable observer system A−KC, i.e., for which all eigenvalues of A−KC are in the unit circuit. In some embodiments, theoptimizer 432 ensures that the initial guess have a stable observer system A−KC using pole placement in which an observer gain is calculated in such a way that places the eigenvalues of A−KC in any desired location provided that the system is observable. - At
step 1004, theoptimizer 432 runs a system identification problem for each initial guess for a small number of iterations M. After the M iterations, atstep 1006 theoptimizer 432 records the cost function and the Kalman gain parameter values that were reached for each initial guess. - At
step 1008, theoptimizer 432 discards initial guesses that lead to an unstable A−KC observer system. That is, for each initial guess, theoptimizer 432 may check whether A−KC is stable after M iterations and only keeps the corresponding guess if theoptimizer 432 determines that A−KC is stable. Atstep 1010, theoptimizer 432 discards initial guesses that lead to an A−KC observer system with a very high condition number (e.g., higher than a threshold number). That is, for each initial guess, theoptimizer 432 determines the condition number of A−KC and only keeps the corresponding initial guess if the condition number is less than a very high threshold number. - At step 1012, the
optimizer 432 determines groups of initial guesses that converge towards the same local optimal solution (e.g., with similar Kalman gain parameter values and cost function values). Atstep 1014, theoptimizer 432 discards all but one initial guess from each group of initial guesses that converge towards the same local optimal solution. Step 1012 andstep 1014 may be explained with reference toFIG. 11 in a similar manner as forsteps 912 andsteps 914 above and not repeated here for the sake of brevity. Theoptimizer 432 thereby avoids running multiple initial guesses of the Kalman gain parameters through many iterations of the system identification problem and/or all of the way to local optimality. - At
step 1016, theoptimizer 432 ranks the initial guesses in order of cost function value from lowest value to highest value after the M iterations, i.e., such that the top-ranked initial guess corresponds to the lowest cost function value after the small number M of iterations. Atstep 1018, theoptimizer 432 runs the system identification problem for the top-ranked initial guess to local optimality or for a large number of iterations P. Theoptimizer 432 thereby generates values for the Kalman gain parameters based on the top-ranked initial guess. - At
step 1020, theoptimizer 432 checks whether the A−KC observer system is stable, controllable, and observable with a condition number less than a threshold number L. If those criteria are not met (i.e., if the A−KC observer system is unstable, uncontrollable, unobservable, or has a condition number higher than L), theprocess 1000 proceeds to step 1022 where the corresponding initial guess is discard. Theprocess 1000 then returns to step 1018 where the system identification problem is run for the top-ranked remaining initial guess to local optimality or for a large number of iterations, the result of which is checked against the criteria described above atstep 1020.Steps - At
step 1024, the resulting obtained system model is output, for example from theoptimizer 432 to the modelpredictive controller 414 ofFIG. 4 . Combined with the A, B, C, and D matrices identified inprocess 900, theprocess 1000 thereby provides identified Kalman gain K. The resulting identified model may be applied in a model predictive control approach as described in detail above to control the building equipment based on the identified model. - Notably,
process 100 avoids running poor initial guesses all the way to local optimality (i.e., for a large number of iterations).Process 1000 also avoids running multiple initial guesses to the same local optimum. Theprocess 1000 is therefore substantially more efficient than other approaches for example generating many initial guesses, running all to local optimality, checking the quality of all models to choose the best result as the obtained model, and repeating the entire process if the obtained model is not satisfactory (e.g., does not satisfy the criteria in step 1020). Experimental results showing this improvement are described below with reference toFIGS. 12-13 . - Referring now to
FIGS. 12-13 , graphical representations of experimental results demonstrating the advantages ofprocess 900 andprocess 1000 are shown, according to an exemplary embodiment.FIG. 12 shows experimental results obtained usingprocesses processes FIG. 13 shows experimental results obtained using an alternative approach of many initial guesses, running all to local optimality, checking the quality of all models to choose the best result as the obtained model, and repeating the entire process if the obtained model is not satisfactory. The graphical representations shown are described in further detail below. - To obtain the experimental results shown in
FIGS. 12-13 , an experiment was conducted on an area of a building located in Milwaukee, Wis. A pseudorandom binary sequence (PBRS) temperature setpoint Tsp signal was generated varying between the values of 73° F. and 75° F. The PRBS signal is designed to stay at each setpoint value for a minimum duration of one hour. The experiment took place over the course of two days where inputs (Tsp, Toa) and output (Tia, {dot over (Q)}HVAC) were collected every ten minutes. The HVAC system utilized in the experiment has a dead-band of 0.5° F. - In a first experiment (corresponding to the results shown in
FIG. 12 ), the collected data was first processed through a saturation detection and removal process, as described in detail in U.S. patent application Ser. No. 15/900,459, filed Feb. 20, 2018, incorporated by reference in its entirety herein. The remaining data was used for parameter estimation based on the state-space system model described in detail above. The simulation prediction error method was used to identify the model parameters, the resulting state-space model was augmented with an integrating disturbance model, and the Kalman filter gain was estimated using the one-step ahead prediction error method. Additionally, the efficient model generation process ofFIGS. 9 and 10 (i.e.,process 900 and process 1000) were applied to facilitate efficient generation of initial guesses and optimization of the prediction error cost functions. For identification of the parameter models (i.e., for process 900), the following values were used: N=50, M=25, P=400, L=9000. For Kalman gain estimation (i.e., for process 1000), the following values were used: N=50, M=50, P=400, L=20,000. The total computation time required for the system identification process to yield an identified system model was 307 CPU seconds. - The resulting model was used to generate and record one-step ahead predictions of the outputs over a two-day period. Actual input-output data for the same time period was also recorded. Illustrating these results,
FIG. 12 includes afirst graph 1200 that shows zone temperature plotted over time and a second graph 1202 that shows QHVAC plotted over time. Both graphs include a measuredline 1204 that represents actual/measured data and a predictedline 1206 that shows the predictions made using the model generated as described above. In both thefirst graph 1200 and the second graph 1202, the predictedline 1206 closely tracks the measuredline 1204. The 2-norm of the one-step prediction error in the outputs of the two days was 1.6175 for the zone temperature and 16.6594 for {dot over (Q)}HVAC. - For comparison, a second experiment was conducted over the same collected input-output data without the use of the efficient model generation process of
FIGS. 9 and 10 (i.e., withoutprocess 900 and process 1000). Instead, each initial guess was run to local optimality and the stability, controllability, observability, and condition numbers of the identified A and A−KC matrices were evaluated. If the result was not satisfactory (i.e., if A or A−KC is unstable, uncontrollable, unobservable, or has a very high condition number), another random guess was generated, used to run the system identification problem to local optimality, and the result was evaluated. An acceptable model was eventually identified. The total computational time for this method to result in an acceptable model was 1923 CPU seconds. - As in the first experiment, the model was used to generate one-step predictions of the outputs over the two-day period.
FIG. 13 shows athird graph 1300 that shows zone temperature plotted over time and a fourth graph 1302 that shows {dot over (Q)}HVAC plotted over time. Bothgraphs 1300, 1302 include a measuredline 1304 that represents actual/measured data and a predictedline 1306 that shows the predictions made using the model generated as described above. In bothgraphs 1300, 1302, the predictedline 1306 roughly follows the measuredline 1304, but with noticeably less accuracy than the predictedline 1206 ofFIG. 12 . In the second experiment, the 2-norm of the one-step prediction error of the outputs for the two days was 7.8597 for the zone temperature and 94.4387 for {dot over (Q)}HVAC, i.e., substantially worse than as stated above for the first experiment. - Accordingly, these experiments demonstrate that the systems and methods described herein for efficient model generation as shown in
FIGS. 9 and 10 provide improved efficiency and save computational time and resources in generating models (e.g., about a 6-fold improvement in the experiment ofFIGS. 12-13 ) as well as improved accuracy of the resulting predictive models. The improved accuracy of the resulting predictive models results in improved control of building equipment to meet demands while minimizing operational and energy consumption costs. The systems and methods described herein thereby constitute concrete, technical improvements in the building equipment and building management systems. - Referring now to
FIG. 14 , a flowchart of aprocess 1400 for generating a system model for a building system and controlling building equipment in accordance with the system model is shown, according to an exemplary embodiment.Process 1400 may be carried out by thecontroller 212 ofFIG. 4 and may correspond to various steps ofprocess 600 ofFIG. 6 . Various steps ofprocess 1400 may also correspond to various steps ofprocess 900 andprocess 1000. - At
step 1402, building equipment (e.g., HVAC equipment 210) is operated to generate training data. For example, an excitation signal may be provided and the inputs and outputs of the system recorded as described above with reference toFIGS. 4 and 6 . Atstep 1404, a prediction error function (cost function) is defined based on the training data and a system model. The prediction error function may be based on a one-step ahead prediction error approach, a simulation prediction error approach, and/or a multi-step ahead prediction error approach. The prediction error function is a function of the parameters of the system model, for example as shown above in Eq. M above. - At
step 1406, multiple initial guesses are generated for the parameters of the system model. The initial guesses may be selected as described with reference to steps 902-904 andstep 1002 above. Atstep 1408, an optimization problem is run for each initial guess for a first group of iterations (e.g., a small number of iterations as described with reference tosteps 906 and 1004). The resulting parameters and prediction error functions may be recorded. - At
step 1410, a portion of the initial guesses are discarded based on one or more criteria, for example as described with reference to steps 910-914 and steps 1008-1014. Various criteria are possible in various embodiments. In some embodiments, the one or more criteria include stability, observability, and controllability of a matrix of the system model. In some embodiments, the one or more criteria relate to a condition number of a matrix of the system model. In some embodiments, discarding a portion of the initial guesses based on one or more criteria includes determining that a first initial guess and a second initial guess lead toward a same local optimum after the first group of iterations and, in response, discarding the first initial guess. Many other criteria are contemplated by the present disclosure. - At
step 1412, a remaining initial guess is selected and the optimization problem is run for the selected initial guess for a second group of iterations and/or to local optimality. The remaining initial guess may be selected as the initial guess corresponding to the lowest value of the of the prediction error function after the first group of iterations. The second group of iterations may include a large number of iterations (e.g., a larger number of iterations than included in the first group of iterations of step 1408). It should be understood that, in some cases, local optimality is also global optimality. - At
step 1414, the parameters resulting fromstep 1412 and/or the system model having the parameters resulting fromstep 1412 are checked against one or more conditions. For example, the one or more conditions may require one or more matrices of the system model to be observable, controllable, and stable. As another example, the one or more conditions may require one or more matrices of the system model to have a condition number less than a threshold condition number. As another example, the one or more conditions may require that the parameters are consistent with one or more physical laws that constrain the behavior of the system. - If the resulting parameters do not satisfy the one or more conditions,
process 1400 returns to step 1412 where a different remaining initial guess is selected and the optimization problem is run for the different remaining initial guess for the second group of iterations or to local optimality. The resulting parameters and/or system model is then checked against the one or more conditions atstep 1414.Steps - If the one or more conditions are determined to be satisfied at
step 1414, the system model is identified as having the parameters resulting from the latest instance ofstep 1412. Atstep 1418, building equipment (e.g., HVAC equipment 210) is operated by applying the system model in a predictive controller. The controller may use the system model to generate control inputs for the building equipment, for example to minimize the utility cost associated with operating the building equipment over an optimization period. The predictive controller may be a model predictive controller or another type of controller in various embodiments.Process 1400 thereby provides for improved operation of building equipment with the improved performance described with reference to the experimental results ofFIGS. 12-13 . - Although the figures show a specific order of method steps, the order of the steps may differ from what is depicted. Also two or more steps can be performed concurrently or with partial concurrence. Such variation will depend on the software and hardware systems chosen and on designer choice. All such variations are within the scope of the disclosure. Likewise, software implementations could be accomplished with standard programming techniques with rule based logic and other logic to accomplish the various connection steps, calculation steps, processing steps, comparison steps, and decision steps.
- The construction and arrangement of the systems and methods as shown in the various exemplary embodiments are illustrative only. Although only a few embodiments have been described in detail in this disclosure, many modifications are possible (e.g., variations in sizes, dimensions, structures, shapes and proportions of the various elements, values of parameters, mounting arrangements, use of materials, colors, orientations, etc.). For example, the position of elements can be reversed or otherwise varied and the nature or number of discrete elements or positions can be altered or varied. Accordingly, all such modifications are intended to be included within the scope of the present disclosure. The order or sequence of any process or method steps can be varied or re-sequenced according to alternative embodiments. Other substitutions, modifications, changes, and omissions can be made in the design, operating conditions and arrangement of the exemplary embodiments without departing from the scope of the present disclosure.
- As used herein, the term “circuit” may include hardware structured to execute the functions described herein. In some embodiments, each respective “circuit” may include machine-readable media for configuring the hardware to execute the functions described herein. The circuit may be embodied as one or more circuitry components including, but not limited to, processing circuitry, network interfaces, peripheral devices, input devices, output devices, sensors, etc. In some embodiments, a circuit may take the form of one or more analog circuits, electronic circuits (e.g., integrated circuits (IC), discrete circuits, system on a chip (SOCs) circuits, etc.), telecommunication circuits, hybrid circuits, and any other type of “circuit.” In this regard, the “circuit” may include any type of component for accomplishing or facilitating achievement of the operations described herein. For example, a circuit as described herein may include one or more transistors, logic gates (e.g., NAND, AND, NOR, OR, XOR, NOT, XNOR, etc.), resistors, multiplexers, registers, capacitors, inductors, diodes, wiring, and so on).
- The “circuit” may also include one or more processors communicably coupled to one or more memory or memory devices. In this regard, the one or more processors may execute instructions stored in the memory or may execute instructions otherwise accessible to the one or more processors. In some embodiments, the one or more processors may be embodied in various ways. The one or more processors may be constructed in a manner sufficient to perform at least the operations described herein. In some embodiments, the one or more processors may be shared by multiple circuits (e.g., circuit A and circuit B may include or otherwise share the same processor which, in some example embodiments, may execute instructions stored, or otherwise accessed, via different areas of memory). Alternatively or additionally, the one or more processors may be structured to perform or otherwise execute certain operations independent of one or more co-processors. In other example embodiments, two or more processors may be coupled via a bus to enable independent, parallel, pipelined, or multi-threaded instruction execution. Each processor may be implemented as one or more general-purpose processors, application specific integrated circuits (ASICs), field programmable gate arrays (FPGAs), digital signal processors (DSPs), or other suitable electronic data processing components structured to execute instructions provided by memory. The one or more processors may take the form of a single core processor, multi-core processor (e.g., a dual core processor, triple core processor, quad core processor, etc.), microprocessor, etc. In some embodiments, the one or more processors may be external to the apparatus, for example the one or more processors may be a remote processor (e.g., a cloud based processor). Alternatively or additionally, the one or more processors may be internal and/or local to the apparatus. In this regard, a given circuit or components thereof may be disposed locally (e.g., as part of a local server, a local computing system, etc.) or remotely (e.g., as part of a remote server such as a cloud based server). To that end, a “circuit” as described herein may include components that are distributed across one or more locations. The present disclosure contemplates methods, systems and program products on any machine-readable media for accomplishing various operations. The embodiments of the present disclosure can be implemented using existing computer processors, or by a special purpose computer processor for an appropriate system, incorporated for this or another purpose, or by a hardwired system. Embodiments within the scope of the present disclosure include program products comprising machine-readable media for carrying or having machine-executable instructions or data structures stored thereon. Such machine-readable media can be any available media that can be accessed by a general purpose or special purpose computer or other machine with a processor. By way of example, such machine-readable media can comprise RAM, ROM, EPROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code in the form of machine-executable instructions or data structures and which can be accessed by a general purpose or special purpose computer or other machine with a processor. Combinations of the above are also included within the scope of machine-readable media. Machine-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing machines to perform a certain function or group of functions.
Claims (20)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/240,028 US10684598B1 (en) | 2019-01-04 | 2019-01-04 | Building management system with efficient model generation for system identification |
US16/447,724 US11210591B2 (en) | 2019-01-04 | 2019-06-20 | Building control system with automated Kalman filter parameter initiation and system identification |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US16/240,028 US10684598B1 (en) | 2019-01-04 | 2019-01-04 | Building management system with efficient model generation for system identification |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/447,724 Continuation-In-Part US11210591B2 (en) | 2019-01-04 | 2019-06-20 | Building control system with automated Kalman filter parameter initiation and system identification |
Publications (2)
Publication Number | Publication Date |
---|---|
US10684598B1 US10684598B1 (en) | 2020-06-16 |
US20200218208A1 true US20200218208A1 (en) | 2020-07-09 |
Family
ID=71075076
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US16/240,028 Active US10684598B1 (en) | 2019-01-04 | 2019-01-04 | Building management system with efficient model generation for system identification |
Country Status (1)
Country | Link |
---|---|
US (1) | US10684598B1 (en) |
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11714393B2 (en) | 2019-07-12 | 2023-08-01 | Johnson Controls Tyco IP Holdings LLP | Building control system with load curtailment optimization |
US11933513B2 (en) | 2021-07-30 | 2024-03-19 | Johnson Controls Tyco IP Holdings LLP | Building control system with setpoint injection for online system identification |
US12007732B2 (en) | 2019-07-12 | 2024-06-11 | Johnson Controls Tyco IP Holdings LLP | HVAC system with building infection control |
Families Citing this family (12)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10127240B2 (en) | 2014-10-17 | 2018-11-13 | Zestfinance, Inc. | API for implementing scoring functions |
US11941650B2 (en) | 2017-08-02 | 2024-03-26 | Zestfinance, Inc. | Explainable machine learning financial credit approval model for protected classes of borrowers |
WO2019173734A1 (en) | 2018-03-09 | 2019-09-12 | Zestfinance, Inc. | Systems and methods for providing machine learning model evaluation by using decomposition |
WO2019212857A1 (en) | 2018-05-04 | 2019-11-07 | Zestfinance, Inc. | Systems and methods for enriching modeling tools and infrastructure with semantics |
US11816541B2 (en) | 2019-02-15 | 2023-11-14 | Zestfinance, Inc. | Systems and methods for decomposition of differentiable and non-differentiable models |
EP3942384A4 (en) | 2019-03-18 | 2022-05-04 | Zestfinance, Inc. | Systems and methods for model fairness |
US11098921B2 (en) * | 2019-07-18 | 2021-08-24 | Johnson Controls Tyco IP Holdings LLP | Building management system with automatic comfort constraint adjustment |
CN111951553B (en) * | 2020-08-17 | 2022-11-11 | 上海电科智能系统股份有限公司 | Prediction method based on traffic big data platform and mesoscopic simulation model |
US11283669B1 (en) | 2020-09-04 | 2022-03-22 | Johnson Controls Tyco IP Holdings LLP | Building management system with control framework |
US11720962B2 (en) | 2020-11-24 | 2023-08-08 | Zestfinance, Inc. | Systems and methods for generating gradient-boosted models with improved fairness |
US12105491B2 (en) | 2020-12-18 | 2024-10-01 | Tyco Fire & Security Gmbh | VAV self commissioning in a building automation system |
CN114039784B (en) * | 2021-11-10 | 2023-11-14 | 中国人民解放军战略支援部队信息工程大学 | Network protocol password guess attack recognition method |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US10762563B2 (en) * | 2017-03-10 | 2020-09-01 | Cerebri AI Inc. | Monitoring and controlling continuous stochastic processes based on events in time series data |
US20180374104A1 (en) * | 2017-06-26 | 2018-12-27 | Sap Se | Automated learning of data aggregation for analytics |
US11067403B2 (en) * | 2018-07-05 | 2021-07-20 | GM Global Technology Operations LLC | Vehicle energy usage tracking |
-
2019
- 2019-01-04 US US16/240,028 patent/US10684598B1/en active Active
Cited By (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11714393B2 (en) | 2019-07-12 | 2023-08-01 | Johnson Controls Tyco IP Holdings LLP | Building control system with load curtailment optimization |
US12007732B2 (en) | 2019-07-12 | 2024-06-11 | Johnson Controls Tyco IP Holdings LLP | HVAC system with building infection control |
US11933513B2 (en) | 2021-07-30 | 2024-03-19 | Johnson Controls Tyco IP Holdings LLP | Building control system with setpoint injection for online system identification |
Also Published As
Publication number | Publication date |
---|---|
US10684598B1 (en) | 2020-06-16 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10684598B1 (en) | Building management system with efficient model generation for system identification | |
US10718542B2 (en) | Building management system with system identification using multi-step ahead error prediction | |
US11210591B2 (en) | Building control system with automated Kalman filter parameter initiation and system identification | |
US11454940B2 (en) | Building control system with heat load estimation using deterministic and stochastic models | |
US11085663B2 (en) | Building management system with triggered feedback set-point signal for persistent excitation | |
EP2820488B1 (en) | Multi-dimensional optimization for controlling environmental maintenance modules | |
US10558178B2 (en) | Central plant control system with linear solver for computation reduction | |
US11243503B2 (en) | Building management system with online configurable system identification | |
US11774122B2 (en) | Building control system with adaptive online system identification | |
US11215375B2 (en) | Building control system with heat disturbance estimation and prediction | |
JP2012149839A (en) | Air conditioner linkage control system, air conditioner linkage control method, and air conditioner linkage control program | |
CN101589656A (en) | System and method for evaluating equipment rack cooling performance | |
US11236917B2 (en) | Building control system with zone grouping based on predictive models | |
US10540457B2 (en) | System and method for predicting thermal-insights of a data center | |
AU2020387403A1 (en) | Building control system with automatic control problem formulation using building information model | |
Zhang et al. | Residual physics and post-posed shielding for safe deep reinforcement learning method | |
CN112288139B (en) | Air conditioner energy consumption prediction method, system and storage medium based on chaos time sequence | |
Fang et al. | Control-oriented modeling and optimization for the temperature and airflow management in an air-cooled data-center | |
JP6455937B2 (en) | Simulation apparatus, simulation method, and program | |
Fischer et al. | Nonlinear Model Predictive Control of a Thermal Management System for Electrified Vehicles using FMI. | |
US11933513B2 (en) | Building control system with setpoint injection for online system identification | |
US12093000B2 (en) | Building management system with automatic training data selection for online system identification | |
CN116954329A (en) | Method, device, equipment, medium and program product for regulating state of refrigeration system | |
Yu | Model-Based multivariate control of conditioning systems for office buildings | |
CN117413273A (en) | Method, apparatus and computer storage medium for monitoring an enclosure environment |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
FEPP | Fee payment procedure |
Free format text: ENTITY STATUS SET TO UNDISCOUNTED (ORIGINAL EVENT CODE: BIG.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
AS | Assignment |
Owner name: JOHNSON CONTROLS TECHNOLOGY COMPANY, MICHIGAN Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:ALANQAR, ANAS W.I.;ELLIS, MATTHEW J.;WENZEL, MICHAEL J.;AND OTHERS;REEL/FRAME:048576/0540 Effective date: 20181203 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: JOHNSON CONTROLS TYCO IP HOLDINGS LLP, WISCONSIN Free format text: NUNC PRO TUNC ASSIGNMENT;ASSIGNOR:JOHNSON CONTROLS TECHNOLOGY COMPANY;REEL/FRAME:058959/0764 Effective date: 20210806 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 4TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1551); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 4 |
|
AS | Assignment |
Owner name: TYCO FIRE & SECURITY GMBH, SWITZERLAND Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:JOHNSON CONTROLS TYCO IP HOLDINGS LLP;REEL/FRAME:067056/0552 Effective date: 20240201 |