Frequency estimation systems are an important subsystem of communication, navigation, radar and various other engineering systems. In some cases, the ability to perform relatively efficient and precise estimation of frequency may be a critical component in system design. Indeed, an inability to perform relatively efficient and precise estimation may significantly limit the performance of these systems as measured by various metrics of performance. For example, in high dynamic global positioning satellite (GPS) receiver applications, effectively acquiring and tracking the GPS carrier signal under dynamic conditions may limit the performance and applicability of these receivers to various applications. For this reason, various architectures suited to such applications have been previously proposed that acquire and track the GPS carrier under dynamic conditions, with the various different methods having a variety of limitations in terms of signal-to-noise ratio, initial frequency uncertainty, and other metrics of performance.
In terms of communication systems, precise frequency and phase may be important in communication systems involving coherent modulation techniques such as multiple quadrature amplitude modulation (MQAM) and multiple phase shift keying (MPSK). In certain communication applications, techniques, such as square law loop or Costas type loop, are used to derive the carrier frequency and phase from modulated signals, or a pilot signal is used which is tracked. The use of square law loop or Costas type loop result in significant loss in terms of phase noise of the reference carrier and phase ambiguity problems associated with phase ambiguity in the carrier phase equal to integer multiple of 2π/M for the MPSK signal. The use of pilot carrier results in a loss of signal power because a significant part of available power is used up in the pilot. The ability to provide fast and accurate frequency and phase estimates at very low signal-to-noise ratios (SNRs) may reduce the loss due to pilot carrier to an insignificant value.
More recently, precise and fast frequency acquisition and tracking have become increasingly important with the evolution of the Orthogonal Frequency Division Multiplexing (OFDM) in mobile communication systems. The OFDM modulation scheme may reduce problems of inter symbol interference (ISI) caused by multipath propagation. It may also exhibit relatively high performance in selective fading environments. Due to these and other features, OFDM has become part of various standards such as Worldwide Interoperability for Microwave Access (WiMax). Because OFDM is based on the orthogonality among various subcarrier signals, it is very important that this orthogonality be maintained when these subcarriers are received at the receiver. However, the mobile wireless channels introduce frequency offsets which cause disruption of the orthogonality among the subcarriers resulting in mutual interference among the various subcarriers. Therefore, it is desirable to precisely estimate such frequency offsets and correct them to avoid problems associated with intercarrier interference. The offsets may be functions of time and may vary with different subcarriers. Therefore, it is further desirable that precise estimation of the frequency offset be made with a minimum requirement on the estimation time and SNR, which is also limited in systems involving error correction coding techniques.
Some of the previous techniques for frequency estimation are based on the extended Kalman filter (EKF). In these techniques, the state of the Kalman filter is comprised of the signal phase, frequency and possibly one or more derivatives of the frequency, and the measurement is a nonlinear function of the state vector. In this approach, the measurement function is linearized about the current estimate of the state. Thus the technique based on EKF is more appropriate in the tracking mode when the initial estimate of the state is close to the true state and under a relatively high signal-to-noise ratio condition. However, when fast acquisition is required starting with a relatively high frequency uncertainty and/or in low signal-to-noise ratio conditions, the EKF based methods may not meet the required performance as they have relatively high thresholds for required signal power to noise density ratio (P/N0). Therefore, if the P/N0 ratio is below the threshold, the EKF may fail to converge and instead it may diverge. In other words, when the EKF diverges, the state estimation error, instead of converging to relatively small value as more and more measurement samples are processed, increases with the number of samples processed and approaches a large estimation error. The EKF estimator also results in a phase locked loop (PLL) configuration with time-varying loop filter coefficients and is thus also an “optimum” PLL. Thus the PLLs have similar limitations as the EKFs.
In fast Fourier transform (FFT) methods for frequency estimation, the N-point Fourier transform of a signal is evaluated, and the peak of the absolute values of the FFT is searched. The FFT frequency corresponding to the peak is taken as the estimate of the unknown frequency associated with the signal. The FFT method has two limitations. First, the estimation error is of the order of the FFT resolution frequency that is equal to (2B/N) where 2B is the interval of frequency uncertainty. Second, in a relatively low SNR condition, selection of the peak among N noisy outputs of the transform involves detection errors corresponding to a large estimation error in the range of −B to B Hz. Increasing the sampling (N) reduces the resolution frequency; however, concurrently it also increases the probability of detecting the incorrect peak thus exhibiting threshold effects with respect to the SNR level.
The techniques that have been used in the estimation of the frequency offset in OFDM systems, based on the assumption that the offset is same for all the sub-carriers, involve correlating the received signal with a reference signal and thereby determining the relative phase between the two signals. By estimating the relative phase at two different time instances and dividing the difference between the two relative phase differences by the time difference provides the frequency estimate. The correlation operation requires that the integration interval T1 for the correlation operation may be much smaller than the inverse of the offset frequency fa else the signal amplitude at the correlator output will be small and close to zero if TI≅1/fa. On the other hand, selection of a small TI leads to relatively large noise at the integrator output which may result in a noisy phase estimate. Differencing the noisy phase estimates may further accentuate the estimation error. Thus the correlation based approach has limitations in terms of the magnitude of the frequency offset and the SNR condition under which it will provide a satisfactory result.
The detailed description is set forth with reference to the accompanying figures. In the figures, the left-most digit(s) of a reference number identifies the figure in which the reference number first appears. The use of the same reference numbers in different figures indicates similar or identical items; however, various embodiments may utilize elements and/or components other than those illustrated in the figures.
Embodiments of the disclosure are described more fully hereinafter with reference to the accompanying drawings, in which embodiments of the disclosure are shown. This disclosure may, however, be embodied in many different forms and should not be construed as limited to the embodiments set forth herein; rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the disclosure to those skilled in the art. Like numbers refer to like elements throughout.
Embodiments of the disclosure are directed to, among other things, estimation of parameters associated with a signal. The disclosure provides a variety of architectures based on Adaptive Kalman filter (AKF) and Fast Fourier Transform (FFT) methods. These various architectures provide relatively fast and precise frequency estimates along with estimates of amplitudes, and phase for the case of single and multiple carriers present in the received signal. The various architectures operate on a vast range of signal-to-noise ratios wherein those operating in low signal-to-noise ratio conditions involve relatively higher computational effort such that over a relatively large range of SNRs, a high precision of estimation is achieved. The various architectures presented also provide precise estimates for the case involving significant frequency derivatives, wherein the frequency derivatives may also be estimated from the received signal and accurate tracking of time-varying frequency is achieved.
The various architectures presented in this disclosure may further be used for single or multiple sinusoidal signals present in the sampled received signal. These architectures include one or more adaptive Kalman filters (AKF). The adaptive Kalman filter is comprised of two coupled Kalman filters. The first Kalman filter (KF) is the state update Kalman filter (SUKF) that may estimate a state vector x(k) that may include in-phase and quadrature components of a sinusoidal signal received in the presence of noise. The SUKF may provide the filtered estimates of the in-phase and quadrature components of the sinusoidal signal, thus filtering out the additive noise from the measurements. The SUKF is based on a state model, where the elements of a state transition matrix associated with the state model are the cos and sin functions of the normalized frequency ω0=2πfa/Fs where fa is the frequency of the received signal and Fs is the sampling frequency. Based on the information provided by the SUKF, the second Kalman filter, termed the parameter update Kalman filter (PUKF), provides the estimates of a parameter vector β whose elements are cos (ω0) and sin (ω0). Based on a delayed filtered parameter vector estimate {circumflex over (β)}(k−1/k−1), the state transition matrix for the SUKF is generated. The two Kalman filters operate in a back to back manner providing the state and the parameter vector estimates {circumflex over (x)}(k/k) and {circumflex over (β)}(k/k) for k=1, 2, . . . . From the state and the parameter vector estimates, the estimates for the frequency, phase, and amplitude are obtained in terms of simple functions of the state and parameter vector estimates. Unlike the EKF, the AKF does not involve any linearization; therefore, it provides fast frequency estimates when the initial frequency offset is relatively large and under medium SNR conditions. Simulations show that for an SNR of 7 dB, an RMS frequency estimation error of about 3 Hz is obtained in about 10 samples when the initial frequency is selected randomly from the range of −50 to +50 Hz and the sampling frequency is 400 Hz. With an increasing number of samples, the RMS error tends to be zero.
In the case of signals with randomly time-varying frequency with independent incremental change at each sample, the AKF may closely track the frequency with the estimation error close to the random independent change in frequency at each time instance. However, in the case of significant frequency derivatives that may themselves be slowly varying functions of time, the disclosure presents another embodiment wherein the frequency derivatives are explicitly estimated, thereby achieving a rapid acquisition followed by close tracking of frequency with relatively small error. Another embodiment of the disclosure presents acquisition and tracking of multiple, N sinusoidal signals present in the received signal, wherein the various frequencies may also have significant frequency derivatives. In this embodiment, the estimator referred to as the adaptive Kalman filter-multiple frequency (AKF-MF), the state update Kalman filter (SUKF) may have dimension 2N and the PUKF may have N KFs with each estimating a parameter vector of dimension 2. In yet another embodiment, the input signal is first filtered by a bank of M polyphase filters or the M FFT filters followed by the AKF-MFs thus resulting in the reduction of the dimension of the SUKF. The estimates from the M AKF-MFs are appropriately combined to provide the final estimates of the frequencies, frequency derivatives, amplitudes and phase of the N sinusoidal signals present in the received signal.
As the SNR is reduced below some value, there is a nonzero probability that the estimates do not converge to small values that are of the order of that predicted from the theoretical Cramer-Rao (C-R) bound. To avoid this possibility, in another embodiment of the disclosure, the input signal, or a segment thereof, is correlated with the complex exponential function of frequencies equal to the estimate provided by the AKF-MF. If the correlation values are not above a certain bound in magnitude, the AKF-MF is rerun with different initial frequency estimates. The process is repeated until a threshold condition is satisfied or the number of trials exceeds a specified number. At the end of the first estimation step, the input signal is reprocessed with N individual single frequency KFs, referred to herein as AKF-SFs, with their initial frequencies provided by the first stage estimation. The second stage may also involve processing of the input signal in segments and the operation of frequency shift at the end of processing each segment and reprocessing each segment multiple times such that the frequency to be estimated by the AKF-SF approaches zero at the end of each segment processing, and the estimates from adaptive Kalman filter sub-systems (AKF-SSs) are accumulated to provide final frequency estimates for the N input frequencies along with other parameters of interest. Simulation examples show that the use of this embodiment results in a root mean squared (RMS) frequency estimation error obtained with 50 random frequency selections in the range of −100 to 100 Hz, and with 100 simulation runs for each such frequency selection, of about 3 Hz for an SNR of 7 dB and in 10 input signal samples with no outliers. This compares to about a 2 Hz RMS theoretical C-R lower bound on the RMS error.
Another embodiment of the disclosure, for the case of very low SNRs (˜−10 dB), involves three stages of estimation. In the first stage, the input signal may be provided at the input to an M-point FFT with M≧N where N is the number of frequencies in the input signal. The FFT may provide, at its output, an estimate of average power present at the M FFT frequencies. A frequency selector block may select Nf≦M frequencies from the M FFT frequencies corresponding to the highest average power levels. The selected Nf frequencies may be inputted to a bank of Nf AKF-SS that processes the input signal to arrive at the final frequency estimates fmK, m=0, 1, . . . , Nf−1. The average power present at the Nf frequencies may be evaluated by correlation. For the case of N equal to 1, two frequencies out of the Nf frequencies fmK with the highest power levels may be selected and their corresponding respective values may be compared to threshold values. If the threshold condition is satisfied, the final estimate fI from the stage 2 of estimation is determined from the two selected frequencies. If the threshold condition is not satisfied, the first and second processes of the estimation are repeated with a frequency offset introduced in the input signal. In the third process of the estimation, the input signal may be shifted in frequency by a complex exponential function at frequency fI. The resulting frequency shifted signal may be averaged over an appropriate interval, and the signal thus obtained may be reprocessed by the AKF to achieve the final estimate of the frequency fa. For the case of N>1, instead of selecting two frequencies in the second stage, N frequencies with the highest power may be selected. The N estimates from the third stage may be provided to the third stage that is comprised of N AKFs, one for each of the N frequencies. Simulations show that this architecture provides very small frequency estimation error even at very low SNRs. For example, at an SNR of −10 dB, an RMS error equal to a fraction of 1 Hz is achieved in about 200 samples with the frequency selected randomly from the range of −200 to 200 Hz. While the disclosure presents various comprehensive architectures for the estimation of frequency and other parameters of multiple sinusoidal signals present in the input signal, these architectures can be adapted to a variety of applications that involve frequency estimation in one or more forms.
Frequency Estimation with Adaptive Kalman Filter (AKF)
Various embodiments of the disclosure describe the adaptive Kalman filter (AKF) estimator and the FFT and correlation based estimators for fast and precise estimation of the frequencies, amplitudes and phases of multiple sinusoidal signals received in the presence of noise when the interval of observation is relatively limited. The first embodiment of the disclosure describes the adaptive Kalman filter (AKF) estimator for the case of a single sinusoidal signal present in the presence of noise. The frequency of the signal may remain constant over the interval of observation or may have some random time-varying component associated with it. In alternative embodiments of the AKF estimator, both the frequency and the frequency derivative may be estimated when there is a significant non-zero frequency derivative present during the observation interval, and the derivative itself may be a constant or varying slowly during the interval of observation. Various embodiments of different computational complexity are presented for signal-to-noise ratios ranging over medium to relatively very low values.
The embodiment of the disclosure for the AKF estimator for estimating the frequency, amplitude and phase of a signal, including a single sinusoidal signal, is disclosed first. In this case, the intermediate frequency signal of some unknown but constant frequency received in the presence of band pass white Gaussian noise over an interval of time of length T0 is given by
z
IF(t)=A cos (2π(fc+fa)t+φ)+n(t);0≦t≦T0 (1)
In (1), fc is known IF frequency, and the unknown frequency fa has a value in the range of −B to B Hz. The parameters A and φ are the amplitude and phase, respectively, both of which are also unknown. The band pass white noise n(t) may have a one-side noise power spectral density of N0 W/Hz. Thus the input signal to noise power ratio is A2/(4N0B), and the signal power to noise power spectral density ratio is equal to A2/(2N0) with the signal power A2/2. The corresponding base band model obtained by the down conversion of the IF signal to complex baseband is given by
z
i(t)=A cos (ωat+φ)+ni(t) (2a)
z
q(t)=A sin (ωat+φ)+nq(t) (2b)
In (2a, 2b) zi(t) and zq(t) are the in-phase and quadrature baseband signals and ωa=2πfa. The baseband noise processes ni(t) and nq(t) are independent white noise processes with the two-sided power spectral density N0. This embodiment discloses an adaptive Kalman filter (AKF) estimator to estimate the unknown parameters A, ωa, and φ with minimum possible errors such that the performance is close to theoretical bounds on such errors. Each of the baseband signals has power A2/2 with the total baseband signal power equal to A2. In the embodiment, the signal power refers to the total baseband power.
The signals zi(t) and zq(t) are sampled at a sampling rate Fs that is at least two times the maximum possible value of the unknown frequency fa=ωa/2π. The corresponding discrete time version of the measurements is given by
z
i(k)=A cos (kω0+φ)+ni(k) (3)
z
q(k)=A sin (kω0+φ)+nq(k);k=0,1, . . . ,Ns (4)
In equations (3) and (4), k denotes the discrete time index, and ω0=ωaTs is the digital frequency in radians (rad), with Ts=1/Fs, denoting the sampling period. The sampled noise sequences ni(k) and nq (k) are independent random sequences with zero mean and variance σn2=N0/Ts. For the purpose of estimation of the unknown parameters A, ω0 and φ by the AKF, the state variables x1(k) and x2(k) are defined as
x
1(k)=A cos (kω0+φ) (5)
x
2(k)=A sin (kω0+φ) (6)
Using trigonometric expansion yields
From (5) (7), the following state update equation for the first state component x1(k) is obtained
x
1(k+1)=β1x1(k)−β2x2(k) (8)
where β1 and β2 are parameters given by
β1=cos (ω0);β2=sin (ω0) (9)
Similarly expansion of x2(k+1) yields
From (5), (6), (8) and (10) one obtains
x
2(k+1)=β2x1(k)+β1x2(k) (11)
Equations (8) and (11) may be expressed in the following matrix vector form
The measurement equations (3) and (4) for the AKF estimator may also be written in the matrix vector form
In (14), the measurement matrix H is equal to the 2×2 identity matrix.
The two Kalman filters 102, 106, therefore, operate in a back-to-back manner providing the state and the parameter vector estimates {circumflex over (x)}(k/k) and {circumflex over (β)}(k/k) for k=1, 2, . . . . From the state and the parameter vector estimates, the estimates for the frequency, phase, and amplitude may be obtained in terms of simple functions of these estimates by an estimator of signal parameter 110. Unlike an EKF, the AKF 100 does not involve any linearization. Therefore, it may provide fast frequency estimates when the initial frequency offset is relatively large and under medium SNR conditions.
It will be appreciated that one or more of the constituent SUKF 102, PUKF 106, and other elements 104, 108, and 110 of the AKF 100 may be implemented in a variety of mechanisms, including, for example, on a processor running instructions to implement the AKF 100. In one aspect, the elements of the AKF may be implemented as modules of a software application stored on one or more memories and accessible by one or more processors configured to execute constituent instructions of the modules and/or software application. Alternatively, each of the elements of the AKF may be implemented with discrete electrical elements communicatively coupled therebetween. These elements may be digital elements incorporating hardware, software, or both hardware and software.
The state update Kalman filter 102 equations for the estimation of the state vector x(k) for the case of known matrix F are given by
{circumflex over (x)}(k/k)={circumflex over (x)}(k/k−1)+K(k){tilde over (z)}(k/k−1) (15a)
{tilde over (z)}(k/k−1)=z(k)−H(k){circumflex over (x)}(k/k−1) (15b)
{circumflex over (x)}(k/k−1)=F(k−1){circumflex over (x)}(k−1/k−1) (15c)
S(k)=H(k)P(k/k−1)HT(k)+R(k) (15d)
K(k)=P(k/k−1)HT(k)S−1(k) (15e)
P(k/k)=P(k/k−1)−P(k/k−1)HT(k)S−1(k)H(k)P(k/k−1) (15f)
P(k+1/k)=F(k)P(k/k)FT(k)+G(k)Q(k)GT(k) (15g)
In equations (15a-15g) {circumflex over (x)}(k/k) denotes the filtered estimate of the state x(k); {circumflex over (x)}(k/k−1) denotes the predicted estimate of x(k) based on measurements up to time k−1, i.e., z(0), z(1), . . . , z(k−1); {tilde over (z)}(k/k−1) is the prediction error; and K(k) is the Kalman filter gain. The matrices P(k/k) and P(k/k−1) are the error covariance matrices for the filtered and predicted estimates respectively of x(k). In general, the matrices F(k) and H(k) may be time-varying; however, in application to equations (12)-(14), these are independent of k, and the matrix G(k) in (15g) is equal to the identity matrix. The process covariance matrix Q is zero for the equation (12). However, to increase the robustness of the algorithm, Q may be set to some small non singular matrix. In an exponentially data weighted version of the Kalman filter, which has a robustness against certain model inaccuracies, the equation (15f) is replaced by
P(k+1/k)=λ−1F(k)P(k/k)FT(k)+G(k)Q(k)GT(k) (15h)
In equation (15h), the parameter λ is the exponential data weighting coefficient with 0<λ<1. The value of λ may be very close to 1, e.g., 0.99 and 1/(1−λ) is the approximate length of data memory. Thus with λ=0.99 the state update roughly depends only on the previous 100 measurements.
From the definitions of the state vector x(k) in (5)-(6), the phase θ(k) at time k is given by
θ(k)=tan2−1(x2(k),x1(k)) (16)
where tan2−1 denotes the 4 quadrant inverse tangent function, Similarly the phase estimate is given in terms of the filtered estimate of the state x(k) by
{circumflex over (θ)}(k)=tan2−1({circumflex over (x)}2(k/k),{circumflex over (x)}1(k/k)) (17)
The phase estimation error is obtained as
{tilde over (θ)}(k)=θ(k)−{circumflex over (θ)}(k) (18)
The filtered estimate of the amplitude A is also obtained from the filtered estimate of the state x(k) as
Â(k)=[{circumflex over (x)}12(k/k)+{circumflex over (x)}22(k/k)]1/2 (19)
A smoothed estimate of the amplitude is given by
where Ns is the total number of samples and N0 is the number of samples that are discarded in the computation of the smoothed estimate of A.
The matrix F in the Kalman filter update equations (15) requires knowledge of the parameters β1 and β2 which are unknown and need to be estimated. In the adaptive Kalman filter (AKF) 100 of the embodiment of this disclosure, these parameters are estimated from {circumflex over (x)}(k/k).
The equations (8) and (11) may be rewritten in the following equivalent form
Replacing the state x(k) by its filtered estimate {circumflex over (x)}(k/k), the equations (21) and (22) may be expressed in the following matrix vector form
In equations (23) and (24), the suffix on the variables z, H, n, etc., signifies that these variables relate to the estimation of the parameter β. The noise vector np accounts for the error in the estimate of the state x(k) and has its covariance matrix equal to Rp(k) that is determined from the Kalman filter update equations (15). In case of fixed frequency, the parameter vector β is not a function of k. However, to include a more general case, it may be assumed to vary according to the following dynamics equation
β(k+1)=Fpβ(k)+Gp(k)ξp(k) (25)
where Fp and Gp are some appropriate matrices and ξp(k) denotes the process noise, which may be zero mean and white, or otherwise spread across a relatively wide spectrum, with covariance matrix Qp. The Kalman filter update equations for the estimation of the parameter β(k) at the parameter update Kalman filter 106 from equations (23) and (25) is given by
{circumflex over (β)}(k/k)={circumflex over (β)}(k/k−1)+Kp(k){tilde over (z)}p(k/k−1) (26a)
{tilde over (z)}
p(k/k−1)=zp(k)−Hp(k){circumflex over (β)}(k/k−1) (26b)
{circumflex over (β)}(k/k−1)=Fp(k−1){circumflex over (β)}(k−1/k−1) (26c)
S
p(k)=Hp(k)Pp(k/k−1)HpT(k)+Rp(k) (26d)
K
p(k)=Pp(k/k−1)HpT(k)Sp−1(k) (26e)
P
p(k/k)=Pp(k/k−1)−Pp(k/k−1)HpT(k)Sp−1(k)H(k)Pp(k/k−1) (26f)
P
p(k+1/k)=Fp(k)Pp(k/k)FpT(k)+Gp(k)Qp(k)GpT(k) (26g)
In an exponentially data weighted version of the parameter update Kalman filter 106, the equation (26g) is replaced by
P
p(k+1/k)=λp−1Fp(k)Pp(k/k)FpT(k)+Gp(k)Qp(k)GpT(k) (26h)
In the Kalman filter equation (15) the matrix F(k−1) is replaced by its estimate {circumflex over (F)}(k−1/k−1) given by
The two sets of equations (15) and (26) are updated in an interlaced manner thus, the sequence of estimates are {circumflex over (β)}(k−1/k−1)→{circumflex over (F)}(k−1/k−1)→{circumflex over (x)}(k/k)→{circumflex over (β)}(k/k) for k=1, 2, . . . with some initial estimate for {circumflex over (β)}(0/0) based on some possibly zero initial estimate for the digital frequency ω0.
In (26h), λp is the exponential data weighting coefficient with 0<λp<1. The covariance matrix Rp in (26d) may be evaluated as follows. The equations (21) and (22) may be combined to obtain the following equation.
Subtraction of both sides of equation (23) from the respective sides of equation (27) yields
x(k)−{circumflex over (x)}(k/k)=[Hpc(k)−Hp(k)]β(k)−np(k); (28)
From the definitions of the matrices Hpc(k) and Hp(k), the equation (28) may be written in the following alternative form
With the definition of F in (13), one obtains from (29)
{tilde over (x)}(k/k)=F{tilde over (x)}(k−1/k−1)−np(k) (30)
Thus
n
p(k)=F{tilde over (x)}(k−1/k−1)−{tilde over (x)}(k/k) (31)
Now subtraction of (15a) from (12) yields
{tilde over (x)}((k/k)=F{tilde over (x)}(k−1/k−1)−K(k){tilde over (z)}(k/k−1) (32)
From (31) and (32) one obtains the covariance of np(k) as
R
p(k)=E [np(k)npT(k)]=K(k)E [{tilde over (z)}(k/k−1){tilde over (z)}T(k/k−1)]KT(k) (33)
Substitution for z(k) from (14) in (15b) results in
{tilde over (z)}(k/k−1)=H(k){tilde over (x)}(k/k−1)+n(k) (34)
As {tilde over (x)}(k/k−1) and n(k) are uncorrelated due to the independence of noise sequence n(k), the covariance of the prediction error {tilde over (z)}(k/k−1) is given by
E[{tilde over (z)}(k/k−1){tilde over (z)}T(k/k−1)]=H(k)P(k/k−1)HT(k)+R(k)=S(k) (35)
Substitution of (35) in (33) yields the desired covariance matrix as
R
P(k)=K(k)S(k)KT(k)=K(k)[H(k)P(k/k−1)HT(k)+R(k)]KT(k) (36)
For the case of Fp=I, corresponding to the case of time invariant parameter and Gp=0, the Kalman filter equations (26) can be simplified to arrive at the weighted least squares algorithm. With the substitution of Fp=I and Gp=0 and replacing k by (k−1) in (26h) yields
P
p(k/k−1)=λp−1Pp(k−1/k−1) (37)
Substitution of (37) in (26f) yields
P
p(k/k)=λp−1Pp(k−1/k−1)−λp−2Pp(k−1/k−1)HpT(k)×{λp−1Hp(k)Pp(k−1/k−1)HpT(k)+Rp}−1Hp(k)Pp(k−1/k−1) (38)
The equation (38) can be organized in the following compact form
P
p(k)=λp−1[Pp(k−1)−Pp(k−1)HpT(k)×{Hp(k)Pp(k−1)HpT(k)+λpRp}−1Hp(k)Pp(k−1)] (39)
where in equation (39) Pp(k) is a more compact notation for Pp(k/k). The Kalman gain Kp for the case of constant β may be expressed as
K
p(k)=Pp(k−1)HpT(k)[Hp(k)Pp(k−1)HpT(k)+λpRp]−1 (40)
Multiplication of (39) by HpT(k) results in
A simplification of (41) yields
P
p(k)HpT(k)=λp−1Pp(k−1)HpT(k){Hp(k)Pp(k−1)HpT(k)+λpRp}−1×[Hp(k)Pp(k−1)HpT(k)+λpRp−Hp(k)Pp(k−1)HpT(k)] (42)
From (40) and (42) one obtains
K
p(k)=Pp(k)HpT(k)Rp−1 (43)
The weighted least squares algorithm is thus given by
P
p(k)=λp−1[Pp(k−1)−Pp(k−1)HpT(k)×{Hp(k)Pp(k−1)HpT(k)+λpRp}−1Hp(k)Pp(k−1)] (44a)
K
p(k)=Pp(k)HpT(k)Rp−1 (45b)
{circumflex over (β)}(k)={circumflex over (β)}(k−1)+Kp(k)[zp(k)−Hp(k){circumflex over (β)}(k−1)] (45c)
In (44), {circumflex over (β)}(k) is the compact notation for {circumflex over (β)}(k/k) in the case of constant β. From the definition of the parameters β1 and β2 in (9), the estimate of the digital frequency ω0 is given by
{circumflex over (ω)}0=tan2−1({circumflex over (β)}2(k/k),{circumflex over (β)}1(k/k)) (46)
with the estimation error in the estimate of the digital frequency ω0 given by
{tilde over (ω)}0(k)=ω0−{circumflex over (ω)}0(k) (47)
The estimate and the estimation error for the analog frequency fa given by
{circumflex over (f)}
a={circumflex over (ω)}0Fs/(2π);{tilde over (f)}a=fa−{circumflex over (f)}a (48)
The set of equations (5), (6), (12)-(15), (17), (19) (20), (23)-(26), (33), (46) and (48) constitute the AKF algorithm for the estimation of the frequency, amplitude and phase of a single sinusoidal signal received in the presence of noise and is referred to as AKFS.
Referring now to
Referring still to
The innovation covariance matrix S(k) is pre- and post-multiplied by K(k) and KT(k) respectively providing the measurement covariance matrix Rp(k) for the parameter vector update Kalman filter according to (36). The elements of the vector {circumflex over (x)}(k−1/k−1) provide the measurement matrix Hp(k) given in (28), (29). The matrix Hp(k) is input to the parameter vector update Kalman filter for which the filtered state estimate {circumflex over (x)}(k/k) is the measurement vector zp(k).
The parameter vector update Kalman filter 106 is similar to the state vector update Kalman filter 102 with the filtered state estimate {circumflex over (x)}(k/k) replaced by the filtered parameter vector estimate {circumflex over (β)}(k/k). For the case of constant parameter vector β, the matrix Fp(k−1) is equal to I2. The elements of the filtered parameter vector estimate {circumflex over (β)}(k−1/k−1) provide the matrix {circumflex over (F)}(k−1/k−1) according to (26i) which is input to the state vector update Kalman filter. The two Kalman filters 102, 106 in
From the filtered parameter vector estimate {circumflex over (β)}(k/k), the estimate for the normalized frequency ω0 is obtained by the tan2−1( ) block that provides the four quadrant inverse tangent of the input according to (46). The estimate for the analog frequency fa may be obtained by multiplying {circumflex over (ω)}0 by Fs/2π where Fs is the sampling frequency. The filtered state estimate {circumflex over (x)}(k/k) is input to a second tan2−1( ) block that yields the estimate for the instantaneous phase θ(k) according to (17). The filtered state estimate {circumflex over (x)}(k/k) is input to the norm ∥ ∥ block that evaluates the Euclidean norm of the input providing the estimate Â(k) for the amplitude according to (19). From Â(k), the smoothed estimate ÂS is obtained by the averaging block that obtains ÂS according to (20).
As a non-limiting simulation example, consider the bandwidth B=200 Hz with a sampling rate Fs selected equal to 400 Hz. The amplitude A=1 volt with the bandpass noise one-sided noise spectral density N0 is equal to 2.5×10−4 W/Hz with the signal power to noise spectral density ratio equal to 33 dB-Hz. This corresponds to the variance of the bandpass noise σn2=2N0B=0.1 W with the signal-to-noise ratio equal to 5 or 7 dB. The one-sided noise spectral density of both the baseband processes ni(t) and nq(t) is equal to 2N0=5×10−4 W/Hz with the baseband SNR for both the in-phase and quadrature components equal to 5 (7 dB). The initial values for the matrices P, Q and Pp are selected as
The exponential data weighting coefficients are selected as λ=λp=0.999.
Comparison with Theoretical Bounds
The performance of the adaptive Kalman filter (AKF) 100 may be compared to the theoretical bound on the frequency estimation error variance, which is also known as Cramer-Rao (C-R) bound. The Cramer Rao bound on the variance of frequency estimation error {tilde over (f)}a defined in (48) is given by
The simulation examples compare the performance of the AKF algorithm with the C-R bound. For the comparison, the AKF algorithm, as executed by the AKF 100 is simulated with the frequency f0 selected randomly from the range (−B, B) Hz based on a uniform distribution and with the initial frequency estimate equal to 0. For each such selection, the AKF algorithm is simulated with ns=100 independent noise sequences. The procedure is repeated with nf different values of the frequency f0 selected on a random basis. For each selection of f0, the RMS frequency estimation error {tilde over (f)}rmsi as a function of the number of samples processed is computed by the mean squared average over the ns simulation runs given by
may be equal to 5 or 7 dB. The initial parameter error covariance matrix Pp is selected as
All the other parameters are selected, as in the non-limiting example, to compare with the C-R bound in (49a), and the RMS estimation error evaluated in (49b) is averaged over all the nf=100 frequency selections as
In another non-limiting example, the frequency fa is a randomly varying function of k according to the following equation
f
a(k)=fa(k−1)+δf(k) (50)
The perturbation δf(k) is modeled as an independent zero mean Gaussian sequence with variance σf2. From the definition of the parameters β1 and β2 in (9), the time-varying versions of these parameters are approximated by
β1(k)≅β1(k−1)−2πTsδf(k)β2(k);β2(k)≅β2(k−1)+2πTsδf(k)β1(k) (51)
As
E[β
1
2(k)]=E[β22(k)]=0.5 (52)
and δf(k) is independent of β1(k−1) and β2(k−1), one obtains
E[β
1(k)−β1(k−1)]2=E[β2(k)−β2(k−1)]2=0.5(2πTs)2σf2≡qa (53)
Thus the process covariance matrix Qp in (26) is selected equal to
In the simulation example, σf2=2 and Q is modified to 0.01 I2 to account for added uncertainty in the estimate for F(k−1) required in the Kalman filter equation (15).
In another embodiment of the AKF estimator, both the frequency and the frequency derivative may be estimated when there is a significant non-zero frequency derivative present during the observation interval, and the derivative itself may be a constant or a slowly varying function of time during the interval of observation.
In the case when the frequency is time-varying with its derivative αa, the in-phase and quadrature baseband signals zi(t) and zq(t) are given by
From (57), the difference between the phase at time kTs and (k−1)Ts is obtained as
With the time-varying normalized frequency ω0(k) defined as
one obtains
θ(k)−θ(k−1)=ω0(k) (60)
ω0(k)=ω0(k−1)+α0;α0≡αaTs2 (61)
From (57), the instantaneous frequency ωi(t) is given by
From (59) and (62), the instantaneous frequency ωi(t) at t=kTs is related to the normalized frequency ω0(k) by
ωi(kTs)=[ω0(k)+α0/2]Fs (63)
where Fs is the sampling frequency. In (61), α0 may also be a slowly time-varying function of k. The parameters β1 and β2 in (9) are time-varying for this case and are given by
β1(k)=cos (ω0(k));β2=sin (ω0(k));k=1,2, . . . (64)
With the state variables x1(k) and x2(k) defined as
x
1(k)=A cos (θ(k)) (65a)
x
2(k)=A sin (θ(k)) (65b)
the state space equations may be written as
The measurement equation is same as (14) rewritten here as (67).
In (67), H is equal to the 2×2 identity matrix. The state vector x(k) is estimated by the Kalman filter equations (15) with F(k−1) replaced by its estimate {circumflex over (F)}(k−1/k−1) obtained by replacing 1k− and β2(k−1) in (66b) by their estimates {circumflex over (β)}1(k−1/k−1) and {circumflex over (β)}2 (k−1/k−1) respectively. The parameter vector estimate {circumflex over (β)}(k/k−1)=[{circumflex over (β)}1(k/k−1) {circumflex over (β)}2(k/k−1)]T is obtained from the parameter update equations (26) with zp(k), Hp(k), and Rp(k) defined by equations (23), (24) and (36) respectively and with the matrix Qp set equal to the 0 matrix, Gp equal to the (2×2) identity matrix and the matrix Fp(k−1) replaced by
In (68), {circumflex over (α)}0(k−1) denotes the estimate of α0 based on the measurement z(i) with i=1, 2, . . . , k−2. In order to obtain the estimate of {circumflex over (α)}0 (k) for any k, the normalized frequency α0(k) at time k is estimated by
{circumflex over (ω)}0(k)=tan2−1({circumflex over (β)}2(k/k),{circumflex over (β)}1(k/k));k=1,2 . . . (69)
In (69), tan2−1( ) denotes the four quadrant inverse tangent functions and {circumflex over (ω)}0(0/0) may be set equal to an initial estimate ω0 of ω(0) which may be equal to 0. In the parameter vector update equation (26), {circumflex over (β)}(0/0) is correspondingly set equal to [cos (ω0)sin (ω0)]T. From (69), the first-order differences are obtained as
{circumflex over (ω)}d(k)={circumflex over (ω)}0(k)−{circumflex over (ω)}0(k−1);k=1,2, . . . (70)
The estimates {circumflex over (ω)}d (k) in (70) constitute the noisy estimate of the parameter α0 wherein α0 may also be a slowly varying function of k. The smoothed estimate of α0(k) is obtained by filtering the estimates {circumflex over (ω)}d(k) by an appropriate filter. For example, use of a first-order filter yields the following smoothed estimate of α0(k).
{circumflex over (α)}0(k)=λα{circumflex over (α)}0(k−1)+(1−λα){circumflex over (ω)}d(k);k=1,2, . . . (71)
In (71), {circumflex over (α)}0(0) may be set equal to an initial estimate of α0 or may be set equal to 0. In (71), λα is a positive constant with 0<λα<1 and may determine the filter time constant which is set in accordance with the expected rate of variation of α0. The parameter λα may itself be made a function of k; for example, initially λα may be set equal to 0.995 to provide a relatively small weighting to the initial estimates {circumflex over (ω)}d(k) with a relatively large estimation error and may be set to 0.99 after some initial period to provide a fast tracking of α0(k). The procedure can be extended to the case where a dynamic model for α0(k) is specified in terms of its derivatives by using a Kalman filter update equation similar to (26) and providing the estimate for α0(k) and that of the derivatives of α0(k) based on the specified dynamic model and treating {circumflex over (ω)}d(k) as the noisy measurement of α0(k).
Referring now to
The normalized frequency estimate {circumflex over (ω)}0(k) may be provided to a first-order differencing block 1830 which may generate a difference frequency {circumflex over (ω)}d(k) according to (70). The difference frequency {circumflex over (ω)}d (k) may be provided to a first-order filter 1840 that generates at its output an estimate of the frequency derivative {circumflex over (α)}0(k) according to (71). The delayed version of {circumflex over (α)}0 (k) may be input to the cascade of the cos ( ) and sin ( ) blocks and the scalar to vector converter 1850, followed by a matrix constructor block 1854 that generates {circumflex over (F)}p(k−1) from the vector [cos ({circumflex over (α)}0(k−1))sin ({circumflex over (α)}0(k−1))]T according to (68). The 2×2 matrix {circumflex over (F)}p(k−1) may be input to the parameter update Kalman filter 1816 for the generation of parameter vector estimate {circumflex over (β)}(k/k).
A non-limiting simulation example is shown for the estimation of the time-varying frequency with the frequency at time k=0 equal to 25 Hz and the parameter α0 equal to 0.007 corresponding to the parameter αa equal to 0.007×4002=1120 rad/sec2. This corresponds to a rate of change in frequency of about 178 Hz/sec. The initial estimates of the frequency and the parameter α0 at time k=0 are equal to −25 Hz and 0 respectively. The SNR for this example is 5 (7 dB) with the initial values for various matrices in the AKF, same as in (49).
In some embodiments of the disclosure, the first and higher order derivatives may be obtained by a Kalman filter 3 that may replace the frequency estimator block 1820 of
x
h(k)=[ω0(k)α0(k)β0(k)]T (71a)
wherein (71a) ω0(k) and α0(k) are the normalized frequency and the normalized first derivative of frequency respectively and β0=βaTs3 with βa denotes the second derivative of the frequency ω(t). The time-variation of β0 may be given by
β0(k+1)=β0(k)+nβ(k) (71b)
In (71b), nβ(k) is a zero mean independent sequence with variance σβ2. The state transition equation for xh(k) is given by
x
h(k+1)=Fhxh(k)+Ghξh (71c)
where in (71c) Gh is the identity matrix and the covariance matrix Qh of the noise vector ξh is given by
The state transition matrix Fh in (71b) is given by
The measurement equation for the Kalman filter 3 is given by
z
h(k)=Hzh(k)+nh(k);H=[1 0 0] (71f)
with zh(k) in (71f) made equal to the normalized frequency estimate obtained from the Kalman filter 2 state estimate {circumflex over (β)}(k/k) as in
R
h(k)=E[{tilde over (ω)}02(k)]≅Trace[Pp(k/k)] (71g)
On the basis of the state space model described by (71a-71g), the Kalman filter 3 may provide the estimate {circumflex over (x)}h (k/k), the second component of which is the estimate of α0(k) that may be inputted to the block 1854 of
In further embodiments of the disclosure, parameter estimation on multiple sinusoidal signals received in the presence of noise may be performed. In this case, the received intermediate frequency (bandpass) signal zIF(t) is given by
In (72), fIF is the known intermediate frequency and the unknown frequencies fam have their values in the range of −B to B Hz for some B. The amplitudes Am and phase φm associated with frequencies fam are also unknown. The bandpass white noise n(t) has a one-sided noise power spectral density of N0 W/Hz. The corresponding baseband model is given by
In (73a, 73b), zi(t) and zq(t) are the in-phase and quadrature signals and ωarm=2πfam for m=1, 2, . . . , N. The baseband processes ni(t) and nq(t) are independent white noise processes with the two-sided power spectral density N0 W/Hz. It is required to estimate the parameters Am, ωam and φm for m=1, 2, . . . , N. The signals zi(t) and zq(t) are sampled at a rate Fs that is at least two times the maximum possible frequency B. The corresponding discrete time version of the measurements is given by
In equation (74), k denotes the discrete time index and ωm=ωamTs, m=1, 2, . . . , N are the digital frequencies in rad with Ts=1/Fs. The sampled noise sequences ni(k) and nq(k) are independent random sequences with zero mean and variance σn2=N0/Ts. In the case of multiple frequencies, the state vector x(k) is a 2N dimensional vector
x(k)=[x1(k)x2(k) . . . x2N(k)]T (75)
With the components xm(k) given by
x
2m-1(k)=Am cos (kωm+φm)
x
2m(k)=Am sin (kωm+φm);m=1, 2, . . . ,N (76)
In the more general case where the mth signal has a frequency derivative αam, the state components in (76) are replaced by
x
2m-1(k)=Am cos (θm(k)) (77a)
x
2m(k)=Am sin (θm(k)) (77b)
where θm(k) is the sampled version of θm(t) given by
and as for the case of a single sinusoidal signal
The measurement equations (74a, 74b) may be written in the following matrix vector form
In (80), the measurement matrix H is a 2×2N matrix given in the following partitioned form
H[I
2
I
2
. . . I
2] (81)
where I2 is the (2×2) identity matrix. The filtered and predicted state estimates {circumflex over (x)}(k/k) and {circumflex over (x)}(k/k−1) are obtained from the Kalman filter equation (15) wherein the corresponding covariance matrices P(k/k) and P(k/k−1) are square matrices of dimension 2N. The process covariance matrix Q may be set to zero as for the case of single frequency estimation. The matrix F(k−1) in (15) is replaced by the estimate {circumflex over (F)}(k−1/k−1) obtained by the parameter vector update equations similar to (26). The matrix {circumflex over (F)}(k−1/k−1) is a 2N×2N matrix given in the following partitioned form
In (82), {circumflex over (F)}m(k−1/k−1) for m=1, 2, . . . , N is a 2×2 matrix given by
The parameter vector estimate {circumflex over (β)}m(k−1/k−1)=[{circumflex over (β)}m1(k−1/k−1){circumflex over (β)}m2(k−1/k−1)]T is obtained recursively from the parameter update equation (26) with {circumflex over (β)}(k/k), {circumflex over (β)}(k/k−1), zp(k), Hp(k) and Rp(k) in (26) replaced by {circumflex over (β)}m(k/k), {circumflex over (β)}m(k/k−1), zpm(k), Hpm(k) and Rpm(k) respectively, where
The matrix Qp is set equal to the zero matrix with Gp equal to the (2×2) identity matrix. The matrix Rp(k) in (33) is a 2N×2N matrix for this case of multiple signals, with Rpm given by the following (2×2) submatrix of Rp(k).
The matrix Fp(k−1) in (26) is replaced by Fpm(k−1) given by
In (87), {circumflex over (α)}m(k−1) denotes the estimate of αm based on the measurements z(i) for i=1, 2, . . . , k−2 and is estimated as for the case of the single frequency estimation. Thus the normalized frequency ωm(k) at time k is estimated by
{circumflex over (ω)}m(k)=tan2−1({circumflex over (β)}m2(k/k),{circumflex over (β)}m1(k/k));k=1,2 . . . (88)
The normalized frequency estimate {circumflex over (ω)}m(0/0) at time 0 may be set to an initial estimate ωm of ωm(0) which may be equal to 0 and {circumflex over (β)}m(0/0) in the parameter vector update equation set equal to [cos (ωm) sin (ωm)]T. From (88), the first order differences are obtained as
{circumflex over (ω)}md(k)={circumflex over (ω)}m(k)−{circumflex over (ω)}m(k−1);k=1,2, . . . (89)
The estimate {circumflex over (ω)}md(k) in (89) constitutes the noisy estimate of the parameter αm which may also be a slowly varying function of k. The smoothed estimate of ωm may be obtained by filtering the estimate {circumflex over (ω)}md(k) by an appropriate filter. For example, use of a first-order filter yields
{circumflex over (α)}(k)=λm{circumflex over (α)}m(k−1)+(1−λm){circumflex over (ω)}md(k);k=1, 2, . . . (90)
In (90), {circumflex over (α)}m(0) may be set equal to an initial estimate of αm or may be set equal to 0. In (90), λm is a positive constant with 0<λm<1 and determines the filter time constant which is set in accordance with the expected rate of variation of αm. The parameter, λm may itself be a function of k; for example, initially λm may be set equal to 0.999 to provide relatively small weighting to the initial estimates {circumflex over (ω)}md(k) with a relatively large estimation error and may be set to 0.99 after some initial period to provide a fast tracking of α0(k). The procedure may be extended to the case where a dynamic model for αm(k) is specified in terms of its derivatives by using a Kalman filter update equation similar to (26) for providing the estimate for αm(k) and that of the derivatives of α0(k) based on the specified dynamic model and treating {circumflex over (ω)}md(k) as the noisy measurement of α0(k).
From the definition of the components of the state vector in (77), the phase estimate at time k is obtained as
{circumflex over (θ)}m(k)=tan2−1({circumflex over (x)}2m(k/k),{circumflex over (x)}2m-1(k/k));m=1,2, . . . ,N (91)
The filtered estimate of the amplitude Am is given by
Â
m(k)=[{circumflex over (x)}2m-12(k/k)+{circumflex over (x)}2m2(k/k)]1/2 (92)
A smoothed estimate of the amplitude Am may be obtained from (93).
In (93), Ns is the total number of samples and N0 is the number of samples that are discarded in the computation of the smoothed estimate of Am.
{circumflex over (x)}
m(k/k)=[{circumflex over (x)}2m-1(k/k){circumflex over (x)}2m(k/k)]T (93a)
A Kalman gain matrix K(k) of dimension 2N×2 may be input to the matrix splitter to partition K(k) into N submatrices K1(k), K2(k), . . . , KN(k) each of dimension 2×2 with
In (93b), the argument k in the elements of the matrix has been dropped for the notational simplification. The innovation covariance matrix S(k) may be pre- and post-multiplied by Km(k) and its transpose KmT(k), and the resulting product may be added to a constant matrix εRI2, for some small positive scalar εR, providing a measurement covariance matrix Rpm for an mth PUS (parameter update subsystem) block 2130(A)-(N) (collectively referred to herein as 2130) for m=1, 2, . . . , N. The component state vector {circumflex over (x)}m (k/k) may be provided to the mth PUS block 2130 to generate the estimates for the frequency {circumflex over (f)}a,m (k), frequency derivative {circumflex over (α)}a,m (k), phase {circumflex over (θ)}m(k) and amplitude Âm(k) and the smoothed amplitude estimate Âm,S, for m=1, 2, . . . , N. The operation of the PUS block 2130 has been explained with reference to block 1818 of
When the number of frequencies N in (72) is relatively large, the dimension of the covariance matrices P(k/k) and P(k/k−1) in the Kalman filter equation (15), equal to 2N×2N, is also correspondingly large. In this case, the matrix dimension can be reduced by filtering the complex valued signal zc(k)=zi(k)+j zq(k); j=√{square root over (−1)} by a set of M complex bandpass filters with their bandwidths equal to 2B/M and their center frequencies selected so that the M filters have mutually disjoint pass bands. For example, with M=4, each of the 4 filters has a bandwidth equal to B/2 with their respective center frequencies equal to −3B/4, −B/4, B/4, and 3B/4 respectively. In alternative embodiments, there may be some non-zero overlap among the adjacent frequency bands of the M complex filters' output signals to avoid attenuating any frequency that may fall in a transition band of the filter.
The outputs of the M filters may be down converted to complex baseband so that each of the M down converted signals has its center frequency equal to 0 and has frequencies in the range of −B/4 to B/4. The sampling rates of the down converted signals are decimated by a factor M to the rate Fs/M. All of the operations of bandpass filtering, down conversion to complex baseband, and decimation can be performed by a bank of polyphase filters.
The individual outputs of the polyphase filters are then processed by the adaptive Kalman filters to acquire and track the frequencies present in the respective outputs of the polyphase filters. The frequency estimates thus obtained are adjusted by the center frequencies of the corresponding bandpass filters to arrive at the frequency, frequency derivative, and the amplitude estimates of the N signals present in the signal zc(k).
In an alternative embodiment, instead of using a polyphase filter, the filtering of the signal zc(i) may be performed by the FFT operation as follows. Let
The operation in (94) constitutes frequency shifting of the signal zc(i) by frequency fm followed by a decimation by the factor M assumed to be even. The signal zm(k) can also be obtained in terms of the discrete Fourier transform or the Fast Fourier transform (FFT)
For a component z0(k) at frequency f0=(Im
0
k((i)=Aejφexp[j2π(fm
where
From (98)
The expression for z0m(k) may also be approximated by
As the adjacent frequencies fm are spaced by Δf, for any frequency in the interval fm
The adaptive Kalman filter for multiple frequencies (AKF-MF) 2100 may be applied to signals zm(k), m=0, 1, . . . , M−1. For any frequency f0 with f0=fm
Thus with the estimate of δf known, the coefficients a1 and a2 and the phase ψ1 and ψ2 may be evaluated from (101a, 101b) after replacing by its estimate and the estimate of the amplitude A may be obtained by the maximal ratio combining of Â1 and Â2 as
Â=|a
1
Â
1
e
−jψ
+a
2
Â
2
e
−jψ
|/(a12+a22) (102a)
For the case of a2=0, the equation (102a) normalizes the amplitude A1 by a1 providing the correct estimate for the amplitude A. When the estimate has significant error, an incoherent combining of the amplitudes Â1 and Â2 may be used to yield the following amplitude estimate.
Â=[a
1
|Â
1
+a
2
|Â
2|]/(a12+a22) (102b)
The estimate for the phase is given by
{circumflex over (φ)}=[arg(A1)−ψ1+arg(A2)−ψ2]/2 (103)
The two dimensional vector zm(k) is input to the AKF-MF block that is also inputted with the matrices Hm(k), Qm(k−1), and Rm(k). The matrix Hm(k) is given by (81) and is of dimension 2×2Nm, Qm(k−1)=εQI2Nm for some small positive scalar εQ and Rm(k)=σ2I2 with σ2=σn2/M and with Nm denoting the number of frequencies in the signal zcm(k) and may be replaced by some appropriate upper bound. Partitioning the input signal zc(i) in this manner reduces both the dimension of the state vector and various other matrices and at the same time reduces the noise variance by the factor M.
Referring still to
When the signal-to-noise ratio is relatively small and the initial frequency uncertainty is relatively large, there may be some small probability that the AKF estimation algorithm may not converge to the true frequency with relatively small estimation error. To avoid such a possibility, a correlation detector is used to validate the frequency estimates provided by the AKF.
In the AKF-CD architecture, the estimation interval of Ns samples is segmented into ms segments of ns samples each wherein in the special case ns may be equal to Ns. In this architecture, the AKF algorithm with various matrices described in equations (74) to (103) may be run for ns samples to estimate {circumflex over (ω)}m (k) and {circumflex over (α)}m (k) for k=1, 2, . . . , ns; m=1, 2, . . . , N where N is the number of frequencies. From (79), the phase estimate {circumflex over (θ)}m(k) is obtained as
{circumflex over (θ)}m(k)={circumflex over (θ)}m(k−1)+{circumflex over (ω)}m(k);k=1,2, . . . ,ns (104)
In (104), {circumflex over (θ)}m(0) may be set to 0. The complex valued signal zc(k)=zi(k)+jzq(k); j=√{square root over (−1)} is correlated with the signal sm(k) in a semi-coherent manner, where
s
m(k)=exp(−j2π{circumflex over (θ)}m(k));k=1,2, . . . ,ns (105)
For the semi-coherent correlation, the interval ns is divided into mc segments of length nc, and the coherent correlation is computed for each of the mc intervals as
In (106), the interval nc is determined such that some bound on the expected frequency estimation error in Hz obtained after processing the ns samples is much smaller than the Fs/nc Hz wherein the bound on the expected frequency estimation error in Hz, for example, may be some multiple of the C-R bound. From (106), the correlation over the interval of ns samples is obtained as
In (107), l0 that may be 0 denotes the number of initial nc length segments that are discarded in the computation of the incoherent correlation rmi. The number of samples l0nc accounts for the initial transient period where the estimation error is relatively high. For the case of αm=0, where the frequency ω(k) is constant, the coherent correlation in (106) reduces to
In (108), {circumflex over (ω)}m denotes the estimate of the normalized frequency in radians based on the processing of ns samples. In this case, l0 in (107) may be set to 0. In the ideal case of small frequency error and relatively small noise variance, the correlation in (107) is nearly equal to rm given by
r
m
={A
m
2+2σn2/nc}1/2≅Am (109)
In the correlation detector, rmi computed from (107) is compared to a correlation threshold γmth which may be equal to some fraction of an estimate of Am. If rmi is greater than or equal to the threshold, the estimate is deemed to converge to some small error. If all the N frequency estimates do not satisfy the threshold conditions, the AKF algorithm described in equations (74) to (103) is repeated for the same initial ns samples but with different random frequency initializations, wherein the initializations for those frequencies which satisfy the threshold conditions are set equal to their estimates obtained in the first run. The frequencies for which the threshold condition is not satisfied are initialized randomly over some appropriate interval; for example, over the interval (−B/4, B/4). In the absence of estimates of the individual Am, the threshold may be applied to the total power estimated as
The power estimated in (110) is compared with some fraction of its prior estimate Pth which may, for example, be obtained as
If PT>δPth for some selected value of δ with 0<δ≦1, then the first part of the estimation procedure may be complete. Otherwise, the AKF algorithm in equations (74) to (103) may be repeated for the same initial ns samples but with different random frequency initializations until either the threshold condition is satisfied or the number of trials exceed some specified threshold Nt. A higher value of δ may in general require a higher number of trials.
Once the threshold condition is satisfied, each of the N frequencies is tracked by further processing of the measurements. In this phase of the algorithm, the second set of ns complex measurements is shifted in frequency by the estimate {circumflex over (ω)}m(ns) for the mth normalized frequency ωm(ns) obtained at the end of the first phase according to equation (112).
z
c,m(k)=zc(k)exp(−jk{circumflex over (ω)}m(ns));k=ns+1, . . . ,2ns (112)
The AKF algorithm processes the ns samples of the measurements zcm(k) to obtain the estimates of the frequency (ωm(k)−{circumflex over (ω)}m(ns), k=ns+1, . . . , 2ns. In processing the second set of ns measurements, the parameter error covariance matrix Pp(k/k−1) may be increased by an appropriate value so as to increase the convergence rate. The estimates of the frequencies (ωm (k)−{circumflex over (ω)}m(ns) thus obtained are adjusted by {circumflex over (ω)}m(ns) to account for the frequency shift providing the estimates for the frequency {circumflex over (ω)}m(k), k=ns+1, . . . , 2ns. This procedure of shifting the frequency of the complex signal by the frequency estimate obtained at the end of the previous segment and applying the AKF to process the current segment and modifying the resulting estimates by the amount of frequency shift is repeated for the remaining ms-2 segments. A further improvement in the estimates may be obtained by reprocessing all of the ms segments Nr-1 times in a manner similar to the processing of the ms-1 segments in the first run where Nr denotes the total number of runs with Nr≧1. For the case of time-varying frequency, the amount of frequency shift at the start of the second and consecutive runs needs to be appropriately adjusted.
In case of multiple frequencies, the signal zc(k) may be segmented after the initial phase into M signals by the use of a polyphase filter or using FFT as in (94)-(96) such that the number of frequencies in any one segment is small and the dimension of the state vector x(k) in the AKF-MF is relatively small for processing any one segment.
The architecture 2600 may further include an algorithm control block 2660 that may be configured to generate various control signals including the R/W (read/write) command to the memory 2610 and an MA (memory address) when needed. The number of available input signal samples Ns may be divided into ms segment each of length ns. During the first interval of nsTs seconds, the complex input zc(k) is connected to the complex to real converter that outputs a dimension 2 vector z(k) with its elements equal to the real and imaginary parts respectively of the signal zc(k). The signal z(k) is input to the first stage AKF-MF 2630 that processes the n samples of the signal z(k) to provide the estimates of various frequencies {circumflex over (ω)}m (k) and frequency derivatives {circumflex over (α)}m(k) for m=1, 2, . . . , N. The operation of the AKF-MF block 2630 has been previously described with reference to
Still referring to
The samples of the input complex signal zc(k) are inputted to a bank of stage 2 AKF1 to AKFN 2650 through the activation of switches S1, S2, and S3 starting with the second segment of ns samples in the first run of the second stage. Referring now to
When I2=1, the frequency estimate {circumflex over (ω)}mr(k) may be added on to the previous value of ωmL providing an updated value for ωmL. Thus ωmL may be set to {circumflex over (ω)}m0(k) in the first run at k=ns and from there on it may be modified by {circumflex over (ω)}mr(k) at intervals of nsTs seconds. The sum of {circumflex over (ω)}mr(k) and ωmL at the end of a previous ns length segment provides the frequency estimates during any run and any segment. These estimates are time multiplexed with the estimates {circumflex over (ω)}m0(k) from stage 1 in MUX1 controlled by the algorithm control block details, which are not shown. Thus if nr=1, then the first segment final estimates are obtained from {circumflex over (ω)}m0(k) with the final estimates for the subsequent segments provided by the second stage. On the other hand, if nr>1, then all of the final estimates come from stage 2.
I4 may be equal to 1 if k=ns and ir>1. Thus the signal ξ1 may be equal to {circumflex over (α)}m0(k) if k=ns and ir=1; equal to {circumflex over (α)}mr(k) if k=ns and ir>1; and equal to 0 otherwise. An accumulator 2 2740 output may be set equal to ξ1 at k=ns for any value of ir. The signal I5 is equal to 1 if k=inns, is>1. If I5=1, the value {circumflex over (α)}mr(k) is added to the accumulated output. The signal I3 is equal to 1 if k=Ns and is 0 otherwise. At the end of Ns samples, an accumulator 2740 output ξ2 is the sum of the derivatives during the ms segments wherein it is assumed that during each segment the derivative is nearly constant. The accumulator 2750 output ξ2 times ns is subtracted from ξ3 to provide the oscillator frequency such that the oscillator frequency is nearly equal to the input signal frequency at the beginning of ns sample segments. The initial frequency estimate for the AKF 2730 is reset to 0 at the end of each ns sample segment in each run, and the covariance matrix P(0/0) is reset to some specified value at the start of each run.
The amplitude A is equal to 1 volt. The correlation threshold γmth in the first phase of the algorithm is 0.5. In the first trial of the first phase of the algorithm, the initial frequency estimate is selected to be 0 Hz; in the subsequent trials, the initial estimate is made randomly with a uniform pdf in the range (−40, 40 Hz). The initial covariance matrices are selected as P(0/0)=2 I2 and Pp(0/0)=2 I2 with I2 equal to the 2×2 identity matrix. At the end of the first phase of the algorithm, the Pp(0/0) is reset to Pp(0/0)=0.05 I2 to speed up the convergence rate of the AKF. After that, it is updated according to AKF update equation (26).
The simulations were performed with 50 random frequency selections from the range of (−200, 200) Hz according to the uniform probability density function (pdf). For each such frequency selection, the algorithm was simulated with 100 independent noise sequences.
For relatively very low signal-to-noise ratio conditions, the Kalman filter based frequency estimation algorithm may not converge to the correct frequency. Instead it may converge to a frequency with an estimation error in the range of −Fs/2 to Fs/2 with some non-zero probability, i.e., the algorithm may diverge. Thus the algorithm converges to the correct frequency for some noise sequence and the initial estimate, while for some other noise sequence and/or initial frequency estimates, it may converge to an estimate with a relatively large error with some non-zero probability. Moreover, the smaller the signal-to-noise ratio, the relatively higher is the probability of divergence. For this case, another embodiment of the disclosure is presented that provides good convergence even under very low signal-to-noise ratio conditions.
In this embodiment of the disclosure, the range of frequency uncertainty Fs=2B is divided into M intervals of length Δf=Fs/M. The integer M is selected such that the ratio Mγ=MA2/(2σn2), with γ=A2(2σn2) denoting the SNR, is higher than some specified threshold value γth and (Ns/M) is an integer. For example, with γ=0.25 and γth=5, M=20, let zc(k) denote the complex valued signal as
z
c(k)=zi(k)+jzq(k);j≡√{square root over (−1)} (113)
The signal zc(k) is correlated with complex exponential functions of frequency fm=−B+mΔf; m=0, 1, . . . , M−1 over an interval of M=Fs/Δf samples providing the correlation values
The expression in (114) can also be evaluated in terms of the discrete Fourier transform (DFT) or the fast Fourier transform (FFT) by substituting the expression for fm in the expression for rm(0). Thus
From (115), the correlation value rm(0) may be expressed as
where z0f(f) is the discrete Fourier transform of zm(i) given by
In (117), the sequence zm(i) is obtained by multiplying the alternative elements of the sequence zc(i) by −1. The DFT of zm(i) in (117) can also be evaluated by the M-point fast Fourier transform of zm(i).
With N1=Ns/M, the correlation values are evaluated over the subsequent (NI−1) intervals by replacing the subsequence [z(1) z(2), . . . , z(M)] by the subsequence of z(k) for the respective interval. The estimate of the average power present during the interval of N samples of zc(k) is obtained by averaging the absolute value squared |rm|2 over the NI intervals for m=0, 1, . . . , M−1, i.e.,
Substitution of zc(i) from (3), (4), and (113) in (115) yields
Evaluation of the sum in (120) results in
For −Δf≦fdm<Δf, Δf=1/(MTs) and M>>1, the absolute value of the expression in (121) may be approximated by
For the case when
f
dm=2nΔf+fδm;−Δf≦fδm<Δf;n an integer with 0<|n|<M/4 (123)
The absolute value of sm(0) in (122) may be approximated as
where κ is a constant in the range of 1 and 2. The noise term nm(0) in (119) is given by
From (125) one obtains
In (126), Re( ) denotes the operation of taking the real part of the argument. As the sequence n(i) is zero mean and independent, it follows from (126) that
wherein equation (127) E denotes the expected value operator. From (125) it follows that nm(0) and nl(0) are uncorrelated and thus due to their Gaussian distribution are independent random variables as
For k≠m, the summation in (128) may be evaluated as
The last term in (129) is zero as |k−m|≦M−1 resulting in
E[n
m(0)n*k(0)]=0;k≠m (130)
Taking the absolute value squared on both sides of (119) yields
|rm(0)|2=|sm(0)|2+|nm(0)|2+2Re{s*mnm};m=0,1, . . . ,M−1 (131)
From (125) to (130), the expression in (131) may be expressed as
In (132) ξm(0) for m=0, 1, . . . , M−1 are zero mean independent random variables, and sm(0) is given by (122). The average power at frequency fm is estimated by
In (133), ξa,m for m=0, 1, . . . , M−1 are zero mean independent random variables with their variance decreasing inversely with increasing NI. The unknown frequency f0 may be estimated by maximization of Pm over m. However, for the case of low SNR γ, and limited number of samples N and thus small NI, ξa,m has significant variance resulting in a significant probability of selecting an incorrect value of m and thus causing a relatively large frequency estimation error f0−fm. Moreover, even when the value of m is correctly selected, there is an estimation error in the range of −Δf/2 and −Δf/2. From (133) the value of |sm (0)|2 may be only A2sinc2(0.5)=0.4 A2 when f0 is in the middle of any two of the frequencies fm resulting in about a 4 dB loss in signal power compared to the case when the frequency f0 is equal to one of the frequencies fm where fm is given by (114). Therefore, the probability of selecting an incorrect frequency fm is much higher in the case when the unknown frequency falls in between the two frequencies fm compared to the latter case.
In order to minimize the probability of selecting an incorrect frequency fm, a number Nf of frequencies {f0s, f1s, . . . , fN
cos [2π(f0+δf)Ts]−cos (2πf0Ts)≅−2πTsδf sin (2πf0Ts) (134)
the estimate for ε is given by
The second equality in (76) follows from the fact that the frequency f0 itself may have any value in the interval (−Fs/2, Fs/2) and thus the argument of the sin function may lie in the interval (−π, π) resulting in the average for sin2( ) equal to 0.5. If the frequency error δf can have any value in the interval (−Δf/2, Δf/2), then σf2 may be approximated by ⅓(Δf/2)2=(Δf)2/12. Substitution for σf2 in (135) results in the estimate for ε equal to π2/(6M2) or approximately 1/m2. For M=20, this estimate is equal to 0.0025. This is much smaller compared to the value for Pp(0/0)=4 I2 used in the EKF without the FFT step. The estimate of the ε derived in (135) applies to that particular initial frequency estimate fms that is close to the true frequency f0 with the error smaller than Δf/2 in its magnitude. The estimate for Pp(0/0) is based on the initial knowledge and needs to be only approximate for the AKF to converge. Denoting by fmK, m=0, 1, . . . , Nf−1 the final frequency estimates obtained by the AKF corresponding to the Nf initial frequency estimates fms, m=0, 1, 2, . . . , Nf−1, an estimate of the power PmK is obtained similar to that for the Pm in equation (133). Thus,
In the absence of any initial estimate of the received signal power level A2, the frequency fmK corresponding to the highest value of PmK is selected for further processing. However, with some estimate of the signal power level A2, detection is performed on the highest value of PmK to eliminate the possibility that none of the frequencies fmK are close to the true frequency f0. The probability of this is a function of M, NI, Nf, and the SNR γ and may be indicated as the highest power out of the M values PmK being relatively very small.
For the frequency fmK close to f0, the expected value of the corresponding power PmK obtained from (136) or from the equations (121) and (133) with fdm in (121) equal to 0 will be close to Pa=A2+2σn2/M. The actual power level may have mean Pa with an error with a variance that is a function of N1 and γ. The actual power will exceed the value Pa with a probability of 0.5. Thus a threshold value PT on the power level PmK can determine whether or not the corresponding frequency fmK is close to fm. However, if PT is too high, one may miss detecting the correct frequency fmK whereas lowering the threshold to a relatively small value may result in a false detection. As an example, with A2=1, σn2=2.5 corresponding to the SNR γ=0.2, and with M=20, one obtains Pa=1.25 and a threshold value of PT=0.8 may be selected. If the highest value of PmK, m=0, 1, . . . , M−1, does not exceed PT, then the sum of the two highest powers PmK is compared with the threshold PT2. If the sum does exceed the threshold PT2 and the corresponding two frequencies are within Δf/2 of each other, then the frequency with the highest power PmK among the two frequencies is accepted as the correct intermediate estimate of the frequency f0. Alternatively the average value of the two frequencies may be taken as the correct intermediate estimate of the frequency f0. For the example with Pa=1.25, a value for PT2 equal to 1 is selected. However, if none of the two threshold conditions are satisfied then the received sequence zc(k) is further processed as follows.
For a specified number of trials Nr=2κ for some integer κ≧0, the steps of correlating the received sampled signal zc(k) with the complex exponential signals with M frequencies fm=−B+mΔf; m=0, 1, . . . , M−1, selecting Nf of these frequencies with the highest correlation values, running the AKF with each of these Nf frequencies as the initial frequency estimates, correlating z(k) with the Nf final frequency estimates provided by the AKF, and comparing the correlation values with the two thresholds, are repeated until the threshold on the correlation value is satisfied or the number of such runs exceeds Nr-1. In each such run, the M frequencies fm defined in (114) are offset by a different value of δf. The offset values of δf in different runs are selected from the set of values {i Δf/Nr; i=1, 2, . . . , Nr−1}. However, the sequence in which these offset values may be taken may not be in an increasing order. For example, with N=2κ for an integer κ, the values may be taken in the order [2κ-1, 2κ-2×(1, 3), . . . , (1, 3, . . . , Nr−1)]Δf/Nr. For example with Nr=8, the order is [4, 2, 6, 1, 3, 5, 7]Δf/8 or
The correlation Pmd between zc(k) and the complex exponential signals with M frequencies fmd=−B+mΔf+δf; m=0, 1, . . . , M−1, can be obtained in terms of generalized FFT as for the case of δf=0.
In equation (139), zifd(m) m=0, 1, . . . , M−1, is the DFT of the ith segment of length M of the modified signal zcd(k) obtained from zc(k) as shown in equation (139) and thus can be evaluated by an FFT algorithm.
Denoting by fI the estimate obtained by the combined FFT and EKF algorithms, a further refinement in the estimate is achieved by demodulating the signal zc(k) by the complex exponential signal at frequency fI which is equivalent to changing the frequency of the signal to fr=(f0−fI), averaging the resulting signal over segments of length M, and processing the averaged signal by the AKF. Thus
In (141), the signal zs(k) is averaged over M consecutive samples thus reducing the sampling rate to Fsa=Fs/M. This is in view of the fact that in the absence of a detection error, the frequency estimation error in fI is limited in magnitude to Δf/2 instead of Fs/2. Thus the sampling rate is reduced by a factor of Fs/Δf=M. The averaging process reduces the noise variance also by the factor M. However, the normalized frequency uncertainty [(f0−fI)Fsa] lies in the range of (−π, π) and therefore the initial covariance matrix P(0/0) may be set equal to εaI2 with εa=(π/3)2≅1 assuming a Gaussian distribution for the initial frequency estimation error with 3σ value equal to π. In the AKF, the sampling time Ts is replaced by Tsa=MTs. The final estimate of the unknown frequency f0 is given by
{circumflex over (f)}
0
=f
I
+{circumflex over (f)}
r (142)
where {circumflex over (f)}r denotes the estimate of the frequency fr=(f0−fI) by the AKF. Finally accurate estimates of the amplitude A and phase φ are obtained by correlating zc(k) with the complex exponential function of frequency {circumflex over (f)}0. Thus the estimates of the amplitude A denoted by  and that of φ denoted by {circumflex over (φ)}, respectively, are given by
When the correlation values are input to a cascade of mod square and averaging blocks 0, 1, . . . , M−1 3926 to 3936 providing the estimated average power P0, P1, . . . , PM-1 present during the Ns samples corresponding to NI blocks of M samples each in the respective passbands of the M FFT filters, the FFT transform may be treated as a bank of M FFT filters. Referring to (114)-(117), the mth output of the FFT block 3918 corresponds to shifting the input signal frequency by fm=−B+mΔf, and averaging the frequency shifted signal over an interval of M samples. The two operations of frequency shifting and averaging are equivalent to bandpass filtering the signal with a complex bandpass filter of center frequency fm and zero crossing bandwidth equal to 2Δf, and down converting the filtered signal to baseband. The power levels P0, P1, . . . , PM-1 at the output of M averaging blocks are input to the frequency selector 1 3938 block that selects Nf frequencies from the set of frequencies fm, m=0, 1, . . . , M−1 with the highest power levels. The selected frequencies {f0s, f1s, . . . , fN
The block diagram of the adaptive Kalman filter subsystem (AKFSS) as discussed in reference to
The frequencies f0K, f1K, . . . , fN
Based on the values of t0 and t1 the algorithm control block 3970 may generate the signal I5 which has 3 possible values of 0, 1, and 2. Based on I5, the frequency selector 3 selects frequency fm
If either t0=1 or t1=1, the first and second steps of the estimator are complete. However if both t0 and t1 are equal to 0, the algorithm control block 3970 may select a different value of 1 or δf=1Δf/Nr and the estimation procedure is repeated until either the threshold condition is satisfied or all of Nr values of δf have been processed. The frequency estimate fI at the completion of step 1 and 2 may be taken as the final estimate of the unknown frequency f0. However, a further refinement in the frequency estimate may be made by the stage 3 of the estimator block 3940.
{circumflex over (f)}0 may control the frequency of a second oscillator 4040 that generates the complex exponential signal at frequency {circumflex over (f)}0 which may be input to the second frequency shifter 4050. The other input of the second frequency shifter 4050 may be with the complex signal zc(k). The output of the second frequency shifter 4050 may be inputted to an averaging circuit 4054 that may average out the Ns samples as the output of the second frequency shifter 4050 and generate the output r according to (145). The output of the averaging circuit 4054 may be inputted to the absolute value ∥ and the arg( ) blocks, respectively, to provide the estimate of the amplitude  and phase {circumflex over (φ)}, respectively of the input signal. When the expected RMS frequency estimation error is not insignificant as may be assessed from the C-R bound, instead of using the coherent averaging in the estimation of Â, a quasi coherent correlation may be used in the estimation of the amplitude A. A switch (not shown) at the input of stage 3 estimator 4000 may route the input zc(k) to either the first or second frequency shifter 4014, 4050 as needed by the algorithm control block 3970 of
Referring now to
Estimation of Multiple Frequencies with the AKF-EFT-CD Algorithm
The AKF-EFT-CD algorithm can be applied to the case of the input signal that includes N signals of different frequencies as in (74).
In a second stage 4220 of the estimator, the AKF algorithm is applied to the signal model described in (74) to (87) with N replaced by Nf therein. In the signal model, the (Nf−N) of the amplitudes Am are zero as the number of frequencies Nf selected is higher than N. With fmK, m=0, 1, . . . , Nf−1 denoting the final frequency estimates obtained by the AKF corresponding to the Nf initial frequencies fms, the average power PmK at these frequencies is evaluated by equation (136). The N frequencies with the highest power estimates PmK are selected as the frequency estimates are obtained. However, if any two frequency estimates are within the resolution frequency fres of each other, with fres equal to a predetermined fraction of Δf, then these two estimates are considered to be the estimates of a single frequency out of the N frequencies. The two such frequency estimates are averaged to provide the overall estimate of the frequency with the corresponding power estimates added to obtain the overall estimate of the power at that frequency. After such a combining of the powers, the N frequencies with the highest power estimates are selected as the N frequency estimates form the step 2 of the algorithm.
As an option, a threshold on the estimates of the power levels of the individual frequencies or a threshold on the total power in all of the N frequencies may be performed as for the case of single frequency estimation. If the threshold condition is not satisfied, then the procedure may be repeated with the M frequencies fm=B+mΔf, m=0, 1, . . . , M−1 offset by 1Δf/2κ for a selected integer κ. with the offset integer taking possible values 1, 2, . . . , 2κ−1, as for the case of the single frequency estimation, to obtain a new set of initial frequencies fms, m=0, 1 . . . , Nf−1, running the AKF algorithm with these new estimates and obtaining the frequency estimates fmK, m=0, 1, . . . , Nf−1 and selecting N frequencies out of the Nf estimates based on their power estimates. The procedure may be repeated with different values of the offset integer i until the threshold condition is satisfied or all the 2κ−1 values of 1 are exhausted.
In the third stage 4230(1)-(N) estimator, the estimates fmI of each of the N frequencies obtained from the second stage 4220 are further individually refined. In this step, the signal zc(k) may be multiplied by complex exponential function of frequency fmI and the product averaged over an interval of M=Fs/Δf samples as in (140)-(141) to obtain the averaged signal za,m(k) that is applied to the AKF algorithm with the dimension of the state vector equal to 2 to obtain the estimate {circumflex over (f)}mr of the residual frequency fmr that is equal to the error in the frequency estimate. The final frequency estimate is given by (145) similar to the estimate in (142) for the single frequency case.
{circumflex over (f)}
m
=+f
m
I
+{circumflex over (f)}
m
r
,m=1,2, . . . N (145)
In the estimation of multiple frequencies, the signal zc(k) may be segmented into multiple signals by a polyphase filter or the bank of FFT filters 4240 as in (94-96), and the AKF-FFT-CD algorithm is applied to each of these segments to reduce the dimension of the state vector in the AKF algorithm and thus the computational requirements.
Akf-Fft-Cd Algorithm without the Last Step of Frequency Translation and Decimation
Simulation results are presented first for the case when the refinement step of frequency translation and decimation in equations (140) and (141) followed by the application of the AKF to the resulting signal is not performed. Instead the estimate based on selecting one of the Nf estimates obtained by the AKF on the basis of the correlation detection performed on these estimates is used as the final estimate.
The estimation error can be further reduced by including the frequency translation and decimation step in (140) and (141) followed by the application of the AKF on the resulting signal.
A frequency estimation system is one of the most important subsystems of communication, navigation, radar and various other engineering systems. In some cases, the efficient and precise estimation may be the critical component in the system design and may significantly limit the performance of these systems with respect to various metrics of performance. For example, in application to high dynamic GPS receivers, the ability to acquire and track the GPS carrier signal under dynamic conditions limits the performance and applicability of these receivers to various important applications. The present disclosure can drastically increase the performance capability of such systems over the existing ones.
In terms of communication systems, precise frequency and phase of the carrier are important in communication systems involving coherent modulation techniques such as MQAM and MPSK. In traditional communication applications, either the techniques that use square law loops or Costas type loops are used to derive the carrier frequency and phase from the modulated signal or a pilot signal is used which is tracked. The use of square law loops or Costas type loops results in significant loss in terms of phase noise of the reference carrier and phase ambiguity problems wherein there is phase ambiguity in the carrier phase equal to integer multiple of 2π/M for an MPSK signal. The use of pilot carrier results in a loss of signal power because a significant part of available power is used up in the pilot. The ability to provide fast and accurate frequency and phase estimates at very low SNRs can reduce the loss due to pilot carrier to an insignificant value. For example with the pilot signal 10 dB below the modulated signal power, the loss is only 0.45 dB, operation at 14 dB below results in only 0.17 dB loss compared to a loss of 1-3 dB in a traditional system. These numbers are based on the assumption that the carrier frequency uncertainty is nearly equal to the modulation signal bandwidth.
More recently precise and fast frequency acquisition and tracking have become very important with the evolution of the OFDM (Orthogonal Frequency Division Multiplexing) in mobile communication systems. The OFDM modulation scheme offers several advantages. For example, it has reduced problems of inter-symbol interference (ISI) caused by multipath propagation. It has superior performance in selective fading environments. Due to these advantages, OFDM has become part of various important standards such as WiMax. However, because the OFDM is based on the orthogonality among various subcarrier signals, it is very important that this orthogonality be maintained when these subcarriers are received at the receiver. However, the mobile wireless channels introduce frequency offsets which cause the disruption of the orthogonality among the subcarriers resulting in mutual interference among the various subcarriers. Therefore, it is very important to precisely estimate such frequency offsets and correct them to avoid the problem of intercarrier interference. The offsets may be functions of time and may be different for different subcarriers. Thus it is necessary that precise estimation of the frequency offset be made with minimum requirements on the estimation time and SNR which is also limited in systems involving error correction coding techniques. The disclosure can virtually eliminate the need for pilot carriers that are provided for the purpose of estimating the carrier offsets resulting in increased efficiency and yet are capable of providing precise estimates for these offsets.
In various radar systems, for example in Doppler and FM chirp radars, the ability to provide accurate acquisition and tracking in very low SNR conditions can result in a drastic reduction in transmit power resulting in “quiet radar.” In certain embodiments, the systems and methods disclosed herein may be applied to various multi-tracking applications including, but not limited to RADAR multi-target tracking, SONAR multi-target tracking, LIDAR multi-target tracking, or combinations thereof. The above only provides a few examples where the disclosure can be exploited. The disclosure can be exploited in diverse applications including satellite communication, terrestrial wireless communication, digital TV, radars, broadcasting, radio astronomy, aeronautical and space systems, structural vibrations, seismology, general instrumentation, etc.
In general, it will be apparent that the embodiments described herein may be implemented in many different embodiments of software, firmware, and/or hardware, for example, based on Field Programmable Gate Array (FPGA) chips or implemented in Application-Specific Integrated Circuits (ASICS). The software and firmware code may be executed by a computer or computing device comprising a processor (e.g., a DSP or any other similar processing circuit) including, for example, the computing device described below. The processor may be in communication with memory or another computer-readable medium comprising the software code. The software code or specialized control hardware that may be used to implement embodiments is not limiting. For example, embodiments described herein may be implemented in computer software using any suitable computer software language type, using, for example, conventional or object-oriented techniques. Such software may be stored on any type of suitable computer-readable medium or media, such as, for example, a magnetic or optical storage medium. According to various embodiments, the software may be firmware stored at an EEPROM and/or other non-volatile memory associated with a DSP or other similar processing circuit. The operation and behavior of the embodiments may be described without specific reference to specific software code or specialized hardware components. The absence of such specific references is feasible, because it is clearly understood that artisans of ordinary skill would be able to design software and control hardware to implement the embodiments based on the present description with no more than reasonable effort and without undue experimentation.
In the example of
The processing unit 5302 may be responsible for executing various software programs such as system programs, application programs, and/or program modules/blocks to provide computing and processing operations for the computing device 5300. The processing unit 5302 may be responsible for performing various voice and data communications operations for the computing device 5300 such as transmitting and receiving voice and data information over one or more wired or wireless communications channels. Although the processing unit 5302 of the computing device 5300 is shown in the context of a single processor architecture, it may be appreciated that the computing device 5300 may use any suitable processor architecture and/or any suitable number of processors in accordance with the described embodiments. In one embodiment, the processing unit 5302 may be implemented using a single integrated processor. The processing unit 5302 may be implemented as a host central processing unit (CPU) using any suitable processor circuit or logic device (circuit), such as a general purpose processor. The processing unit 5302 also may be implemented as a chip multiprocessor (CMP), dedicated processor, embedded processor, media processor, input/output (I/O) processor, co-processor, microprocessor, controller, microcontroller, application-specific integrated circuit (ASIC), field programmable gate array (FPGA), programmable logic device (PLD), or other processing device in accordance with the described embodiments.
As shown, the processing unit 5302 may be coupled to the memory and/or storage component(s) 5304 through the bus 5308. The bus 5308 may comprise any suitable interface and/or bus architecture for allowing the processing unit 5302 to access the memory and/or storage component(s) 5304. Although the memory and/or storage component(s) 5304 may be shown as being separate from the processing unit 5302 for purposes of illustration, it is worthy to note that in various embodiments some portion or the entire memory and/or storage component(s) 5304 may be included on the same integrated circuit as the processing unit 5302. Alternatively, some portion or the entire memory and/or storage component(s) 5304 may be disposed on an integrated circuit or other medium (e.g., hard disk drive) external to the integrated circuit of the processing unit 5302. In various embodiments, the computing device 5300 may comprise an expansion slot to support a multimedia and/or memory card, for example.
The memory and/or storage component(s) 5304 represent one or more computer-readable media. The memory and/or storage component(s) 5304 may be implemented using any computer-readable media capable of storing data such as volatile or non-volatile memory, removable or non-removable memory, erasable or non-erasable memory, writeable or re-writeable memory, and so forth. The memory and/or storage component(s) 5304 may comprise volatile media (e.g., random access memory (RAM)) and/or non-volatile media (e.g., read only memory (ROM), Flash memory, optical disks, magnetic disks and the like). The memory and/or storage component(s) 5304 may comprise fixed media (e.g., RAM, ROM, a fixed hard drive, etc.) as well as removable media (e.g., a Flash memory drive, a removable hard drive, an optical disk). Examples of computer-readable storage media may include, without limitation, RAM, dynamic RAM (DRAM), Double-Data-Rate DRAM (DDRAM), synchronous DRAM (SDRAM), static RAM (SRAM), read-only memory (ROM), programmable ROM (PROM), erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), flash memory (e.g., NOR or NAND flash memory), content addressable memory (CAM), polymer memory (e.g., ferroelectric polymer memory), phase-change memory, ovonic memory, ferroelectric memory, silicon-oxide-nitride-oxide-silicon (SONOS) memory, magnetic or optical cards, or any other type of media suitable for storing information.
The one or more I/O devices 5306 allow a user to enter commands and information to the computing device 5300, and also allow information to be presented to the user and/or other components or devices. Examples of input devices include data ports, analog to digital converters (ADCs), digital to analog converters (DACs), a keyboard, a cursor control device (e.g., a mouse), a microphone, a scanner and the like. Examples of output devices include data ports, ADCs, DACs, a display device (e.g., a monitor or projector, speakers, a printer, a network card). The computing device 5300 may comprise an alphanumeric keypad coupled to the processing unit 5302. The keypad may comprise, for example, a QWERTY key layout and an integrated number dial pad. The computing device 5300 may comprise a display coupled to the processing unit 5302. The display may comprise any suitable visual interface for displaying content to a user of the computing device 5300. In one embodiment, for example, the display may be implemented by a liquid crystal display (LCD) such as a touch-sensitive color (e.g., 76-bit color) thin-film transistor (TFT) LCD screen. The touch-sensitive LCD may be used with a stylus and/or a handwriting recognizer program.
The processing unit 5302 may be arranged to provide processing or computing resources to the computing device 5300. For example, the processing unit 5302 may be responsible for executing various software programs including system programs such as operating system (OS) and application programs. System programs generally may assist in the running of the computing device 5300 and may be directly responsible for controlling, integrating, and managing the individual hardware components of the computer system. The OS may be implemented, for example, as a Microsoft® Windows OS, Symbian OS™, Embedix OS, Linux OS, Binary Run-time Environment for Wireless (BREW) OS, JavaOS, or other suitable OS in accordance with the described embodiments. The computing device 5300 may comprise other system programs such as device drivers, programming tools, utility programs, software libraries, application programming interfaces (APIs), and so forth.
In various embodiments disclosed herein, a single component may be replaced by multiple components, and multiple components may be replaced by a single component to perform a given function or functions. Except where such substitution would not be operative, such substitution is within the intended scope of the embodiments.
While various embodiments have been described herein, it should be apparent that various modifications, alterations, and adaptations to those embodiments may occur to persons skilled in the art with attainment of at least some of the advantages. The disclosed embodiments are therefore intended to include all such modifications, alterations, and adaptations without departing from the scope of the embodiments as set forth herein.
Embodiments may be provided as a computer program product including a non-transitory machine-readable storage medium having stored thereon instructions (in compressed or uncompressed form) that may be used to program a computer (or other electronic device) to perform processes or methods described herein. The machine-readable storage medium may include, but is not limited to, hard drives, floppy diskettes, optical disks, CD-ROMs, DVDs, read-only memories (ROMs), random access memories (RAMs), EPROMs, EEPROMs, flash memory, magnetic or optical cards, solid-state memory devices, or other types of media/machine-readable medium suitable for storing electronic instructions. Further, embodiments may also be provided as a computer program product including a transitory machine-readable signal (in compressed or uncompressed form). Examples of machine-readable signals, whether modulated using a carrier or not include, but are not limited to, signals that a computer system or machine hosting or running a computer program can be configured to access, including signals downloaded through the Internet or other networks. For example, the distribution of software may be an Internet download.
Although embodiments have been described in language specific to structural features and/or methodological acts, it is to be understood that the disclosure is not necessarily limited to the specific features or acts described. Rather, the specific features and acts are disclosed as illustrative forms of implementing the embodiments. Conditional language, such as, among others, “can,” “could,” “might,” or “may,” unless specifically stated otherwise, or otherwise understood within the context as used, is generally intended to convey that certain embodiments could include, while other embodiments do not include, certain features, elements, and/or steps. Thus, such conditional language is not generally intended to imply that features, elements, and/or steps are in any way required for one or more embodiments or that one or more embodiments necessarily include logic for deciding, with or without user input or prompting, whether these features, elements, and/or steps are included or are to be performed in any particular embodiment.