A real-time optimizer defines an operating region of a process to achieve a long-term cost-efficiency. The optimizer typically spans over multiple units in an industrial process being controlled, and may be plant-wide. The optimizer usually assumes a steady-state operation and a full operational range. Capturing process behavior over the full operational range requires a non-linear model. The role of an advanced model-based predictive controller is to ensure safe operation around an operating point which is determined by the optimizer, to attenuate disturbances, and to handle transitions between operating points. The controller uses a dynamical control model, as it most of the time operates within a region around a given operating point and transitions are relatively infrequent. The dynamical control model may be linearized and may change upon the change of the operational region. The dynamical control model, although localized to an operating region, is more detailed than that of the optimizer, by including process states (which may not be measurable) and disturbances.
Both steady-state and dynamic models are typically obtained off-line, based on controlled experiments on the process. The dynamic and static models should be consistent, meaning that their predictions for steady-states coincide. At the same time, they should be consistent with measured data. However careful was acquiring the model during the off-line phase, the process model can change in time due to changes of environment, raw material compositions, equipment aging, and fouling. For this, an adaptation tool can be included, which collect process data and modifies the steady-state model using some tuning parameters to be consistent with the data. The changes in the steady-state model are then propagated in the dynamic model.
The tool for the steady-state model adaptation processes measured data, implicitly assuming that the process is in the steady state, which is often not true. The adaptation algorithm takes into account process data collected during a certain time interval, during which various short-time variations are averaged out. The process, however, may be subject to slow transitions from one operation point to another. On one hand, it is good for the estimator to have data from multiple operation points. On the other hand, however, during the transition various accumulations of mass/energy may occur, which means that process outputs may lag behind the changes in process inputs, the data may temporarily be inconsistent with the steady-state model, disrupting the adaptation algorithm. As the adaptation algorithm works on the steady-state model only, it has no information on the accumulation flows, which cannot be directly measured on the process.
A multi-layer process controller-optimizer with steady-state model adaptation includes a model based predictive controller running on a computer to receive measurements of controlled variables and disturbance variables from a process to compute manipulated variables to control the process as a function of a dynamic process model, a state estimator (as e.g. Kalman filter) to provide an estimated state of the process to the model based predictive controller, a steady-state real-time optimizer to set economically optimal steady-state targets to the model-based predictive controller, a model adaptation tool to modify the nonlinear steady state model to be consistent with process data and to modify the linear dynamic model to be consistent with the nonlinear steady state model in the steady-state, and a quasi steady state estimator to provide estimates of manipulated variables and controlled variables such that they are consistent with a steady state of the process for a given disturbance.
A method includes receiving process data control variables and disturbance variables from a process to compute, via a model based predictive controller running on a computer, manipulated variables to control the process as a function of a dynamic model, providing an estimated state of the process to the model based predictive controller via a Kalman filter, setting economically optimal steady-state targets for the model-based predictive controller, modifying the steady state model via a model adaptation tool to be consistent with process data, and providing estimates of manipulated variables and controlled variables, via a quasi-steady state estimator, such that they are consistent with a steady state of the process for a given disturbance.
A computer readable storage device having instructions to cause a computer system to implement a multi-layer controller-optimizer with steady-state model adaptation. The controller-optimizer includes a model based predictive controller to receive measurements of controlled variables and disturbance variables from a process to compute manipulated variables to control the process as a function of a dynamical model, a Kalman filter to provide an estimated state of the process to the model based predictive controller, a steady-state optimizer to provide economically optimal steady-state targets to the model-based predictive controller, a model adaptation tool to modify the steady state model to be consistent with process data, and a quasi-steady-state estimator to provide estimates of manipulated variables and controlled variables such that they are consistent with a steady state of the process for a given disturbance.
In the following description, reference is made to the accompanying drawings that form a part hereof, and in which is shown by way of illustration specific embodiments which may be practiced. These embodiments are described in sufficient detail to enable those skilled in the art to practice the invention, and it is to be understood that other embodiments may be utilized and that structural, logical and electrical changes may be made without departing from the scope of the present invention. The following description of example embodiments is, therefore, not to be taken in a limited sense, and the scope of the present invention is defined by the appended claims.
The functions or algorithms described herein may be implemented in software or a combination of software and human implemented procedures in one embodiment. The software may consist of computer executable instructions stored on computer readable media such as memory or other type of storage devices. Further, such functions correspond to modules, which are software, hardware, firmware or any combination thereof. Multiple functions may be performed in one or more modules as desired, and the embodiments described are merely examples. The software may be executed on a digital signal processor, ASIC, microprocessor, or other type of processor operating on a computer system, such as a personal computer, server or other computer system.
A block diagram of a process control system utilizing a control/optimization hierarchy with state estimation for steady-state model adaptation is illustrated generally at 100 in
A layer above advanced control 115, 125 is a real-time optimization, RTO 135 layer that aims on the long-term process profitability. Several model-based predictive controllers may be within the scope of the optimizer. The optimizer receives information on external supplies, and demands, resource availability, on-line changing prices etc. The optimizer computes production targets to be achieved within the controller's horizon on the assumption that the process will be in an equilibrial steady-state. RTO uses a steady-state model which is valid for the full operational range, typically a non-linear one.
The internal models within MPC, KF and RTO may be modified by a parameter tuned in the model adaptation tool (MAT) 140. This tool modifies steady-state non-linear model to be consistent with process data provided from the process monitoring as process variables 145. MAT 140 involves an optimization algorithm to achieve the best agreement between the data predicted by the model and process data. It needs to operate in the real time, and to have some sort of recursion to update its state upon receiving fresh data.
At least one algorithm that may be used may be recursive least squares. In addition, some sort of forgetting should be considered in order to track changes in varying model parameters. The adaptation algorithm executed by MAT 140 may be robust to information poor data, as occurs when the system stays in a steady-state for a long time. Hence, variations from the model obtained by the original identification experiment may be limited by the algorithm. One example algorithm for MAT is the use of recursive least-squares with exponential forgetting, that is enhanced by including constraints on the shape of the functional steady-state model. MAT may also detect outliers in process data (due to e.g. sensor faults or any sort of disturbance) and not to use suspicious data or model adaptation.
The system 100 described above will be first described below. To improve the system, a quasi-steady-state estimator (QSSE) 150 is added to convert the KF state estimate in data compensations variables. These compensation variables vanish if the process is in the steady state, even though KF model is of incorrect gain. Details of the QSSE 150 and how it modifies the process values provided to the MAT 140 will be described following a description of operation of system 100 without the QSSE 150 to provide a clearer understanding of the benefits provided by QSSE 150.
A steady-state non-linear model may be expressed in the following forms (the choice depends on the process or the formulation of the RTO optimization problem).
y(ū,
The over-bar denotes steady-state values; y denotes a PV (not necessarily a CV as used in control), u is MV and d is process disturbance DV. The representation above is the nominal one, representing the process in time when the data for model identification were obtained. The models can be perturbed by additional (vector-valued) parameters to reflect changes in the process as
θy(ū,
Obtaining the respective parameter θu or θy is the role of MAT 140. Note that the steady-state model for the optimizer may be explicit in process inputs (MV) and not process outputs (CV/PV)—in the problem formulation of RTO is this classification of variables often irrelevant.
The linear, parameter-varying dynamical representation of the process localized to the neighborhood of a particular operational point given by the couple (ū,
{dot over (x)}(t)=A(ū,
δy(t)=C(ū,
where δu=u−ū, δy=y−
x(k+1)=AD(ū,
δy(k)=CD(ū,ū)x(k)+DDu(ū,
The correspondence between models (2) and (3) is well known.
The consistency of static non-linear model
The cases of the invertibility assumption not holding are those of processes that include pure integrators. In that case, the steady state can be achieved only for a sub-space of ū×
For representation
The invertibility on the right-hand side is a sufficient condition for the equivalence between steady-state models in (1), according to the inverse function theorem. This singularity would imply an arbitrary increase in the outputs upon zero increase in the inputs; it can be expected that the system will not be operated in the region, where this pathological case can occur.
When the non-linear model is parameterized by the tuning parameter, we need to parameterize the dynamical model to guarantee the consistency; a possible option is as follows
Similar parameterization can be done for (5) and (6). The objective for the model adaptation tool is to fit the non-linear model on data, as, e.g., by minimizing the cost function
with respect to the parameter θy for each time step k=1, 2, . . . , Parameter λ is the so-called forgetting factor and is set between 0 and 1. This puts more weight on fresh data than the old ones, thus facilitating the parameter tracking. On the other hand, when the process is not sufficiently excited, and dwells in one steady-state, the optimization problem is ill-posed and certain kind of regularization is necessary. The cost function may involve more penalty terms as e.g. to penalize changes of θy. The optimization problem may further involve various constraints in order to prevent the optimizer to produce models significantly different from the nominal model due to low excitation and measurement noises. An equivalent model can be naturally formulated for parameterization involving θu.
The problem with the formulation in (8) is that there is no guarantee of the process being in the steady-state. In fact, many processes spend in transients most of the time as they adapt to external conditions. During transients, various accumulations of mass and energy occur and the nonlinear model (1) is invalid, as can be seen in
QSSE 150 uses estimated steady-state model parameters 127 during the transients when accumulations occur by distributing the parameter estimation task between MAT 140 and KF 125. Quasi-steady state estimator (QSSE) uses the state 127 estimated by Kalman filter 125 and computes process data corrections that correspond to the ‘nearest’ steady state.
The role of the Quasi-steady state optimizer 150 is to produce estimates of MV 124 and CV 120, denoted as ūq and
When considering the discrete-time local state-space model 3, the quasi steady state is obtained from the solution of the minimum-norm solution of the following underdetermined linear equation
There, the scheduling arguments (ū,
ū
q(k)=u(k)+Δūq(k),
The Kalman filter model gain is adapted by the parameter estimator, which in turn, uses corrections based on KF estimate. Hence, at this point, there is no guarantee of the correctness of the KF estimate 127. In particular, if the gain is wrong and the process were in the steady state, the right-hand side of (9) would be non-zero, and so would be the correction variables Δuq and Δyq; the equilibrium of KF is facilitated by the innovation term (a well-known notion of Kalman filters) that is nonzero in the steady state, if the model is wrong. This would give the model adaptation tool 140 wrong quasi-steady-state data. Nevertheless, the gain information in these data would be closer to reality than the gain estimate currently built in KF 125; hence, in the future iterations, MAT 140 would gradually adjust the gain of KF 125 so that this state estimator would converge to a steady state as well. But this correction would take a comparatively long time (depending on the forgetting factor setting in MAT). For this, an unknown input observer may be used. It is assumed that the process is perturbed by an unmeasured disturbance. The location of this disturbance within the process model depends on where is the possible gain uncertainty. If it is expected that the uncertainty in the MV−CV channel, MV is perturbed by an offset that is unknown; this offset is modeled by an integrator whose state is estimated by Kalman filter. In KF context it is also called random walk model. The augmented plant is described as
x(k+1)=ADx(k)+BDux1(k)+BDuδu(k)+BDdδd(k)
x
1(k+1)=x1(k)
δy(k)=CDx(k)+DDux1(k)+DDuδu(k)+DDdδd(k) (12)
The fictitious input is the additional state x1. This augmented process can be used in QSSE as the original one by substituting
In that case, the last row in (9) is zero, for both left- and right-hand sides. This form of process model guarantees zero innovation term in the steady-state; model-data mismatch is explained primarily by the unknown offset. In the steady state, the right-hand side of (9) is zero and the data sent to the Model Adaptation Tool are uncorrected. More than one unknown input model may append the process model. However, all these models have to be observable from measured data used by KF. Necessarily, there must be as many measurements than unknown input observers with random walk models.
To summarize the main points of the proposed solution are using KF state estimate in the quasi steady-state estimator to compensate process data for the effects of accumulations, using input disturbance estimate in KF to have zero compensations in the steady state.
An example of model adaptation in a boiler optimization is now described. Although the proposed solution can be applied to control and optimization of any process with nonlinear steady-state model and process dynamics involving accumulation, the boiler was chosen as an example. A boiler steady-state model for the optimizer involves the relationship between the raw-material (fuel) and the product—steam. This relationship is given by the following formula
where FF and FS are fuel and steam flows, respectively, in mass-flow units, as kg/s. Symbol c denotes the fuel calorific value in, e.g, Mega Joule per kilogram. Δh denotes the enthalpy increase from feed-water to the output steam. Consistently with the above, its unit is again Mega Joule per kilogram. Function η denotes the efficiency, depending on the process load (output steam) and other auxiliary variables. First of all, combustion efficiency depends on the air-to-fuel ratio, which is reflected in the oxygen concentration in flue gas. This air-to-fuel ratio is usually controlled so that the flue gas concentration of O2 follows a specific dependency on the load—the so-called Oxygen curve denoted as δO2. The efficiency thus can be parameterized by variations of O2 measurements from this oxygen curve. Further auxiliary parameter may be the deviation of flue gas temperature from its nominal value. The efficiency is dimensionless and takes values between 0 and 1. The enthalpy increase depends on the feed-water temperature and pressure and on the temperature and pressure of the output steam. These variables are controlled, although variations are possible.
The steady-state model above may change due to variations of fuel quality (resulting in changes in the fuel calorific value); fouling of heat exchangers (resulting in deterioration of the efficiency).
These model changes are gradual, especially the latter one; other model changes are possible, as e.g., changes in the air-to-fuel ratio control. An example plot of the efficiency function η (for constant auxiliary parameters) is shown in
This adaptation parameter can compensate for fuel quality variations and to also for efficiency deterioration. Its nominal value is equal to one, and the adaptation algorithm should not allow its value to drift too far from one. Further parametric modifications are possible, e.g., including an additive perturbation. This is omitted here. It is, however, always advisable to keep the number of parameters low, considering the fact that the process data are often information-poor.
A linearized dynamic model of the boiler is in shown in block flow form at 500 in
Note that steam is being developed within a considerable volume and thus this variable is not accessible for measurement. The thermal model for fuel/steam variations is essentially a low-pass filer; for control purposes, it may be possible to approximate this model by a first-order transfer function. Sometimes, it may be necessary to append this model by a fuel transport model, in particular, for solid fuels, where also some significant accumulation may occur. This is, however, not considered here.
In one embodiment, a drum model 540 is basically modeled as a vessel with material flowing in (developed steam from water) and out (output steam flowing to a steam header 545). The rate of change for the internal pressure in the drum 540 is proportional to the mass balance of steam flows. The steam outflow from the boiler depends on the pressure difference between the boiler and the steam header 545. Header pressure enters this model at 550 as a disturbance. The function for the output flow as the function of pressure difference is non-linear, it is proportional to the square root of the pressure difference. Within a limited range it can be approximated by a gain Kv1 at 555 and an offset o1 at 560 essentially forming a valve 565. Finally, the header model is again a simple vessel model—the pressure is proportional to the integral if the balance between steam mass flow flowing into the header (i.e., the flow from the drum) and extractions of steam to turbines. This latter extraction is the process disturbance. For simplicity, only one boiler is considered here; multiple parallel boilers feeding steam to a common header are usually present (their load allocation is then subject to real-time optimization). Scaling up the solution to multiple boilers is straightforward.
In the steady state, the drum pressure is constant, which implies equality between steam developed S1 and steam output Fs. For the pressure in the drum we have pd1=(Fs−o)Kv1+pH. The steam-fuel relationship is, in the steady state, given by FS−FS0=K·(Ff−Ff0); This relationship should be consistent with (13), so that for an operating point given by a nominal load FS0, he gain K is given by (replacing the auxiliary efficiency parameters by symbol
The continuous-time state-space model of the process is given by
State variables x1, x2 and x3 are δS1, pD, and pH respectively. Other variables, including those representing operating point values can be regarded as known inputs. Measurements are given as
F
S
=K
v(x2−x3)+o
p
H
=x
3 (16)
Of those measurements, only the first one is relevant for the steady-state model. Model (15) includes one pure integrator. Steady-state is characterized by the following equations:
1
=KδF
S
=
1
S
Due to the fact that the process involves a pure integrator, steady-state values of MV−δF and DV−d are dependent. Further, pressures in the drum and in the header are not fully determined by the steady state, only their difference. Their values are dependent on process history prior to the steady state.
There are accumulation effects that may affect the estimation of parameter θ, including mass accumulation of steam in the drum and in the header, and heat accumulation in water and vessel walls
Some simulations demonstrate effects of QSSE 150. Steam flow from the boiler, FS and header pressure pD are used as measured PVs for state estimation. One simulation involves a response to initial conditions and a transition of the operation point; this transition is driven by a step-change of the steam extraction from the header and the response by the master pressure controller that adjusts fuel flow accordingly (as the process is unstable, only closed-loop simulations are sensible). Responses are shown in
As for quasi-steady state computed using KF state estimate: the steam/fuel gain is correct after the convergence of KF state estimate. The gain estimates are shown in
Up to now, the Kalman filter was assumed to have process model of correct gain; the latter is not known exactly and is subject to estimation by the model adaptation tool 140. To get a realistic evaluation of quasi-steady state, we shall consider KF model having a considerably different gain from the correct process model. In particular, the gain from fuel input to steam output in KF was chosen as the correct gain multiplied by the factor of 0.75. It can be seen that even if KF operates with the wrong steady-state model, quasi-steady states based on its state are correct upon convergence of KF. Nevertheless, even during the transition the gain error is not significant, as can be observed in
The estimated quasi-steady state of the steam flow to the header as shown in
A new method for compensating transitions and accumulations in estimating steady-state models uses a Kalman filter state estimate. Kalman filter is often present in the advanced controller, and hence, the implementation costs are low. Only some modifications may be necessary, in particular, appending the process model by unknown input models. A quasi-steady-state estimator 150 is added to convert the KF state estimate 127 in data compensations variables. These compensation variables vanish if the process is in the steady state, even though KF model is of incorrect gain.
Computer-readable instructions stored on a computer-readable medium are executable by the processing unit 1202 of the computer 1200. A hard drive, CD-ROM, and RAM are some examples of articles including a non-transitory computer-readable medium. For example, a computer program 1218 capable of providing a generic technique to perform access control check for data access and/or for doing an operation on one of the servers in a component object model (COM) based system may be included on a CD-ROM and loaded from the CD-ROM to a hard drive. The computer-readable instructions allow computer 1200 to provide generic access controls in a COM based computer network system having multiple users and servers.
A multilayer process controller-optimizer with nonlinear steady-state model adaptation comprising:
a model based predictive controller running on a computer to receive measurements of controlled variables and disturbance variables from a process to compute manipulated variables to control the process as a function of a dynamical model;
a filter to provide an estimated state of the process to the model based predictive controller;
a steady-state real-time optimizer setting economically optimal steady-state targets to the model-based predictive controller;
a model adaptation tool to modify the nonlinear steady state model to be consistent with process data and to modify a linear dynamic model to be consistent with the nonlinear steady state model in the steady-state; and
a quasi-steady-state estimator to provide estimates of manipulated variables and controlled variables such that they are consistent with a steady state of the process for a given disturbance.
2. The multilayer process controller-optimizer of example 1 wherein the filter comprises a Kalman filter.
3. The multilayer process controller-optimizer of example 2 wherein the Kalman filter provides an unknown input disturbance estimate to compensate for incorrect model gain in the steady-state.
4. The multilayer process controller-optimizer of any of examples 1-3 wherein the quasi-steady-state estimator converts the estimated state of the process into data compensation variables, modifying the manipulated and controlled variables to be consistent with the steady-state of the process when supplied to the model adaptation tool.
5. The multilayer process controller-optimizer of example 4 wherein the compensation variables vanish when the process is in steady state and the compensated variables supplied to the model adaptation tool coincide with process variables.
6. The process controller of any of examples 1 wherein the steady state model comprises a boiler steady state model.
7. The process controller of example 6 wherein the boiler steady state model comprises a linearized dynamic boiler model having a steam developer, a drum, a valve, and a header, with feedback from the header provided to the drum.
8. A method comprising:
receiving measured control variables and disturbance variables from a process to compute, via a model based predictive controller running on a computer, manipulated variables to control the process as a function of a dynamical model;
providing an estimated state of the process to the model based predictive controller via a Kalman filter;
setting economically optimal steady-state targets to the model-based predictive controller via steady-state real-time optimizer using a steady-state model;
modifying the steady state model used by the real-time optimizer via a model adaptation tool to be consistent with process data using parameters tuned by the model adaptation tool;
modifying the (identical) dynamical models used by the model-based predictive controller and by the Kalman filter to be consistent with the steady-state model of the optimizer; and
providing estimates of manipulated variables and controlled variables, via a quasi-steady-state estimator, such that they are consistent with a steady state of the process for a given disturbance to the model adaptation tool.
9. The method of example 8 wherein the Kalman filter provides an unknown input disturbance estimate compensating a possibly incorrect model gain in the steady-state.
10. The method of any of examples 8-9 wherein the quasi-steady-state estimator converts the estimated state of the process into data compensation variables that vanish when the process is in steady state and the compensated variables supplied for model adaptation coincide with process variables.
11. The method of any of examples 8-10 and further comprising providing an optimized operating point for the model based predictive controller via a real time optimizer.
12. The method of example 11 wherein the model based predictive controller comprises a boiler steady state model.
13. A computer readable storage device having instructions to cause a computer system to implement a multi-layer controller-optimizer, the controller-optimizer comprising:
a model based predictive controller to receive measured controlled variables and disturbance variables from a process to compute manipulated variables to control the process as a function of a dynamical model;
a filter to provide an estimated state of the process to the model based predictive controller;
a steady-state real-time optimizer setting economically optimal steady-state targets to the model-based predictive controller;
a model adaptation tool to modify the steady state model to be consistent with process data; and
a quasi-steady-state estimator to provide estimates of manipulated variables and controlled variables such that they are consistent with a steady state of the process for a given disturbance.
14. The computer readable storage medium of example 13 wherein the steady state model is nonlinear and wherein the model adaptation tool modifies the nonlinear steady state model to be consistent with process data and modifies a linear dynamic model to be consistent with the nonlinear steady state model in the steady-state.
15. The computer readable storage medium of example 14 wherein the filter comprises a Kalman filter that provides an unknown input disturbance estimate to compensate for incorrect model gain in the steady-state, and wherein the quasi-steady-state estimator converts the estimated state of the process into data compensation variables, modifying the manipulated and controlled variables to be consistent with the steady-state of the process when supplied to the model adaptation tool.
Although a few embodiments have been described in detail above, other modifications are possible. For example, the logic flows depicted in the figures do not require the particular order shown, or sequential order, to achieve desirable results. Other steps may be provided, or steps may be eliminated, from the described flows, and other components may be added to, or removed from, the described systems. Other embodiments may be within the scope of the following claims.
Number | Date | Country | Kind |
---|---|---|---|
13197035.2 | Dec 2013 | EP | regional |