The Routh array is a tabular method permitting one to establish the stability of a system using only the coefficients of the characteristic polynomial.  Central to the field of control systems design, the Routh–Hurwitz theorem and Routh array emerge by using the Euclidean algorithm and Sturm's theorem in evaluating Cauchy indices.
The Cauchy index
Given the system:
 
Assuming no roots of  lie on the imaginary axis, and letting
 lie on the imaginary axis, and letting
 = The number of roots of = The number of roots of with negative real parts, and with negative real parts, and
 = The number of roots of = The number of roots of with positive real parts with positive real parts
then we have
 
Expressing  in polar form, we have
 in polar form, we have
 
where
![{\displaystyle \rho (x)={\sqrt {{\mathfrak {Re}}^{2}[f(x)]+{\mathfrak {Im}}^{2}[f(x)]}}\quad (5)}](./_assets_/f3342273646dc0f1235561b387b7af52e776938a.svg) 
and 
![{\displaystyle \theta (x)=\tan ^{-1}{\big (}{\mathfrak {Im}}[f(x)]/{\mathfrak {Re}}[f(x)]{\big )}\quad (6)}](./_assets_/f7b2086266668256c2065a93ae151bb2aba594d0.svg) 
from (2) note that
 
where
 
Now if the ith root of  has a positive real part, then (using the notation y=(RE[y],IM[y]))
 has a positive real part, then (using the notation y=(RE[y],IM[y]))
![{\displaystyle {\begin{aligned}\theta _{r_{i}}(x){\big |}_{x=-j\infty }&=\angle (x-r_{i}){\big |}_{x=-j\infty }\\&=\angle (0-{\mathfrak {Re}}[r_{i}],-\infty -{\mathfrak {Im}}[r_{i}])\\&=\angle (-|{\mathfrak {Re}}[r_{i}]|,-\infty )\\&=\pi +\lim _{\phi \to \infty }\tan ^{-1}\phi ={\frac {3\pi }{2}}\quad (9)\\\end{aligned}}}](./_assets_/8b5b7395910dafa111cef24840a04b6f678dde27.svg) 
and
![{\displaystyle \theta _{r_{i}}(x){\big |}_{x=j0}=\angle (-|{\mathfrak {Re}}[r_{i}]|,0)=\pi -\tan ^{-1}0=\pi \quad (10)}](./_assets_/a8a52bccf4aeb16d032d5a102c1ae9bc8b6bcd1f.svg) 
and
![{\displaystyle \theta _{r_{i}}(x){\big |}_{x=j\infty }=\angle (-|{\mathfrak {Re}}[r_{i}]|,\infty )=\pi -\lim _{\phi \to \infty }\tan ^{-1}\phi ={\frac {\pi }{2}}\quad (11)}](./_assets_/838372f37cf13c3c184a2477039b676104cb7a5f.svg) 
Similarly, if the ith root of  has a negative real part,
 has a negative real part,
![{\displaystyle {\begin{aligned}\theta _{r_{i}}(x){\big |}_{x=-j\infty }&=\angle (x-r_{i}){\big |}_{x=-j\infty }\\&=\angle (0-{\mathfrak {Re}}[r_{i}],-\infty -{\mathfrak {Im}}[r_{i}])\\&=\angle (|{\mathfrak {Re}}[r_{i}]|,-\infty )\\&=0-\lim _{\phi \to \infty }\tan ^{1}\phi =-{\frac {\pi }{2}}\quad (12)\\\end{aligned}}}](./_assets_/cb66015512b6985b691bd082240e95221662faa4.svg) 
and
![{\displaystyle \theta _{r_{i}}(x){\big |}_{x=j0}=\angle (|{\mathfrak {Re}}[r_{i}]|,0)=\tan ^{-1}0=0\,\quad (13)}](./_assets_/f0af975bb9b398ec5e8cf3b476787d1db575c52d.svg) 
and
![{\displaystyle \theta _{r_{i}}(x){\big |}_{x=j\infty }=\angle (|{\mathfrak {Re}}[r_{i}]|,\infty )=\lim _{\phi \to \infty }\tan ^{-1}\phi ={\frac {\pi }{2}}\,\quad (14)}](./_assets_/ec04aab88fc87619bb9b6771313b6b3e63ccb771.svg) 
From (9) to (11) we find that  when the ith root of
 when the ith root of  has a positive real part, and from (12) to (14) we find that
 has a positive real part, and from (12) to (14) we find that  when the ith root of
 when the ith root of  has a negative real part.  Thus,
 has a negative real part.  Thus,
 
