Abstract

This paper presents and validates a new proposal for effective speed vector control of induction motors based on linear Generalized Predictive Control (GPC) law. The presented GPC-PI cascade configuration simplifies the design with regard to GPC-GPC cascade configuration, maintaining the advantages of the predictive control algorithm. The robust stability of the closed loop system is demonstrated by the poles placement method for several typical cases of uncertainties in induction motors. The controller has been tested using several simulations and experiments and has been compared with Proportional Integral Derivative (PID) and Sliding Mode (SM) control schemes, obtaining outstanding results in speed tracking even in the presence of parameter uncertainties, unknown load disturbance, and measurement noise in the loop signals, suggesting its use in industrial applications.

1. Introduction

The Model Predictive Control (MPC) groups a set of controllers which are based on the model of the system and the known future reference for optimal control signal calculation. The operational principle of predictive control is to calculate in advance the control signal required by the system, when the future input reference that will be applied is known beforehand [1]. In this sense, the system is able to react to the input reference, anticipating its changes and avoiding the effects of delay in system response [2]. There are countless applications in industry where the input reference is known beforehand, such as robotic systems, and machine tools. Therefore, in all these systems predictive control algorithms can be implemented. Since Clarke et al. proposed the design principles of Generalized Predictive Control [3, 4], many authors have used this advanced technique for induction motor control in the last two decades. There is extensive research related to the application of predictive controllers in electric drives, and, for this reason, predictive algorithms compete with other advanced control techniques such as fuzzy control [5], sliding mode control [6, 7], and nonlinear control [8].

Predictive algorithms are often implemented using two or more GPC blocks to control several loops of the electrical machine, and usually they are connected in cascade form [911]. Frequently, only one predictive regulator for the control of the main variable of the machine is implemented, such as speed [1215] or position [16], while the rest of the variables are controlled with classical algorithms, usually PI/PID and hysteresis comparators. Some authors use more complex formulations in order to control several variables of the engine, such as the multivariable GPC [17], and others implement a predictive algorithm in the current loops [18, 19], using the classic PI regulators for the main variables such as speed and rotor flux.

All predictive control schemes are based on the minimization of a cost function. In the GPC this implies solving a quadratic programming problem in the case where physical constraints are introduced in the optimization. If no constraints are considered, an analytical solution can be obtained. In this sense, it is known that all real systems have constraints, such as saturation values, frequencies, and time limits of the actuators [13, 16, 20]. Hence, a numerical method is required to solve the quadratic programming problem, which implies a high computation cost for the processor where the controller is implemented. For this reason, the sample period of a predictive controller is usually greater than other types of controllers [9], which limit its applicability to quick response systems. Due to this issue, some works do not consider constraints, implementing the analytical solution with acceptable results [15, 17]. Moreover, constraints can be considered after the predictive control law is obtained [15].

In addition, even if the delay time of the electric motor systems is usually small, sometimes it can be long enough so that its compensation improves significantly the system behaviour [21], and in this way it can be used in precision applications. In this sense, the predictive algorithms allow to compensate easily the delay time of the controlled system, because this aspect is included in the implementation of these algorithms.

Finally, the robustness of the GPC regulator is another aspect included by some authors in the controller design [16, 20], obtaining relevant results, but with an arduous controller design process. In this sense, it is known that all closed loop controlled systems have inherent robustness [22] that in the presented GPC speed controller is enough to overcome the typical uncertainty cases of induction motor, without having to design an explicit robust controller nor to include any method for the adaptive identification of the motor parameters.

After all these considerations and taking into account the complexity in the design of predictive controllers and their important computational costs, this paper presents an induction motor speed indirect vector control that combines the GPC algorithm with PI regulators, proposing a simple, robust, and effective design which provides better dynamical behaviour than other speed regulators such as other GPC, PID, and Sliding Mode (SM). The rest of the paper is organized as follows. In Section 2 the design of the proposed GPC speed regulator is presented, detailing the objectives, the dynamics of the induction motor, the design of the controller and its tuning, and finally its robust stability. Section 3 contains a brief description of the used experimental platform and the simulation and experimental tests carried out by implementing the proposed regulator. Comparative results are given of the presented speed GPC regulator with other GPC, PI/PID, and SM speed controllers. Finally, Section 4 summarizes the most important ideas.

