The technical field of this disclosure concerns communication systems and more particularly systems for reducing background noise from a signal of interest.
The related art concerns methods and systems for reducing background noise in voice communications. Communication terminals used for public safety and professional communications (PSPC) are often required to operate in noisy environments. In the case of firefighters such background noise can include chainsaws, pumps, fans and so on. For police, the common background noise can arise from vehicular traffic, sirens, and crowds. Other users may need to operate their communication terminals in the presence of industrial machinery. Regardless of the exact source of such background noise, it is well-known that excessive noise can make difficult or completely inhibit radio communication. To the extent that communication is possible at all, even moderate amounts of background noise can be problematic insofar as is places cognitive strain on recipients, thereby increasing listener fatigue. Noise suppression is common in PSPC communications equipment, but a satisfactory solution to the problem has proven to be challenging.
Some systems for reducing background noise use multiple microphones and incorporate beamforming technology which seeks to amplify sounds in a direction of a user voice while reducing sounds from other directions. Other systems rely on the concept of near-field and far-filed acoustic attenuation to distinguish voice from noise. Such systems rely on a spectral subtraction technique to separate voice and noise. While these systems can be effective, they are costly to implement due the fact that they are highly sensitive to small differences in the response of the microphones that are used. Accordingly, the microphones must be calibrated at the factory and/or a separate algorithm must be implemented to dynamically equalize the microphones.
This document concerns a method for noise reduction and a communication terminal that incorporates a noise reduction system. The method involves receiving a primary signal at a first microphone system of a communication device and a secondary signal at a second microphone system of the communication device. The first and the second microphone systems are disposed at first and second locations on the communication device which are separated by a distance. The method involves the use of a processing element to dynamically identify an optimal transfer function of a correction filter which can be applied to the secondary signal processed by the second microphone system to obtain a correction signal. Once the correction signal has been obtained, it is subtracted from the primary signal to obtain a remainder signal which approximates a signal of interest contained within the primary signal. According to one aspect, the optimal transfer function is dynamically determined by a series of operations. A sequence of estimates is generated which comprises both an autocorrelation of the secondary signal, and a cross-correlation of the secondary signal to primary signal. Thereafter, a noise filter is applied to each estimate in the sequence of estimates to obtain a sequence of filtered estimates with reduced noise. The optimal transfer function is then iteratively estimated using the sequence of filtered estimates.
According to one aspect, the filter is a Kalman filter. A computation cost of the Kalman filter process is reduced by defining both the vector representations of the correlation function and the autocorrelation function as atomic state variables. A computation cost of the Kalman filter is reduced by defining in the Kalman filter a variance associated with both an error around a current state estimate and a process noise to be scalar values. The Kalman gain is a scalar value and the optimal correction filter is determined using a Khobotov-Marcotte algorithm.
In the method described herein, it is understood that far field sound originating in a far field environment relative to the first and second microphone systems produces a first difference in sound signal amplitude at the first and second microphone systems. The sound signal amplitude of the far field sound is received at approximately equal amplitude levels in the first and second microphone systems. To achieve the foregoing, the location of first and second microphones respectively associated with the first and second microphone systems are carefully selected. The microphone locations also ensure that near field sound originating in a near field environment relative to the first microphone produces a second difference in sound signal amplitude at the first and second microphone systems. Notably, the second difference can be substantially greater than the first difference. The near field sound is received at a substantially higher sound signal amplitude by the first microphone system as compared to the second microphone system.
The solution also concerns a communication terminal. The communication terminal includes a first microphone system and a second microphone system. A noise reduction processing unit (NRPU) is also included in the communication terminal. The NRPU is configured to receive a primary signal from the first microphone system and a secondary signal from the second microphone system. Using a methodology described herein, the NRPU dynamically identifies an optimal transfer function of a correction filter which can be applied to the secondary signal provided by the second microphone system to obtain a correction signal. The NRPU causes the correction signal to be subtracted from the primary signal to obtain a remainder signal which approximates a signal of interest contained within the primary signal. The optimal optimal transfer function is dynamically determined by generating a sequence of estimates comprising both an autocorrelation of the secondary signal, and a cross-correlation of the secondary signal to primary signal. A noise filter is applied to each estimate in the sequence of estimates to obtain a sequence of filtered estimates with reduced noise and the optimal transfer function is iteratively estimated by the NRPU using the sequence of filtered estimates.
In the communication terminal described herein, the noise filter is advantageously selected to be a Kalman filter. Further, the NRPU can be configured to reduce a computation cost of the Kalman filter process by defining both the vector representations of the correlation function and the autocorrelation function as atomic state variables. According to one aspect, the NRPU is configured to reduce a computation cost of the Kalman filter by defining in the Kalman filter a variance associated with both an error around a current state estimate and a process noise to be scalar values. The Kalman gain is a scalar value and the NRPU is configured to determine the optimal correction filter by using a Khobotov-Marcotte algorithm.
In the communication terminal, the first microphone system includes a first microphone and the second microphone system includes a second microphone. The first and second microphones are respectively disposed at first and second locations on the communication terminal and separated by a predetermined distance. Consequently, a far field sound originating in a far field environment relative to the first and second microphones produces a first difference in sound signal amplitude at the first and second microphone systems. In particular, the first and second microphones are positioned so that the sound signal amplitude of the far field sound is received at approximately equal amplitude levels in the first and second microphone systems. The first and second microphones are also positioned to cause near field sound originating in a near field environment relative to the first microphone to produce a second difference in sound signal amplitude at the first and second microphone systems. The second difference is substantially greater than the first difference such that the near field sound is received at a substantially higher sound signal amplitude by the first microphone as compared to the second microphone.
This disclosure is facilitated by reference to the following drawing figures, in which like reference numerals represent like parts and assemblies throughout the several views. The drawings are not to scale and are intended for use in conjunction with the explanations in the following detailed description.
It will be readily understood that the solution described herein and illustrated in the appended figures could involve a wide variety of different configurations. Thus, the following more detailed description, as represented in the figures, is not intended to limit the scope of the present disclosure, but is merely representative of certain implementations in various different scenarios. Further, particular features described herein can be used in combination with other described features in each of the various possible combinations and permutations. It is noted that various features are described in detail with reference to the drawings, in which like reference numerals represent like parts and assemblies throughout the several views. While the various aspects are presented in the drawings, the drawings are not necessarily drawn to scale unless specifically indicated.
The methods and/or systems disclosed herein may provide certain advantages in a communication system. Specifically, the method and/or system will facilitate voice communications in the presence of environmental background noise.
Shown in
With the foregoing microphone arrangement, there will usually be some difference in amplitude of audio signals that are received by the first microphone and the second microphone. This difference is dependent on the location of the sound source relative to the microphones due to the difference in a near field sound attenuation model and a far field sound attenuation model. Sound originating in a far field relative to the communications terminal 100 will be received by the first and second microphone at approximately equal sound amplitude levels. In contrast, sound originating in the near field relative to the first microphone 110 will be received by the second microphone at a much lower sound amplitude level. This phenomena can be exploited to remove noise sources located in the far field relative to the communication terminal.
Shown in
As noted above, the method described herein exploits a phenomena which involves a difference in the way that sound attenuates over distance relative to its source. The volume of sound that originates from a source in a near-field relative to a microphone location will attenuate rapidly as a function of distance. This is sometimes referred to as a near-field attenuation model. In contrast, the volume of sound that originates from a source in a far-field relative to a microphone location will attenuate much more slowly as a function of distance. This is sometimes referred to as a far-field attenuation model. In this solution, the user or speaker who is the source of signal (A) is understood to be in the near field relative to both the primary and secondary microphone systems 204, 206 whereas sources of noise are understood to be in the far field. Accordingly, attenuation of the voice signal (A) originating with the user will occur in accordance with a near-field attenuation model and the attenuation of noise signal (N) will occur in accordance with a far field attenuation model.
In the present solution it is understood that the primary microphone system 204 is positioned somewhat closer to the source of voice signal (A) as compared to secondary microphone 206. Consequently, as a result of the operation of the near field attenuation model, the voice signal will predominantly couple to only the primary microphone 204 whereas the noise signal (N) couples into both the primary 204 and the secondary microphone 206 approximately equally. As shown in
In
The solution for identifying H(z) described herein involves solving for a linear time invariant (“LTI”) “black box” filter using variational inequalities (VI). This so-called black-box problem can be addressed in both deterministic and stochastic forms. In the deterministic form, both the primary and secondary signals are known a priori in their entirety and any stochastic processes that contributes to the input signal's construction are already complete, i.e. all random variables have been sampled. Thus, the solution found using the deterministic method is a single, optimal filter for the specific pair of signals. From the foregoing it will be understood that the deterministic method may not be ideal for real world applications involving the communication terminal because the pair of input signals are not known a priori in their entirety, and the acoustics of the environment are understood to be constantly changing over time. In the stochastic form of the solution, it is accepted that neither signal is known in its entirety at any point while solving for H(). Instead, multiple samples are drawn from the signals to create a series of approximate solutions. These approximate solutions will ultimately converge to the same answer as found by the deterministic method.
Because of the respective characteristics and preconditions associated with each of the deterministic and stochastic solutions, the deterministic method is most suitable for post-processing applications where one time-invariant solution is needed. The stochastic method is most suitable for real-time applications but still suffers from certain limitations when applied to practical signal processing applications. These limitations are described in further detail below, followed by a description and analysis of an optimal solution which is referred to herein as an adaptive stochastic method. An understanding of the optimal solution is best understood with reference to an understanding of the deterministic solution and a basic (non-adaptive) stochastic solution. Accordingly, the detailed description below includes a description of the deterministic solution followed by a (non-adaptive) stochastic solution to provide context for an optimal adaptive stochastic method.
The analysis disclosed herein relies heavily of the Z-transform, which is the discrete-time equivalent to the Laplace transform. To review, if x[k]=xk is a discrete time signal, where xk∈, then the Z-transform of x is
X(z)={x[k]}=Σk=−∞+∞xkz−k (1)
The corresponding inverse transform is given by the contour integral
where C is a contour around the origin enclosing all of the poles (roots of the denominator) of X(z).
Note that the Z-transform is a Laurent series over z. To avoid potential distractions regarding infinite time-domain sequences, we define M,N to be the set Laurent series of z only containing non-zero coefficients between the M-th and N-th powers of z. This restriction causes no loss of utility in engineering applications.
M,N={Σk=MNckz−k|N,M∈,ck∈} (3)
The advantage of the Z-transform is that is simplifies the bookkeeping of the essential operation of linear time-invariance systems, including convolution and correlation. To review, convolution in the time domain is multiplication in the Z-domain
{x[k]*y[k]}=X(z)Y(z) (4)
and correlation is convolution with a time reversal
There are two operations required here that are not in common usage for the Z-transform: an inner-product and projection onto arbitrary M,N sets. We define as the inverse Z-transform of the correlation of two signal evaluated at zero.
This definition is equivalent to the inner product of the two associated time series.
(X(z),Y(z)=x[k],y[k]=Σk=−∞+∞xkyk (7)
The projection operation is denoted ΠS
ΠS
which is simply the truncation of the coefficients outside the powers of z included in the set.
Choosing the Correction Filter H()
Various different methods and techniques can be applied to the problem of choosing the correction filter H(). Alternatives include both a deterministic method and a stochastic method. A brief discussion of each is provided below, followed by a more detailed description of an adaptive stochastic method which overcomes limitations of both.
Recalling
R(z,H(z))=P(z)−H(z)S(z) (9)
Assuming the characteristics of the signal within P(z) are unknown, a good criterion for optimizing the choice of H(z) is to minimize the L2 norm (sometimes referred to as the Euclidean norm) of R(z, H(z)); let J[H(z)] be that norm.
By its construction, J is convex and has exactly one minimum. Using the calculus of variations, H(z) can be shown to be that minimum if
J[H(z)]≤J[H(z)+ϵη(z)] ∀η(z)∈M,N (13)
for any ϵ∈ close to zero and η(z) is any Laurent series of z with a finite number of non-zero coefficients. Following the derivation of the Euler-Lagrange equation, H(z) also minimizes J when the derivative of J with respect to E evaluated at zero is identically zero for all choices of η(z).
Recalling the definition of the inner product offered above in the discussion of the deterministic approach, we convert the inner product to the contour integral
where F(x, H(z)) is defined to be
For the contour integral to be zero for all possible η(z−1), F(z, H(z)) must also be identically zero. Therefore we can say F(z, H(z))≡0 if and only if H(z) minimizes J.
To build intuition about this result, we note the F(z, H(z)) is equivalent to the gradient of the cost function in a more traditional linear algebra approach. We further note that the product S(z−1)S(z) is the auto-correlation function of S and S(z−1)P(z) is the cross-correlation of S and P. Lastly we note that F(z, H(z)) is still a Laurent series of z, meaning that for F to be identically zero, all coefficients of F must be zero. In effect, F encodes a system of equations with one equation per power of z, all of which must be individually equal to zero.
{F(z,H(z))}[k]≡0 ∀k∈ (19)
If there are no constraints on what characteristics a solution needs to have, we can solve F(z, H(z))≡0 to find the global optimum. This may not be practical because H(z) may have an infinite number of non-zero coefficients even though P(z), S(z)∈M,N. A more manageable approximation will be to constrain H(z) to −R,+R, which would allow the solution to be implemented as an (2R+1)-tap finite impulse response (FIR) filter.
Depending on the application, additional constraints may also be required. We introduce such that ⊂−R,+R to be the admissible set containing all possible values of H(z) that satisfy all constraints of the application. A constrained minimization of J[H(z)] such that H(z)∈ can now be written as a variational inequality, provided is both convex and compact.
F(z,H(z)),Y(z)−H(z)≥0 ∀Y(z)∈ (20)
Solving this VI can be done using a fixed-point iteration scheme using equation 21, known as the natural equation, which requires a step-size, τ, and the projection operator, , as defined above. Since F is a gradient of J for this application, the natural equation is equivalent to a steepest-descent method where the result of each iteration is projected back onto the solution set. Convergence on a solution is detected when ∥Hk(z)−Hk−1(z)∥<ϵ. The convergence of the natural equation is guaranteed if the defining function F is both strongly monotonic and Lipschitz continuous, and if τ is chosen to suit both properties of F.
H
k+1(Z)=(Hk(z)−τF(z,Hk(z))) (21)
There is a second category of iterative methods for solving variational inequalities known as the extra-gradient methods. These methods tend to be slower than other iterative solvers but have more reliable convergence properties, guaranteeing convergence when F is both monotone (but not strongly monotone) and Lipschitz continuous with constant L and step-size
the basic extra-gradient method is a two-step method defined as shown in equations 22 and 23.
k(z)=(Hk(z)−τkF(z,Hk(z))) (22)
H
k+1(z)=(Hk(z)−τkF(z,
The basic from of the extra-gradient method leaves the step-size constant across all iterations. A more robust method is known as Khobotov's method which estimates the local Lipschitz constant once per iteration and decreases the step-size if τk exceeds the reciprocal of that estimate. The Khobotov's method has been further refined by Marcotte's rule, which allows τk to increase each iteration subject to the upper limit described by Khobotov. The combination of Khobotov's method with Marcotte's rule (“the Khobotov-Marcotte algorithm”) has shown to be useful for this application, and is shown in equation 24. The parameter α is the rate at which τ shrinks or expands and is typical around the value of one. The parameter β scales the estimate of the reciprocal of the local Lipschitz constant such that β∈(0,1). Finally, the parameter {circumflex over (τ)} is the minimum step-size, which should be significantly less than one but greater than zero.
The Stochastic Method
For purposes of understanding the stochastic method it is useful to refer to
As may be understood from
Correlation Estimation
The first step 301 of the stochastic method is to generate a sequence of estimates of both the secondary signal's autocorrelation, S(z−1)S(z), and the secondary-to-primary cross-correlation, S(z−1)P(z). To simplify the notation, the true autocorrelation of S and it's noisy estimate will denoted a U(z) and U(z, ω), respectively, where co is the (possibly infinite) set of random variables at play within the approximation of U. Similarly, the cross-correlation of S to P will be denoted as V(z) and V(z, ω).
U(z)=S(z−1)S(z) (25)
V(z)=P(z−1)S(z) (26)
The approximations of U and V may be calculated a variety of ways including a infinite impulse response (IIR) averaging methods and sliding window averaging methods. For the purposes of analysis, U and V are modeled as their true counterparts corrupted by additive random noise components. Let ϕ1(z, ω) and ϕ2 (z, ω) be the random components of these respective approximations.
U(z,ω)=U(z)+ϕ1(z,ω) (27)
V(z,ω)=V(z)+ϕ2(z,ω) (28)
The estimates U(z, ω) and V(z, ω) will ultimately be used to calculate F while minimizing J[H(z)]. Since the solution filter H(z) is constrained to −R,+R, the estimates of U(z, ω) and V(z, ω) only need to include terms necessary to approximate F in −R,+R as well. This is means U(z, ω)∈−2R,+2R and V(z, ω)∈−R,+R would be sufficient support.
Given this limitation on the reach of U(z, ω) and V(z, ω), U and V can be estimated directly in real time using the recent history of the time-domain primary and secondary signals p[t] and s[t]. Conveniently, the auto-correlation function U must have even symmetry so only half the function need to be observed.
The most trivial estimation method is to multiply the time-domain signals p[t] and s[t] with time-shifted versions of themselves and average over blocks of N samples. The resulting functions, vN[n, k] and uN[n, k] are indexed by their starting position in the time, n, and by relative time-shift of the component signals, k. It should be noted that N=1 produces a valid, if noisy, estimate.
These time-domain estimates of the correlations functions can be related back to corresponding z-domain noisy correlation functions by treating each starting position of the block averages as separate samples of the set of random variables in ω. Note that the formula for U is exploiting the even symmetry of the function.
Optimization
The second step 302 of the stochastic method is to iteratively estimate H(z)∈ to minimize J[H(z)] using many successive samples of the correlation functions U(z, ω) and V(z, ω). Similarly to the deterministic method described above, the true solution H(z) will reached by a stochastic version of the natural equation, shown in equation 33, where the step-size τ is replaced by a sequence of step-sizes τk that must converge towards zero at the right rate.
H
k+1(Z)=(Hk(z)−τkF(z,ω,Hk(z))) (33)
In equation 33, the short-term approximation of F is denoted F(z, ω, H(z)) and is defined similarly as a function of the approximations of U and V. Since F is linear with respect to U and V, F(z, H(z)) is also equal to its deterministic counterpart plus additive random noise.
The challenge in using the stochastic natural equation is in choosing the step-size to manage both the noise in the approximations of the correlation functions and the convergence criteria of the solution. The requirement that τk to go to zero as k goes to infinity is not suitable for typically real-time signal processing applications where conditions cannot be assumed to persist indefinitely. In a practical signal processing application, conditions typical evolve over time such that current optimization problem may be replaced by another related problem. To address this, step-sizes are usually bounded away from zero by some small positive number so that the algorithm can always adapt. This means convergence to the deterministic solution is never achieved, but the iterative approximations remaining close enough to truth to be useful.
In the stochastic solution, the solution of H() once determined is applied at 303. The resulting operation on S() at 303 will produce the necessary correction signal which is then subtracted from P() at 304. Subtracting the correction signal from P() from leaves remainder R() which comprises the signal of interest.
Adaptive Stochastic Method
As discussed in the previous section, the challenge to the stochastic method for real-time signal processing applications is choosing the solver's step-size to balance two key attributes, the rate of convergence to the solution and the noise rejection of the algorithm, which often run contrary to each other. The method offered here attempts to separate noise rejection from the constrained optimizer by adding a Kalman filter of the correlation functions, and thus allowing the step-size to be chosen for the best rate of convergence. The resulting algorithm shown in
This approach is reasonable because the defining function of variational inequality, F, is linear with respect to the noisy estimates of the correlation functions, U(z, ω) and V(z, ω), as shown in equation 34. This means that the expectation of F solved using noisy estimates of the correlation functions is the same as F solved with the expectation of the same noisy correlation estimates; in other words, the expectation can be taken on the inputs or the outputs of F with changing the answer.
Correlation Estimation
The first step of the adaptive-stochastic method is to calculate estimates of the correlation functions, V(z, ωn) and UN (Z, ωn). These estimates are calculated in the same as the manner as for the stochastic method above. Care should be taken in choosing the averaging block-size parameter N because it has a direct impact on the performance of Kalman filter in next step. Larger values of N will perform better than small values.
The Kalman filters are provably optimal for linear systems with additive Gaussian noise and retain good performance when the noise is only approximately Gaussian. For the best overall performance, it is therefore necessary to have the noise about U and V to be approximately Gaussian as possible. When N is small, there is higher risk that the noise about U and V may not be sufficiently Gaussian because the noise about U and V becomes increasingly dependent on the characteristics of the underlying signals S and P as N approaches one. Consider input signals S and P each with independent, additive Gaussian noise. For such inputs, the noise around U and V for N=1 will both be the products of two Gaussian random variables. These Gaussian-product distributions have high kurtosis and thus are poor approximations of Gaussian distributions. Accordingly, the performance of the Kalman filter for U and V for N=1 will suffer. For other noise distributions on S and P, the performance loss may be arbitrarily bad.
The solution to the under-performance of the Kalman filter is to increase N. The central limit theorem states that as N becomes large, the error in UN and VN will become Gaussian. Accordingly, there will be a large enough N to support the desired performance of the overall system. In practice, larger values of N have larger computation costs, so the best choice of N will always be a trade-off dependent on the characteristics of S and P as well as the available computation budget. It is therefore recommended that the noise characteristics of S and P be understood prior to choosing N whenever possible.
Kalman Filter
The Kalman filters in the second step of the adaptive-stochastic method further refine the V(z, ωn; N) and U(z, ωn; N) functions calculated in the first step in better estimates of the true V(z) and U(z) functions. These refined estimates will be denoted as Û and {circumflex over (V)}. The formulation of these Kalman filters follows the standard formulation described in modern control theory with one departure: the observers treats the vector representations of V(z, ωn; N) and U(z, ωn; N) as two atomic state variables rather than two vectors of 2R+1 independent scalars. This can be thought of as the observers working on function-valued state variables instead of scalar-valued state variables. The end result of this alteration is a significant decrease in computation cost with no loss of optimality for this particular application.
Filter Algorithm
The Kalman filter is a non-linear, two-phase iterative algorithm for estimating the current state of a system using a dynamical model describing the evolution of the system's state over time, and an observation model relating system's state to a set of noisy measurements. The classic Kalman filter assumes both models are linear and all noises are Gaussian. Both these assumption are true for this application.
For each iteration, the first phase of the Kalman filter is to predict the current state estimate of the system using the prior state estimate, and to predict the variance of the error in the current state estimate from the variance of the error in the prior state estimate. Equation 38 shows the trivial state prediction: the prediction of the current state, denoted as Ûk|k−1 and {circumflex over (V)}k|k−1, is the same as the prior state. This trivial prediction is often sufficient for applications where H(z) is not expected to change quickly. More complex prediction steps can also be used if required by a particular application.
Equation 39 shows the predictive update of the variance of the error around the state vector, denoted as {circumflex over (σ)}. Unlike equation 38, this equation is the same for all applications. Here the predicted variance {circumflex over (σ)}k|k−1 is shown to be the variance of the prior iteration, {circumflex over (σ)}k−1|k−1, plus the process noise q. In a typical Kalman implementation, both {circumflex over (σ)} and q are covariance matrices, but this algorithm exploits a special case allowing both to be scalars; discussion of this special case will follow.
Û
k|k−1
=Û
k−1|k−1 (38)
{circumflex over (σ)}k|k−1={circumflex over (σ)}k−1|k−1+q (39)
The second phase of the Kalman filter is to update the current state estimate using measured data. For this application, this second phase it further broken down into two steps: first, LTI filtering the raw correlation functions U(z, ω; N) and V(z, ω; N) and estimating the variance of their errors, and second, calculating updating the current state estimate and it's variance. Both steps are implemented as single-pole low-pass IIR filter, but the latter update of the state estimate uses a adaptive time constant chosen by the Kalman equations.
Equation 40 shows the update of the estimated mean of the raw input U(z, ω; N); V (z, ω; N) is processed similarly. The mean is denoted as Ū. The parameter α is chosen so that the time constant of the averaging is relatively short. The goal of this filter is mainly to support the estimation of the variance of the input data; the bulk of the filtering occurs in the next step.
Equation 41 shows the update of the estimated variance of the raw input U(z, ω; N); again, V(z, ω; N) is processed similarly. The variance is denoted as
Ū
k
=Ū
k−1+α(Uk−Ūk−1) (40)
k
2−
Using the variances of the predicted state and the input measurement, the Kalman gain can be calculated as shown in equation 42. Here again, this equation has been simplified from matrices to scalars. This substitution is a significant cost savings over the standard algorithm because the denomination of the division would require the factoring or inversion of a (2R+1)×(2R+1) matrix for each iteration of the algorithm.
Finally, equation 43 shows the current state estimate update as the weighted sum of the predicted current state and the measured state, where the weighting of the sum is set by the Kalman gain calculated in equation 42. Equation 44 shows the corresponding update to the variance of the error around the state estimate.
Û
k|k
=Û
k|k−1
+K(Ūk−Ûk|k−1) (43)
{circumflex over (σ)}k|k2=(1−K){circumflex over (σ)}k|k−12 (44)
Algorithm Analysis
A noteworthy aspect of the algorithm described in the foregoing section is that the variances are represented as scalars instead of matrices. The variance of a vector-valued random variable is normally described as a matrix which contains the variance of each vector component individually and the covariance of all pairwise combinations of the vector components. In contrast, the variance of a complex-valued random variable is described as a single real-value scalar despite the complex value's similarity to a vector with dimension 2. This is because the complex value is considered to be atomic—the real and imaginary components of the values cannot be considered individually as is done with a vector. In a solution described herein, the optimization of the Kalman filter is done by treating the vector approximations of the correlation functions in a manner that is similar to the complex value. The correlation functions are thus treated as atomic values (in this case a function) and thus the variance is a single real-only scalar. This method is instructed by the calculus of variations.
Ultimately, the foregoing optimization cuts out the need for costly matrix inversion/factoring steps required by the canonical Kalman filter, and for this specific application, this optimization comes with no penalty to performance. This substitution is a significant saving in computation cost without loss of optimality for special case: if the measurement variance and the process variance differ only by a scalar multiplier, then the Kalman gain will effectively become a scalar value. Consider a Kalman filter consisting of trivial prediction and measurement models, with state variance Pi, constant process variance Q, and constant measurement variance R. The canonical Kalman gain for this system is shown matrix notation in equation 45. Note that Pi+Q is the state variance after prediction, so this equation 46 cascades the prediction and update steps into one.
K
i=(Pi+Qi)(Pi+Qi+Ri)−1 (45)
P
i+1=(I−Ki)(Pi+Qi) (46)
The Kalman algorithm calls for running equations 45 and 46 endlessly with the guarantee that limiting value of the state variance P∞ will be the global achievable minimum. The value of P∞ is defined implicitly in equation 47 by substituting equation 45 into equation 46 and setting Pi=Pi+1=P∞. For any given pair of constant process variance Q and constant measurement variance R, there will be a unique solution for P∞.
P
∞=(I−(P∞+Q)(P∞+Q+R)−1)(P∞+Q) (47)
The premise for this numerical shortcut is that the process and measure variances are scaled version of a common matrix, so we assume Q=qS, and R=rS where S is common covariance matrix related to the raw data and q and r are positive scalars. If P∞=pS where p is also a positive scalar, then the implicit definition of P∞ can be reduced to equation 48.
(p2+pq−qr)S=0 (48)
Equation 48 is clearly satisfied if the quadratic polynomial of p of scalar equals to zero. The determinant of this polynomial is q2+4qr, which is the sum of products of positive number and is therefore positive. Accordingly, p has two real roots, only one of which can be valid given the uniqueness of P∞. Further examination of the determinate shows √{square root over (q2+4qr)}>q, meaning p will have one positive and one negative root. The negative root is outside the domain of valid scalars because pS would not have the proper construction to be a covariance matrix if p<0. We therefore conclude the positive root of p provides the one and only solution to P∞=pS.
Returning to equation 45 with that the knowledge that P∞=pS given Q=qS and R=rS, we find the limiting value of the Kalman gain K∞=kI, where is k∈[0,1] and I is the identity matrix. Essentially, the Kalman gain matrix has been reduced to a gain scalar, and iterative scalar Kalman algorithm converges to the same gain as the iterative matrix algorithm. Applying these scalar substitutions to equations 46 and 45 reduced them to the prediction and update equations seem in the discussion above concerning the filter algorithm, thereby resulting in significantly reduced computation cost.
For all of the above to be applicable, the requirement that the process and measure variances are scaled version of a common matrix must be true. This is true for this application because the Kalman filter is refining the short-time estimates Ū and
Constrained Optimization
The last step of the adaptive-stochastic method is to determine the best filter H(z) given the estimates of Û and {circumflex over (V)} discovered by the Kalman filters, subject to the constraints which define the admissible set . The optimizing method used here is the same Khobotov-Marcotte algorithm which was described above. The choice of the admissible set will be application dependent, but a general recommendation is to place L2 of L-infinity bounds on the possible of values of H(z) to prevent the system from chasing unreasonable solutions.
Shown in
The NRPU described herein can comprise one or more components such as a computer processor, an application specific circuit, a programmable logic device, a digital signal processor, or other circuit programmed to perform the functions described herein. The system can be realized in one computer system or several interconnected computer systems. Any kind of computer system or other apparatus adapted for carrying out the methods described herein is suited.
Referring now to
The computer system 600 is comprised of a processor 602 (e.g. a central processing unit or CPU), a main memory 604, a static memory 606, a drive unit 608 for mass data storage and comprised of machine readable media 620, input/output devices 610, a display unit 612 (e.g. a liquid crystal display (LCD) or a solid state display. Communications among these various components can be facilitated by means of a data bus 618. One or more sets of instructions 624 can be stored completely or partially in one or more of the main memory 604, static memory 606, and drive unit 608. The instructions can also reside within the processor 602 during execution thereof by the computer system. The input/output devices 610 can include a keyboard, a mouse, a multi-touch surface (e.g. a touchscreen) and so on.
The drive unit 608 can comprise a machine readable medium 620 on which is stored one or more sets of instructions 624 (e.g. software) which are used to facilitate one or more of the methodologies and functions described herein. The term “machine-readable medium” shall be understood to include any tangible medium that is capable of storing instructions or data structures which facilitate any one or more of the methodologies of the present disclosure. Exemplary machine-readable media can include magnetic media, solid-state memories, optical-media and so on. More particularly, tangible media as described herein can include; magnetic disks; magneto-optical disks; CD-ROM disks and DVD-ROM disks, semiconductor memory devices, electrically erasable programmable read-only memory (EEPROM)) and flash memory devices. A tangible medium as described herein is one that is non-transitory insofar as it does not involve a propagating signal.
Computer system 600 should be understood to be one possible example of a computer system which can be used in connection with the various implementations disclosed herein. However, the systems and methods disclosed herein are not limited in this regard and any other suitable computer system architecture can also be used without limitation. Dedicated hardware implementations including, but not limited to, application-specific integrated circuits, programmable logic arrays, and other hardware devices can likewise be constructed to implement the methods described herein. Applications that can include the apparatus and systems broadly include a variety of electronic and computer systems. In some scenarios, certain functions can be implemented in two or more specific interconnected hardware modules or devices with related control and data signals communicated between and through the modules, or as portions of an application-specific integrated circuit. Thus, the exemplary system is applicable to software, firmware, and hardware implementations.
Further, it should be understood that embodiments can take the form of a computer program product on a tangible computer-usable storage medium (for example, a hard disk or a CD-ROM). The computer-usable storage medium can have computer-usable program code embodied in the medium. The term computer program product, as used herein, refers to a device comprised of all the features enabling the implementation of the methods described herein. Computer program, software application, computer software routine, and/or other variants of these terms, in the present context, mean any expression, in any language, code, or notation, of a set of instructions intended to cause a system having an information processing capability to perform a particular function either directly or after either or both of the following: a) conversion to another language, code, or notation; or b) reproduction in a different material form.
Furthermore, the described features, advantages and characteristics disclosed herein may be combined in any suitable manner. One skilled in the relevant art will recognize, in light of the description herein, that the disclosed systems and/or methods can be practiced without one or more of the specific features. In other instances, additional features and advantages may be recognized in certain scenarios that may not be present in all instances.
As used in this document, the singular form “a”, “an”, and “the” include plural references unless the context clearly dictates otherwise. Unless defined otherwise, all technical and scientific terms used herein have the same meanings as commonly understood by one of ordinary skill in the art. As used in this document, the term “comprising” means “including, but not limited to”.
Although the systems and methods have been illustrated and described with respect to one or more implementations, equivalent alterations and modifications will occur to others skilled in the art upon the reading and understanding of this specification and the annexed drawings. In addition, while a particular feature may have been disclosed with respect to only one of several implementations, such feature may be combined with one or more other features of the other implementations as may be desired and advantageous for any given or particular application. Thus, the breadth and scope of the disclosure herein should not be limited by any of the above descriptions. Rather, the scope of the invention should be defined in accordance with the following claims and their equivalents.