At instance  , the
, the  (complex-valued) output signals (measurements)
 (complex-valued) output signals (measurements) ![{\textstyle y_{m}[t]}](//wikimedia.org/api/rest_v1/media/math/render/svg/7cec8b7ea57e392c3751759f186b097f37ebcd5b) ,
,  , of the system are related to the
, of the system are related to the  (complex-valued) input signals
 (complex-valued) input signals ![{\textstyle x_{k}[t]}](//wikimedia.org/api/rest_v1/media/math/render/svg/002ef890715b5fb15e4835840bb6f23f6d2b93c6) ,
,  , as
, as![{\displaystyle y_{m}[t]=\sum _{k=1}^{K}a_{m,k}x_{k}[t]+n_{m}[t],}](//wikimedia.org/api/rest_v1/media/math/render/svg/3f1b92adae299092f734a97ddcb04d9d1c1dfd94) where
 where ![{\textstyle n_{m}[t]}](//wikimedia.org/api/rest_v1/media/math/render/svg/bffa9e35a362d3ca33ef175ae0caef36f96dab4c) denotes the noise added by the system. The one-dimensional form of ESPRIT can be applied if the weights have the form
 denotes the noise added by the system. The one-dimensional form of ESPRIT can be applied if the weights have the form  , whose phases are integer multiples of some radial frequency
, whose phases are integer multiples of some radial frequency  . This frequency only depends on the index of the system's input, i.e.
. This frequency only depends on the index of the system's input, i.e.  . The goal of ESPRIT is to estimate
. The goal of ESPRIT is to estimate  's, given the outputs
's, given the outputs ![{\textstyle y_{m}[t]}](//wikimedia.org/api/rest_v1/media/math/render/svg/7cec8b7ea57e392c3751759f186b097f37ebcd5b) and the number of input signals,
 and the number of input signals,  . Since the radial frequencies are the actual objectives,
. Since the radial frequencies are the actual objectives,  is denoted as
 is denoted as  .
.   
Collating the weights  as
 as ![{\displaystyle \mathbf {a} (\omega _{k})=[\,1\,\ e^{-j\omega _{k}}\,\ e^{-j2\omega _{k}}\,\ ...\,\ e^{-j(M-1)\omega _{k}}\,]^{\top }}](//wikimedia.org/api/rest_v1/media/math/render/svg/d5d3e0e3ade790b20a979fe90b81a27faca6efa1) and the
 and the  output signals at instance
 output signals at instance  as
 as ![{\displaystyle \mathbf {y} [t]=[\,y_{1}[t]\,\ y_{2}[t]\,\ ...\,\ y_{M}[t]\,]^{\top }}](//wikimedia.org/api/rest_v1/media/math/render/svg/17f0ff33805dc1aeca5b0d0122a2d612d1949e50) ,
, ![{\displaystyle \mathbf {y} [t]=\sum _{k=1}^{K}\mathbf {a} (\omega _{k})x_{k}[t]+\mathbf {n} [t],}](//wikimedia.org/api/rest_v1/media/math/render/svg/ace50535a35edc7e1934bc13a9d0a5f43ed68e96) where
where ![{\displaystyle \mathbf {n} [t]=[\,n_{1}[t]\,\ n_{2}[t]\,\ ...\,\ n_{M}[t]\,]^{\top }}](//wikimedia.org/api/rest_v1/media/math/render/svg/f1cc909553dbf2fdd278ba280f4afab22bb584c5) . Further, when the weight vectors
. Further, when the weight vectors  are put into a Vandermonde matrix
 are put into a Vandermonde matrix ![{\displaystyle \mathbf {A} =[\,\mathbf {a} (\omega _{1})\,\ \mathbf {a} (\omega _{2})\,\ ...\,\ \mathbf {a} (\omega _{K})\,]}](//wikimedia.org/api/rest_v1/media/math/render/svg/907101e1e6a08760d4288819ec9fa90757ed9a9d) , and the
, and the  inputs at instance
 inputs at instance  into a vector
 into a vector ![{\displaystyle \mathbf {x} [t]=[\,x_{1}[t]\,\ ...\,\ x_{K}[t]\,]^{\top }}](//wikimedia.org/api/rest_v1/media/math/render/svg/f96ebb6ed010b4596eeecf7457f4c774c2e6b170) , we can write
, we can write![{\displaystyle \mathbf {y} [t]=\mathbf {A} \,\mathbf {x} [t]+\mathbf {n} [t].}](//wikimedia.org/api/rest_v1/media/math/render/svg/c2e2f82c22641c822443c94d025691050a275d03) With several measurements at instances
 With several measurements at instances  and the notations
 and the notations ![{\textstyle \mathbf {Y} =[\,\mathbf {y} [1]\,\ \mathbf {y} [2]\,\ \dots \,\ \mathbf {y} [T]\,]}](//wikimedia.org/api/rest_v1/media/math/render/svg/76b139810b8afe71ebfa2b8b4cd03ac649f34daa) ,
, ![{\textstyle \mathbf {X} =[\,\mathbf {x} [1]\,\ \mathbf {x} [2]\,\ \dots \,\ \mathbf {x} [T]\,]}](//wikimedia.org/api/rest_v1/media/math/render/svg/2fc240c92a9e936bff1d58f97214c9388f174b95) and
 and ![{\textstyle \mathbf {N} =[\,\mathbf {n} [1]\,\ \mathbf {n} [2]\,\ \dots \,\ \mathbf {n} [T]\,]}](//wikimedia.org/api/rest_v1/media/math/render/svg/d52ca548b1d16679e252b0baae634e206dfce86c) , the model equation becomes
, the model equation becomes
Signal subspace
The singular value decomposition (SVD) of  is given as
 is given as where
 where  and
 and  are unitary matrices and
 are unitary matrices and  is a diagonal matrix of size
 is a diagonal matrix of size  , that holds the singular values from the largest (top left) in descending order. The operator
, that holds the singular values from the largest (top left) in descending order. The operator  denotes the complex-conjugate transpose (Hermitian transpose).
 denotes the complex-conjugate transpose (Hermitian transpose). 
Let us assume that  . Notice that we have
. Notice that we have  input signals. If there was no noise, there would only be
 input signals. If there was no noise, there would only be  non-zero singular values. We assume that the
 non-zero singular values. We assume that the  largest singular values stem from these input signals and other singular values are presumed to stem from noise. The matrices in the SVD of
 largest singular values stem from these input signals and other singular values are presumed to stem from noise. The matrices in the SVD of  can be partitioned into submatrices, where some submatrices correspond to the signal subspace and some correspond to the noise subspace.
 can be partitioned into submatrices, where some submatrices correspond to the signal subspace and some correspond to the noise subspace. where
 where  and
 and  contain the first
 contain the first  columns of
 columns of  and
 and  , respectively and
, respectively and  is a diagonal matrix comprising the
is a diagonal matrix comprising the  largest singular values.
 largest singular values. 
Thus, The SVD can be written as where
 where  , 
,  , and
, and  represent the contribution of the input signal
 represent the contribution of the input signal ![{\textstyle x_{k}[t]}](//wikimedia.org/api/rest_v1/media/math/render/svg/002ef890715b5fb15e4835840bb6f23f6d2b93c6) to
 to  . We term
. We term  the signal subspace. In contrast,
 the signal subspace. In contrast,  ,
,  , and
, and  represent the contribution of noise
 represent the contribution of noise ![{\textstyle n_{m}[t]}](//wikimedia.org/api/rest_v1/media/math/render/svg/bffa9e35a362d3ca33ef175ae0caef36f96dab4c) to
 to  .
. 
Hence, from the system model, we can write  and
 and  . Also, from the former, we can write
. Also, from the former, we can write where
 where  . In the sequel, it is only important that there exists such an invertible matrix
. In the sequel, it is only important that there exists such an invertible matrix  and its actual content will not be important.
 and its actual content will not be important.
Note: The signal subspace can also be extracted from the spectral decomposition of the auto-correlation matrix of the measurements, which is estimated as![{\displaystyle \mathbf {R} _{\mathrm {YY} }={\frac {1}{T}}\sum _{t=1}^{T}\mathbf {y} [t]\mathbf {y} [t]^{\dagger }={\frac {1}{T}}\mathbf {Y} \mathbf {Y} ^{\dagger }={\frac {1}{T}}\mathbf {U} {\mathbf {\Sigma } \mathbf {\Sigma } ^{\dagger }}\mathbf {U} ^{\dagger }={\frac {1}{T}}\mathbf {U} _{\mathrm {S} }\mathbf {\Sigma } _{\mathrm {S} }^{2}\mathbf {U} _{\mathrm {S} }^{\dagger }+{\frac {1}{T}}\mathbf {U} _{\mathrm {N} }\mathbf {\Sigma } _{\mathrm {N} }^{2}\mathbf {U} _{\mathrm {N} }^{\dagger }.}](//wikimedia.org/api/rest_v1/media/math/render/svg/ffaea5135fb57d4a2d2b3fec9cb8cfeb39cda28a)
Estimation of radial frequencies
We have established two expressions so far:  and
 and  . Now,
. Now,  where
 where  and
 and  denote the truncated signal sub spaces, and
 denote the truncated signal sub spaces, and  The above equation has the form of an eigenvalue decomposition, and the phases of the eigenvalues in the diagonal matrix
The above equation has the form of an eigenvalue decomposition, and the phases of the eigenvalues in the diagonal matrix  are used to estimate the radial frequencies.
 are used to estimate the radial frequencies.  
Thus, after solving for  in the relation
 in the relation  , we would find the eigenvalues
, we would find the eigenvalues  of
 of  , where
, where  , and the radial frequencies
, and the radial frequencies  are estimated as the phases (argument) of the eigenvalues.
 are estimated as the phases (argument) of the eigenvalues. 
Remark: In general,  is not invertible. One can use the least squares estimate
 is not invertible. One can use the least squares estimate  . An alternative would be the total least squares estimate.
. An alternative would be the total least squares estimate.
Algorithm summary
Input: Measurements  :=[\,\mathbf {y} [1]\,\ \mathbf {y} [2]\,\ \dots \,\ \mathbf {y} [T]\,]}
  
![{\textstyle \mathbf {Y} :=[\,\mathbf {y} [1]\,\ \mathbf {y} [2]\,\ \dots \,\ \mathbf {y} [T]\,]}](//wikimedia.org/api/rest_v1/media/math/render/svg/13bd8ef9fdd9d30748044da47b0609c69dac7845) , the number of input signals
, the number of input signals  (estimate if not already known).
 (estimate if not already known).
- Compute the singular value decomposition (SVD) of  and extract the signal subspace and extract the signal subspace as the first as the first columns of columns of . .
- Compute  and and , where , where![{\displaystyle \mathbf {J} _{1}=[\mathbf {I} _{M-1}\quad \mathbf {0} ]}](//wikimedia.org/api/rest_v1/media/math/render/svg/d8106898387fbfd491aeba760285097359cc08cf) and and![{\displaystyle \mathbf {J} _{2}=[\mathbf {0} \quad \mathbf {I} _{M-1}]}](//wikimedia.org/api/rest_v1/media/math/render/svg/3939f3c571a47bb94f80f5ef511c43bd35b85203) . .
- Solve for  in in (see the remark above). (see the remark above).
- Compute the eigenvalues  of of . .
- The phases of the eigenvalues  provide the radial frequencies provide the radial frequencies , i.e., , i.e., . .