2. Linear GPC Speed Controller for Induction Motor

2.1. Objective and Description

The objective of this paper is to demonstrate experimentally that the GPC algorithm can be used in speed regulation of induction motors in an effective way with a simple, robust, and stable design, offering faster speed tracking than other algorithms such as PID or SM, allowing being implemented in industrial applications.

The proposed speed regulator combines a GPC scheme with two PI current regulators. The dynamics of the induction motor is regulated using a distributed control in cascade form: the stator, (1), (2), is regulated with the PI current regulators and the rotor, (4), (5), with a GPC speed controller. The PI current regulators are very effective, simple, and provide fast response, offering similar results to the ones obtained by implementing a GPC-based current regulator. These are combined with a Space Vector Pulse Width Modulation (SVPWM), which is a standard modulator that is implemented in many commercial Digital Signal Process (DSP) processors, even in many low-cost processors. The proposed GPC controller is designed taking into account the first order transfer function (mechanical equation, (4), (5)) of the induction motor, considering the delay time, but without considering the constraints. Therefore, it is a simpler approach to GPC-based controllers than previous works.

2.2. Induction Motor Dynamics

The dynamics of the motor can be described by the stator voltage equations and the rotor flux equation, expressed all in the - synchronous rotating reference frame [23], assuming that the quadrature component of rotor flux is null, , and consequently the rotor flux is formed only by its direct component, :

The employed symbols are described as follows::viscous friction coefficient,:moment of inertia,:magnetizing inductance,:stator inductance,:rotor inductance,:rotor resistance,:stator resistance,:number of poles,:leakage factor,:electromagnetic torque,:load or disturbance torque,:synchronous rotating speed,:mechanical rotor speed,:electrical rotor speed,:rotor flux vector,:direct and quadrature components of the rotor flux vector,:stator current vector,,:direct and quadrature components of the stator current vector,:stator voltage vector,,:direct and quadrature components of the stator voltage vector.

2.3. GPC Speed Controller Design

Figure 1 shows the speed vector control diagram of an induction motor, where the block is the proposed GPC controller for the speed loop whose algorithm will be detailed later. The two PI blocks are a pair of PI controllers for the two current loops. Their function is to convert the and current commands in their respective and voltage commands. This conversion is necessary because the inverter needs voltage commands, instead of current commands. The VSI block is the three-phase Voltage Sourced Inverter, block gets the space vector in the - synchronous rotating reference frame from the , and motor stator three-phase currents measured with Hall effect sensors, using Park’s transformation [23, 24], while the block makes the reverse Park’s transformation. It should be noted that this transformation uses the rotor flux angular position, , and therefore this angle is calculated using the indirect method, obtained by integrating the synchronous speed.

Next, the dynamics of the induction motor system will be calculated in order to design the GPC.

As it is known that the synchronous speed can be expressed as follows: where is the slip speed, and is the rotor speed. As it is assumed that the direct and quadrature components of the rotor flux are decoupled, then , and , and consequently the rotor flux is formed only by the direct component [23, 24]. In this context, the slip speed is obtained from the following: where the rotor flux is calculated by (3), while the rotor speed is proportional to the mechanical rotor speed, which is measured using a incremental encoder: From diagram of Figure 1 it is possible to obtain the external representation of the induction motor (Figure 2).

Usually the rotor flux is held constant, fixing the rotor flux current command () to a constant value, that is, ; see Figures 1 and 2. Then the pole associated to the electrical time constant can be neglected and consequently (3) in a steady state takes the following expression:

