Numerically Efﬁcient Fuzzy MPC Algorithm with Advanced Generation of Prediction—Application to a Chemical Reactor

: In Model Predictive Control (MPC) algorithms, control signals are generated after solving optimization problems. If the model used for prediction is linear then the optimization problem is a standard, easy to solve, quadratic programming problem with linear constraints. However, such an algorithm may offer insufﬁcient performance if applied to a nonlinear control plant. On the other hand, if a model used for prediction is nonlinear, then non–convex optimization problem must be solved at each algorithm iteration. Then the numerical problems may occur during solving it and the time needed to calculate the control signals cannot be determined. Therefore approaches based on linearized models are preferred in practical applications. A fuzzy algorithm with an advanced generation of the prediction is proposed in the article. The prediction is obtained in such a way that the algorithm is formulated as a quadratic optimization problem but offers performance very close to that of the MPC algorithm with nonlinear optimization. The efﬁciency of the proposed approach is demonstrated in the control system of a nonlinear chemical control plant—a CSTR (Continuous Stirred–Tank Reactor) with van de Vusse reaction.


Introduction
The Model Predictive Control (MPC) algorithms during the calculation of the control signals use the model of the control plant directly, predicting the behavior of the process.Thanks to such an approach they can be successfully applied in control systems of control plants with difficult dynamics (delay, inverse response), with constraints and for MIMO (Multiple-Input Multiple-Output) processes, see for example, References [1][2][3][4][5][6][7].
The simplest MPC algorithms are based on linear control plant models; see for example, References [1,8].Unfortunately, if a control plant is nonlinear and the MPC algorithm should operate for different operating points, as in control system structures with steady-state setpoint optimization (see e.g., References [7,9,10]), then the algorithm based on a linear model may be insufficient in terms of control performance.In such a case operation of the control system can be usually improved using the MPC algorithm based on a nonlinear model.
On the other hand, if a nonlinear process model is used in the MPC algorithm directly (such algorithm is called NMPC-Nonlinear MPC), then the optimization problem solved at each algorithm iteration to generate the control signals is a nonlinear optimization problem; see for example, References [11][12][13].Thus, it is usually non-convex, hard to solve, and time-consuming computational task.Moreover, the time needed to find the solution cannot be foreseen in advance.One of the ways to cope with this problem is to apply so called fast NMPC algorithms in which the solution is generated faster than in the standard approach, but unfortunately, at the expense of suboptimality; see for example, References [14][15][16].One of such approaches is the explicit one in which most of calculations are done off-line; see for example, References [17][18][19].It is an interesting approach and it is optimal if the linear model is used [20][21][22].However it has a serious drawback-the complexity of the controller grows significantly with the number of inequality constraints in the problem.When the fuzzy models are used, then of course the nonlinear optimization can be applied in the algorithm.However the form of the model is such that easier to solve algorithms can be formulated.Among the algorithms exploiting the structure of the fuzzy models there is a group which is based on Linear Matrix Inequalities (LMIs); see for example, References [23][24][25][26][27].The other group is based on the classical fuzzy Takagi-Sugeno approach in which a few algorithms based on linear models are used to form the fuzzy controller; see for example, References [28,29].
The other approach consists in online linearization of the process model at each MPC algorithm iteration; see for example, References [7,[30][31][32][33][34][35][36].Then prediction is formulated in such a way that it is linear relative to decision variables in the optimization problem solved at each iteration of the algorithm.Such form of the prediction leads to the formulation of the optimization problem as the quadratic one.In the linearization-based algorithms the prediction can be based on a classical linearization or a clever method of prediction generation can be used, exploiting structure of the nonlinear model the algorithm is based on.In the algorithms using linearization of the fuzzy Takagi-Sugeno model, described in References [31,34], both-the free response and the dynamic matrix were obtained using the model obtained after the linearization.In References [32,36] the model obtained after linearization was used to obtain the dynamic matrix whereas the (classical) free response was calculated using the nonlinear model.
The MPC algorithms proposed in the article are an extension of the algorithm presented in Reference [36] and, like their predecessor, are based on two models-a nonlinear model and its, easy to obtain, fuzzy approximation.The nonlinear model can have any form of the model generating outputs on the base of input signals.This model is used to obtain an advanced (based on the previously calculated trajectory of the future control signals) free response of the process prediction.The easy-to-obtain fuzzy model is used to derive the dynamic matrix describing influence of the future, calculated control signals on prediction.The prediction has such a form that the proposed algorithms are formulated as the standard quadratic programming problem.Thus, the algorithms combine the computational simplicity of the MPC algorithms based on linear models with control performance almost as good as the one offered by the algorithm with nonlinear optimization.The prediction can be also improved iteratively, if needed.Iterative prediction improvement, though slightly different in details, is also used in the interesting iterative-learning-based approaches to batch control, see for example, References [37][38][39].
Standard MPC algorithms based on linear and nonlinear models are described in the next section.In Section 3 the MPC algorithms based on fuzzy and nonlinear models are proposed, and mechanisms of their improvements and simplifications are detailed.A simulation example of the application of the proposed algorithms to a nonlinear chemical reactor with the inverse response is presented in Section 4, illustrating the efficiency of the proposed approach.The article is concluded in the last section.

Model Predictive Control Algorithms
Future control signal trajectories are generated in the MPC algorithms in such a way that predicted, many sampling instants ahead, future behavior of the control plant fulfills assumed criteria.It is usually formulated as an optimization problem in which, it is demanded that a performance function is minimized subject to the constraints put on control and output signals.The performance function takes into consideration future, predicted control errors and the shape of control signals.
Thus, the optimization problem solved by the MPC algorithm in each iteration has, most often, the following form [1,4,5,7]: subject to: where k+j|k is a value of the jth output for the (k + i)th sampling instant predicted at the kth sampling instant using a control plant model, ∆u m k+i|k are future changes in manipulated variables, κ j ≥ 0 and λ m ≥ 0 are weighting coefficients for the predicted control errors of the jth output and for the changes of the mth manipulated variable, respectively; p and s denote prediction and control horizons, respectively; n y , n u denote number of output and manipulated variables, respectively; ∆u min , ∆u max , u min , u max , y min , y max are vectors of lower and upper bounds of changes and values of the control signals and of the values of output variables, respectively; κ i has p elements, Λ i has s elements.The reference trajectories are grouped in the following vector: y = y 1 , . . ., y n y T , y j = y j k+1|k , . . ., y j k+p|k .(10) It is often assumed that reference trajectories are constant on the prediction horizon, then the vectors y j (each composed of p elements) have the following form: where y j k is a setpoint value for the jth output.As a solution to the optimization problem ((1)-( 4)) the optimal vector of control action is obtained in such a way that future, predicted control errors are minimized (the first component of the performance index), control signals do not vary too much (the second component) and the constraints on control and output signals are fulfilled.The ∆u m k|k elements from the vector ∆u are applied in the control system and the algorithm passes to the next iteration.The predicted values of output signals y j k+j|k are derived using a control plant model the MPC algorithm is based on.

MPC Algorithms Based on Nonlinear Models (NMPC)
Assume that we have a nonlinear process model: where y k−i = y  (12) directly in the optimization problem ((1)-( 4)), then the prediction takes the form of the following formulas, passed to the optimization problem as a set of equality constraints: where u k+i|k = u 1 k+i|k , . . ., u n u k+i|k T is a vector containing future control values, depending on decision variables from the vector ∆u and where T is a vector of recently measured output values; it is assumed that d k is the same for all instants in the prediction horizon-an approach proposed in the Dynamic Matrix Control (DMC) algorithm and therefore called the DMC-type disturbance model; see for example, Reference [7].
Unfortunately, the optimization task with the prediction (13), based on a nonlinear model, is not a quadratic optimization task.The optimization problem ((1)-( 4)) becomes, in general, non-convex nonlinear optimization problem.Solving such a problem is difficult and time-consuming task, there is no guarantee to find a global solution and time needed to obtain solution cannot be estimated in advance.Different kinds of nonlinear process models can be used in the algorithm, but they are exploited in a similar way, see for example, References [13,[40][41][42]; such algorithms will be referred to as Nonlinear MPC (NMPC).Due to problems caused by formulation of NMPC algorithms, in practice MPC algorithms based on linear approximations of process models, obtained at each iteration of the algorithm are considered.Such linear approximation is used to formulate the, easy to solve, quadratic optimization problem [35].Such an optimization problem is also used in the MPC algorithms based on linear models, therefore now their formulation will be reminded.In the next section, the proposed algorithms, based on an advanced approximation of the nonlinear model, will be proposed.

MPC Algorithms Based on Linear Models (LMPC)
In the case of linear models the superposition principle holds, therefore the vector of predicted output values y can be decomposed into two parts: where y is called the free response of the plant, because it contains future values of output signals calculated assuming that the control signal does not change in the future -it describes influence of the past values of control signals; form of the free response depends on the model used for prediction, see for example, References [1,4,5,7].The second component in the formula (15) depends on future (to be calculated) changes of the control signals and is called the forced response; the matrix A, called the dynamic matrix, is given by the following formula: where a j,m i are the control plant step response coefficients describing influence of the mth input on the jth output; it can be shown that the dynamic matrix has the same form regardless a type of linear models MPC algorithms are based on [7].
After applying the prediction based on a linear model ( 15) the performance function ( 1) is transformed to a function which depends quadratically on decision variables ∆u: After using prediction (15) also in the constraints (3), all constraints depend linearly on decision variables.Thus, the optimization problem (( 1)-( 4)) becomes an, easy to solve, standard linear-quadratic optimization problem.Unfortunately, application of an LMPC algorithm to a nonlinear process may result in unsatisfactory control performance, especially if operation in different operating points is demanded.Therefore, the fuzzy MPC (FMPC) algorithm being a combination of the LMPC and NMPC algorithms was proposed in Reference [36].Now it will be improved by appropriate usage of the nonlinear model.Formulation of the proposed algorithm is presented in the next section.It still uses two models the original, nonlinear one is used to calculate the free response in an advanced way.The fuzzy one, composed of a set of a few step responses, is applied to calculate the dynamic matrix, which is updated at each iteration of the algorithm.

Fuzzy MPC Algorithm with Advanced Generation of Prediction
In order to avoid algorithm complications resulting from the need to solve a nonlinear optimization task in each iteration, one can use approximation of the process model carried out in each iteration.Using an easy-to-obtain fuzzy model to get the dynamic matrix and a nonlinear model to obtain the advanced free response leads to prediction which can be generated in a relatively simple way, is linear relative to decision variables, and mimics the nonlinearity of the process very well.Next, in each iteration of the algorithm, an optimization problem ((1)-( 4)) which uses this prediction is formulated as a quadratic optimization problem.Such a problem is easy to solve using commonly available optimization routines.Now it will be described how to obtain such an advanced prediction.

Generation of the Dynamic Matrix
The dynamic matrix, needed to obtain forced response in the prediction can be calculated using an easy-to-obtain fuzzy Takagi-Sugeno model which has local models in the form of step responses [34].Design process of such a model is very simple, because it is sufficient to collect a few sets of step responses (near a few operating points).These step responses can be obtained directly on the control plant or using a nonlinear model of the process.Next, the premises of the model should be formulated using expert knowledge, and then tuned, for example, by means of a fuzzy neural network [7].Thus, the model has the following form: and . . .and and . . .and where y j y k is the value of j y th output variable at the kth sampling instant, u j u k is the value of j u th manipulated variable at the kth sampling instant, are the coefficients of step responses in the f th local model, j y = 1, . . ., n y , j u = 1, . . ., n u , f = 1, . . ., l, l is number of fuzzy rules.The output values of the model ( 20) can be calculated using the following formula: where and w f are the normalized firing strengths of the fuzzy rules calculated using fuzzy reasoning, see for example, References [43,44].Note that one can consider the model ( 21) as the step response describing behavior of the control plant near the current operating point.This model is then used at each sampling instant of the proposed algorithms to obtain a new, updated dynamic matrix:

Generation of the Free Response
The basic idea of the free response generation for an MPC algorithm is to use a non-linear process model assuming that the control signals do not change over the entire prediction horizon-a classic free response; see for example, Reference [36].In the case of the proposed algorithm, future control increments calculated in the algorithm in the previous iterations are also used when the free response is calculated.Thus, more information is exploited to obtain the improved prediction.Assume that future control values are decomposed as follows: where ǔm k+i|k can be interpreted as a corrections of the control signal u m k+i|k−1 obtained in the last (k − 1)st iteration.Similarly, future control increments will be given by the formula: Assume In this case, using the nonlinear model, the free response is iteratively derived as follows: • First, the nonlinear model ( 12) is used to obtain • Next, the values y k+1 are used when calculating the output values y k+2 for the next sampling instant: • For the ith iteration, using the values y k+1 , . . ., y k+i−1 one obtains: • After taking into account the estimation of unmeasured disturbances d k = y k − y k|k−1 , containing also influence of modeling errors, the final form of the formula describing the elements of the free response is obtained:

Formulation of the Optimization Problem
Now the dynamic matrix (22) will be used to predict the influence of control corrections on the control plant outputs.Therefore, after using the free response (30) and the dynamic matrix (22) one obtains the following prediction: Due to the change of decision variables, optimization task ((1)-( 4)), which is solved by the control algorithm in each iteration can be written as: subject to: where Note that the performance function in (32) depends quadratically on decision variables ∆ ǔ and all constraints depend linearly on decision variables.Thus, a standard, easy-to-solve linear-quadratic optimization problem was obtained.
Remark 1.In the proposed algorithm, one can also use a slightly modified form of the performance index, in which the second component depends only on the corrections ∆ ǔ of the control signals determined in the previous iteration of the algorithm, that is, It should be emphasized, however, that such modification causes a change in the meaning of the λ parameter in relation to the classical formulation.Consequently, algorithms with a modified form of the performance function generate faster responses, but influence of the λ parameter on system robustness becomes significantly limited.

Iterative Improvement of the Prediction
In practice, the proposed approach gives results very similar to those offered by the NMPC algorithm.However it is possible to further improve the control quality, if necessary, thanks to iterative improvement of the prediction determined in the algorithm.Then smaller corrections of control trajectories in each subsequent iteration are obtained, what is beneficial because impact of them on the process outputs is predicted using the dynamic matrix instead of a more accurate non-linear process model.
The first, internal iteration of the algorithm is the same as in the basic version of the algorithm.After receiving the future control trajectories, one can either apply them in the process or try to improve the resulting solution.In such a case, the second internal iteration of the algorithm should be executed.Denote the values of future control signal trajectories obtained in the first iteration as u m k+i|k(1) and future control increments as ∆u m k+i|k(1) .In subsequent iterations, because subsequent control signal trajectories are available, future control values are decomposed as follows: where i w -index of the internal iteration of the algorithm, i w = 2, 3, . ... Similarly, future control increments are decomposed: Assume u k+i|k(i w −1) = u 1 k+i|k(i w −1) , . . ., u n u k+i|k(i w −1) Thus, using the non-linear process model, the free response is iteratively derived as follows: • First, the model is used to obtain values • Next, the values y k+1 are used to calculate the output values y k+2 for the next sampling instant: • For the ith iteration, using the values y k+1 , . . ., y k+i−1 one obtains: • After taking into account the estimation of unmeasured disturbances d k = y k − y k|k−1 , containing also influence of modeling errors, like in (30), the final formula describing the elements of the free response is obtained: As in the basic algorithm, the dynamic matrix is used to predict the influence of control corrections on the control plant outputs.Thus, after using the free response (44) and the dynamic matrix (22) one obtains the following prediction: where ∆ ǔ = ∆ ǔ1 , . . ., ∆ ǔn u T , ∆ ǔm = ∆ ǔm k+1|k(i w ) , . . ., ∆ ǔm k+s−1|k(i w ) .(46) This prediction should then be used to formulate the optimization task in the same way as in the basic algorithm.After solving this task, one can either use the result to control the process or to perform another internal iteration of the algorithm.
Note that the lower the values of the corrections of the future control trajectories are obtained, the better the prediction is obtained, because it will be closer to the one obtained fully using a nonlinear model.The number of internal iterations of the algorithm can therefore be selected depending on how large the corrections of the future control trajectories are (provided that the time for generating control signals has not expired).If these adjustments become small enough, one should stop doing further internal iterations.
Due to the lack of proof of the convergence of the described procedure, it is advisable to check after each internal iteration whether the performance function in the problem solved by the algorithm and control corrections decrease.If there is no improvement in the value of the performance function (especially when there is a large increase of it) or control adjustments begin to increase the internal iterations should be interrupted.

Fast Generation of the Control Action-Analytical Approach
Note that if in each iteration of the proposed approach the following optimization problem without constraints is solved: then it has the following solution given by the analytical formula: where ∆ − → u contains elements of future control increments trajectory, corrections of which are collected in the vector ∆ ǔ.
Remark 2. If one uses the performance index (37), that is, the modified version: then the following analytical formula should be used: It should be once again emphasized, however, that this modification changes the meaning of the parameter matrix Λ comparing to the classical formulation and algorithms with a modified form of the performance index generate faster responses than the algorithm using the control law (47), but influence of the λ parameter on system robustness becomes significantly limited.
Due to the fact that the dynamic matrix A k changes, in general, in every iteration, then in each iteration of the algorithm the formulas (47) (or ( 49)) allowing to calculate the control action should be used.As a consequence, appropriate rows of the matrix (corresponding to the control increments for the current sampling instant ∆u m k|k ) should be calculated in each iteration of the algorithm.

Disturbance Measurement Utilization
The proposed algorithms are formulated in such a way that the mechanisms of disturbance measurement utilization presented in Reference [45] can be applied in them easily.The proposed algorithms are based on two models, therefore two such mechanisms can be applied.They will be now shortly reminded.

Employing Fuzzy Model
The first method consists in extending local models of the fuzzy model ( 20) using the models of disturbance influence on the control plant in the form of step responses.It results then in extending the prediction (31) with a term dependent on measured disturbance; for details see References [34,45]: where Then the following performance function in the optimization problem ( 1)-( 4) should be now used: or the modified one: In the example presented in the next section, this mechanism was simplified by assuming that only one model of disturbance influence on the process is obtained, that is, e j, f i = e j i for f = 1, . . ., l, then the prediction transforms to the following formula: where .and the matrix E is constant in each iteration, what simplifies the calculations.Thus, disturbance measurement utilization mechanism becomes actually the same as in the DMC algorithm.

Employing Nonlinear Model
The second approach assumes that the disturbance is one of the inputs of the model used to obtain the free response: where u d k−i is value of disturbance in the (k − i)th sampling instant.Then the nonlinear process model ( 12) becomes: Then it is sufficient to use measured values of the disturbance during calculation of the free response to include this information in the prediction.During calculation of the free response, as future values of the disturbance its estimates can be used or, if one does not have any, they should be assumed unchanged, like in the case of classical free response.

Example
The control plant is a nonlinear, isothermal CSTR in which the van de Vusse reaction takes place.The steady-state characteristic of the control plant is depicted in Figure 1.The CSTRs in which the van de Vusse reaction takes place are a popular benchmark due to their nonlinearity and difficult dynamics, willingly used to test newly developed control algorithms; see for example, References [46][47][48][49][50][51].The process model of the reactor is composed of two composition balance equations; see for example, Reference [52]: where C A , C B are the concentrations of components A and B, respectively, F is the inlet (and also outlet) flow rate, V is the volume in which the reaction takes place (assumed constant and V = 1 L), C Af is the concentration of component A in the inlet flow stream (if not declared otherwise, it is assumed that C Af = 10 mol/L).The values of parameters are: The output variable is the concentration C B of substance B, the manipulated variable is the inlet flow rate F, C Af is the disturbance variable.The control plant has the inverse response, thus it is a control plant difficult to control using a standard algorithm.Therefore, it is natural to use an MPC algorithm in this case.

Experiments
For the considered control plant a few MPC algorithms were designed-an NMPC one based on the nonlinear model and nonlinear optimization, an LMPC one based on a linear model in the form of a step response (of DMC type) and the proposed FMPC algorithms using a fuzzy model, different methods of prediction improvements, and different forms of the performance index (FMPC1-with classical performance index, and FMPC2-with the modified performance index).The fuzzy model used in the FMPC algorithms is composed of three step responses obtained near the following operating points: The model used to obtain the dynamic matrix is thus composed of three rules; the membership functions, same as in Reference [34], chosen after analysis of the steady-state characteristic of the control plant, are shown in Figure 2. The simulation experiments were done using Matlab.The sampling time equal to T s = 3.6 s was assumed; the values of tuning parameters were as follows: prediction horizon p = 70, control horizon s = 35, and at the beginning weighting coefficient λ = 0.001.During the experiments operation of control systems with NMPC, LMPC and FMPC algorithms was compared.The LMPC algorithm was designed using the step response obtained near the R2 point.The FMPC algorithms use two models: nonlinear one in the form of state equations, to generate a free response and the fuzzy one with local models in the form of step responses, to obtain the dynamic matrix.
Responses of the control system to changes in the setpoint and to the change of the disturbance by 10% in the 6th minute of the experiment are shown in Figure 3.If the setpoint was changed to C B1 = 1 mol/L, responses obtained in the control system with the FMPC1 algorithm (blue lines in Figure 3) are very close to those obtained with NMPC algorithm with nonlinear optimization (red lines in Figure 3).In both cases there is almost no overshoot and both algorithms work much better than their LMPC counterpart (magenta lines in Figure 3).In the latter case there is a significant overshoot.Moreover, settling time is much longer than in the case of NMPC and FMPC algorithms.The FMPC1 algorithm is slightly slower than the NMPC one, whereas the FMPC2 is practically as fast as NMPC.In the case when setpoint changed to C B2 = 1.25 mol/L, the responses obtained with the FMPC algorithms are even faster than the one generated with NMPC algorithm.In the case of all the algorithms the setpoint is reached without overshoot, but LMPC works much slower than the algorithms based on nonlinear models.
Disturbance responses obtained near C B = 1 mol/L with FMPC and NMPC algorithms are almost the same.There is no overshoot which is present in the response of the LMPC algorithm.The algorithms based on nonlinear models slightly faster compensate the change in disturbance.In the case of operation near C B = 1.25 mol/L, the NMPC is the fastest in compensation of the disturbance change.The FMPC1 is slightly slower and the LMPC is much slower than its counterparts.
It can be noticed that the FMPC algorithms offer control performance close to the one which can be obtained with the NMPC algorithm and with nonlinear optimization.In one case (setpoint change to C B2 = 1.25 mol/L) they are even faster.It should be, however, emphasized that the FMPC algorithms use reliable quadratic programming routine to generate control action.
Duration of action of the researched algorithms in the experiments depicted in Figure 3 is compared in Table 1.For each algorithm and for each setpoint five measurements of duration were done (time needed to simulate the control plant was subtracted) and averaged.Then these average durations were summed in the last row of the table.Both FDMC algorithms work much (around 20 times) faster than the NMPC algorithm.There was also done an experiment with λ = 0.0001 (10 times smaller than in the first experiment; Figure 4).All the algorithms work now faster; the control action in all cases is more aggressive, but the relations between FMPC, NMPC, and LMPC algorithms remain unchanged; they are the same as in the previous experiment, for λ = 0.001.However, as the λ parameter is closer to zero, the differences between FMPC1 and FMPC2 algorithms became much smaller comparing to the previous experiment.The FMPC1 algorithm is practically as fast as the FMPC2 one.Such a phenomenon is reasonable, because for λ = 0 both performance indexes (32) and (37) are the same.Thus, the closer value of the λ coefficient to 0 is, the closer responses generated with FMPC1 and FMPC2 are.
There were also done experiments with shortening the control horizon s (Figures 5 and 6).Note, that the smaller the control horizon is the less number of decision variables in the optimization problem.Therefore, it is simpler to solve and can be solved faster.In the case of both algorithms FMPC1 and FMPC2, with different values of λ for many values of the control horizon the responses generated with the algorithms do not change too much.Thus, the control horizon can be shorted significantly.In the considered examples for FMPC1 algorithm the responses generated for s = 35 and for s = 10 are almost the same; in the case of control system with FMPC2 algorithm-the responses generated for s = 35 and for s = 5 are almost the same.Further decreasing of the control horizon brings changes in the responses.
In the case of the control system with FMDC1 algorithm, for s = 5 the disturbance compensation near C B = 1.25 mol/L becomes faster, but unfortunately achieving the setpoint C B1 = 1 mol/L lasts longer.Further decrease of the control horizon to s = 1 causes that the disturbance compensation near C B = 1.25 mol/L becomes even faster as well as reaching the setpoint C B2 = 1.25 mol/L, however at the cost of slower response to the setpoint change to C B1 = 1 mol/L and worsened disturbance compensation near C B = 1 mol/L.In the control system with FMDC2 algorithm, for s = 2 and s = 1 the disturbance compensation near C B = 1.25 mol/L becomes slightly faster, but unfortunately achieving both the setpoints C B1 = 1 mol/L and C B2 = 1.25 mol/L lasts longer.Moreover disturbance compensation near C B = 1 mol/L is now slower.Thus, in this case, as in the case of FMPC1 algorithm, decreasing the control horizon should be done also carefully and there is also a threshold which should not be crossed in order to avoid control performance deterioration.To sum up, during designing of an algorithm it is advisable to check if the control horizon can be decreased (and optimization problem solved by the algorithm simplified).However, it should be done carefully, because for too short control horizon control performance can got worse.The mechanisms of disturbance measurement utilization were used in the next experiments.Both FMPC algorithms generated similar responses.The first method of disturbance measurement utilization (red lines in Figures 7 and 8) is based on the same approach as in the standard DMC algorithm, the second one employs the nonlinear process model (magenta lines in Figures 7 and 8).Disturbance compensation near C B = 1.25 mol/L is almost the same in the case of both methods; differences in responses are really small.It is because the model of disturbance influence on the control plant for the first method was obtained near this output value.Application of both methods of disturbance measurement utilization near C B = 1 mol/L causes reduction of the maximal control error by around 50% comparing to the case when disturbance measurement was not exploited (blue lines in Figures 7 and 8).Both methods offer very good disturbance compensation.However, in the case of the one based on the nonlinear model (magenta lines in Figures 7 and 8) the output value achieves the setpoint slightly faster than the one based on the linear model (red lines in Figures 7 and 8) while changes of the control signal are smaller.

Conclusions
The numerically efficient FMPC algorithms proposed in the article use the easy-to-obtain fuzzy model to calculate the dynamic matrix, which describes the influence of future control action on prediction, and the nonlinear to derive the free response of the control plant in a clever way which allows obtaining very good prediction.As a result, the algorithms offer control performance very close to the one offered by the NMPC algorithm, based on the nonlinear optimization.The FMPC algorithms, however, despite they are also based on nonlinear models, thanks to a clever way of prediction generation are formulated as the easy-to-solve quadratic optimization problem.
Modifications of the algorithms proposed to improve their operation can be applied by a system designer if needed.Thus the algorithm can be tailored to a particular application.Thus, it can offer a good balance between control performance which is needed in the problem at hand, and control algorithm complication.One can adjust the algorithm to a given problem so the computational demand is as small possible.
∆u d k , ∆u d k−1 , ∆u d k−2 , . . ., ∆u d k−p z +2 , = 1, . . ., p z , j = 1, . . ., n y , f = 1, . . ., l)are the coefficients of step responses to the change of disturbance, in the f th local model, u d k−i are values of the disturbance measured in the (k − i)th sampling instant.

Figure 1 .
Figure 1.Steady-state characteristic of the control plant.

Figure 2 .
Figure 2. Membership functions of the fuzzy model used to obtain the dynamic matrix.

Figure 3 .
Figure 3. Responses of the control system to changes in the setpoint to C B1 = 1 mol/L and C B2 = 1.25 mol/L and to the change of the disturbance by 10% in the 6th minute of the experiment; λ = 0.001; Nonlinear Model Predictive Control (NMPC)-red lines, linear MPC (LMPC)-green lines, fuzzy MPS (FMPC)1-blue lines, FMPC2-magenta lines.

Figure 4 .
Figure 4. Responses of the control system to changes in the setpoint to C B1 = 1 mol/L and C B2 = 1.25 mol/L and to the change of the disturbance by 10% in the 6th minute of the experiment; λ = 0.0001; NMPC-red lines, LMPC-green lines, FMPC1-blue lines, FMPC2-magenta lines.

Figure 5 .
Figure 5. Responses of the control system with FMPC1 algorithm and λ = 0.001 to changes in the setpoint to C B1 = 1 mol/L and C B2 = 1.25 mol/L and to the change of the disturbance by 10% in the 6th minute of the experiment; s = 35-black lines, s = 10-green dashed lines, s = 5-magenta lines, s = 1-blue lines.

Figure 6 .
Figure 6.Responses of the control system with FMPC2 algorithm and λ = 0.001 to changes in the setpoint to C B1 = 1 mol/L and C B2 = 1.25 mol/L and to the change of the disturbance by 10% in the 6th minute of the experiment; s = 35-black lines, s = 5-green dashed lines, s = 2-magenta lines, s = 1-blue lines.

Figure 7 .
Figure 7. Responses of the control system with FMPC1 algorithm and λ = 0.0001 to changes in the setpoint to C B1 = 1 mol/L and C B2 = 1.25 mol/L and to the change of the disturbance by 10% in the 6th minute of the experiment; mechanism of disturbance measurement utilization: not used-blue lines, based on the linear model-red lines, based on the nonlinear model-magenta lines.

Figure 8 .
Figure 8. Responses of the control system with FMPC2 algorithm and λ = 0.0001 to changes in the setpoint to C B1 = 1 mol/L and C B2 = 1.25 mol/L and to the change of the disturbance by 10% in the 6th minute of the experiment; mechanism of disturbance measurement utilization: not used-blue lines, based on the linear model-red lines, based on the nonlinear model-magenta lines.

Table 1 .
Average duration of action of the algorithms in the experiments depicted in Figure3.