So, if we define
 
then we have the relationship
 
and combining (3) and (17) gives us
 and and 
Therefore, given an equation of  of degree
 of degree  we need only evaluate this function
 we need only evaluate this function  to determine
 to determine  , the number of roots with negative real parts and
, the number of roots with negative real parts and  , the number of roots with positive real parts.
, the number of roots with positive real parts.
| .jpg)  | 
| Figure 1 | 
|   versus   | 
In accordance with (6) and Figure 1, the graph of  vs
 vs  , varying
, varying  over an interval (a,b) where
 over an interval (a,b) where  and
 and  are integer multiples of
 are integer multiples of  , this variation causing the function
, this variation causing the function  to have increased by
 to have increased by  , indicates that in the course of travelling from point a to point b,
, indicates that in the course of travelling from point a to point b,  has "jumped" from
 has "jumped" from  to
 to  one more time than it has jumped from
 one more time than it has jumped from  to
 to  .  Similarly, if we vary
.  Similarly, if we vary  over an interval (a,b) this variation causing
 over an interval (a,b) this variation causing  to have decreased by
 to have decreased by  , where again
, where again  is a multiple of
 is a multiple of  at both
 at both  and
 and  , implies that
, implies that ![{\displaystyle \tan \theta (x)={\mathfrak {Im}}[f(x)]/{\mathfrak {Re}}[f(x)]}](./_assets_/517bdc0afc4cdf73846d5681bfd6527a3189b43f.svg) has jumped from
 has jumped from  to
 to  one more time than it has jumped from
 one more time than it has jumped from  to
 to  as
 as  was varied over the said interval.
 was varied over the said interval.
Thus,  is
 is  times the difference between the number of points at which
 times the difference between the number of points at which ![{\displaystyle {\mathfrak {Im}}[f(x)]/{\mathfrak {Re}}[f(x)]}](./_assets_/2f620a737220c91bbf20684bf6b26abd7231b22c.svg) jumps from
 jumps from  to
 to  and the number of points at which
 and the number of points at which ![{\displaystyle {\mathfrak {Im}}[f(x)]/{\mathfrak {Re}}[f(x)]}](./_assets_/2f620a737220c91bbf20684bf6b26abd7231b22c.svg) jumps from
 jumps from  to
 to  as
 as  ranges over the interval
 ranges over the interval  provided that at
 provided that at  ,
, ![{\displaystyle \tan[\theta (x)]}](./_assets_/1add4cb96e2e9fde725301edaec88e5603cbf8ef.svg) is defined.
 is defined.
| .svg.png)  | 
| Figure 2 | 
|   versus   | 
In the case where the starting point is on an incongruity (i.e.  , i = 0, 1, 2, ...) the ending point will be on an incongruity as well, by equation (17) (since
, i = 0, 1, 2, ...) the ending point will be on an incongruity as well, by equation (17) (since  is an integer and
 is an integer and  is an integer,
 is an integer,  will be an integer).  In this case, we can achieve this same index (difference in positive and negative jumps) by shifting the axes of the tangent function by
 will be an integer).  In this case, we can achieve this same index (difference in positive and negative jumps) by shifting the axes of the tangent function by  , through adding
, through adding  to
 to  .  Thus, our index is now fully defined for any combination of coefficients in
.  Thus, our index is now fully defined for any combination of coefficients in  by evaluating
 by evaluating ![{\displaystyle \tan[\theta ]={\mathfrak {Im}}[f(x)]/{\mathfrak {Re}}[f(x)]}](./_assets_/1ac74db804df37ddb6ef8ff4d6f721bd086850a8.svg) over the interval (a,b) =
  over the interval (a,b) =  when our starting (and thus ending) point is not an incongruity, and by evaluating
 when our starting (and thus ending) point is not an incongruity, and by evaluating