The electromagnetic torque of the induction motor in steady state, taking into account that torque and rotor flux current components are decoupled in` the - rotating reference frame, (5), also can be expressed as follows [24]: where is the torque constant (12) and is the rotor flux:

Considering that the SVPWM and the VSI modules have neither dynamics nor gain in diagram of Figure 1, it is possible to obtain the following transfer function: where the mechanical time constant and the rotor electrical time constant are, respectively,

Now, if the dynamics associated to the two current loops are neglected, because they are much faster than the rest, the following second order transfer function of the induction motor is obtained as follows: where is the delay time of the induction motor.

Taking into account the consideration to obtain (10) from (3), Figure 2, and also considering that the dynamics associated to the rotor electrical time constant is much faster than the mechanical time constant, then the electrical pole is neglected. Thus, the following first order transfer function of the induction motor is obtained

The design of the GPC controller is carried out using the first order transfer function of the motor. As the GPC controller is defined in discrete time, the transfer function must be transformed into a discrete time transfer function. Then, using the ZOH (Zero-Order Hold) discretization method, it is obtained that

Taking into account GPC theory and employing the CARIMA model [1], it is possible to obtain the following equation of the system, in which the output is replaced by , the input is replaced by , and white noise is included in the previous transfer function (17): where is the delay time of the system and it is multiple of the sample time chosen, is the white noise with null average, , and the is the noise polynomial that is chosen to be 1 for simplicity in this design [1].

The GPC algorithm involves applying a control sequence that minimizes a multistage cost function of the form: where is the predicted output step ahead of actual time , is the minimum cost horizon, is the maximum cost horizon, is  the control horizon, and are the weighting sequences, and is the future reference trajectory. The GPC regulator design requires tuning the prediction horizons and the two weighting factors. If one takes into account the possibility that the plant has a delay time, then the minimum and maximum horizons are, respectively, and [1], where is the prediction horizon. Since a high value for the control horizon produces an undesirable oscillation in the control signal [3, 4], which could cause the chattering phenomenon in the induction motor, then it is assumed that .

The prediction of the future output is as follows: where and polynomials are calculated by operating times, where , according to the following Diophantine identity:

Taking into account that the following set of ahead optimal predictions for the system expressed in matrix form (23) can be obtained: where, for an prediction horizon, one obtains the matrix, which contains values of the step sequence of the plant (induction motor), with dimension:

Thus, from (22) and (24) we can see that the matrix depends only on the process parameters, while the term is the free response of the system, and it is easy to deduce that it is a vector of elements:

Assuming that the control weighting sequence is constant and equal to 1, then the cost function (19) can be written in the following form:

The minimum of the cost function (26) when no constraints are considered can be calculated by equalling 0 the gradient of , obtaining the following analytical expression: where and are two vectors of elements:

As the receding horizon strategy is used, the control signal applied to the process is obtained from the first element of , where the following expression must be employed: where , that is, the first row of the matrix in (27).

Now replacing the variables and , by and , respectively, it is obtained that where finally the control law for the induction motor GPC speed regulation (31) is obtained, Figure 3 as follows:

The analytical solution of the cost function minimization is possible only if the control signal (31) is not restricted or limited [1]. As induction motors can support stator overcurrents up to 2.5 times the rated value in short periods, this GPC design does not need to limit the stator currents. That is, the control signal is not limited, allowing the implementation of the more simple, low computational cost analytical solution. With regard to the current, it is fixed to a value to produce the nominal rotor flux, . Finally, the calculation of the , , , and parameters is carried out off-line, without using any identification algorithm, because the usual variation of the main parameters of the motor should be overcome in an effective form by the inherent robustness of any closed loop controller [22].

2.4. Regulator Tuning
2.4.1. PID and PI Controllers

The two current PI regulators use the same tuning values. The higher the bandwidth chosen for these controllers, the faster the current loops dynamics are. However, in practice, any real system’s bandwidth is limited physically. In the employed experimental platform (Section 3.1), which uses the induction motor described in Table 1, this limit is located at 4000 rad/s; up to this value, the platform produces the undesirable chattering phenomenon and dangerous mechanical vibrations that can damage the machine.

As to the speed regulation, in the first case, a PID speed controller has been used to measure the delay time of the system. This PID speed regulator has also been designed in the frequency domain, using a bandwidth which is 10 times smaller than the PI current loop regulators [24]. Then, the optimal tuning of the PID speed regulator has been obtained taking into account this ratio of bandwidths and the physical limit of the experiment platform. Thus, the most efficient PID-PI (speed currents) controller system has been designed with the following parameter values: rad/s with a margin phase of  rad (82°) and  rad/s with a margin phase of rad (90°). The D action of the speed loop is added after PI is tuned, and a small value is enough to do faster the response but without any overshot, where and the PID-PI controller is obtained. The delay time measured in the experiment platform using this PID-PI speed regulator tuning is 700 μs, using the sample time of 100 μs, (Section 3.2).

2.4.2. SM Controller

A sliding-mode speed regulator for induction motor is also implemented in order to be compared with the proposed GPC regulator. This advanced speed regulator was presented by the authors in [7], where the parameters used in its design for the induction motor (Table 1) are obtained considering an uncertainty around 50% in the system parameters: , , , , , and . This speed scheme uses the same two current PI regulators employed in GPC and PI speed schemes and detailed in the previous subsection.

2.4.3. GPC Controller

The tuning of the GPC regulator requires choosing the values of two horizons and two weighting factors. The control horizon, , and the output error weighting factor, , both have been fixed to 1 (Section 2.1). The prediction horizon, , determines the size of the matrix and the vector, and, as a consequence, the number of the GPC controller’s coefficients. A larger value for increases the anticipative effect, involving a better control and performance of the system. However, this increases the number of the coefficients and the computational cost of the control law, which requires increasing the sample time. So should be selected to ensure proper dynamic behaviour and low computational cost. In this design it has been set to 5. From Section 2.1, it is known that the minimum and maximum horizons take into account the delay time of the system, and . Considering two GPC speed regulator designs, D1 and D2, using sample times of 100 μs and 700 μs, respectively, and taking into account that the measured experimental delay time is 700 μs (Section 3.2), then the delay values are for D1 and for D2 (Table 2).

The control weighting factor, , has a direct impact on the response of the controlled system. Hence, the higher its value, the slower the resulting controlled system. On the other hand, if its value is too small, it can produce the chattering phenomenon that can damage the motor in a real case. Then, it is desirable to find a value for to provide an effective response of the controlled system. Taking into account the recommendation in [15], an easy way to obtain an effective and stable value for factor is applying the following empirical expression: where takes a value inversely proportional to the sample time. For D1 design the parameter results in a value of 60, and for D2, equals 2 (tens for 100 μs, units for 700 μs).

2.5. Robust Stability Analysis

The closed loop stability of the motor - currents with the PI controllers is guaranteed if the phase margins are positive and sufficiently high. As to the speed loop, the stability of the controlled system is analysed using the classic RST poles placement scheme [25], where the control law is obtained as

In this sense, it is necessary to translate the GPC controlled system parameters to its equivalent RST controlled system parameters [1], to check the stability of the system. Identifying the terms between (31) and (33), we can obtain the general expression of equivalence in both RST and GPC algorithms for any first order plant with delay time: where it should be noted that the polynomial multiplies the future references vector (33). Thus, the controller should be designed so that the controlled system presents all the poles inside the unit circle. In order to achieve this a graphical representation (Nichols chart) of the open loop system is more appropriate as gain margin and phase margin can be observed.

The robust stability is analysed taking into account the parametric uncertainties of the induction motor in two limit real cases of each control loop detailed in Table 2. These limits are used to determine the robustness of the speed and current regulators, as these limits are both critical in real cases. Hence, as the controller is lineal, any uncertainty case located into the defined limits has the stability guaranteed.

First, the following two uncertainty cases for the limits of robustness, related with the mechanical parameters of the induction motor, are considered in the proposed GPC. The U1 takes a 100% higher, and the U2 that considers 10 times higher, increasing 2 times and reducing 10 times, respectively, the mechanical time constant of the machine. The D1 and D2 designs are presented for the speed GPC regulator. The D1 uses a sample time of 100 μs and nominal of 0.057 kg m2, and D2, a sample time of 700 μs and a nominal of 0.0285 kg m2. On the other hand, another two limit cases are considered for the PI current controllers, which are related with the stator windings resistances () modified by their temperature. Us1 determines the uncertainty when the temperature of the windings is 0°C (before starting in a cold place), and Us2 considers the heating case of the stator windings when the induction motor is working at rating power for half an hour or more, where the stator windings are around 130°C. As it is known, the temperature variation produces the proportional increase of the stator windings resistance: and the proportional decrease of the stator electrical time constant:

Table 2 shows the two efficient designs for the GPC speed regulator, D1 and D2, taking into account different nominal moments of inertia of the induction motor and sample times in each case. The two uncertainties cases, U1 and U2, have been based in the D1 and D2 designs, but even so, the stability of the controlled system is guaranteed observing the gain and phase margins obtained from Figure 4. In Table 2, the efficient design for the two PI current controllers is detailed, with Us1 and Us2 uncertainties cases. Figure 5 shows that the temperature variations in the stator windings practically have not any effect.

3. Simulation and Experimental Results

3.1. Experiment Platform

The employed platform is composed by a PC with MatLab7/Simulink R2007a, dsControl 3.2.1, and the DS1103 Controller Board real time interface of dSpace, with a floating point PowerPC processor to 1 GHz; and a set of electric machines that includes a M2AA 132M4ABB commercial induction motor of 7.5 kW of die-cast aluminium squirrel-cage type (1445 rpm), Table 1, connected to a DC bus of 540 V by VSI inverter, and a 190U2 Unimotor synchronous AC servo in motor of 10.6 kW to generate the load torque (controlled in torque), presented in [15]. An incremental encoder of 4096 pulses is employed to measure the mechanical speed of the induction motor. The rotor flux of the induction motor has been set to its nominal value of 1.01 Wb, keeping the flux current command , that is, , to a constant value of 8.61 A. Finally, as the SVPWM modulator frequency is fixed at 10 kHz, then the sample time employed for the PI current controllers is 100 μs.

3.2. Speed Tracking

Using D1 design for the GPC controller, simulation and experimental tests are carried out with a trapezoidal speed reference of 1445 rpm and 0.33 Hz, adding an square form load torque of 30 Nm (starting from the second period of the speed reference).

Results are shown in Figure 6, where very satisfactory speed tracking can be observed, obtaining a stationary speed error of about 2 rpm (0.138%) in the experimental case, both without and with load torque. In addition, the electromagnetic torque does not present any aggressiveness, and consequently it will not generate the undesirable chattering phenomenon, as seen in the third graph. Moreover, around and , the motor is working at nominal speed and torque (Table 2), obtaining an excellent speed tracking. Considering the electromagnetic torque reference current, , it should be noted that it is not limited, which justifies the employed analytical. Moreover, it can be seen that the rotor flux current, , takes the value imposed by its reference in accordance with the previous assumption of the theoretical section (see Section 2.3), and consequently that the rotor flux remains constant at its nominal value for a short time after it is requested, verifying the decoupling of its components. The great similarity between the simulation and the experimental tests validates the presented GPC speed regulator, and they show that the choice of the first order model for the induction motor is correct.

Figure 7 shows the speed response and the electromagnetic torque reference current for D1 of GPC speed controller and PID speed regulator cases. It can be observed that the PI regulator has a delay of 700 μs and that the GPC controller generates the control signal 12 sample times () before the speed reference, compensating for the delay time of the system and anticipating 5 steps () the reaction of the speed response.

In Figure 8 the performance comparison between the regulator proposed in this paper, GPC1, and a previously proposed GPC one [15] based on a second order transfer function (15), GPC2, can be observed. The tests are based on a 1200 rpm and 0.75 Hz a saw-toothed speed reference and an unknown load torque of 25 Nm starting from 1.65 s. Comparing the two speed responses, it is possible to appreciate that the proposed GPC speed regulator (GPC1) is better than the previous version (GPC2), because the speed response is similar but is less oscillatory.

Figure 9 compares the GPC1, SM, PI, and PID speed regulators, in the same test conditions as in the previous case. Comparing the responses of the GPC1 and SM regulators, it can be observed that the predictive response is a little faster than sliding modes’ response. Moreover, the effect of the load torque in the GPC1 case is minor than the SM case, which demonstrates the robustness of the approach when varying load torques are applied. In addition, it can be seen that the PID is faster than PI due to derivative effect. Also, it can be observed that the GPC1 regulator’s response is considerably faster than PID’s response.

Figures 10 and 11 show the comparative experimental tests of the GPC1, SM, and PID speed regulators using constant acceleration and variable acceleration cases, respectively. Figure 10 shows that the speed tracking without any load torque (between 0 and 2.25 s) is very similar for the three regulators though it can be observed that the speed error is about 2 rpm for GPC while its magnitude is increased to 4 and 5 rpm in the SM and PID cases. When the load torque is considered, the speed tracking is considerably worse for SM and PID cases, while the GPC maintains a good speed tracking (fourth graph (a)). Moreover, GPC regulator supports better than the SM and PID controllers the load torque changes (fourth graph on the right (b)). Figure 11 shows that the speed tracking without any load torque (between 0 and 2.25 s) is similar for the three regulators although the speed error is 2 rpm for GPC while it increases to 4 an 5 rpm in the SM cases, and about 8 rpm in the PID case. Moreover, the GPC regulator provides a faster response in the initial half period (fourth graph on the left (a)). When the load torque appears, the speed tracking is considerably worse for PID case, while the GPC and SM maintain a good speed tracking (fourth graph on the right (b)), though the GPC response is a little faster than sliding mode’s response.

Therefore, the use of the first order transfer function model is justified because the first order model simplifies the computational cost and the controlled performance contains less oscillations than the second order case.

3.3. Load Disturbance, Uncertainties, and Measurement Noise Rejection

One of the issues that usually exists in real applications is load disturbance, and, in the previous tests, the proposed GPC speed controller has demonstrated its performance even in presence of this effect. Moreover, parametric uncertainties that is, the change of values in the induction motor parameters can arise. These have been considered as U1 and U2 in Table 2. Finally, the measurement noise in the two loop signals, in the rotor speed, and in the stator current has a negative impact on the controllers.

In this sense, the graphs of Figure 12 show the simulation and real tests, using a 1200 rpm and 0.33 Hz trapezoidal speed reference and an unknown square form load disturbance of 30 Nm. The GPC speed regulator is designed taking into account the nominal parameters of the motor, D2 design (Table 2). In the simulation case the induction motor has the nominal values in its parameters, and the unknown load disturbance in its shaft only is considered. In the experimental case, an additional, software based, measurement white noise is induced in the two feedback signals, and (using MatLab/dSControl). In this way, robustness against measurement noises is demonstrated. Additionally, in this case parameter uncertainties and load disturbances are introduced, this is, a greater stator (Cu) resistance, at 130°C and a 100% greater moment of inertia, Us2 and U2 cases for D2 design in Table 2. Observing the graphs of Figure 10, it can be seen that the motor response is very good in spite of all the adversities, and a satisfactory speed tracking is achieved. The electromagnetic torque manifests some activity due to the sensor noises, but not due to the controller action, as observed in the simulation test in the second graph. As to real computational cost of the GPC-PI controller, as the calculation of the parameters , , , and is realized offline, its value is the same as the PI-PI controller: 10 μs employing a PowerPC processor at 1 GHz.

4. Conclusions

The contribution of this work consists of the combination of the GPC algorithm in the speed loop with a PI based control in the current loops, using an easy and effective design, where the robust stability is demonstrated for typical induction motors’ parametric uncertainties. The GPC speed controller design is based on the first order model of the induction motor with a delay time, which is compensated. This regulator design is simpler to implement than other predictive proposed schemes, as neither constraints nor robustness terms have been taken into account.

The proposed controller has been tested using various simulation and experimental tests in the presence of the parametric uncertainties, unknown load disturbance, and measurement noise in the loop signals: the rotor speed and the stator current. The experiment demonstrates the effectiveness of the approach. Moreover, the presented results also show that the GPC speed regulator is considerably faster than the classic PID and slightly faster than the advanced SM speed controller, using the same computational cost. This work demonstrates that the GPC-PI controller is an effective speed control algorithm, in both adverse and acceptable conditions, its robustness is clearly shown, the proposed control scheme is also easy to tune and to implement in a real system, and therefore it can be used in industrial applications.

Acknowledgments

The authors are very grateful to the UPV/EHU for its support throughout the project GUI07/08 and the Basque Government for the support to this work throughout the project S-PE09UN12.