International Journal of Computers, Communications & Control Vol. II (2007), No. 4, pp. 388-402 A Toolbox for Input-Output System Inversion Antonio Visioli, Aurelio Piazzi Abstract: In this paper a Matlab-based toolbox for the input-output system inversion of linear systems is presented. Different methods, based either on analytical or nu- merical approaches, are implemented. The toolbox can be exploited in the design of a feedforward action for control systems in different contexts in order to improve per- formances in the set-point regulation. The use of a pre-actuation and a post-actuation time can be easily analyzed as well as the role played by the choice of the desired output function. Keywords: CACSD, input-output inversion, feedforward, set-point regulation, opti- mization. 1 Introduction It is well-known that a (properly designed) feedback controller provides robustness to a control sys- tem with respect to parameter variations and allows to compensate for external disturbances. On the other side, a high performance in the set-point following task can be achieved by adopting a suitable feedfor- ward action. Indeed, the proper design of a control system consists of suitably combining feedback and feedforward control. Different techniques have been developed for the synthesis of a feedforward con- troller for a linear system (see e.g. [1, 2, 3]). When the set-point regulation is of concern, a (noncausal) system inversion approach has been proven to be effective in this context [4]-[13]. Basically, the approach consists of selecting a desired output func- tion in order to achieve a transition from a current output value y0 to a new one y1 and then to determine the corresponding input function by applying a stable inversion procedure. Then, the calculated input function is adopted as a reference command input to the (closed-loop) system, instead of the typical step signal. Actually, while many software packages are available for the synthesis of feedback controllers (for ex- ample, via root locus techniques or Bode plots), they are not available for the synthesis of a system inversion based feedforward action. Indeed, the presence of a Computer Aided Control Systems Design tool makes the applicability of these (somewhat complex) techniques much easier and it can be exploited to understand deeply the role of the command function in the context of set-point regulation. In this paper a Matlab-based toolbox for the input-output system inversion of a linear system is presented. Different techniques in this context are considered, related both to a noncausal and a causal approach. The toolbox allows to evaluate the role of the use of a pre-actuation and a post-actuation time as well as the role of the choice of the desired output function. It can be adopted as a useful tool in different fields, such as robust control, process control and control of mechatronic systems. The paper is organized as follows. In Section 2 the input-output system inversion approach is briefly reviewed and the different methodologies implemented in the toolbox are presented. The functions im- plemented in the toolbox are described in Section 3 and application examples are shown in Section 4. Conclusions are drawn in Section 5. Notation. Ci denotes the set of scalar real functions that are continuous till the ith derivative and BCi denotes the subset of Ci of the scalar real functions that are bounded. The ith order differential operator is Di. Copyright © 2006-2007 by CCC Publications A Toolbox for Input-Output System Inversion 389 2 Input-output system inversion Consider a general asimptotically stable nonminimum-phase linear system Σ described by the fol- lowing rational transfer function (note that this might represent the transfer function of a feedback control system): H(s) = K1 b(s) a(s) = K1 sm + bm−1sm−1 +···+ b0 sn + an−1sn−1 +···+ a0 , K1 6= 0 (1) where it is assumed that polynomials a(s) and b(s) are coprime (no pole-zero cancellations occur) and that Σ has not purely imaginary zeros. The input and output of Σ are u ∈ R and y ∈ R respectively and the relative order (or relative degree) of Σ is ρ := n−m. The set of all cause/effect pairs associated with Σ is denoted by B := {(u(·), y(·)) ∈ Pc ×Pc : Dny + an−1Dn−1y +···+ a0y = K1(Dmu + bm−1Dm−1u +···+ b0u)} (2) where Pc denotes the set of piecewise continuous functions defined over (−∞, +∞), i.e. the real field R. In the framework of the behavioral approach, B is the behavior set of Σ that can be rigorously introduced by means of the so-called weak solutions of the differential equation associated to Σ [14]. The following proposition [14] is useful in the development of the subsequent analysis. Proposition 1. Consider any pair (u(·), y(·)) ∈ B. Then, u(·) ∈ Cl (R) if and only if y(·) ∈ Cρ+l (R) with l being a nonnegative integer. The considered regulation problem consists of obtaining an output transition from a previous value y0 to a new value y1. Without loss of generality, in the following we will consider y0 = 0. Define yd (·) ∈ BCk with yd (t) = 0 for t < 0 as the desired output function to obtain the transition. From a practical point of view, a transition time τ has to be defined, i.e. the desired output function is defined as yd (t) :=    0 for t < 0 y01(t) for 0 ≤ t ≤ τ y1 for t > τ. (3) Then, the following stable input-output inversion (SIOI) problem can be formulated. SIOI problem. Determine an input function ud (·) ∈ BCk−ρ such that (ud (·), yd (·)) ∈ B. (4) The general solution to the SIOI problem can be derived as follows [15]. First, express the inverse of the transfer function (1) as H−1(s) = 1 K1 a(s) b(s) = ξρ sρ + ξρ−1sρ−1 +···+ ξ0 + H0(s) (5) where H0(s) is a strictly proper rational transfer function representing the zero dynamics of Σ. By using the fraction expansion, H0(s) can be decomposed as H0(s) = H − 0 (s) + H + 0 (s) = d(s) b−(s) + e(s) b+(s) (6) where b−(s) and b+(s) are the monic polynomials containing the roots of b(s) with negative and pos- itive real parts, respectively. Define η−0 (t) and η + 0 (t) as the analytic extensions of L −1[H−0 (s)] and L−1[H+0 (s)] over the space of the Bohl functions for which η − 0 (t)1(t) = L −1[H−0 (s)] and η + 0 (t)1(t) = 390 Antonio Visioli, Aurelio Piazzi L−1[H+0 (s)] respectively. Then, the solution of the SIOI problem is derived as: ud (t) = ξρ Dρ yd (t) +···+ ξ1Dyd (t) + ξ0yd (t) + ∫ t 0 η−(t −v)yd (v)dv− ∫ +∞ t η +(t −v)yd (v)dv. (7) It is worth noting that, in general, ud (t) is defined over the time interval (−∞, +∞) and therefore, in order to practically use it, it is necessary to truncate it. Thus, the input function exhibits a pre-actuation (associated with the unstable zeros) and a post-actuation (associated with the stable zeros) time intervals (see for example [16]), denoted as tp and t f respectively. They can be calculated with arbitrary precision by selecting two arbitrary small parameters ε0 and ε1 and by subsequently determining t0 := max{t′ ∈R : |ud (t)| ≤ ε0 ∀t ∈ (−∞,t′]} (8) and t1 := min { t′ ∈R : ∣∣∣∣ud (t)− 1 H(0) ∣∣∣∣ ≤ ε1 ∀t ∈ [t′, ∞) } . (9) Then, it has to be fixed tp = min{0,t0} t f = max{τ,t1}. (10) Hence, the actual input function to be applied to the system is given by ũd (t) :=    0 for t < tp ud (t) for tp ≤ t ≤ t f 1 y1 for t > t f . (11) Alternatively, the pre-actuation and post-actuation time intervals can be calculated as [4] tp = − 10 Drhp t f = 10 Dlhp (12) where Drhp and Dlhp are the minimum distance of the right and left half plane zeros respectively from the imaginary axis of the complex plane. It is worth noting that the pre-actuation time is zero when there are no unstable zeros and the post- actuation time is zero when there are no stable zeros. In general, the integrals in expression (7) can not be solved analytically and therefore a numerical solution has to be determined (in this context the Cavalieri-Simpson’s rule can be conveniently exploited to found an accurate solution with a small computational time [15]). A notable exception occurs when the selected desired output function is a polynomial function [17], i.e. yd (t; τ) =    0 for t < 0 y1 (2k+1)! k!τ 2k+1 ∑ k i=0 (−1)k−i i!(k−i)!(2k−i+1) τ it 2k−i+1 for 0 ≤ t ≤ τ y1 for t > τ (13) Note that function yd (t; τ), parameterized by the transition time τ is a Ck-function over (−∞, +∞) and is strictly increasing in the interval [0, τ] so that neither overshooting nor undershooting appear in this output planning for set-point regulation. In this case an analytical solution can be found [18] and this fact can be exploited in speeding up the computational time and most of all in avoiding numerical problems. A very interesting application of the analytical stable inversion procedure is for the improvement of the set-point following performance of Proportional-Integral-Derivative (PID) controllers. Specifically, if a PID controller is employed for a first-order plus dead-time (FOPDT) process, described by the following transfer function, P(s) = K T s + 1 e−Ls, (14) A Toolbox for Input-Output System Inversion 391 or for an integrator plus dead-time (IPDT) process, described by the transfer function P(s) = K s e−Ls, (15) then a closed-form solution of the stable input-output inversion applied to the closed-loop system can be exploited (a rational closed-loop transfer function is obtained by adopting a Padè approximation) [13]. Indeed, the actual command signal to be applied for a given process and a given PID controller is determined by substituting the actual value of the process and PID parameters into the resulting closed- form expression. In this context the PID transfer function is expressed as C(s) = Kp ( 1 + 1 Tis + Td s ) 1 Tf s + 1 , (16) where Kp is the proportional gain, Ti is the integral time constant, Td is the derivative time constant and Tf is the time constant of the filter that is adopted to render the system proper. A polynomial output function can be also usefully exploited in determining a causal input-output inver- sion despite the presence of unstable zeros [9]. In particular, the order of the polynomial function is selected in order to satisfy boundary conditions so that yd (·) ∈ BCk with k ≥ ρ and at the same time to have a number of free coefficients equal to the number of the unstable zeros of the system Σ. Then, the free parameters are determined in order to annihilate the unstable modes in the input function determined by the inversion procedure. In this way there is no need of a pre-actuation time interval and the resulting inversion is causal. It can be therefore employed when a preview time is not available in a given ap- plication. However, this is paid by the possible presence of undershoots and overshoots in the resulting output function. Note that the approach can be easily extended in order to avoid also the presence of a post-actuation time interval. 3 Toolbox description The designed Matlab-based toolbox implements the methods described in Section 2. It requires the Control System Toolbox and the Symbolic Math Toolbox of Matlab. The following main functions are available. [time,command,preaction,postaction]=numdyninvcs(sys,yd,tau,st) This function determines the input command function of a system that causes a desired output function by means of an input-output inversion scheme based on the use of the Cavalieri-Simpson’s rule for the determination of the integrals in (7) [15]. In particular, the meaning of the parameters is the following one: • sys is the transfer function of the system expressed in symbolic form (with s as a symbolic variable); • yd is the desired output function (for t ∈ [0, τ]) expressed as an array of numerical values from 0 to τ corresponding to the time instant equally spaced by the sampling time; • tau is the transition time; • st is the sampling time; • time is the output time vector; it starts from the preaction time tp but for convenience the zero time is shifted to tp; 392 Antonio Visioli, Aurelio Piazzi • command is the determined input function expressed as a numerical array corresponding to the time array time; • preaction is the pre-actuation time calculated with formula (12); • postaction is the post-actuation time calculated with formula (12). [time,command,preaction,postaction]=outdyninvcs(sys,yd,tau,st) This function operates basically as numdyninvcs with the difference that the desired output function yd is expressed as a symbolic expression with symbolic variable t. [time,command,preaction,postaction]=numdyninv(sys,yd,tau,st) This function is very similar to numdyninvcs but it performs the numerical integration by applying a rectangular rule. In order to obtain an accurate result, a small value of the sampling time has to be selected. This might result in a high computational time. [time,command,preaction,postaction]=outdyninv(sys,yd,tau,st) This function is very similar to outdyninvcs but it performs the numerical integration by applying a rectangular rule. Also in this case, in order to obtain an accurate result, a small value of the sampling time has to be selected. This might result in a high computational time. [time,command,preaction,¯postaction]=dyninv(sys,y1,tau,threshold0, threshold1,st) This function solves the input-output inversion problem when the desired output function is a polynomial function (13). The order of the polynomial is automatically selected, according to Proposition 1, in order to obtain a continuous input function, i.e. such as ud (·) ∈ BC0. Since the input function is determined analytically, the pre-actuation and post-actuation time intervals are conveniently determined by adopting formulae (10). The function parameters that are different from those that have been already described have the following meaning: • y1 is the desired new output steady-state value (it is assumed, without loss of generality, that the current input and output steady-state values are zero); • threshold0 is the parameter ε0 in formula (8), which is adopted to calculate the pre-actuation time; • threshold1 is the parameter ε1 in formula (9), which is adopted to calculate the post-actuation time. [time,command,taunum,preaction,postaction]= optdyninv(sys,y1,constraints,threshold0,threshold1,tc) This function solves the minimum-time inversion problem that consists of finding the minimum output transition time subject to constraints posed on the input function and its derivatives until an arbitrary order l. Formally, the optimisation problem is posed as follows [18]: min τ∈R+ τ (17) such that, i = 0, 1, . . . , l, |Diud (t; τ)| ≤ u(i)M ∀t ∈ (−∞, +∞) (18) A Toolbox for Input-Output System Inversion 393 where the positive values u(i)M , i = 0, 1, . . . , l, are given bounds of the problem. Note that the problem admits a solution if u(0)M > 1/|H(0)| and u (i) M > 0, i = 1, . . . , l. The optimisation problem is solved by applying a simple bisection algorithm in conjunction with a gridding of the time axis [17]. With respect to the function dyninv there are the following different parameters: • constraints is the array (of l + 1 elements) of the constraints for the input derivatives until the lth order; note that the user-chosen dimension of the array automatically determines the order of the constrained derivatives and therefore the order of the output polynomial function (which is determined as l −1 + ρ so that ud (·) ∈ BCl−1); • taunum is the resulting optimal transition time. It is worth noting that, if a rigorous determination of the transition time is sought, the posed optimisation problem should be approached with the tools of global optimisation. In this context the presented input- output inversion toolbox can be easily integrated with the b4m toolbox that allows to handle interval arithmetic, which is a well-known effective tool for global optimisation [19]. [time,command,out,postaction]=causaldyninv(sys,y1,tau,st,hbc,pa) This function implements the causal approach proposed in [9]. The resulting pre-actuation time is always zero despite the possible presence of unstable zeros. In particular, the function deals with the following parameters: • hbc is the order h of the boundary conditions to be satisfied for the polynomial output function at time t = 0 and t = τ , so that yd (·) ∈ BC2h+1. Note that it has to be h ≥ ρ in order to ensure that the input function is at least continuous, i.e. ud (·) ∈ BC0; • pa is a string that, if set to ‘nopostaction’, avoid also the use of a post-actuation time even if the system has stable zeros. In other words, in this case the system attains an equilibrium point at t = τ . If the parameter is not adopted or if it is set to another value, then a post-actuation time is present and it is determined by means of formula (12). [time,command,preaction,¯postaction]=piddyninvFOPDT(K,T,L,Kp,Ti,Td, Tf,tau,st) This function determines the input command function to unitary feedback closed-loop system in which a process described by a FOPDT transfer function is controlled by a PID controller. The following parameters are adopted: • K, T, L are the process gain, time constant and dead time respectively (see (14)); • Kp, Ti, Td, Tf are the PID parameters (see (16), where the meaning of the different parameters is obvious). [time,command,preaction,postaction]=piddyninvIPDT(K,T,L,Kp,Ti,Td,Tf, tau,st) This function determines the input command function to unitary feedback closed-loop system in which a process described by a IPDT transfer function is controlled by a PID controller. The meaning of the parameters can be straightforwardly derived by considering those of the previous function together with expression (15). 394 Antonio Visioli, Aurelio Piazzi 4 Application examples In order to better understand the usage of the input-output inversion toolbox, a few examples are given. Consider the system H(s) = 4 (1−s)(s + 1) (s + 2)(s2 + 2s + 2) . (19) To insert the system in symbolic form in the Matlab workspace, the following two commands can be applied: syms s H=4*(1-s)*(s+1)/(s+2)/(s^2+2*s+2) Then, suppose that an output transition from 0 to y1 = 1 is required to be performed in τ = 3 by means of the following output function: y(t) = 4796646617206209 562949953421312 t 63 25 − 4658008624178539 562949953421312 t 127 50 + (20) 6313836048447483 5316911983139663491615228241121378304 t 39. The output function can be inserted in the Matlab workspace (denote the variable as yt) either in symbolic form or as an array whose elements are the values of y(t) for t = 0, Ts, 2Ts, . . . , τ , where Ts is the sampling time (in this case it has been selected Ts = 0.001). In the first case the command to be adopted is: [time,command,preaction,postaction]=outdyninvcs(H,yt,3,0.001) while in the second case it has to be [time,command,preaction,postaction]=numdyninvcs(H,yt,3,0.001) In both cases the pre-actuation time results to be tp = −10 s and the postaction time is t f = 10 s (according to expressions (12)). The resulting input function and the output function obtained by applying it to the actual system are reported in Figure 1 (note that the result is the same in both cases). Select now a polynomial output function (13) to perform again an output transition from 0 to y1 = 1 and select the parameters ε0 = ε1 = 10−3. In this case the Matlab command to be adopted is [time,command,preaction,postaction]=dyninv(H,1,3,0.001,0.001,0.001) The resulting pre-actuation and post-actuation times preaction and postaction (determined by means of formula (10)) are respectively tp = −6.256 s and t f = 3.547 s. The determined input and the corresponding system output are plotted in Figure 2. Note that the resulting output function is a cubic polynomial, i.e. yd (t; τ) = y1 ( − 2 τ 3 t 3 + 3 τ 2 t 2 ) t ∈ [0, τ] as it is k = ρ = 1 in formula (13). Consider now the minimum time problem (17)-(18) and set the limits on the input derivatives as u(0)M = 2, u(1)M = 10 and u (2) M = 20. This means that the following Matlab command has to be executed: limits=[2 10 20] Then, the following function has to be employed (note that the sampling time is 0.001 s as before and again it is ε0 = ε1 = 10−3): [time,command,taunum,pre,post]=optdyninv(H,1,limits,0.001,0.001,0.001) The resulting optimal transition time taunum is equal to 0.875 s, while the pre-actuation and post- actuation times are tp = −7.111 s and t f = 4.402 s. The determined command input and the correspond- ing system output are shown in Figure 3, while the first and second derivatives of the command input are plotted in Figure 4. It can be deduced that the active constraint is the one related to the second time derivative of the input. If the causal approach is desired, i.e. the pre-actuation time is to be avoided, then the function A Toolbox for Input-Output System Inversion 395 causaldyninv has to be adopted. In particular, we select the order of the boundary conditions as h = ρ = 1 and the desired transition time as τ = 3. Then, if a post-actuation time interval is allowed, the Matlab command to be adopted is: [time,command,out,postaction]=causaldyninv(H,1,3,0.001,1) In this case the resulting command input and the corresponding output are plotted in Figure 5. Note that the post-actuation time interval is t f = 10 s. Conversely, if a post-actuation is not allowed, the Matlab function to be employed is [time,command,out,postaction]=causaldyninv(H,1,3,0.001,1,‘nopostaction’) The resulting command input and the corresponding output function are shown in Figure 6. It can be seen that in both cases the output function is not monotonic. Indeed, the possible overshoots and undershoots are more and more significant when the selected transition time decreases. In order to verify the effectiveness of the inversion approach for PID control, consider first the system P(s) = 2 10s + 1 e−5s, (21) controlled by a PID controller (see (16)) with Kp = 1.2, Ti = 10, Td = 2.5, Tf = 0.01. The transition time is fixed to 15 s and the sampling time to 0.01 s. Then, the following Matlab command is adopted: [time,command,pre,post]=piddyninvFOPDT(2,10,5,1.2,10,2.5,0.01,15,0.01) The resulting command input (applied to the closed-loop system) and output functions are plotted in Fig- ure 7. The pre-actuation and post-actuation time intervals are tp = −16.67 s and t f = 50.01 s. Note that the output function is slightly different from the desired one because of the Padè approximation. Then, a IPDT transfer function is considered: P(s) = 0.1 s e−5s. (22) In this case the tuning of the PID parameters is Kp = 0.12, Ti = 10, Td = 2.5, Tf = 0.01. The transition time and the sampling time are the same as before, so that the following function is employed: [time,command,pre,post]=piddyninvIPDT(0.1,10,5,0.12,10,2.5,0.01,15,0.01) Figure 8 reports the determined closed-loop command input and the resulting system output. Also in this case the pre-actuation and post-actuation time intervals are tp = −16.67 s and t f = 50.01 s. 5 Conclusions A Matlab-based toolbox for the input-output inversion of linear scalar systems has been described in this paper. The toolbox is very useful to understand and to verify the effectiveness of a feedforward action in a control scheme and, in general, of a combined feedback/feedforward synthesis. In this context, the role played by the planned output function can be easily evaluated as well as the influence of the noncausal approach with respect to a causal one. Indeed, all the aspects related to the use of an input- output inversion-based control design can be thoroughly investigated and analyzed. The toolbox can be exploited in different fields such as motion control, robust control, and process control. It can be downloaded from the website http://www.ing.unibs.it/∼visioli/ioitoolbox.htm 396 Antonio Visioli, Aurelio Piazzi 0 2 4 6 8 10 12 14 16 18 20 0 0.2 0.4 0.6 0.8 1 time [s] command input resulting output Figure 1: Command input and resulting system output with system (19) and desired output function (20) 0 2 4 6 8 10 12 14 0 0.2 0.4 0.6 0.8 1 time [s] command input resulting output Figure 2: Command input and resulting system output with system (19) and a polynomial desired output function (13) A Toolbox for Input-Output System Inversion 397 0 2 4 6 8 10 12 0 0.2 0.4 0.6 0.8 1 1.2 time [s] command input resulting output Figure 3: Optimal command input and resulting minimum-time system output with system (19) and a polynomial desired output function (13) 0 2 4 6 8 10 12 −20 −15 −10 −5 0 5 10 15 20 time [s] first derivative second derivative Figure 4: First and second derivative of the optimal command input with system (19) and a polynomial desired output function (13) 398 Antonio Visioli, Aurelio Piazzi 0 1 2 3 4 5 6 −0.2 0 0.2 0.4 0.6 0.8 1 time [s] command input resulting output Figure 5: Command input and resulting system output with system (19) and a causal approach with post-actuation 0 0.5 1 1.5 2 2.5 3 3.5 4 −1 −0.5 0 0.5 1 1.5 2 time [s] command input resulting output Figure 6: Command input and resulting system output with system (19) and a causal approach without post-actuation A Toolbox for Input-Output System Inversion 399 0 10 20 30 40 50 60 70 0 0.2 0.4 0.6 0.8 1 time [s] command input resulting output Figure 7: Command input and resulting system output with system (21) with a PID controller 0 10 20 30 40 50 60 70 −3 −2 −1 0 1 2 3 4 5 6 time [s] command input resulting output Figure 8: Command input and resulting system output with system (22) with a PID controller 400 Antonio Visioli, Aurelio Piazzi Bibliography [1] B. C. Kuo, Automatic Control Systems, Prentice Hall, Englewood Cliffs (NJ), 1995. [2] A. Wallen, K. J. Åström, Pulse-step control, Preprints of the 15th IFAC World Congress on Auto- matic Control, Barcelona (Spain), 2002. [3] A. Visioli, A new design for a PID plus feedforward controller, Journal of Process Control, Vol. 14, No. 4, pp. 455-461, 2004. [4] H. Perez, S. Devasia, Optimal output transitions for linear systems, Automatica, Vol. 39, pp. 181-192, 2003. [5] Q. Zou, S. Devasia, Preview-based optimal inversion for output tracking: application to scanning tunneling microscopy, Proceedings IEEE International Conference on Decision and Control, Las Vegas (USA), pp. 79-85, 2002. [6] D. Iamratanakul, H. Perez, S. Devasia, Feedforward trajectory design for output transitions in discrete-time systems: disk-drive example, Proceedings of the American Control Conference, Den- ver (USA), pp. 3142-3147, 2003. [7] A. Piazzi, A. Visioli, Minimum-time system-inversion-based motion planning for residual vibration reduction, IEEE/ASME Transactions on Mechatronics, Vol. 5, No. 1, pp. 12-22, 2000. [8] A. Piazzi, A.Visioli, Optimal inversion-based control fo the set-point regulation of nonminimum- phase uncertain scalar systems, IEEE Transactions on Automatic Control, Vol. 46, No. 10, pp. 1654- 1659, 2001. [9] M. Benosman, G. Le Vey, Stable inversion of SISO nonminimum phase linear systems through output planning: an experimental application to the one-link flexible manipulator, IEEE Transactions on Control Systems Technology, Vol. 11, No. 4, pp. 588-597, 2003. [10] C. Guarino Lo Bianco, A. Piazzi, A servo control system design using dynamic inversion, Control Engineering Practice, Vol. 10, No, 8, pp. 847-855, 2002. [11] A. Piazzi, A. Visioli, Optimal dynamic inversion based control of an overhead crane, IEE Proceed- ings - Control Theory and Applications, Vol. 149, No. 5, pp. 405-411, 2002. [12] A. Visioli, A. Piazzi, Improving set-point following performance of industrial controllers with a fast dynamic inversion algorithm, Industrial Engineering and Chemistry Research, Vol. 42, pp. 1357- 1362, 2003. [13] A. Piazzi, A. Visioli, A noncausal approach for PID control, Journal of Process Control, Vol. 16, pp. 831-843, 2006. [14] J. W. Polderman, J. C. Willems, Introduction to Mathematical Systems Theory, Springer-Verlag, New York, 1998. [15] D. Pallastrelli, A. Piazzi, Stable dynamic inversion of nonminimum-phase scalar linear systems, Preprints of the 16th IFAC World Congress on Automatic Control, Prague (CZ), 2005. [16] Q. Zou, S. Devasia, Preview-based inversion of nonlinear nonminimum-phase systems: VTOL ex- ample, Proceedings of the IEEE International Conference on Decision and Control, Paradise Island (The Bahamas), pp. 4350-4356, 2004. A Toolbox for Input-Output System Inversion 401 [17] A. Piazzi, A. Visioli, Optimal noncausal set-point regulation of scalar systems, Automatica, Vol. 37, No. 1, pp. 121-127, 2001. [18] A. Piazzi, A. Visioli, Using stable input-output inversion for minimum-time feedforward con- strained regulation of scalar systems, Automatica, Vol. 41, No. 2, pp. 305-313, 2005. [19] E. Hansen, G. W. Walster, Global optimization using interval analysis - 2nd edition, Marcel Dekker, 2003. Antonio Visioli University of Brescia Dipartimento di Elettronica per l’Automazione Via Branze 38, I-25123 Brescia, Italy E-mail: antonio.visioli@ing.unibs.it Aurelio Piazzi University of Parma Dipartimento di Ingegneria dell’Informazione Parco Area delle Scienze 181A, I-43100 Parma, Italy Received: January 2, 2007 402 Antonio Visioli, Aurelio Piazzi Antonio Visioli received the Laurea degree in electronic en- gineering from the University of Parma, Parma, Italy, and the Ph.D. degree in applied mechanics from the University of Brescia, Brescia, Italy, in 1995 and 1999 respectively. His Ph.D. dissertation was on control strategies for industrial robot ma- nipulators. He is currently an Associate Professor of Automatic Control, Department of Electronics for Automation, University of Brescia, Italy. His research interests include industrial robot control and trajectory planning, dynamic-inversion-based control and process control. He is the author or co-author of more than 100 papers in international journals and refereed conference proceedings and he is the author of the book Practical PID Control published by Springer. Dr. Visioli is a senior member of IEEE and a member of IFAC and Anipla (Italian Association for the Automation). Aurelio Piazzi received the Laurea degree in nuclear engineer- ing in 1982 and the Ph.D. degree in system engineering in 1987, both from the University of Bologna, Italy. From 1990 to 1992, he was Research Associate in System Theory, DEIS, University of Bologna. Since 1992 he has been at the University of Parma where he is currently Full Professor of Automatic Control at the Department of Informatics Engineering. His main research in- terests are in system and control theory and related engineering applications. His recent research activities have focused on opti- mization and dynamic inversion techniques for autonomous vehi- cle guidance and for the design of high-performance control sys- tems. Scientific coordinator of bilateral research programs in col- laboration with various industries (among them CNR, ENEL, RFI -Ferrovie dello Stato), in 2002 and 2003 he has directed the Eu- ropean Project COOKIES within the EU cluster Eutist-IMV (In- tegrated Machine Vision) in collaboration with Gruppo Colussi (Perugia) for the artificial vision-based control of food industrial ovens. He is a member of IEEE and SIAM and has published over 90 scientific papers in international journals and conference proceedings.