Root locus analysis: Difference between revisions
GreenC bot (talk | contribs) Rescued 1 archive link. Wayback Medic 2.5 per WP:URLREQ#ieee.org |
|||
(368 intermediate revisions by more than 100 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Stability criterion in control theory}}{{For|the behavior of polynomial roots in general|Geometrical properties of polynomial roots}} |
|||
In [[control theory]], a '''root locus''' is the [[Locus_(mathematics)|locus]] of the [[Pole_(complex_analysis)|poles]] and [[Zero (complex analysis)|zeros]] of a system's [[S-function]] as the system gain is varied from 1 to [[infinity]]. The root locus is one of the most useful tools for analyzing [[single input single output]] [[linear]] [[dynamic systems]]. A system is stable if all of its poles are in the left-hand side of the [[s-plane]]. |
|||
{{More citations needed|date=January 2008}}{{Moreinline|date=December 2022}}[[File:Spirule.jpg|thumb|Spirule]]In [[control theory]] and [[stability theory]], '''root locus analysis''' is a graphical method for examining how the roots of a system change with variation of a certain system [[parameter]], commonly a [[Loop gain|gain]] within a [[feedback]] system. This is a technique used as a [[stability criterion]] in the field of [[classical control theory]] developed by [[Walter R. Evans]] which can determine [[stable polynomial|stability]] of the system. The root locus plots the [[zeros and poles|poles]] of the [[closed loop transfer function]] in the complex [[s-plane|''s''-plane]] as a function of a gain parameter (see [[pole–zero plot]]). |
|||
Evans also invented in 1948 an [[analog computer]] to compute root loci, called a "Spirule" (after "spiral" and "[[slide rule]]"); it found wide use before the advent of [[digital computer]]s.<ref name="McKelvey School of Engineering at Washington University in St. Louis">{{cite web | title=1990 | website=McKelvey School of Engineering at Washington University in St. Louis | url=https://engineering.wustl.edu/offices-services/alumni/McKelvey-Engineering-Award-Years/1990.html | access-date=2023-03-12}}</ref><ref>{{Citation|last=Evans|first=Walter R.|title=Spirule Instructions|year=1965|location=Whittier, CA|publisher=The Spirule Company|author-link=Walter R. Evans}}</ref><ref name="Robert H. 2012 p. 727">{{cite book | last=Robert H. | first=J.C. | title=Dynamics of Physical Systems | publisher=Dover Publications | series=Dover Civil and Mechanical Engineering | year=2012 | isbn=978-0-486-13969-2 | url=https://books.google.com/books?id=ZVa8AQAAQBAJ&pg=PA727 | access-date=2023-03-12 | page=727}}</ref><ref name="Doebelin 1985 p. 312">{{cite book | last=Doebelin | first=E.O. | title=Control System Principles and Design | publisher=Wiley | year=1985 | isbn=978-0-471-08815-8 | url=https://books.google.com/books?id=dTmh81Dz7PgC&pg=PA312 | access-date=2023-03-12 | page=312}}</ref><ref name="Savant 1958 p. ">{{cite book | last=Savant | first=C.J. | title=Basic Feedback Control System Design | publisher=McGraw-Hill | series=Engineering special collection | year=1958 | url=https://books.google.com/books?id=DtVSAAAAMAAJ | access-date=2023-03-12 | page=}}</ref><ref name="Harris 1961 p. ">{{cite book | last=Harris | first=L.D. | title=Introduction to Feedback Systems | publisher=Wiley | year=1961 | isbn=978-0-598-48455-0 | url=https://books.google.com/books?id=9RcoAQAAMAAJ | access-date=2023-03-12 | page=}}</ref><ref name="DAzzo Houpis 1968 p. ">{{cite book | last1=D'Azzo | first1=J.J. | last2=Houpis | first2=C.H. | title=Principles of Electrical Engineering: Electric Circuits, Electronics, Instrumentation, Energy Conversion, Control Systems, Computers | publisher=C. E. Merrill Publishing Company | year=1968 | url=https://books.google.com/books?id=Ns4iAAAAMAAJ | access-date=2023-03-12 | page=}}</ref><ref name="Gupta Hasdorff 1983 p. ">{{cite book | last1=Gupta | first1=S.C. | last2=Hasdorff | first2=L. | title=Fundamentals of Automatic Control | publisher=Krieger | year=1983 | isbn=978-0-89874-578-8 | url=https://books.google.com/books?id=MRooAQAAMAAJ | access-date=2023-03-12 | page=}}</ref><ref name="Dransfield 1968 p. ">{{cite book | last=Dransfield | first=P. | title=Engineering Systems and Automatic Control | publisher=Prentice-Hall | year=1968 | url=https://books.google.com/books?id=sAZCAAAAIAAJ | access-date=2023-03-12 | page=}}</ref> |
|||
== |
==Uses== |
||
[[File:Effect of Pole Location in a Root Locus Plot.PNG|thumbnail|Effect of pole location on a second order system's natural frequency and damping ratio. This pole's [[complex conjugate]] (which necessarily exists since this pole has a nonzero imaginary component) is not shown.]] |
|||
* [http://www-me.mit.edu/Lectures/RLocus/ MIT - Lectures in Classic Control Theory]; lecture describing the root-locus, its properties, and a step-by-step procedure for constructing a root-locus. Case studies are included which illustrate how to use the root-locus for designing a control system. |
|||
In addition to determining the stability of the system, the root locus can be used to design the [[damping ratio]] (''[[Zeta|ζ]]'') and [[natural frequency]] (''ω''<sub>''n''</sub>) of a feedback system. Lines of constant damping ratio can be drawn radially from the origin and lines of constant natural frequency can be drawn as arccosine whose center points coincide with the origin. By selecting a point along the root locus that coincides with a desired damping ratio and natural frequency, a gain ''K'' can be calculated and implemented in the controller. More elaborate techniques of controller design using the root locus are available in most control textbooks: for instance, [[Lead-lag compensator|lag, lead]], PI, PD and [[PID controller|PID]] controllers can be designed approximately with this technique. |
|||
The definition of the [[damping ratio]] and [[natural frequency]] presumes that the overall feedback system is well approximated by a second order system; i.e. the system has a dominant pair of poles. This is often not the case, so it is good practice to simulate the final design to check if the project goals are satisfied. |
|||
{{stub}} |
|||
==Definition== |
|||
[[de:Wurzelortskurve]] |
|||
The root locus of a feedback system is the graphical representation in the complex [[s-plane|''s''-plane]] of the possible locations of its [[closed-loop poles]] for varying values of a certain system parameter. The points that are part of the root locus satisfy the angle condition. The value of the parameter for a certain point of the root locus can be obtained using the [[magnitude condition]]. |
|||
Suppose there is a feedback system with input signal <math>X(s)</math> and output signal <math>Y(s)</math>. The forward path [[transfer function]] is <math>G(s)</math>; the feedback path transfer function is <math>H(s)</math>. |
|||
For example, in the forward path is a motor with an expression 1/(s + 5) driving a roller with an transfer function expression 1/s. A controller with an adjustable gain K and and a transfer function expression 1/(s + 10). A unity feedback loop is introduced to complete this feedback system. Root locus analysis is then carried out on this feedback system. |
|||
[[File:Simple feedback system.svg|center]] |
|||
For this system, the [[closed-loop transfer function]] is given by{{sfn|Kuo|1967|p=331}} |
|||
:<math>T(s) = \frac{Y(s)}{X(s)} = \frac{G(s)}{1+G(s)H(s)}</math> |
|||
Thus, the closed-loop poles of the closed-loop transfer function are the roots of the characteristic equation <math>1 + G(s)H(s) = 0</math>. The roots of this equation may be found wherever <math>1+G(s)H(s) = 0</math>. |
|||
In systems without pure delay, the product <math>G(s)H(s)</math> is a rational polynomial function and may be expressed as{{sfn|Kuo|1967|p=332}} |
|||
:<math>G(s)H(s) = K \frac{ (s + z_1) (s + z_2) \cdots (s + z_m)}{(s + p_1) (s + p_2) \cdots (s + p_n) }</math> |
|||
where <math>-z_i</math> are the <math>m</math> [[zeros and poles|zeros]], <math>-p_i</math> are the <math>n</math> poles, and <math>K</math> is a scalar gain. Typically, a root locus diagram will indicate the transfer function's pole locations for varying values of the parameter <math>K</math>. A root locus plot will be all those points in the ''s''-plane where <math>G(s)H(s) = -1</math> for any value of <math>K</math>. |
|||
The factoring of <math>K</math> and the use of simple monomials means the evaluation of the rational polynomial can be done with vector techniques that add or subtract angles and multiply or divide magnitudes. The vector formulation arises from the fact that each monomial term <math>(s-a)</math> in the factored <math>G(s)H(s)</math> represents the vector from <math>a</math> to <math>s</math> in the s-plane. The polynomial can be evaluated by considering the magnitudes and angles of each of these vectors. |
|||
According to vector mathematics, the angle of the result of the rational polynomial is the sum of all the angles in the numerator minus the sum of all the angles in the denominator. So to test whether a point in the ''s''-plane is on the root locus, only the angles to all the open loop poles and zeros need be considered. This is known as the angle condition. |
|||
Similarly, the magnitude of the result of the rational polynomial is the product of all the magnitudes in the numerator divided by the product of all the magnitudes in the denominator. It turns out that the calculation of the magnitude is not needed to determine if a point in the s-plane is part of the root locus because <math>K</math> varies and can take an arbitrary real value. For each point of the root locus a value of <math>K</math> can be calculated. This is known as the magnitude condition.<!-- (have not been able to find a photo of a spirule yet.) --> |
|||
The root locus only gives the location of closed loop poles as the gain <math>K</math> is varied. The value of <math>K</math> does not affect the location of the zeros. The open-loop zeros are the same as the closed-loop zeros. |
|||
===Angle condition=== |
|||
A point <math>s</math> of the complex ''s''-plane satisfies the angle condition if |
|||
:<math>\angle (G(s)H(s)) = \pi</math> |
|||
which is the same as saying that |
|||
:<math>\sum_{i=1}^{m}\angle(s+z_i) - \sum_{i=1}^{n}\angle(s+p_i) = \pi</math> |
|||
that is, the sum of the angles from the open-loop zeros to the point <math>s</math> (measured per zero w.r.t. a horizontal running through that zero) minus the angles from the open-loop poles to the point <math>s</math> (measured per pole w.r.t. a horizontal running through that pole) has to be equal to <math>\pi</math>, or 180 [[Degree (angle)|degrees]]. Note that these interpretations should not be mistaken for the angle differences between the point <math>s</math> and the zeros/poles. |
|||
===Magnitude condition=== |
|||
A value of <math>K</math> satisfies the magnitude condition for a given <math>s</math> point of the root locus if |
|||
:<math>|G(s)H(s)| = 1</math> |
|||
which is the same as saying that |
|||
:<math> K\frac{ |s + z_1| |s + z_2| \cdots |s + z_m|}{|s + p_1| |s + p_2| \cdots |s + p_n| } = 1</math>. |
|||
==Sketching root locus== |
|||
[[Image:RL&ZARL-(1 3)-(1 3 5 1).png|thumb|300px|RL = root locus; ZARL = zero angle root locus]] |
|||
Using a few basic rules, the root locus method can plot the overall shape of the path (locus) traversed by the roots as the value of <math>K</math> varies. The plot of the root locus then gives an idea of the stability and dynamics of this feedback system for different values of <math>K</math>.<ref>{{Citation |first=W. R. |last=Evans |author-link=Walter R. Evans |title=Graphical Analysis of Control Systems |journal= Trans. AIEE |issn=0096-3860 |volume=67 |issue=1 |pages= 547–551 |date= January 1948 |doi= 10.1109/T-AIEE.1948.5059708|s2cid=51634121 }}</ref><ref>{{Citation |first=W. R. |last=Evans |author-link=Walter R. Evans |title=Control Systems Synthesis by Root Locus Method |journal=Trans. AIEE |issn=0096-3860 |volume=69 |issue=1 |pages=66–69 |date= January 1950 |doi=10.1109/T-AIEE.1950.5060121 |s2cid=51633514 }}</ref> The rules are the following: |
|||
* Mark open-loop poles and zeros |
|||
* Mark real axis portion to the left of an odd number of poles and zeros |
|||
* Find [[asymptote]]s |
|||
Let ''P'' be the number of poles and ''Z'' be the number of zeros: |
|||
:<math>P - Z = \text{number of asymptotes} \, </math> |
|||
The asymptotes intersect the real axis at <math>\alpha</math> (which is called the centroid) and depart at angle <math>\phi</math> given by: |
|||
:<math>\phi_l = \frac{180^\circ + (l - 1)360^\circ}{P-Z}, l = 1, 2, \ldots, P - Z</math> |
|||
:<math>\alpha = \frac{\operatorname{Re}\left(\sum_P - \sum_Z\right)}{P - Z}</math> |
|||
where <math>\sum_P</math> is the sum of all the locations of the poles, <math>\sum_Z</math> is the sum of all the locations of the explicit zeros and <math>\operatorname{Re}()</math> denotes that we are only interested in the real part. |
|||
* Phase condition on test point to find angle of departure |
|||
* Compute breakaway/break-in points |
|||
The breakaway points are located at the roots of the following equation: |
|||
:<math>\frac{dG(s)H(s)}{ds} = 0\text{ or }\frac{d\overline{GH}(z)}{dz} = 0</math> |
|||
Once you solve for ''z'', the real roots give you the breakaway/reentry points. Complex roots correspond to a lack of breakaway/reentry. |
|||
==Plotting root locus== |
|||
Given the general closed-loop denominator rational polynomial |
|||
:<math> 1 + G(s)H(s) = 1 + K \frac{b_m s^m + \ldots + b_1 s + b_0}{s^n + a_{n-1}s^{n-1} + \ldots + a_1 s + a_0}, </math> |
|||
the characteristic equation can be simplified to |
|||
:<math> s^n + a_{n-1}s^{n-1} + \ldots + (a_m + K b_m)s^m + \ldots + (a_1 + K b_1)s + (a_0 + K b_0) = 0.</math> |
|||
The solutions of <math>s</math> to this equation are the root loci of the closed-loop transfer function. |
|||
===Example=== |
|||
Given |
|||
:<math> 1 + G(s)H(s) = 1 + K \frac{s + 3}{s^3 + 3s^2 + 5s + 1}, </math> |
|||
we will have the characteristic equation |
|||
:<math> s^3 + 3s^2 + (5 + K)s + (1 + 3 K) = 0. </math> |
|||
The following MATLAB code will plot the root locus of the closed-loop transfer function as <math>K</math> varies using the described manual method as well as the <code>rlocus</code> built-in function: |
|||
<syntaxhighlight lang="Matlab"> |
|||
% Manual method |
|||
K_array = (0:0.1:220).'; % .' is a transpose. Looking up in Matlab documentation. |
|||
NK = length(K_array); |
|||
x_array = zeros(NK, 3); |
|||
y_array = zeros(NK, 3); |
|||
for nK = 1:NK |
|||
K = K_array(nK); |
|||
C = [1, 3, (5 + K), (1 + 3*K)]; |
|||
r = roots(C).'; |
|||
x_array(nK,:) = real(r); |
|||
y_array(nK,:) = imag(r); |
|||
end |
|||
figure(); |
|||
plot(x_array, y_array); |
|||
grid on; |
|||
% Built-in method |
|||
sys = tf([1, 3], [1, 3, 5, 1]); |
|||
figure(); |
|||
rlocus(sys); |
|||
</syntaxhighlight> |
|||
[[File:Root Locus Plot.png|thumb|315x315px|Root Locus Plot]] |
|||
The following Python code can also be used to calculate and plot the root locus of the closed-loop transfer function using the Python Control Systems Library<ref>{{Citation |title=The Python Control Systems Library |date=2023-12-19 |url=https://github.com/python-control/python-control |access-date=2023-12-19 |publisher=Control Systems Library for Python}}</ref> and Matplotlib<ref>{{Cite web |title=Matplotlib — Visualization with Python |url=https://matplotlib.org/ |access-date=2023-12-19 |website=matplotlib.org}}</ref>.<syntaxhighlight lang="python" line="1"> |
|||
import control as ct |
|||
import matplotlib.pyplot as plt |
|||
# Define the transfer function |
|||
sys = ct.TransferFunction([1, 3], [1, 3, 5, 1]) |
|||
# Calculate and plot the root locus |
|||
roots, gains = ct.root_locus(sys, plot=True) |
|||
plt.show() |
|||
</syntaxhighlight> |
|||
==''z''-plane versus ''s''-plane== |
|||
<!-- There is an image here but I can't get it to display: [[b:Image:Bilinear Transform Mapping.svg]] --> |
|||
The root locus method can also be used for the analysis of [[sampled data systems]] by computing the root locus in the [[z-transform|''z''-plane]], the discrete counterpart of the ''s''-plane. The equation {{math|''z'' {{=}} ''e''<sup>''sT''</sup>}} maps continuous ''s''-plane poles (not zeros) into the ''z''-domain, where {{mvar|T}} is the sampling period. The stable, left half ''s''-plane maps into the interior of the unit circle of the ''z''-plane, with the ''s''-plane origin equating to ''|z|'' = 1 (because ''e''<sup>0</sup> = 1). A diagonal line of constant damping in the ''s''-plane maps around a spiral from (1,0) in the ''z'' plane as it curves in toward the origin. The Nyquist [[aliasing]] criteria is expressed graphically in the ''z''-plane by the ''x''-axis, where {{math|''ωnT'' {{=}} ''π''}}. The line of constant damping just described spirals in indefinitely but in sampled data systems, frequency content is aliased down to lower frequencies by integral multiples of the [[Nyquist frequency]]. That is, the sampled response appears as a lower frequency and better damped as well since the root in the ''z''-plane maps equally well to the first loop of a different, better damped spiral curve of constant damping. Many other interesting and relevant mapping properties can be described, not least that ''z''-plane controllers, having the property that they may be directly implemented from the ''z''-plane transfer function (zero/pole ratio of polynomials), can be imagined graphically on a ''z''-plane plot of the open loop transfer function, and immediately analyzed utilizing root locus. |
|||
Since root locus is a graphical angle technique, root locus rules work the same in the {{mvar|z}} and {{mvar|s}} planes. |
|||
The idea of a root locus can be applied to many systems where a single parameter {{mvar|K}} is varied. For example, it is useful to sweep any system parameter for which the exact value is uncertain in order to determine its behavior. |
|||
==See also== |
|||
* [[Phase margin]] |
|||
* [[Routh–Hurwitz stability criterion]] |
|||
* [[Nyquist stability criterion]] |
|||
* [[Bode plot#Gain margin and phase margin|Gain and phase margin]] |
|||
* [[Bode plot]] |
|||
== References == |
|||
{{reflist|25em}} |
|||
* {{cite book |last=Kuo |first=Benjamin C. |title=Automatic Control Systems |edition=second |publisher=Prentice-Hall |location=Englewood Cliffs, NJ |year=1967 |lccn=67016388 |asin=B000KPT04C |oclc=3805225 |chapter=Root Locus Technique |pages=329–388}} |
|||
==Further reading== |
|||
* {{Citation |
|||
|title= Numerical Computation of Root Loci Using the Newton-Raphson Technique |
|||
|first1= R. H. |
|||
|last1=Ash |
|||
|first2= G. H. |
|||
|last2= Ash |
|||
|journal= IEEE Transactions on Automatic Control |
|||
|date= October 1968 |
|||
|volume= 13 |
|||
|issue= 5 |
|||
|pages= 576–582 |
|||
|doi= 10.1109/TAC.1968.1098980}} |
|||
* {{Citation |
|||
|title= Design Data to assist the Plotting of Root Loci (Part I) |
|||
|first= S. E. |
|||
|last= Williamson |
|||
|journal=Control Magazine |
|||
|date= May 1968 |
|||
|volume= 12 |
|||
|issue= 119 |
|||
|pages= 404–407 |
|||
}} |
|||
* {{Citation |
|||
|title= Design Data to assist the Plotting of Root Loci (Part II) |
|||
|first= S. E. |
|||
|last= Williamson |
|||
|journal=Control Magazine |
|||
|date= June 1968 |
|||
|volume= 12 |
|||
|issue= 120 |
|||
|pages= 556–559 |
|||
}} |
|||
* {{Citation |
|||
|title= Design Data to assist the Plotting of Root Loci (Part III) |
|||
|first= S. E. |
|||
|last= Williamson |
|||
|journal=Control Magazine |
|||
|date= July 1968 |
|||
|volume= 12 |
|||
|issue= 121 |
|||
|pages= 645–647 |
|||
}} |
|||
* {{Citation |
|||
|title=Computer Program to Obtain the Time Response of Sampled Data Systems |
|||
|first= S. E. |
|||
|last= Williamson |
|||
|journal= Electronics Letters |
|||
|volume=5 |
|||
|issue= 10 |
|||
|pages= 209–210 |
|||
|date= May 15, 1969 |
|||
|doi= 10.1049/el:19690159|bibcode= 1969ElL.....5..209W |
|||
}} |
|||
* {{Citation |
|||
|title= Accurate root locus plotting including the effects of pure time delay. Computer-program description |
|||
|url= https://ieeexplore.ieee.org/document/5249527 |
|||
|archive-url= https://web.archive.org/web/20190629123900/https://ieeexplore.ieee.org/document/5249527/ |
|||
|url-status= dead |
|||
|archive-date= June 29, 2019 |
|||
|first= S. E. |
|||
|last= Williamson |
|||
|journal= Proceedings of the Institution of Electrical Engineers |
|||
|volume= 116 |
|||
|issue= 7 |
|||
|pages= 1269–1271 |
|||
|date= July 1969 |
|||
|doi= 10.1049/piee.1969.0235}} |
|||
==External links== |
|||
* [[b:Control Systems/Root Locus|Wikibooks: Control Systems/Root Locus]] |
|||
* [http://www.engin.umich.edu/group/ctm/rlocus/rlocus.html Carnegie Mellon / University of Michigan Tutorial] |
|||
* [http://www.swarthmore.edu/NatSci/echeeve1/Ref/LPSA/Root_Locus/RLocusExamples.html#ex5 Excellent examples. Start with example 5 and proceed backwards through 4 to 1. Also visit the main page] |
|||
* [https://web.archive.org/web/20070301215842/http://www.atp.ruhr-uni-bochum.de/rt1/syscontrol/node46.html The root-locus method: Drawing by hand techniques] |
|||
* [http://www.coppice.myzen.co.uk "RootLocs": A free multi-featured root-locus plotter for Mac and Windows platforms] |
|||
* [https://web.archive.org/web/20091027092528/http://geocities.com/aseldawy/root_locus.html "Root Locus": A free root-locus plotter/analyzer for Windows] |
|||
* [http://wikis.controltheorypro.com/index.php?title=Root_Locus Root Locus at ControlTheoryPro.com] |
|||
* [http://www.roymech.co.uk/Related/Control/root_locus.html Root Locus Analysis of Control Systems] |
|||
* [http://www.mathworks.com/help/toolbox/control/ref/rlocus.html MATLAB function for computing root locus of a SISO open-loop model] |
|||
* {{Citation |
|||
|last=Wechsler |first= E. R. |
|||
|url= http://ipnpr.jpl.nasa.gov/progress_report/42-73/73F.PDF |
|||
|title= Root Locus Algorithms for Programmable Pocket Calculators |
|||
|journal= Telecommunications and Data Acquisition Progress Report |
|||
|volume= 73 |
|||
|publisher= NASA |
|||
|date= January–March 1983 |
|||
|pages= 60–64 |
|||
|bibcode= 1983TDAPR..73...60W |
|||
}} |
|||
* [http://reference.wolfram.com/mathematica/ref/RootLocusPlot.html Mathematica function for plotting the root locus] |
|||
* {{cite journal |last1=Šekara |first1=Tomislav B. |last2=Rapaić |first2=Milan R. |title=A revision of root locus method with applications |journal=Journal of Process Control |date=1 October 2015 |volume=34 |pages=26–34 |doi=10.1016/j.jprocont.2015.07.007 }} |
|||
[[Category:Classical control theory]] |
|||
The location of the roots ( poles and zeros ) are found for each adjustment of value K. The calculation can be laborious. A few simple steps, the root locus method, can locate the overall shape of the path ( locus )traversed by the roots and can give you an approximate location of the poles as K value increases from 0 to a large number, hence, give an idea of the stability of this unity feedback system for different values of K. |
Latest revision as of 04:52, 31 July 2024
This article needs additional citations for verification. (January 2008) |
This article includes a list of general references, but it lacks sufficient corresponding inline citations. (December 2022) |
In control theory and stability theory, root locus analysis is a graphical method for examining how the roots of a system change with variation of a certain system parameter, commonly a gain within a feedback system. This is a technique used as a stability criterion in the field of classical control theory developed by Walter R. Evans which can determine stability of the system. The root locus plots the poles of the closed loop transfer function in the complex s-plane as a function of a gain parameter (see pole–zero plot).
Evans also invented in 1948 an analog computer to compute root loci, called a "Spirule" (after "spiral" and "slide rule"); it found wide use before the advent of digital computers.[1][2][3][4][5][6][7][8][9]
Uses
[edit]In addition to determining the stability of the system, the root locus can be used to design the damping ratio (ζ) and natural frequency (ωn) of a feedback system. Lines of constant damping ratio can be drawn radially from the origin and lines of constant natural frequency can be drawn as arccosine whose center points coincide with the origin. By selecting a point along the root locus that coincides with a desired damping ratio and natural frequency, a gain K can be calculated and implemented in the controller. More elaborate techniques of controller design using the root locus are available in most control textbooks: for instance, lag, lead, PI, PD and PID controllers can be designed approximately with this technique.
The definition of the damping ratio and natural frequency presumes that the overall feedback system is well approximated by a second order system; i.e. the system has a dominant pair of poles. This is often not the case, so it is good practice to simulate the final design to check if the project goals are satisfied.
Definition
[edit]The root locus of a feedback system is the graphical representation in the complex s-plane of the possible locations of its closed-loop poles for varying values of a certain system parameter. The points that are part of the root locus satisfy the angle condition. The value of the parameter for a certain point of the root locus can be obtained using the magnitude condition.
Suppose there is a feedback system with input signal and output signal . The forward path transfer function is ; the feedback path transfer function is .
For this system, the closed-loop transfer function is given by[10]
Thus, the closed-loop poles of the closed-loop transfer function are the roots of the characteristic equation . The roots of this equation may be found wherever .
In systems without pure delay, the product is a rational polynomial function and may be expressed as[11]
where are the zeros, are the poles, and is a scalar gain. Typically, a root locus diagram will indicate the transfer function's pole locations for varying values of the parameter . A root locus plot will be all those points in the s-plane where for any value of .
The factoring of and the use of simple monomials means the evaluation of the rational polynomial can be done with vector techniques that add or subtract angles and multiply or divide magnitudes. The vector formulation arises from the fact that each monomial term in the factored represents the vector from to in the s-plane. The polynomial can be evaluated by considering the magnitudes and angles of each of these vectors.
According to vector mathematics, the angle of the result of the rational polynomial is the sum of all the angles in the numerator minus the sum of all the angles in the denominator. So to test whether a point in the s-plane is on the root locus, only the angles to all the open loop poles and zeros need be considered. This is known as the angle condition.
Similarly, the magnitude of the result of the rational polynomial is the product of all the magnitudes in the numerator divided by the product of all the magnitudes in the denominator. It turns out that the calculation of the magnitude is not needed to determine if a point in the s-plane is part of the root locus because varies and can take an arbitrary real value. For each point of the root locus a value of can be calculated. This is known as the magnitude condition.
The root locus only gives the location of closed loop poles as the gain is varied. The value of does not affect the location of the zeros. The open-loop zeros are the same as the closed-loop zeros.
Angle condition
[edit]A point of the complex s-plane satisfies the angle condition if
which is the same as saying that
that is, the sum of the angles from the open-loop zeros to the point (measured per zero w.r.t. a horizontal running through that zero) minus the angles from the open-loop poles to the point (measured per pole w.r.t. a horizontal running through that pole) has to be equal to , or 180 degrees. Note that these interpretations should not be mistaken for the angle differences between the point and the zeros/poles.
Magnitude condition
[edit]A value of satisfies the magnitude condition for a given point of the root locus if
which is the same as saying that
- .
Sketching root locus
[edit]Using a few basic rules, the root locus method can plot the overall shape of the path (locus) traversed by the roots as the value of varies. The plot of the root locus then gives an idea of the stability and dynamics of this feedback system for different values of .[12][13] The rules are the following:
- Mark open-loop poles and zeros
- Mark real axis portion to the left of an odd number of poles and zeros
- Find asymptotes
Let P be the number of poles and Z be the number of zeros:
The asymptotes intersect the real axis at (which is called the centroid) and depart at angle given by:
where is the sum of all the locations of the poles, is the sum of all the locations of the explicit zeros and denotes that we are only interested in the real part.
- Phase condition on test point to find angle of departure
- Compute breakaway/break-in points
The breakaway points are located at the roots of the following equation:
Once you solve for z, the real roots give you the breakaway/reentry points. Complex roots correspond to a lack of breakaway/reentry.
Plotting root locus
[edit]Given the general closed-loop denominator rational polynomial
the characteristic equation can be simplified to
The solutions of to this equation are the root loci of the closed-loop transfer function.
Example
[edit]Given
we will have the characteristic equation
The following MATLAB code will plot the root locus of the closed-loop transfer function as varies using the described manual method as well as the rlocus
built-in function:
% Manual method
K_array = (0:0.1:220).'; % .' is a transpose. Looking up in Matlab documentation.
NK = length(K_array);
x_array = zeros(NK, 3);
y_array = zeros(NK, 3);
for nK = 1:NK
K = K_array(nK);
C = [1, 3, (5 + K), (1 + 3*K)];
r = roots(C).';
x_array(nK,:) = real(r);
y_array(nK,:) = imag(r);
end
figure();
plot(x_array, y_array);
grid on;
% Built-in method
sys = tf([1, 3], [1, 3, 5, 1]);
figure();
rlocus(sys);
The following Python code can also be used to calculate and plot the root locus of the closed-loop transfer function using the Python Control Systems Library[14] and Matplotlib[15].
import control as ct
import matplotlib.pyplot as plt
# Define the transfer function
sys = ct.TransferFunction([1, 3], [1, 3, 5, 1])
# Calculate and plot the root locus
roots, gains = ct.root_locus(sys, plot=True)
plt.show()
z-plane versus s-plane
[edit]The root locus method can also be used for the analysis of sampled data systems by computing the root locus in the z-plane, the discrete counterpart of the s-plane. The equation z = esT maps continuous s-plane poles (not zeros) into the z-domain, where T is the sampling period. The stable, left half s-plane maps into the interior of the unit circle of the z-plane, with the s-plane origin equating to |z| = 1 (because e0 = 1). A diagonal line of constant damping in the s-plane maps around a spiral from (1,0) in the z plane as it curves in toward the origin. The Nyquist aliasing criteria is expressed graphically in the z-plane by the x-axis, where ωnT = π. The line of constant damping just described spirals in indefinitely but in sampled data systems, frequency content is aliased down to lower frequencies by integral multiples of the Nyquist frequency. That is, the sampled response appears as a lower frequency and better damped as well since the root in the z-plane maps equally well to the first loop of a different, better damped spiral curve of constant damping. Many other interesting and relevant mapping properties can be described, not least that z-plane controllers, having the property that they may be directly implemented from the z-plane transfer function (zero/pole ratio of polynomials), can be imagined graphically on a z-plane plot of the open loop transfer function, and immediately analyzed utilizing root locus.
Since root locus is a graphical angle technique, root locus rules work the same in the z and s planes.
The idea of a root locus can be applied to many systems where a single parameter K is varied. For example, it is useful to sweep any system parameter for which the exact value is uncertain in order to determine its behavior.
See also
[edit]- Phase margin
- Routh–Hurwitz stability criterion
- Nyquist stability criterion
- Gain and phase margin
- Bode plot
References
[edit]- ^ "1990". McKelvey School of Engineering at Washington University in St. Louis. Retrieved 2023-03-12.
- ^ Evans, Walter R. (1965), Spirule Instructions, Whittier, CA: The Spirule Company
- ^ Robert H., J.C. (2012). Dynamics of Physical Systems. Dover Civil and Mechanical Engineering. Dover Publications. p. 727. ISBN 978-0-486-13969-2. Retrieved 2023-03-12.
- ^ Doebelin, E.O. (1985). Control System Principles and Design. Wiley. p. 312. ISBN 978-0-471-08815-8. Retrieved 2023-03-12.
- ^ Savant, C.J. (1958). Basic Feedback Control System Design. Engineering special collection. McGraw-Hill. Retrieved 2023-03-12.
- ^ Harris, L.D. (1961). Introduction to Feedback Systems. Wiley. ISBN 978-0-598-48455-0. Retrieved 2023-03-12.
- ^ D'Azzo, J.J.; Houpis, C.H. (1968). Principles of Electrical Engineering: Electric Circuits, Electronics, Instrumentation, Energy Conversion, Control Systems, Computers. C. E. Merrill Publishing Company. Retrieved 2023-03-12.
- ^ Gupta, S.C.; Hasdorff, L. (1983). Fundamentals of Automatic Control. Krieger. ISBN 978-0-89874-578-8. Retrieved 2023-03-12.
- ^ Dransfield, P. (1968). Engineering Systems and Automatic Control. Prentice-Hall. Retrieved 2023-03-12.
- ^ Kuo 1967, p. 331.
- ^ Kuo 1967, p. 332.
- ^ Evans, W. R. (January 1948), "Graphical Analysis of Control Systems", Trans. AIEE, 67 (1): 547–551, doi:10.1109/T-AIEE.1948.5059708, ISSN 0096-3860, S2CID 51634121
- ^ Evans, W. R. (January 1950), "Control Systems Synthesis by Root Locus Method", Trans. AIEE, 69 (1): 66–69, doi:10.1109/T-AIEE.1950.5060121, ISSN 0096-3860, S2CID 51633514
- ^ The Python Control Systems Library, Control Systems Library for Python, 2023-12-19, retrieved 2023-12-19
- ^ "Matplotlib — Visualization with Python". matplotlib.org. Retrieved 2023-12-19.
- Kuo, Benjamin C. (1967). "Root Locus Technique". Automatic Control Systems (second ed.). Englewood Cliffs, NJ: Prentice-Hall. pp. 329–388. ASIN B000KPT04C. LCCN 67016388. OCLC 3805225.
Further reading
[edit]- Ash, R. H.; Ash, G. H. (October 1968), "Numerical Computation of Root Loci Using the Newton-Raphson Technique", IEEE Transactions on Automatic Control, 13 (5): 576–582, doi:10.1109/TAC.1968.1098980
- Williamson, S. E. (May 1968), "Design Data to assist the Plotting of Root Loci (Part I)", Control Magazine, 12 (119): 404–407
- Williamson, S. E. (June 1968), "Design Data to assist the Plotting of Root Loci (Part II)", Control Magazine, 12 (120): 556–559
- Williamson, S. E. (July 1968), "Design Data to assist the Plotting of Root Loci (Part III)", Control Magazine, 12 (121): 645–647
- Williamson, S. E. (May 15, 1969), "Computer Program to Obtain the Time Response of Sampled Data Systems", Electronics Letters, 5 (10): 209–210, Bibcode:1969ElL.....5..209W, doi:10.1049/el:19690159
- Williamson, S. E. (July 1969), "Accurate root locus plotting including the effects of pure time delay. Computer-program description", Proceedings of the Institution of Electrical Engineers, 116 (7): 1269–1271, doi:10.1049/piee.1969.0235, archived from the original on June 29, 2019
External links
[edit]- Wikibooks: Control Systems/Root Locus
- Carnegie Mellon / University of Michigan Tutorial
- Excellent examples. Start with example 5 and proceed backwards through 4 to 1. Also visit the main page
- The root-locus method: Drawing by hand techniques
- "RootLocs": A free multi-featured root-locus plotter for Mac and Windows platforms
- "Root Locus": A free root-locus plotter/analyzer for Windows
- Root Locus at ControlTheoryPro.com
- Root Locus Analysis of Control Systems
- MATLAB function for computing root locus of a SISO open-loop model
- Wechsler, E. R. (January–March 1983), "Root Locus Algorithms for Programmable Pocket Calculators" (PDF), Telecommunications and Data Acquisition Progress Report, 73, NASA: 60–64, Bibcode:1983TDAPR..73...60W
- Mathematica function for plotting the root locus
- Šekara, Tomislav B.; Rapaić, Milan R. (1 October 2015). "A revision of root locus method with applications". Journal of Process Control. 34: 26–34. doi:10.1016/j.jprocont.2015.07.007.