The invention relates generally to digital filters.
Finite impulse response (FIR) filters are commonly used digital filters.
An FIR filter has an impulse response that settles to zero in a finite number of sample periods. FIR filters are inherently stable because FIR filters require no feedback and have their poles at the origin (within the unit circle of the complex z plane). However, all digital filters, including FIR filters, are sensitive to perturbations in the filter's tap coefficients.
A digital filter constructed as a cascade of two or more subfilters can possess the capability of lowering the filter's sensitivity to these filter coefficient perturbations. This property is described in J. W. Adams and A. N. Willson, Jr., “A new approach to FIR digital filters with fewer multipliers and reduced sensitivity,” IEEE Trans. Circuits Syst., vol. CAS-30, pp. 277-283, May 1983 [referred to herein as “Adams”] which is herein incorporated by reference in its entirety.
In general, during the design of an FIR filter, the filter's length and tap coefficient's are selected to meet pre-defined characteristics that are usually specified in terms of the filter's frequency response H(ejω). One goal of FIR filter design is to select filter taps and filter length that minimize stopband ripple and passband ripple for the filter's frequency response. (For a digital filter, the frequency response function is the filter's transfer function H(z), evaluated on the unit circle in the complex z-plane, i.e., z=ejω) The Remez algorithm is often used in FIR filter design to solve for the filter tap coefficients that produce the desired equal ripple passband and stopband behavior.
In Adams, an efficient digital FIR lowpass filter was implemented as a cascade of a multiplierless prefilter and an amplitude equalizer. Instead of building the conventional filter as dictated by the design technique used, a less costly implementation is utilized for the prefilter (e.g., all tap coefficients set to one with the first null occurring at the beginning of the stopband). The prefilter is not an optimal filter by itself. However, the cascaded amplitude equalizer fixes the imperfections of the rough pre-filter. The resulting efficient FIR lowpass filter meets the required design constraints for the FIR filter and has both a reduction in hardware implementation costs as well as improved sensitivity. Roughly speaking, the lowered sensitivity of the filter's frequency response to perturbations of the amplitude equalizer's coefficients results from the filtering action of the prefilter.
A common component in digital circuitry for communication systems is the halfband filter. Halfband filters are often used in cooperation with up-samplers and down-samplers in multirate systems when a sampling-rate change is required. Because of the requirements of a halfband filter, the type of prefilter used in Adams cannot implement a desensitized halfband filter.
When a filter removes a band of frequencies (the frequencies in the filter's stopband) from an input signal, the usual desire is that the signal's frequencies that remain (the frequencies in the filter's passband) are not altered. Insofar as the magnitude of these passband-frequency signal-components is concerned, this means that, ideally, we desire the filter's passband gain to be exactly 1, i.e., the magnitude of the filter's transfer function should be exactly 1 throughout the filter's passband. On a decibel scale, this gain of 1 is equivalent to a value of 0 dB. Usually, this “exactly 0 dB” (perfectly flat) passband is not possible to achieve, so the filter designer is required to keep the deviations away from 0 dB, for the magnitude of the filter's transfer function, sufficiently small throughout the passband.
One form of passband deviation that is often encountered is “passband droop.” This kind of deviation from the ideal occurs near the edge of the passband, where the transfer function is beginning the process of making its transition to the stopband.
What is therefore needed are desensitized filters providing droop correction without the use of a separate droop correction element.
The present invention will now be described with reference to the accompanying drawings. In the drawings, like reference numbers generally indicate identical, functionally similar, and/or structurally similar elements. The drawing in which an element first appears is indicated by the leftmost digit(s) in the reference number.
The following detailed description of the present invention refers to the accompanying drawings that illustrate exemplary embodiments consistent with this invention. References in the specification to “one embodiment,” “an embodiment,” “an example embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment.
Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to affect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
Other embodiments are possible, and modifications may be made to the embodiments within the spirit and scope of the invention. Therefore, the detailed description is not meant to limit the invention. Rather, the scope of the invention is defined by the appended claims.
While techniques for designing digital filters are well known, an entirely new method for the design and implementation of halfband filters is presented here, one in which the filter's transfer function can be provided with a significant insensitivity to the filter's tap coefficient values. Such insensitivity can be exploited in the filter-design process to yield halfband filters with reduced hardware requirements, which can lead to circuits having lower power consumption, higher operating speeds, and smaller IC area.
As described above, because of the requirements of a halfband filter, the type of prefilter used in Adams cannot implement a desensitized halfband filter. Fortunately, however, a modification can be made to the type of prefilter that was employed in Adams and it can yield a suitable halfband prefilter. If we consider a cascade of two of the simplest prefilters from Adams, i.e., let P(z)=(1+z−1)(1+z−1) then this P(z) is a halfband filter. We have: P(z)=1+2z−1+1z−2. The resulting prefilter (with taps 1, 2, 1) can be implemented cheaply because no real multiplication is necessary. Multiplication by two (or any positive or negative integer power of two) can be implemented in binary with a shift operation. The design of desensitized halfband filters is described in further detail in Section II, below.
A common component in digital circuitry for communication systems is the halfband filter. This section provides a brief review of halfband filter characteristics and requirements. An FIR halfband filter is an FIR digital filter whose transfer function is of the form
Thus, an FIR halfband filter is a symmetric (hence, linear phase) FIR filter of length 2N+1, for some odd integer N, for which all coefficients hk, where k is an even integer, have the value zero, except for the coefficient in the center h0 which is nonzero. Typically, h0 has the value ½, and the other nonzero hk coefficients can have any desired values.
Since the factor z−N in equation (1) satisfies |z−N|=1 for all z on the unit circle of the complex z plane, the design of a halfband filter is often carried out using the real-valued (albeit physically unrealizable, so called zero phase) transfer function
which can be written as
for all unit-magnitude complex values z, i.e., for z=ejω. FIR filters are, in fact, usually designed by working with a zero-phase function of the equation (3) type, and the factor z−N of equation (1) is then included to create the physically realizable transfer function H(z), for which |H(ejω)|=|H0(ejω)|.
The halfband filter constraints on the hk having even k (i.e., hk=0 for all even k≠0) provide all halfband filters with the general feature that the real-valued zero-phase part of the halfband filter satisfies H0(ejπ/2)=½ and, furthermore, the function H0(ejω) possesses odd symmetry about this ω=π/2 value. That is, we have
H
0(ej(−ω+π/2))+H0(ej(ω+π/2))=1, for all ωε[0,π/2]. (4)
Typically, the halfband filter's nonzero coefficients are chosen such that the relation H0(ejω)≈1 holds in the passband (i.e., it holds for low frequencies within the interval ωε[0, π/2]) and the odd-symmetry relation (4) then causes H0(ejω)≈0 in the stopband (i.e., it holds for high frequencies within the interval ωε[π/2, π]).
As depicted in
h
0+2(h1+h3+ . . . )=1 (5)
and this situation will also be accompanied by H0(ejπ)=0 due to the odd-symmetry of H0(ejω) discussed above.
A halfband filter may also be scaled by an arbitrary value P (as illustrated in
h
0=2(h1+h3+ . . . ) (6)
wherein the scaling value P need not appear explicitly, and this more general constraint of course accommodates the unsealed relation (5) for which h0=½.
H(z)=z−1(h1z1+h0+h1z−1)
This case accommodates the above-mentioned halfband prefilter which, after scaling P(z) by ¼, becomes
Here, it will follow that H0(ejω)=½+½ cos ω (i.e., we set h0=½ and h1=¼).
According to equation (1), the second-smallest halfband filter will have length 7, and will correspond to the N=3 case:
H(z)=z−3(h3z3+h1z1+h0+h1z−1+h3z−3)
This filter will be described by tap coefficients h0, h1 and h3, as illustrated in
The multipliers 530a-c are commonly referred to as “taps” and the coefficients of the multipliers (h0, h1 and h3) are referred to as the “tap coefficients.” The structure of
In
Halfband filters are often used in cooperation with up-samplers and down-samplers in multirate systems when a sampling-rate change is required.
One consequence of an up-sampling operation is the appearance of images of lower frequencies at higher frequencies in the up-sampled signal's spectrum. As depicted in
A consequence of implementing a filter after an up-sampling operation is that the digital circuitry of the filter must operate at a higher data rate then if the circuitry is built prior to the up-sampling operation (e.g., at least twice the rate, for an up-sampling by 2 operation). Therefore, it is preferable to move components of the digital filter in front of the up-sampling operation. While it is evident that the up-sampling occurs before the filtering for such anti-imaging filters, it is possible to move some components of the filter back through the up-sampler so that they operate at the lower frequency.
Therefore, the designer wants the up-sampling component located more forward so as to cause as much as possible of the filter hardware to operate at the lower sample rate.
Notice that the z−2 elements that would have appeared near the top of
As described above, when an up-sampling by 2 operation is performed, a zero is produced after every input sample. Therefore, in filter 700, up-sampler 780a is putting out a signal having zeros every other sample. Up-sampler 780b is also putting out a signal having zeros every other sample. Because the output of up-sampler 780a is delayed by one, the zeros produced by up-sampler 780a are not occurring at the same time as the zeros produced by up-sampler 780b when both data streams arrive at adder 745. Because a zero is always being added to a non-zero signal, the adder operation 745 can be replaced by an interleaving operation. Consequently, the elements included in block 790 of
An FIR filter may also be implemented in an alternate transpose configuration. It is convenient to obtain the transposed-form filter from a direct-form filter by reversing all signal-flow directions.
Notice that the transposed-form filter of
As described above, the transfer function of any halfband filter is going to have a polynomial of a special structure having zeros for every other tap except for the center tap. To implement a desensitized halfband filter as a prefilter-equalizer cascade, it is necessary that the transfer function of the overall halfband filter have the transfer function of the prefilter as a factor. In embodiments, the second-order prefilter P(z) mentioned above (P(z)=(1+z−1)(1+z−1)) can be used. This section describes the necessary constraints on a halfband filter in order for its transfer function to possess the factor (1+z−1).
This requirement is simply the requirement that the polynomial in z−1 that defines the halfband transfer function H(z) possess a zero at z=−1, i.e., at ω=π. Viewed this way, the requirement becomes simply that H(ejπ)=0. It therefore follows, from the above discussion, that the set of desensitized halfband filters must be restricted to the set whose coefficients obey equation (6). Equivalently, again using the above insights, our desensitized halfband filters must satisfy H(ej0)=1. These limitations are reasonably mild, in that any well-designed halfband filter will possess coefficients that approximately satisfy equation (6), as discussed previously.
Having limited the halfband filters to ones whose transfer function possesses the factor (1+z−1) it will then happen—automatically—that the halfband filter will also have a second (1+z−1) factor. An easy proof of this fact is to simply recall that the transfer function H(ejω) is periodic of period 2π and also that the halfband filter's zero-phase function (3) is symmetric about the point ω=π. This means, of course, that H0(ejπ)=0 can only occur if the derivative of H0 is also zero at ω=π. That is, a double zero is necessarily present at ω=π whenever one zero exists at ω=π.
Accordingly, the above proves that the transfer function of an FIR halfband filter will possess the factor P(z)=(1+z−1)(1+z−1) if and only if any of these three equivalent conditions holds:
|H(ejω)|=0 at ω=π i)
|H(ejω)|=1 at ω=0 ii)
h
0=2(h1+h3+ . . . ). iii)
[collectively referred to herein as “Theorem”]
One more insight, regarding Condition iii) of this Theorem is worth mentioning: It is well known that, in a system such as depicted in
Assuming now that the halfband filter's transfer function possesses the factor (1+z−1), it can be factored out of the transfer function H(z). For the degree-fourteen transfer function of the
H(z)=(1+z−1)[h7+(−h7)z−1+(h7+h5)z−2+(−h7−h5)z−3+(h7+h5+h3)z−4+(−h7−h5−h3)z−5+(h7+h5+h3+h1)z−6+(h7+h5+h3+h1)z−7+(−h7−h5−h3)z−8+(h7+h5+h3)z−9+(−h7−h5)z−10+(h7+h5)z−11+(−h7)z−12+h7z−13]
which can be rewritten as
H(z)=(1+z−1){[a0z−6+a1(z−4−z−8)+a2(z−2−z−10)+a3(1−z−12)]+z−1[a0z−6−a1(z−4−z−8)−a2(z−2−z−10)−a3(−z−12)]} (7)
where
a
0
=h
1
+h
3
+h
5
+h
7
a
1
=h
3
+h
5
+h
7
a
2
=h
5
+h
7
a3=h7. (8)
Notice that the halfband filter's center-tap value h0 is not explicitly used in the definition of the ak values—its value being understood as redundant information, in that equation (6) is assumed to hold.
Using the factorization of equation (7), it is possible to create an implementation of the halfband filter of
Desensitized structure 900 includes a delay chain 910 having a series of six one-unit delays (z−1) 912a-f, a set of multipliers (taps) 935a-d having coefficients (a0, a1, a2, and a3), and a set of adders 940a-g prior to the up-sampling components 980a, b (i.e., in the lower sample-rate section). Structure 900 further includes a one unit delay (z−1) 915 and an adder 945 following the up-sampling components 980a, b. The output of adder 945 is fed into the (1+z−1) block 960.
Adder 940d receives the present input sample and an input sample delayed by z−6 (after multiplication by −1). The output of adder 940d is multiplied by coefficient a3 by multiplier 935d. Adder 940c receives an input sample delayed by z−1 and an input sample delayed by z−5 (after multiplication by −1). The output of adder 940c is multiplied by coefficient a2 by multiplier 935c. Adder 940b receives an input sample delayed by z−2 and an input sample delayed by z−4 (after multiplication by −1). The output of adder 940b is multiplied by coefficient a1 by multiplier 935b. Multiplier 935a receives an input sample delayed by z−3 and multiplies the input value by the coefficient a0. As will be appreciated by one of ordinary skill in the art, the −1 multiplications can be omitted by the use of subtractors in place of the adders: 940d, 940c, and 940b.
The outputs of multipliers 935b, c, and d are combined and added to the output of multiplier 935a in adder 940g and subtracted from the output of multiplier 935a in adder 940a. The output of adder 940a is fed as input into up-sampler 980a and the output of adder 940g is fed as input into up-sampler 980b.
The structure of
Although the above section derived the desensitized structure for a 15-tap halfband filter, its realization and its mathematical description are simple enough that a similar design procedure for halfband filters of other lengths would be appreciated by persons of skill in the art.
Just as the conventional halfband filter can be implemented in a transposed form, it may be useful to find a transposed-form implementation of the desensitized halfband filter. To accommodate the presence of an up-sampler in the system, as noted above, the transposed-form of a conventional halfband filter needs a few extra delay elements that are not present in the direct-form filter (i.e., the three z−1 blocks at the bottom of
The right side of (7) can easily be rearranged such that the part inside the curly brackets is written as a sum of terms that each have just a single ak factor, yielding:
H(z)=(1+z−1){a0z−6(1+z−1)+a1z−4(1−z−4)(1−z−1)+a2z−2(1−z−8)(1−z−1)+a3(1−z−12)(1−z−1)}.
This form of H(z) easily leads to the implementation shown in
In block 1090, adder 1094a subtracts an input sample delayed by z−1 from the present input sample to produce X(z)(1−z−1) which is fed as an input into the delay block 1010 and as input into adder 1040d. Adder 1094b adds an input sample delayed by z−1 to the present input sample to produce X(z)(1+z−1) which is fed through the three delays 1095a, b, and c.
One additional modification may be useful in desensitized systems. It concerns the “pushing back” of the system output's (1+z−1) block (e.g., block 960 in
In
Whether or not there is an appreciable hardware savings at the block diagram level of the desensitized structures (
To demonstrate the lowered sensitivity, the operation of a commercially available conventional filter is compared to the operation of the desensitized 15-tap halfband filter of
When the coefficients of the AD filter, re-normalized such that h0=0.5, are rounded to 13 fractional bits, the halfband filter has the transfer function whose magnitude plot is shown in
An identical plot to
Another perspective on this situation can be obtained by computing the sensitivities of the transfer function to the coefficient values. Due to the relatively large variations in transfer function magnitude across the stopband, we use the normalized sensitivity function:
Using such a (frequency dependent) measure of transfer function sensitivity, the curves shown in
The top chart of
The desensitized structures described above can also be used to obtain realizations of halfband filters that require less hardware than the conventional halfband structures require. To do this, the focus is moved to a deeper level, below the block-diagram level considered above, closer to the physical structure that will be built. The actual construction of the multipliers is considered and the lowered sensitivity of new desensitized structures is exploited to achieve savings in the building of these multipliers.
Much work has been reported in the literature on the efficient implementation of tap-coefficient multipliers in digital filters, and in similar systems. For additional information on efficient implementation of tap-coefficient multipliers in digital filters, see A. G. Dempster and M. D. Macleod, “Use of minimum-adder multiplier blocks in FIR digital filters,” IEEE Trans. Circuits Syst.-II, vol. 42, pp. 569-577, September 1995 [Dempster], O. Gustafsson, “A difference based adder graph heuristic for multiple constant multiplication problems,” in Proc. IEEE Int. Symp. Circuits Syst., New Orleans, May 2007, pp. 1097-1100 [Gustafsson I], and O. Gustafsson, “Lower bounds for constant multiplication problems,” IEEE Trans. Circuits Syst.-II, vol. 54, pp. 974-978, November 2007 [Gustafsson II], each of which is incorporated by reference in its entirety.
It has been shown that a “multiplier block” can be created, a structure wherein an input value X is multiplied by a set of fixed integer coefficients—also referred to as a “multiple constant multiplication” (MCM) block—and, by sharing some internal computations, very efficient realizations of these simultaneous multiplications can be obtained. Indeed, Gustafsson I and II have demonstrated the capability of obtaining optimal (e.g., minimal adder) implementations. In applying this work to the sensitivity problem described herein, an important insight is developed that when systems are made less sensitive to their system parameter values, then this insensitivity can be exploited to permit an implementation whose computations with these parameters can require fewer adders.
This section describes these signed power of two (SPT) desensitized filters. First, the implementation of a version of a small halfband filter using the conventional halfband architecture is described. Next, the implementation of a small halfband filter using the desensitized structure is described and the results of both implementations are compared. This section uses two examples taken from a classic halfband-filter paper by D. J. Goodman, “Nine digital filters for decimation and interpolation,” IEEE Trans. Acoust., Speech, Signal Processing, vol. ASSP-25, pp. 121-126, April 1977 [Goodman], which is incorporated herein by reference in its entirety.
Consider this 11-tap halfband filter (Goodman's F7 filter) having taps {h5 0 h3 0 h1 h0 h1 0 h3 0 h5} where
The complete 11-tap conventional halfband filter structure is shown in
Next, the 11-tap desensitized version of the 11-tap filter with data-rate expander is designed. The coefficients for the desensitized halfband structure are computed, using the formulae indicated in equations (8):
a
0
=h
1
+h
3
+h
5=256
a
1
=h
3
+h
5=−46
a2=h5=7. (9)
A transposed-form desensitized structure is used to implement this filter.
It is possible to use Gustafsson's algorithm to obtain an optimal implementation for multiplier block 2035 that contains just two adders, as shown in
Comparing the multiplier blocks implemented in these two implementations (depicted in FIGS. 17/18 and FIGS. 19/20), it can be concluded that the insensitivity of the new structure has allowed the desensitized implementation to reduce the required number of adders from four (
In this regard, it is noted that all of the filters given in Goodman obey the h0=2(h1+h3+ . . . ) constraint—a situation mentioned by Goodman, although it is not apparent that the connections given in the Theorem above were presented by Goodman nor was the consequence that the filters all possess the P(z) factor. Certainly Goodman does not mention the possibility of implementing the filters in a two-factor cascade, hence achieving the insensitivity.
An additional example from Goodman is considered. The 19-tap “baseband filter” of Goodman requires the tap-coefficients:
a
0
=h
1
+h
3
+h
5
+h
7
+h
9=119
a
1
=h
3
+h
5
++h
9=−30
a
2
=h
5
+h
7
+h
9=16
a
3
=h
7
+h
9=−6
a4=h9=6
which can be implemented by the three-adder block shown in
Another advantage offered by the desensitized filter structure is that the smaller multiplier blocks obtained for the desensitized implementations also tend to have a smaller maximum tree depth. For example, the eleven-tap conventional filter example required a four-adder block with a depth-three tree (as shown in
As described in Willson, another approach to the implementation of a desensitized halfband filter would be to factor the complete halfband prefilter polynomial P(z)=(1+z−1)(1+z−1) out of the H(z) transfer function. That is:
H(z)=(1+z−1)(1+z−1)[q6+q5z−1 . . . +q5z−11+q6z−12].
If this type of factorization is done for the 19-tap halfband filter just considered, the following results:
H(z)=(1+z−1)(1+z−1){[q8(1+z−16)+q6(z−2+z−14)+q4(z−4+z−12)+q2(z−6+z−10)+q0z−8]+z−1[q7(1+z−14)+q5(z−2+z−12)+q3(z−4+z−10)+q1(z−6+z−8)]}.
This yields the desensitized halfband filter shown in
h0=238, h1=149, h3=−46, h5=22, h7=−12, h9=6
this leads (using equations like equations (2) of Willson) to the values:
q8=6, q7=−12, q6=6, q5=0, q4=16, q3=−32, q2=2, q1=28, q0=91 which, when built in two blocks ({q0, q2, q4, q6, q8} and {q1, q3, q5, q7}) and put into the “direct form,” require a total of 5 adders to implement. But, while this is a savings from the 6 adders required by this filter as a conventional halfband, it is not as good as the three-adder block discussed above and shown in
This section investigates the advantages of using the desensitized halfband filter structure for the implementation of larger halfband filters. The investigation begins with another example filter taken from a commercial product. The data sheet for the AD9776/AD9778/AD9779 by Analog Devices describes a 55-tap halfband interpolation filter (referred to herein as “ADI-55”). This halfband filter provides at least 87.5 dB attenuation over its stopband, the interval 0.6π≦ω≦π. As a benchmark, by using Gustafsson's algorithm, an optimal multiplier block that implements ADI-55 using 16 adders in an adder tree of depth six can be obtained. However, ADI-55 does not satisfy equation (6) above. Hence, the investigation must start with a new reference filter that does satisfy this condition, and then use it as the basis on which to design a desensitized counterpart.
Using linear programming techniques, another 55-tap halfband filter is designed (referred to herein as “ANW-55”). ANW-55 has slightly better stopband attenuation then ADI-55, over the same stopband (the interval 0.6π≦ω≦π), and it satisfies equation (6). ANW-55 requires an implementation complexity comparable to ADI-55, as illustrated in Table 1 below.
The ANW halfband filter is then used to design a desensitized halfband filter, “Desensitized-55,” which is also summarized in Table 1. Not only is the Desensitized-55 filter implemented with three fewer adders than ADI-55, it has better stopband attenuation (by more than 1.5 dB) and its tree depth is just five. The 13-adder tree for Desensitized-55—again obtained via Gustafsson's algorithm—is shown in
The actual design of ANW-55, and then Desensitized-55, was performed by a procedure which started with a 55-tap halfband filter whose stopband attenuation exceeded the target 87.5 dB of ADI-55. This design was performed using linear programming. The taps of the filter ANW-55 were computed as floating-point real numbers. They were rounded to 25-bit values that met the requirements of equation (6). These were then converted via the formulae indicated by equations (8) into the tap values of the desensitized structure. Now, both sets of 25-bit coefficients (for the conventional filter and the desensitized filter) were manipulated via an ad hoc procedure:
They were written in SPT form. Then, repeatedly, certain nonzero LSBs were deleted until a combination of remaining bits in the set of coefficients was found for which the stopband attenuation was suitable (i.e., better than that of ADI-55). Due to the structure's insensitivity, the set of coefficients that would ultimately yield Desensitized-55 was found to permit the deletion of LSBs having larger bit-weights than those in the set of coefficients that would yield ANW-55. Thus, it was possible to remove more nonzero LSBs from the desensitized coefficient set than could be removed from the set yielding ANW-55. When it was judged that the best coefficients had been found, the use of Gustafsson's algorithm confirmed that these fewer SPT Wails in the Desensitized-55 design correlated well with the requiring of fewer additions than in the traditional structure, ANW-55. Most significantly, Desensitized-55 was superior to ADI-55 as indicated in Table 1. It was deemed coincidental that the stopband attenuation of Desensitized-55 turned out to be slightly better than that of ANW-55.
This section considers one final reasonably large halfband filter whose implementation can be improved by employing the desensitized halfband filter structure. This is a 47-tap halfband filter whose design is reported in A. Y. Kwentus, Z. Jiang, and A. N. Willson, Jr., “Application of filter sharpening to cascaded integrator-comb decimation filters,” IEEE Trans. Signal Processing, vol. 45, pp. 457-467, February 1997 [Kwentus], which is incorporated by reference in its entirety, where it is called a “Third Halfband Filter,” (referred to herein as “THF”). The minimum stopband attenuation of the THF is approximately 73.1 dB.
As in the case of ADI-55, the THF tap coefficients did not satisfy equation (6). Thus, the design proceeded in a manner similar to that described above. The process began with an over-designed halfband filter whose 47 tap coefficients did satisfy equation (6). Those coefficients were quantized and transformed into the coefficients of a desensitized halfband structure using SPT coefficient representation. What appeared to be an optimal set of nonzero LSBs were found that could be omitted while still keeping the minimum stopband attenuation greater than 73.1 dB. The result of this process was a 47-tap halfband filter “Desensitized-47” that achieves a minimum stopband attenuation of approximately 73.38 dB and that requires a depth-three adder tree having just ten adders.
This compares favorably to the 16 adders in a depth-five tree that, according to Gustafsson's algorithm, are required to realize the coefficients of THF given in Kwentus. That is, the resulting desensitized halfband filter architecture provides a (16−10)/1637.5% reduction in adders.
The “trellis-search” type design techniques given in C-L. Chen and A. N. Willson, Jr., “A trellis search algorithm for the design of FIR filters with signed-powers-of-two coefficients,” IEEE Trans. Circuits Syst.-II, vol. 46, pp. 29-39, January 1999 [Chen], which is incorporated herein by reference in its entirety, can also be extended to the new class of desensitized halfband filters in order to create an easier, more systematic, and better method of performing the type of design discussed here for the 47-tap and 55-tap examples. The design successes obtained by the present ad hoc methods provide considerable encouragement that a more systematic process stemming from Chen is likely to yield excellent halfband filter designs that exploit the advantages inherent within the desensitized structure to obtain significant reductions in hardware complexity. Other design techniques may also yield improved methods of performing the type of design discussed here, one example being M. Aktan, A. Yurdakul, and G. Dundar, “An algorithm for the design of low-power hardware-efficient FIR filters,” IEEE Trans. Circuits Syst.-I, vol. 55, pp. 1536-1545, July 2008 [Aktan], which is incorporated herein by reference in its entirety.
Converting Transposed-Form Halfband Filters into Direct-Form Filters
Both the direct and transposed forms of FIR filter implementation have their own relative advantages and disadvantages. For example, if a design goal is the maximization of operating speed, then a direct-form filter can exhibit the disadvantage of having a longer critical path than that of its transposed-form counterpart. (As shown in
Thus, if possible, it is important for a designer to have the option of choosing either the direct form or the transposed form for the physical implementation of an FIR filter. Fortunately, it is known from O. Gustafsson and A. G. Dempster, “On the use of multiple constant multiplication in polyphase FIR filters and filter banks,” in Proc. Nordic Signal Process. Symp., June 2004, pp. 53-56 [Gustafsson III], which is incorporated herein by reference in its entirety, that, when implementing an FIR filter that uses an MCM block architecture—e.g., by using Gustafsson's algorithm—this implementation can be accomplished in either the direct or transposed form while incurring the same overall adder expense. Hence, if an adder tree for a transposed-form FIR filter is obtained, it can be “operated backwards” and the resulting multi-input/single-output block can be employed in a direct-form version of the same filter. Moreover, even though the transposed block will be one in which adder nodes are transformed into branch nodes and vice versa, the total number of adders required in the direct-form filter will exactly equal the total number of adders required in the transposed-form filter. The term “total number” is used here because it is important to include all adders needed in the summing up of the various paths in both structures. For example, while the three adders (2640a, b, and c) shown in the direct-form implementation of
As mentioned above, the result that the same adder expense occurs in both direct- and transposed-form filters is not new. One can, however, easily establish it as follows:
We actually prove that if a graph contains only two-input adder nodes and two-output branch nodes, and if the graph has exactly one input node and exactly one output node, then the total number of branch nodes equals the total number of adder nodes.
Proof: Without loss of generality, the graph can be put into the form of an array of B branch nodes and S sum nodes, as shown in
In converting an FIR filter into a graph for the purposes of this discussion, the z−1 delay blocks are simply “short-circuited”. This yields the desired one-input/one-output graph consisting of an interconnection of the terminals of the B and S nodes. When the system contains data rate expanders, these essentially get short circuited too. It is, however, simpler to just move them back out of the filter, then the filter and its transpose can be compared to one another directly.
To illustrate the invariance of the number of adders when comparing direct-form and transposed-form filters, or, equivalently, the overall equality in the number of branch nodes and sum nodes, consider the example of the MCM tree of
Input block 2990 includes a one unit delay 2992, two adders 2994a, b, and two unit delays 2995a and b. In block 2990, adder 2994a subtracts an input sample delayed by z−1 from the present input sample to produce X(z)(1−z−1) which is fed as an input into the delay loop 2910 and as input into adder 2940a. Adder 2994b adds an input sample delay by z−1 to the present input sample to produce X(z)(1+z−1) which is fed through the two delays 2995a and b.
Delay loop 2910 includes four two unit delays 2912a-d. Multiplier block 2935 includes three multipliers 2930a, b, and c. The outputs of multipliers 2930a, b, and c are combined by adders 2940c and d. The output of adder 2940d is fed as an input to the (1+z−1) block 2960.
When the block of
Although it was not required for the present analysis,
When transposing the MCM-block that is suitable for the transposed-form structure of
When the center tap h0 of the desired halfband filter equals ½, as it usually would, then the value of a0 becomes ¼ (because of equations (6) and (8)). Thus, the a0 tap's implementation becomes trivial; no adders are required. Hence, both of the
It is also useful to mention that, while tap coefficients have been normalized to have integer values for most of the discussion herein, it is straightforward to re-scale them to have fractional values, as will likely be preferable for practical implementation. The fractional tap coefficients for the
a
0=¼
a
1=−46/1024
a
2=7/1024. (10)
By starting at the left side of
In addition to a halfband filter's use in combination with data-rate expanders, halfband filters may also be used along with decimators in systems wherein an input signal's data rate is lowered. In such systems the input data must be lowpass filtered prior to the decimation operation so as to avoid creating so-called aliasing components in the output data.
Input block 3590 includes a (1+z−1) block 3565, two decimators 3595a,b, a one unit delay 3592, two adders 3594a, b, and two one-unit delays 3575a, b. The output of (1+z−1) block 3565 is fed as input to decimator 3595a and as input to delay 3592. The output of delay 3592 is fed as input to decimator 3595b. In block 3590, adder 3594a subtracts the output of decimator 3595b from the output of decimator 3595a. Adder 3594b adds the output of decimator 3595b to the output of decimator 3595a.
Delay loop 3510 includes four two unit delays 3512a-d. Multiplier block 3535 includes three multipliers 3530a, b, and c. The output of adder 3540a is fed as input to multiplier 3530a and the output of adder 3540b is fed as input to multiplier 3530b. The outputs of multipliers 3530a, b, and c are combined by adders 3540c and d.
For systems implemented with desensitized halfband/decimator combinations, it is of interest to consider the implications of the presence or absence of the equation (6) relation: h0=2(h1+h3+ . . . ). By the Theorem of Section 3, this relation is equivalent to |H(ejω)=0 at ω=ρ which, in fact, means that the halfband filter must possess a double zero at ω=π. A zero at ω=π will completely eradicate any spectral component of the X(ejω) input signal at the input's Nyquist frequency, which is the frequency that the decimator would otherwise cause to become aliased directly onto the DC value of the spectrum of the output signal Y(ejω). In fact, the presence of a double zero at ω=π will tend to have a strong attenuating influence on all frequencies near the input's Nyquist frequency.
As is well known in the use of so-called CIC filters due to E. B. Hogenauer, “An economical class of digital filters for decimation and interpolation,” IEEE Trans. Acoust., Speech, Signal Processing, vol. ASSP-29, pp. 155-162, April 1981 [Hogenauer], which is incorporated by reference in its entirety, such well-placed transmission zeros can significantly and efficiently protect low-frequency input signal components in a down-sampling system wherein the information contained in these components is particularly important and must be protected from corruption by unwanted aliasing. Such situations may include ones wherein the halfband/decimator circuit is but the first stage of a multi-stage down-sampling operation. Thus, as in the up-sampling application, the equation (6) relation is quite likely one that is desirable for reasons quite apart from its being required by our desensitized halfband filter structures.
While the discussion thus far has focused on the design of halfband filters, there is another somewhat similar type of filter that can potentially benefit from the present invention. It has been called a “halfband-like filter” in O. Gustafsson, L. S. DeBrunner, V. DeBrunner, and H. Johansson, “On the design of sparse half-band like FIR filters,” in Proc. Asilomar Conf. Signals, Syst., Comp., 2007, pp. 1098-1102 [Gustafsson IV], which is incorporated herein by reference in its entirety. Such filters have transfer functions whose magnitude |H(ejω)| does not possess a halfband filter's precise odd-symmetry about the ω=π/2 value, as discussed above in Section I. All halfband filters must have their passband and stopband aligned as shown in
Clearly, the cheaply built halfband filter P(z) can provide a coarse approximation to the desired halfband-like transfer function, and the cascade implementation could inherit benefits due to the insensitivity of the overall transfer function H(z) to perturbations in the parameters of the transfer function G(z), as has been demonstrated above in the case of halfband filters H(z). By deviating from the strict halfband frequency-domain requirements, it will happen that the halfband-like filters will no longer have alternate tap multiplier coefficients of value zero. Nonetheless, the enhanced insensitivity could still penult some hardware savings to occur through efficient MCM tree savings and it may even be possible to meet the less-demanding frequency-domain design constraints with a lower degree transfer function H(z) than would be possible when using a true halfband filter.
In addition to the FIR halfband filters that have been discussed herein, it is well known that halfband filters can be built in IIR form. The major difference between FIR halfband filters and IIR halfband filters is the fact that the former are described by a transfer function that can be put into the form of a polynomial in the variable z−1 while the transfer function of an IIR halfband filter is a rational function in z−1. That is, in terms of the complex variable z, the transfer functions of both an FIR and an IIR filter can be put into the form of a function constructed as a numerator polynomial in z divided by a denominator polynomial in z, where the roots of the numerator polynomial are the transfer function's zeros and the roots of the denominator polynomial are the transfer function's poles. While system stability demands that all poles lie within the unit circle of the z-plane, the distinguishing feature of an FIR filter is that all of its poles will be located at the origin, i.e., at z=0, while a stable IIR filter will have poles located at points other than z=0, although still within the unit-circle. Design methods for IIR halfband filters can be found in S. K. Mitra, Digital Signal Processing., 3rd ed. New York: McGraw-Hill, 2006, Section 13.6.5, pp. 787-790. [Mitra], which is incorporated herein by reference in its entirety, and in M. Renfors and T. Saramaki, “Recirsive n-th band digital filters, Parts I and II,” IEEE Trans. Circuits and Systems, vol. CAS-34, pp. 24-51, January 1987 [Renfors], which is incorporated by reference in its entirety, and elsewhere.
The presence of nonzero poles for an IIR filter does not interfere with the possibility of organizing the transfer function in a way such that it possesses at least two zeros at z=−1. Therefore, it is evident that the same kind of desensitizing advantages that have been exhibited for FIR halfband filters can be achieved as well by IIR halfband filters.
An example of an IIR filter design is presented in R. Yamashita, X. Zhang, T. Yoshikawa, and Y. Takei, “Design of IIR half-band filters with arbitrary flatness and its application to filter banks,” Electronics and Communications in Japan, Part 3, vol. 87, No. 1, pp. 134-141, 2004 [Yamashita], which is incorporated by reference in its entirety, wherein the halfband filter's transfer function has the pole/zero plot shown in
It is well known that a very simple relationship exists between FIR halfband filters and discrete-time Hilbert transformers. In Mitra, Section 15.7, pp. 893-899. [Mitra2], which is incorporated herein by reference in its entirety, it is shown that a discrete-time Hilbert transformer H(ejω) is related to a halfband filter G(ejω) by a rather simple relationship, namely:
The relationship between the tap coefficients of G and H is shown in H. W. Schussler and P. Steffen, “Halfband filters and Hilbert transformers,” Circuits Systems Signal Processing, vol. 17, no. 2, pp. 137-164, 1998 [Schussler], which is incorporated by reference in its entirety. Given the halfband filter G, the Hilbert transformer H is obtained by getting the tap coefficients of H from:
which, specifically implies
These relations show that one can build a desensitized discrete-time Hilbert transformer by directly mapping the taps of a corresponding desensitized halfband filter via the well-known relationships given above, and elsewhere.
The half-band filters discussed herein may be used in multistage sample rate changing systems. These halfband filters are discussed in Alan Willson, “Desensitized Half-Band Filters,” IEEE Trans. On Circuits and Systems-I, vol. 57, no. 1, pp. 152-165, January 2010, which is incorporated herein by reference in its entirety. For example, half-band filters may be used in decimation stages where the sample rate is reduced by a factor of two. Similarly, half-band filters may be used in interpolation stages where sample rates are increased by a factor of two.
In addition to a conventional CIC filter, other filters can possess similar “droop producing” properties. Examples of such filters are contained in Y. Gao, L. Jia, and H. Tenhunen, “A partial-polyphase VLSI architecture for very high speed CIC decimation filters,” Proc. 12th Annual IEEE International ASIC/SOC Conf., pp. 391-395, 1999, and in X. Liu and Alan N. Willson, Jr., “A 1.2 Gb/s Recursive Polyphase Cascaded Integrator-Comb Prefilter for High Speed Digital Decimation Filters in 0.18-μm CMOS,” Proc. IEEE International Symp. Circuits and Systems, Paris, 2010, to be published (both of which are incorporated herein by reference in their entirety), and elsewhere. Therefore, as would be appreciated by a person of skill in the art, for discussion of systems containing a “CIC filter” or a “sine filter” such references are intended to include such other droop producing filters, in addition to the more narrowly defined traditional CIC and sine filters.
Inset 4050 magnifies a portion of diagram 4000. As can be seen in inset 4050, the frequency response of droop-correction filter 3950 as shown by line 4045 compensates for the passband droop caused by CIC filter's 3910 roll-off depicted by line 4052. Because droop correction filter 3950 is located after the other components, its operation is at the lowest data rate in the decimation system. Therefore, the separate droop correction filter is realtively inexpensive from a power consumption perspective. It appears unlikely that a hardware augmentation of other filter components (which operate at higher sample rates) would provide a better solution for droop correction than the small FIR filter used in Brandt.
However, it is possible to eliminate the droop correction filter at no additional costs by modifying the half-band filter. In embodiments of the present invention, droop correction is achieved by omitting the 1+z−1 block of the half-band filter. No additional components are required in the system.
The following discussion illustrates how removal of the 1+z−1 block addresses droop in a half-band filter. On the unit-circle in the z-plane, where the complex variable z has magnitude 1, z can be expressed in polar form as z=ejω. Then, the expression 1+z−1 becomes 1+e−jω, which equals e−jω/2(ejω/2+e−jω/2). But since the magnitude of the complex value e−jω/2 is 1 (for all ω), we have that, on the unit-circle in the z-plane, the magnitude of 1+z−1 becomes |ejω/2+e−jω/2|. Now, in view of the well-known Euler relation, ejx=cos(x)+j sin(x), the magnitude of 1+z−1 therefore becomes |2 cos(ω/2)| on the unit-circle in the z-plane. Which, in turn, becomes just cos(ω/2) if we include a trivial factor of ½ along with the 1+z−1 expression and if we limit the range of ω to the interval 0≦ωπ. Thus, it becomes evident that by eliminating the factor
from the transfer function of a half-band filter, the effect is as if the magnitude of the transfer function has had the expression cos(ω/2) factored out from whatever it's previous magnitude function was.
Such a modification to the half-band filter's transfer function can be viewed as one in which a certain amount of “droop” has been removed from the transfer function's passband magnitude. This is because the cosine function deviates more (in dropping more and more below 1) as ω varies from 0 toward the right edge of the passband). The removal will also affect the stopband, by reducing the stopband attenuation somewhat, but this may not be a serious degradation of the stopband behavior, which can even be ensured by over-designing the original filter (and perhaps even other filters in the cascade of several filters) to be prepared for the removal of the
factor.
factor has been removed, according to embodiments of the present invention. It also includes a decimate-by-2 operation. Filter 4100 comes from a desensitized 19-tap half-band filter. The design of this filter takes into account the presence of sine-filter roll-off across the half-band filter's stopband. As would be appreciated by a person of skill in the art, any order of half-band filter can be utilized in the present invention. A 19-tap half-band filter was selected for comparison relative to the exemplary decimation system having a separate droop correction filter presented in Brandt.
Filter 4100 includes an input block 4190, a delay loop 4110, and a multiplier block 4135. Input block 4190 includes two decimators 4195a,b, a one unit delay 4192, two adders 4194a, b, and four one-unit delays 4175a-d. Unlike the desensitized half-band filter depicted in
Delay loop 4110 includes eight one unit delays 4112a-h. Multiplier block 4135 includes four multipliers 4130a-d and associated adders 4140a-d. The output of adder 4140a is fed as input to multiplier 4130a, the output of adder 4140b is fed as input to multiplier 4130b, the output of adder 4140c is fed as input to multiplier 4130c, and the output of adder 4140d is fed as input to multiplier 4140d. The outputs of multipliers 4130a-d are combined by adders 4140e, f, and g. The output of the adder 4140g and a fifth multiplier 4130e are fed as inputs to adder 4140h.
The multipliers 4130a-e within the encircled part of the
The filter of
Embodiments of the present invention therefore have down-sampling after the filter.
If the amount of droop that must be compensated does not happen to match the amount of compensation that is provided by the removal of a
factor, then it could be that another power-of-two sub-factor p can make p(1+z−1) become a good match. Such values as p=¼, p=1, or p=2 would, for example, be just as trivial to employ as is the p=½ case we've been considering, since a power-of-two sub-factor p can easily be achieved by just a hard-wired bit-shift of the data path on which the filtered signal is riding. Alternatively, doubling coefficient values can be done, as mentioned previously. No computation, no power consumption, and no increase in system size should be required to accommodate such p values. Moreover, if both of the desensitized halfband filter's (1+z−1) factors would be extracted, and then omitted, such a p(1+z−1)(1+z−1) removal factor would provide a sharper rise in the droop-compensation curve, ultimately giving twice (on a dB scale) the amount of droop compensation. In this case, there would perhaps be an additional implementation price, in that the implementation of the remaining halfband component (e.g., see
In addition to multistage decimation and interpolation systems in which a modified half-band filter, being one of a plurality of filters in cascade, is providing droop compensation for droop produced by another filter, or several other filters in the cascade, the droop that must be compensated for could be droop that is produced by the half-band filter itself. In this situation, the removal of the half-band filter's
factor can provide “self compensation” for droop. If the removal this way provides too much compensation, which could even result in creating passband distortion in which the passband is rising too much in the vicinity of the passband edge, making the passband gain too high, then the removal of p(1+z−1), where p is chosen to provide an amount of droop correction that is close to optimal, would be an alternative. In terms of the frequency-domain equivalent of the p(1+z−1) factor's removal, namely by removing the factor A cos(ω/2) where the scale-factor A is chosen appropriately, the passband distortion due to droop, in the vicinity of ω=ωp can be reduced, perhaps at the cost of introducing a small amount of distortion at other passband frequencies, such as at ω=0 (i.e., at DC) which would, however, be acceptably small. In general, the removal of the A cos(ω/2) factor could be aimed at reducing the distortion throughout the passband. Typically, one would seek to minimize the maximum distortion at all frequencies within the passband. Such “self correction” of half-band filter passband distortion, including droop, can be applied to a half-band filter operating in isolation, i.e., one that is not necessarily a part of a multistage filter cascade. Various ways of determining a desirable scale-factor A would range from simulating the filter and employing trial-and-error techniques, through more analytical-based approaches by which the computation of an optimal scale-factor A would be determined. Such procedures would be well within the capabilities of one who is skilled in the relevant art.
In addition to down-sampling applications, embodiments of the present invention are used in up-sampling applications.
Althrough
As described above, an alternate implementation of a desensitized half-band anti-imaging filter uses “sample-and-hold up-samplers.” A sample-and-hold up-sampler combines the system output's (1+z−1) block with the up-samplers. An exemplary 15-tap desensitized half-band anti-imaging filter using sample-and-hold up-samplers is depicted in
Since the sample-and-hold up-sampler is equivalent to a conventional up-sampler followed by a (1+z−1) block, in embodiments of the present invention, the (1+z−1) block is omitted by replacing the sample-and-hold up-sampler of desensitized half-band filters such as the filter depicted in
Embodiments of the invention may be implemented using hardware, programmable hardware (e.g., FGPA), software or a combination thereof and may be implemented in a computer system or other processing system. In fact, in one embodiment, the invention is directed toward a software and/or hardware embodiment in a computer system. An example computer system 4702 is shown in
Computer system 4702 also includes a main memory 4708, preferably a random access memory (RAM), and can also include a secondary memory or secondary storage 4710. The secondary memory 4710 can include, for example, a hard disk drive 4712 and a removable storage drive 4714, representing a floppy disk drive, a magnetic tape drive, an optical disk drive, etc. The removable storage drive 4714 reads from and/or writes to a removable storage unit 4716 in a well known manner. Removable storage unit 4716, represents a floppy disk, magnetic tape, optical disk, etc. which is read by and written to by removable storage drive 4714. As will be appreciated, the removable storage unit 4716 includes a computer usable storage medium having stored therein computer software and/or data.
In alternative embodiments, secondary memory 4710 may include other similar means for allowing computer software and data to be loaded into computer system 4702. Such means can include, for example, a removable storage unit 4720 and an storage interface 4718. Examples of such can include a program cartridge and cartridge interface (such as that found in video game devices), a removable memory chip (such as an EPROM, or PROM) and associated socket, and other removable storage units 4720 and interfaces 4718 which allow software and data to be transferred from the removable storage unit 4720 to the computer system 4702.
Computer system 4702 can also include a communications interface 4722. Communications interface 4722 allows software and data to be transferred between computer system 4702 and external devices 4726. Examples of communications interface 4722 can include a modem, a network interface (such as an Ethernet card), a communications port, a PCMCIA slot and card, etc. Software and data transferred via communications interface 4722 are in the form of signals, which can be electronic, electromagnetic, optical or other signals capable of being received by the communications interface 4722. These signals are provided to the communications interface 4722 via a channel 4724. This channel 4724 can be implemented using wire or cable, fiber optics, a phone line, a cellular phone link, an RF link and other communications channels.
Computer system 4702 may also include well known peripherals 4703 including a display monitor, a keyboard, printers and facsimile, and a pointing device such a computer mouse, track ball, etc. In this document, the terms “computer program medium” and “computer usable medium” are used to generally refer to media such as the removable storage devices 4716 and 4718, a hard disk installed in hard disk drive 4712, and semiconductor memory devices including RAM and ROM. These computer program products are means for providing software (including computer programs that embody the invention) and/or data to computer system 4702.
Computer programs (also called computer control logic or computer program logic) are generally stored in main memory 4708 and/or secondary memory 4710 and executed therefrom. Computer programs can also be received via communications interface 4722. Such computer programs, when executed, enable the computer system 4702 to perform the features of the present invention as discussed herein. In particular, the computer programs, when executed, enable the processor 4704 to perform the features of the present invention. Accordingly, such computer programs represent controllers of the computer system 4702.
In an embodiment where the invention is implemented using software, the software may be stored in a computer program product and loaded into computer system 4702 using removable storage drive 4714, hard drive 4712 or communications interface 4722. The control logic (software), when executed by the processor 4704, causes the processor 4704 to perform the functions of the invention as described herein.
In another embodiment, the invention is implemented primarily in hardware using, for example, hardware components such as application specific integrated circuits (ASICs), stand alone processors, and/or digital signal processors (DSPs). Implementation of the hardware state machine so as to perform the functions described herein will be apparent to persons skilled in the relevant art(s). In embodiments, the invention can exist as software operating on these hardware platforms.
In yet another embodiment, the invention is implemented using a combination of both hardware and software. Field-programmable gate arrays (FPGA) could, for example, support such an embodiment.
While various embodiments of the present invention have been described above, it should be understood that they have been presented by way of example, and not limitation. It will be apparent to persons skilled in the relevant art(s) that various changes in form and detail can be made therein without departing from the spirit and scope of the invention. Thus the present invention should not be limited by any of the above-described exemplary embodiments, but should be defined only in accordance with the following claims and their equivalents.
This patent application is a continuation-in-part of U.S. patent application Ser. No. 12/185,062, filed on Aug. 1, 2008, which claims the benefit of Provisional Patent Application No. 60/953,355, filed Aug. 1, 2007, entitled “Desensitized Halfband Filters,” each of which is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
60953355 | Aug 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 12185062 | Aug 2008 | US |
Child | 12731122 | US |