![{\displaystyle \tan[\theta '(x)]=\tan[\theta +\pi /2]=-\cot[\theta (x)]=-{\mathfrak {Re}}[f(x)]/{\mathfrak {Im}}[f(x)]\quad (19)}](./_assets_/6e718d1233f9c08d6cb4344dae637f97bc9804db.svg) 
over said interval when our starting point is at an incongruity.
This difference,  , of negative and positive jumping incongruities encountered while traversing
, of negative and positive jumping incongruities encountered while traversing  from
 from  to
 to  is called the Cauchy Index of the tangent of the phase angle, the phase angle being
 is called the Cauchy Index of the tangent of the phase angle, the phase angle being  or
 or  , depending as
, depending as  is an integer multiple of
 is an integer multiple of  or not.
 or not.
The Routh criterion
To derive Routh's criterion, first we'll use a different notation to differentiate between the even and odd terms of  :
:
 
Now we have: 
 
Therefore, if  is even,
 is even, 
![{\displaystyle {\begin{aligned}f(j\omega )&=(-1)^{n/2}{\big [}a_{0}\omega ^{n}-a_{1}\omega ^{n-2}+a_{2}\omega ^{n-4}-\cdots {\big ]}&{}\quad (23)\\&+j(-1)^{(n/2)-1}{\big [}b_{0}\omega ^{n-1}-b_{1}\omega ^{n-3}+b_{2}\omega ^{n-5}-\cdots {\big ]}&{}\\\end{aligned}}}](./_assets_/4e495902015ba0b7f57501e6d3d82ee9ab5ef62a.svg) 
and if  is odd:
 is odd:
![{\displaystyle {\begin{aligned}f(j\omega )&=j(-1)^{(n-1)/2}{\big [}a_{0}\omega ^{n}-a_{1}\omega ^{n-2}+a_{2}\omega ^{n-4}-\cdots {\big ]}&{}\quad (24)\\&+(-1)^{(n-1)/2}{\big [}b_{0}\omega ^{n-1}-b_{1}\omega ^{n-3}+b_{2}\omega ^{n-5}-\cdots {\big ]}&{}\\\end{aligned}}}](./_assets_/2031e504dd4c89445e158080035a39a2e0e17c2b.svg) 
Now observe that if  is an odd integer, then by (3)
 is an odd integer, then by (3)  is odd.  If
 is odd.  If  is an odd integer, then
 is an odd integer, then  is odd as well.  Similarly, this same argument shows that when
 is odd as well.  Similarly, this same argument shows that when  is even,
 is even,  will be even.  Equation (15) shows that if
 will be even.  Equation (15) shows that if  is even,
 is even,  is an integer multiple of
 is an integer multiple of  .  Therefore,
.  Therefore,  is defined for
 is defined for  even, and is thus the proper index to use when n is even, and similarly
 even, and is thus the proper index to use when n is even, and similarly  is defined for
 is defined for  odd, making it the proper index in this latter case.
 odd, making it the proper index in this latter case.
Thus, from (6) and (23), for  even:
 even:
![{\displaystyle \Delta =I_{-\infty }^{+\infty }{\frac {-{\mathfrak {Im}}[f(x)]}{{\mathfrak {Re}}[f(x)]}}=I_{-\infty }^{+\infty }{\frac {b_{0}\omega ^{n-1}-b_{1}\omega ^{n-3}+\cdots }{a_{0}\omega ^{n}-a_{1}\omega ^{n-2}+\ldots }}\quad (25)}](./_assets_/d9829781584a0ac5eac8c828f3b075583bb496da.svg) 
and from (19) and (24), for  odd:
 odd:
![{\displaystyle \Delta =I_{-\infty }^{+\infty }{\frac {{\mathfrak {Re}}[f(x)]}{{\mathfrak {Im}}[f(x)]}}=I_{-\infty }^{+\infty }{\frac {b_{0}\omega ^{n-1}-b_{1}\omega ^{n-3}+\ldots }{a_{0}\omega ^{n}-a_{1}\omega ^{n-2}+\ldots }}\quad (26)}](./_assets_/3d8786a9be2f8a0f8cff61b436453fa922966c5d.svg) 
Lo and behold we are evaluating the same Cauchy index for both:
 
Sturm's theorem
Sturm gives us a method for evaluating  .  His theorem states as follows:
.  His theorem states as follows:
Given a sequence of polynomials  where:
 where:
1)   If  then
 then  ,
,  , and
, and ![{\displaystyle \operatorname {sign} [f_{k-1}(x)]=-\operatorname {sign} [f_{k+1}(x)]}](./_assets_/a866748052776183bc0b2820b98b37558342d6a5.svg) 
2)    for
 for  
and we define  as the number of changes of sign in the sequence
 as the number of changes of sign in the sequence  for a fixed value of
 for a fixed value of  , then:
, then:
 
A sequence satisfying these requirements is obtained using the Euclidean algorithm, which is as follows:
Starting with  and
 and  , and denoting the remainder of
, and denoting the remainder of  by
 by  and similarly denoting the remainder of
 and similarly denoting the remainder of  by
 by  , and so on, we obtain the relationships:
, and so on, we obtain the relationships:
 
or in general 
 
where the last non-zero remainder,  will therefore be the highest common factor of
 will therefore be the highest common factor of  .  It can be observed that the sequence so constructed will satisfy the conditions of Sturm's theorem, and thus an algorithm for determining the stated index has been developed.
.  It can be observed that the sequence so constructed will satisfy the conditions of Sturm's theorem, and thus an algorithm for determining the stated index has been developed.
It is in applying Sturm's theorem (28) to (29), through the use of the Euclidean algorithm above that the Routh matrix is formed.
We get
 
and identifying the coefficients of this remainder by  ,
,  ,
,  ,
,  , and so forth, makes our formed remainder
, and so forth, makes our formed remainder 
 
where
 
Continuing with the Euclidean algorithm on these new coefficients gives us
 
where we again denote the coefficients of the remainder  by
 by  ,
,  ,
,  ,
,  ,
making our formed remainder
,
making our formed remainder 
 
and giving us
 
The rows of the Routh array are determined exactly by this algorithm when applied to the coefficients of (20).  An observation worthy of note is that in the regular case the polynomials  and
 and  have as the highest common factor
 have as the highest common factor  and thus there will be
 and thus there will be  polynomials in the chain
 polynomials in the chain  .
.
Note now, that in determining the signs of the members of the sequence of polynomials  that at
 that at  the dominating power of
 the dominating power of  will be the first term of each of these polynomials, and thus only these coefficients corresponding to the highest powers of
 will be the first term of each of these polynomials, and thus only these coefficients corresponding to the highest powers of  in
 in  , and
, and  , which are
, which are  ,
,  ,
,  ,
,  , ... determine the signs of
, ... determine the signs of  ,
,  , ...,
, ...,  at
 at  .
.
So we get  that is,
 that is,  is the number of changes of sign in the sequence
 is the number of changes of sign in the sequence  ,
,  ,
,  , ... which is the number of sign changes in the sequence
, ... which is the number of sign changes in the sequence  ,
,  ,
,  ,
,  , ... and
, ... and  ; that is
; that is  is the number of changes of sign in the sequence
 is the number of changes of sign in the sequence  ,
,  ,
,  , ... which is the number of sign changes in the sequence
, ... which is the number of sign changes in the sequence  ,
,  ,
,  ,
,  , ...
, ... 
Since our chain  ,
,  ,
,  ,
,  , ... will have
, ... will have  members it is clear that
 members it is clear that  since within
 since within  if going from
 if going from  to
 to  a sign change has not occurred, within
 a sign change has not occurred, within 
 going from
 going from  to
 to  one has, and likewise for all
 one has, and likewise for all  transitions (there will be no terms equal to zero) giving us
 transitions (there will be no terms equal to zero) giving us  total sign changes.
 total sign changes.
As  and
 and  , and from (18)
, and from (18)  , we have that
, we have that  and have derived Routh's theorem -
 and have derived Routh's theorem -
The number of roots of a real polynomial  which lie in the right half plane
 which lie in the right half plane  is equal to the number of changes of sign in the first column of the Routh scheme.
 is equal to the number of changes of sign in the first column of the Routh scheme.
And for the stable case where  then
 then  by  which we have Routh's famous criterion:
 by  which we have Routh's famous criterion:
In order for all the roots of the polynomial  to have negative real parts, it is necessary and sufficient that all of the elements in the first column of the Routh scheme be different from zero and of the same sign.
 to have negative real parts, it is necessary and sufficient that all of the elements in the first column of the Routh scheme be different from zero and of the same sign.
References
- Hurwitz, A., "On the Conditions under which an Equation has only Roots with Negative Real Parts", Rpt. in Selected Papers on Mathematical Trends in Control Theory, Ed. R. T. Ballman et al.  New York: Dover 1964
- Routh, E. J., A Treatise on the Stability of a Given State of Motion.  London: Macmillan, 1877.  Rpt. in Stability of Motion, Ed. A. T. Fuller.  London: Taylor & Francis, 1975
- Felix Gantmacher (J.L. Brenner translator) (1959) Applications of the Theory of Matrices, pp 177–80, New York: Interscience.