Digital implementations of filters provide many advantages over conventional analog implementations. In a digital implementation of an analog filter that is being applied to an electrical signal, the electrical signal is sampled periodically and the samples are digitized to form a digital stream that is input to a computational circuit that performs the filter computations on the digitized samples to generate an output digital stream that can then be converted back to an analog signal. For the purposes of this discussion, the term filter latency will be defined as the time delay between the entry of a digital sample into the computational engine and the generation of the next output digital sample that depended on the input sample in question.
This time delay is particularly important for filters that are used in systems that are controlled by feedback loops. A filter can be thought of as lowering or amplifying signal components at chosen frequencies. Alternately, it can be thought of as creating a transfer function of a desired shape in the frequency domain. If a digitally implemented filter is placed in the control loop, the delay introduced by the filter can cause the control system to become unstable leading to oscillations in the parameter that was to be controlled. In essence, the control system tries to regulate the system based on data that is too old to be valid and hence the control system overcompensates or under compensates the system in question.
Another problem with digitally implemented filters is the computational accuracy needed by the computational engine to accurately generate the filtered data stream. These problems can be minimized by utilizing computational engines having high precision floating-point arithmetic units. However such computational engines are economically unattractive for many applications and often involve significantly more computational latency than fixed point units. Hence implementations that can be carried out in fixed-point arithmetic are preferred.
Both of these problems are intensified in applications in which a plurality of filters must be cascaded to remove the effects of multiple resonances and anti-resonances within the system being controlled. If two filters are cascaded, the latency of the pair of filters is twice that of an individual filter. If the cascaded pair is replaced by a single filter that implements same filtering operation, the length of the single filter is longer than either of the original filters. For example, two cascaded biquad filters would be replaced by a single filter whose numerator and denominator implemented 4th order polynomials. In some cases, the numerical precision required to implement the filter in fixed-point arithmetic increases substantially.
The present invention includes a filter and method for filtering a signal. The filter is equivalent to a plurality of bi-quad or bilinear filters connected in series, and is implemented on a digital processor that receives a sequence of signal values at a sampling rate characterized by a sampling interval and generates a filtered signal value upon receiving each received signal value. The filter has a latency that is less than the sampling interval. The filtered values can be generated by adding a term to a received signal value and multiplying the sum by a gain constant that depends on the filter constants. The added term does not depend on the current received signal value. The filter can be implemented in fixed-point integer arithmetic.
The manner in which the present invention provides its advantages can be more easily understood with reference to
d(k)=−a1d(k−1)−a2d(k−2)+u(k), (1)
{tilde over (y)}(k)=d(k)+{tilde over (b)}1d(k−1)+{tilde over (b)}2d(k−2), (2)
and
y(k)=b0{tilde over (y)}(k) (3)
where b0 is referred to as the direct feedthrough gain, in that it is the scaling of the input, u(k), which shows up without delay at the output, y(k).
Alternately, Equation (2) can be replaced by
{tilde over (y)}(k)={tilde over (b)}1d(k−1)+{tilde over (b)}2d(k−2)−a1d(k−1)−a2d(k−2)+u(k) (2a)
or
{tilde over (y)}(k)=({tilde over (b)}1−a1)d(k−1)+({tilde over (b)}2−a2)d(k−2)+u(k). (2b)
The parameters a1, a2, b0, b1, b2 are determined by the desired poles and zeros of the digital filter, which in turn provide properties such as the center frequency, etc. In one embodiment, the filter can be specified to be an anti-resonance, resonance pair which will equalize out the effects of a resonance, anti-resonance pair in the system dynamics. In another embodiment, the filter can be set to be a single lead/lag filter or a double lead/double lag filter. In another embodiment, the filter can be a single or double lag/lead filter. In a further embodiment, the filter can be shaped to be a band pass or a band stop filter. The manner in which these parameters are chosen will be discussed in more detail below.
It should be noted that the quantity −a1d(k−1)−a2d(k−2) can be computed as soon as u(k−1) is received, and hence, the latency in computing d(k) is just the time to perform one addition. Similarly, {tilde over (b)}1d(k−1)+{tilde over (b)}2 d(k−2) can be computed as soon as u(k−1) is received, and ({tilde over (b)}1−a1)d(k−1)+({tilde over (b)}2−a2)d(k−2) can be computed as soon as u(k−1) is received. Hence, it can be seen from Equations 2a, 2b, and 3 that the total latency in computing y(k) is the time for one add and one multiply.
The manner in which the computational method of the present invention provides its advantages can be more easily understood by defining a sequence of delay vectors. For a single bi-quad filter, define the sequence of vectors
whose components are given by
{tilde over (d)}
1(k)={tilde over (d)}(k) (4)
{tilde over (d)}
2(k)={tilde over (d)}1(k−1) (5)
These vectors will be referred to as “D-vectors” in the following discussion. Each time a new signal value, u(k) is received, the D-vector is updated as follows:
and the filtered value is computed according to
The vectors defined by the products
can be computed as soon as u(k−1) is received, and hence, the latency is the time needed for one scalar add and the final multiply to obtain y(k). It should also be noted that the multiple scalar adds can be performed in parallel, and hence, can be performed without increasing the filter latency time.
A single bi-quad filter provides filtering for one resonance/anti-resonance pair. To filter out multiple pairs or to implement a higher order transfer function, a series of bi-quad filters can be cascaded as shown in
A single bi-quad is represented by the transfer function:
which, as noted above, can be implemented in the time domain as:
d(k)=a1d(k−1)−a2d(k−2)+u(k), (11)
y(k)=b0d(k)+b1d(k−1)+b2d(k−2) (12)
In one embodiment, b0 is factored out and hence,
In this case,
d(k)=−a1d(k−1)−a2d(k−2)+u(k), (14)
{tilde over (y)}(k)=d(k)+{tilde over (b)}1d(k−1)+{tilde over (b)}2d(k−2), and (15)
y(k)=b0{tilde over (y)}(k) (16)
In the following discussion, a filter having the transfer function form
will be referred to as a unit direct feedthrough gain bi-quad filter because its value for the direct feedthrough gain, b0, is set to 1. Refer now to
It should be noted that the numerator of Eq. (10) attenuates signals in a frequency band corresponding to the notch. The denominator provides the gain in a second band of frequencies. The coefficients, a1 and b1, are related to the properties of these bands. The b0 coefficient is, by definition the direct feedthrough gain of the bi-quad. By factoring out the b0 term, a cascade of bi-quads having the same (unity) direct feedthrough gain can be implemented followed by a single gain stage. This facilitates implementations in which a general filter processor is provided which will implement the cascade in response to the user inputting the parameters for each bi-quad and the overall gain of the system.
To simplify the following discussion, in a chain of bi-quads, extra subscripts are utilized to denote the quantities that are associated with the individual bi-quads. The quantities of interest are as follows:
u
0(k)=u(k), (17)
u
1(k)={tilde over (y)}0(k), (18)
u
2(k)={tilde over (y)}1(k), (19)
u
N−1(k)={tilde over (y)}N−2(k),ũN−1(k)={tilde over (y)}N−2(k), (20)
{tilde over (y)}(k)={tilde over (y)}N−1(k), and (21)
y(k)=(bN−1,0bN−2,0 . . . b1,0b0,0){tilde over (y)}(k) (22)
d
1(k)=ai,1d(k−1)−ai,2d(k−2)+u1(k) (23)
{tilde over (y)}
i(k)=di(k)+{tilde over (b)}i,1di(k−1)+{tilde over (b)}i,2di(k−2) (24)
For each di(k), define two components, di,1(k) and di,2(k) as follows:
{tilde over (d)}
i,1(k)=di(k) (25)
{tilde over (d)}
i,2(k)={tilde over (d)}i,1(k−1) (26)
The coefficients, ai,1, ai,2, bi,1, bi,2, and bi,0 are determined from the desired filter properties as follows. First, for the ith filter denote:
The parameters in question are then related to these filter parameters as follows:
The manner in which the present invention provides its advantages can be more easily understood in terms of a vector.
It can be shown from the above definitions that
{tilde over (D)}(k)=MD*D(k−1)+u(k)CD (28)
Here, MD is a matrix and CD is a constant vector. For example, in the case in which three bi-quads are cascaded, it can be shown that
It should be noted that the matrix product MD*D(k−1) can be computed as soon as u(k−1) is received. Hence, this formulation avoids the increased latency associated with a cascade of bi-quads.
Similarly, define a vector
It can be shown that
Y(k)=MY*D(k−1)+u(k)*C Y (29)
Here, MY is a matrix and CY is a constant vector
For example, in the case in which three bi-quads are cascaded, it can be shown that
The matrix product MY*D(k−1) can be computed as soon as D(k−1) is known. As noted above, D(k−1) can be computed as soon as u(k−1) is received. Assuming that the computations are carried out on a computer that has a cycle time that is much faster than the rate at which samples are received, they can be completed in less time than the time difference between successive samples. Thus, the precalculated portions of the filter are ready and the time to respond to the most recent sample is simply the time for one addition and one multiply. In this regard, it should be noted that the matrix multiplications and adds can be carried out in parallel on a machine having multiple processors or in programmable logic such as a Field Programmable Gate Array (FPGA).
It should also be noted that the filter output depends only on {tilde over (y)}2(k), i.e. y(k)=
The actual numeric calculations can be simplified by noting that two quantities for each bi-quad are repeated a number of times in the matrix products, and hence, these quantities can be computed once and used to compute the matrix products. In particular, the quantities
p{tilde over (r)}eci,1(k)=ai,1{tilde over (d)}i,1(k−1)+ai,2{tilde over (d)}i,2(k−1) and (31a)
p{tilde over (r)}eci,2(k)={tilde over (b)}i,1{tilde over (d)}i,1(k−1)+{tilde over (b)}i,2{tilde over (d)}i,2(k−1) (31b)
are useful in reducing the computational complexity in that the matrix D vector products can be written in terms of sums and differences of these quantities. For example, in the case of three cascaded bi-quads,
An implementation of the filter shown in
If the sample rate is high compared to the frequencies of the dynamics to be filtered (such as the biquad providing a notch/resonance pair), and the computations are carried out in fixed-point integer arithmetic, the sums and differences discussed above can suffer from round-off errors, because,
{tilde over (b)}i,1≈−2 and {tilde over (b)}1,2≈1 and
ai,1≈−2 and ai,2≈1.
For the purposes of this discussion, the sampling rate will be said to be high compared to the frequencies of the dynamics to be filtered if the sampling rate is greater than 10 times the frequency of the lowest frequency notch. Consider the term:
{tilde over (b)}0,1−a0,1
that appears in Eq. (30). This term involves the difference of two quantities that are nearly equal. Hence, the difference in fixed-point arithmetic can be a number with only a few bits of accuracy even when the quantities in question are represented by numbers having 10 or 12 bits.
In one aspect of the present invention, the round-off error problems are significantly reduced by substituting
{tilde over (b)}
i,1=−2+{tilde over (b)}i,1Δ
{tilde over (b)}
i,2=−1+{tilde over (b)}i,2Δ
a
i,1=−2+ai,1Δ
a
i,2=−1+ai,2Δ
In terms of precalculated quantities described above, the new form of p{tilde over (r)}eci,1 (k) and p{tilde over (r)}eci,2(k) make use of these coefficients:
p{tilde over (r)}eci,1(k)□p{tilde over (r)}eci,1W(k)+p{tilde over (r)}eci,1F(k) where
p{tilde over (r)}eci,1W(k)=−2{tilde over (d)}i,1(k−1)+{tilde over (d)}i,2(k−1) and
p{tilde over (r)}eci,1F(k)=ai,1Δ{tilde over (d)}i,1(k−1)+ai,2Δ{tilde over (d)}i,2(k−1).
Here, p{tilde over (r)}eci,1F(k) uses scaled coefficients for more accurate multiplication:
p{tilde over (r)}eci,1FL(k)=(2E
and then the scaling is removed before adding to p{tilde over (r)}eci,1W(k):
p{tilde over (r)}eci,1F(k)=2−E
Here, the coefficient, Ei, is chosen such that the multiplications have the desired precision. Furthermore, it is possible to select a different value of Ei for each coefficient in the equation. Similarly,
p{tilde over (r)}eci,2(k)=p{tilde over (r)}eci,2W(k)+p{tilde over (r)}eci,2F(k) where
p{tilde over (r)}eci,2W(k)=−2{tilde over (d)}i,1(k−1)+{tilde over (d)}i,2(k−1)=p{tilde over (r)}eci,1W(k)
p{tilde over (r)}eci,2F(k)=bi,1Δ{tilde over (d)}i,1(k−1)+bi,2Δ{tilde over (d)}i,2(k−1)
p{tilde over (r)}eci,2FL(k)=(2E
p{tilde over (r)}eci,2F(k)=2−E
Refer now to
Refer now to
While the above-described embodiments of the present invention are directed to filters that have notches and resonances, the method of the present invention can be applied to the computation of any filter that is equivalent to a series of bi-quad filters. Similarly, any bi-quad stage can be used to implement a bilinear filter (with one pole and one zero) by setting, ai,2 and {tilde over (b)}i,2 to 0. In this case,
resulting in coefficient values
ai,1=−e−ω
bi,1=−e−ω
The same filter structure as before could now be calculated. However, for improved precision, it is possible to change the computation of the Δ coefficients. For high sample rates compared to the dynamics to be filtered, then
ai,1,{tilde over (b)}i,1≈−1,
which means that increased accuracy can be obtained by calculating:
a
i,1=−1+ai,1Δ so ai,1Δ=ai,1+1,
ai,2=0 so ai,2Δ=0,
{tilde over (b)}
i,1=−1+{tilde over (b)}i,1Δ so {tilde over (b)}i,1Δ={tilde over (b)}i,1+1, and finally
{tilde over (b)}i,2=0 so {tilde over (b)}i,2Δ=0.
For this bi-quad section:
p{tilde over (r)}eci,1(k)=p{tilde over (r)}eci,1W(k)+p{tilde over (r)}eci,1F(k) where
p{tilde over (r)}eci,1W(k)=−1{tilde over (d)}i(k−1)
p{tilde over (r)}eci,1F(k)=ai,1Δ{tilde over (d)}i(k−1)
p{tilde over (r)}eci,1FL(k)=(2E
p{tilde over (r)}eci,1F(k)=2−E
where the coefficient, is chosen such that the multiplications have the desired precision and likewise
p{tilde over (r)}eci,2(k)=p{tilde over (r)}eci,2W(k)+p{tilde over (r)}eci,2F(k) where
p{tilde over (r)}eci,2W(k)=−2{tilde over (d)}i(k−1)=p{tilde over (r)}eci,1W(k)
p{tilde over (r)}eci,2F(k)={tilde over (b)}i,1Δ{tilde over (d)}i(k−1)
p{tilde over (r)}eci,2FL(k)=(2E
p{tilde over (r)}eci,2F(k)=2−E
Again, it is possible to select a different value of Ei for each coefficient in the equations.
While embodiments above have discussed a single-input, single output (SISO) filter, it will be understood that this invention can be applied to filters with multiple inputs (MI) multiple outputs (MO), or both (MIMO).
The software or logic blocks used to implement the present invention can optimized for state space implementation (such as Equations 28-30) or transfer function form implementations (such as Equations 17-24), or something in between (such as Equations 31-32). It will be clear from the discussion above that these computations can be implemented any of these, or other similar forms.
The above-described embodiments of the present invention have been provided to illustrate various aspects of the invention. However, it is to be understood that different aspects of the present invention that are shown in different specific embodiments can be combined to provide other embodiments of the present invention. In addition, various modifications to the present invention will become apparent from the foregoing description and accompanying drawings. Accordingly, the present invention is to be limited solely by the scope of the following claims.
This is a continuation of International Application PCT/US11/26555 with an international filing date of 28 Feb. 2011.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/US11/26555 | Feb 2011 | US |
Child | 14011670 | US |