The disclosure relates to signal processing techniques, especially PDM domain signal processing and, more particularly but not restricted to, active noise cancellation in the digital domain for audio applications.
Active noise cancellation circuits may be used in a variety of applications, such as personal communication systems, wireless communication devices, digital media players, and audio output devices, such as headphones. Active noise cancellation systems actively reduce acoustic noise of the environment by generating so-called “anti-noise” which may be the inverse form of the noise in the surrounding environment. Active noise cancellation systems generally comprise one or more microphones that capture environmental noise signals, a circuit that generates anti-noise, and one or more speakers to play the anti-noise in order to cancel the environmental noise. The anti-noise may destructively interfere with the surrounding environmental noise and thereby reduce the noise signal that reaches the ear of the user.
Conventional active noise cancellation circuits are often implemented via analog signal processing. This is because analog circuits have very short processing delays relative to digital circuits. However, analog signal processing has disadvantages in that it is difficult to make analog signal processing configurable or adaptive.
Active noise cancellation may be performed in the digital domain via signal filtering. The signal filtering may occur in stages that introduce different levels of filtering. Conventional filtering in digital active noise cancellation circuits may require memory-based delay circuits between the filter stages. These memory-based delay circuits can become very large in terms of memory space in the circuit, particularly when signals are oversampled.
This disclosure describes circuit configurations that may be used for active noise cancellation in the digital domain. This disclosure describes the use of a down sample unit and an up sample unit, rather than memory-based delay circuits, to achieve one or more desired delays in digital adaptive noise cancellation circuits. The delay achieved by the down sample unit and the up sample unit may be tunable so as to allow flexibility in producing the necessary delay for different active noise cancellation circuit configurations. Many different adaptive noise cancellation circuit configurations are discussed, including hybrid circuits that filter samples within two or more different sample rate domains. The delay techniques may also be used in other circuits (i.e., circuits that do not perform active noise cancellation). For example, the delay techniques using a down sample unit and an up sample unit, rather than memory-based delay circuits, may also be used in low-latency equalization circuits or other circuits.
In one example, this disclosure describes an apparatus comprising a down sample unit, and an up sample unit. The down sample unit and the up sample unit are each tuned such that a combined delay associated with processing a sample via the down sample unit and the up sample unit corresponds to a pre-defined delay. In some cases, the pre-defined delay may be selected to promote active noise cancellation.
In another example, this disclosure describes a method comprising processing a sample via a down sample unit and an up sample unit, wherein a combined delay associated with processing a sample via the down sample unit and the up sample unit corresponds to a pre-defined delay, such as a pre-defined delay that is selected to promote active noise cancellation.
In another example, this disclosure describes a device comprising means for down sampling, and means for up sampling, wherein the means for down sampling and the means for up sampling are each tuned such that a combined delay associated with down sampling and up sampling corresponds to a pre-defined delay. In some cases, pre-defined delay may be selected to promote active noise cancellation.
Aspects of the techniques described in this disclosure may be implemented in hardware, software, firmware, or combinations thereof. If implemented in software, the software may be executed in one or more processors, such as a microprocessor, application specific integrated circuit (ASIC), field programmable gate array (FPGA), or digital signal processor (DSP). The software that executes the techniques may be initially stored in a computer-readable medium and loaded and executed in the processor.
Accordingly, this disclosure also contemplates a computer-readable storage medium comprising instructions that upon execution in a processor cause the processor to perform active noise cancellation, wherein the instructions cause the processor to process a sample via a down sample unit and an up sample unit, wherein a combined delay associated with processing a sample via the down sample unit and the up sample unit corresponds to a pre-defined delay that is selected to promote active noise cancellation. The combined delay may comprise a tunable parameter of a circuit that includes the down sample unit and the up sample unit, wherein the instructions cause the processor to select the tunable parameter.
The details of one or more aspects of the disclosure are set forth in the accompanying drawings and the description below. Other features, objects, and advantages of the techniques described in this disclosure will be apparent from the description and drawings, and from the claims.
This disclosure describes circuit configurations that may be used for active noise cancellation in the digital domain. The described circuits may be used in a wide variety of active noise cancellation settings or applications, such as in personal communication systems, digital media players, wireless communication devices, and audio output devices, such as headphones. Active noise cancellation actively reduces acoustic noise of the environment by generating so-called “anti-noise” which may comprise audio signals that are the inverse form of the noise in the surrounding environment. Active noise cancellation systems generally comprise one or more microphones to pick up external noise signal, an active noise cancellation circuit to generate the anti-noise, and one or more speakers to play the anti-noise that cancels the environmental noise. The anti-noise generated by the active noise cancellation circuit may destructively interfere with the surrounding background noise and thereby reduce the noise signal that reaches the ear of the user.
Although the delay techniques of this disclosure are primarily described in the context of active noise cancellation, the delay techniques may also be used in other circuits (i.e., circuits that do not perform active noise cancellation). For example, the delay techniques using a down sample unit and an up sample unit, rather than memory-based delay circuits, may also be used in low-latency equalization circuits or other circuits.
Conventional active noise cancellation in the digital domain may use memory-based delay circuits between one or more stages of a digital active noise cancellation circuit. This disclosure describes the use of a down sample unit and an up sample unit, rather than memory-based delay circuits, to achieve one or more desired delays in digital adaptive noise cancellation circuits. The delay achieved by the down sample unit and the up sample unit may be tunable so as to allow flexibility in producing the necessary delay for different active noise cancellation circuit configurations. Many different adaptive noise cancellation circuit configurations are discussed, including hybrid circuits that filter samples within two or more different sample rate domains. To the extent that the down sample unit and the up sample unit themselves include memory delay elements, the memory delay elements in the down sample unit and the up sample unit may be significantly less than the memory required for conventional memory based delay circuits.
In the example shown in
Ordinary digital filters for PCM samples typically require a one-sample delay between successive filter stages (sometimes called filter tap stages). Each filter stage may perform an incremental amount of filtering and combine such filtering to a feedback signal. To achieve the one-sample delays between filter stages, memory delay circuits may be used.
Adders 23A-23H combine the output of amplifiers 22A-22H with the output of amplifiers 24A-22G and memory based delay circuits 25A-25G, respectively, as illustrated. Memory based delay circuits 25A-25G provide one sample delays between each successive stage of the circuit, as the samples are processed. Thus, the different stages of the circuit are separated by memory based delay circuits 25A-25G. An input sample is filtered by each filter stage, but as a given sample moves through the stages along memory based delay circuits 25A-25G, the filtering accumulates to provide a desirable anti-noise effect in the output.
As noted herein, such memory based delay circuits 25A-25G may be undesirable from an implementation standpoint. In some cases, PCM samples may be further up sampled into pulse density modulation (PDM) samples, which typically have smaller bit depths than PCM samples. In typical applications, PDM samples from an analog-digital-converter may have bit depths of 1 to 4 bits. PDM sample representation of the signal typically uses a higher sampling rate than the signal band width, and the typical oversampling ratio (e.g., the ratio between over sampling rate and a sampling rate of the base band signal) may range between approximately 64 and 256. In some cases, PDM samples after analog-to-digital conversion can have larger bit depths than PCM samples bit for signal processing.
The approach of
The circuit of
An oversampling ratio may refer to the ratio between PDM signal sampling rate and the base band signal sampling rate. For example, typical PDM representation of 8 kHz base band signal can use 2048 kHz sampling rate where the oversampling ratio is 256. In such a case, a digital filter with 1 sample delay between taps can have effects over the whole 1024 kHz band width, while the signal of interest only spans up to 4 kHz. It may be desirable to use decimated filter structure which uses multiple sample delay between filter taps. By using a 256 delay between taps, the filter can still have full control up to full signal band width (4 kHz), but one can reduce the number of multipliers and adders by a factor of 1 to 256. The necessary delay for signals by memory based delay circuits 35A-35G may be a function of the oversampling ratio and the base band sampling frequency. Therefore, the required memory size can become very large when the audio sampling frequency and over-sampling frequency are high. In addition, a filtering circuit that uses such memory-based delay circuits 35A-35G may have stability problems due to the limited word length of the filter coefficients associated with amplifiers 32A-32H and 34A-34G, and the input data. Limited word length means the bit-width of the coefficients are not large enough in real scenarios. The bit-width (i.e., bit depth) of the coefficients or data can proportionally increase the silicon area needed to fabricate the circuit in a chip. Therefore, it may be undesirable to use very large bit-widths in real applications. However, when bit width is not big enough, the coefficients or data can have relatively lower resolution, which can add a lot of quantization error or quantization noise to the data.
The circuits in both
This disclosure provides an alternative delay structure by utilizing an adjustable group delay feature of a down sample unit and up sample unit pair. As one example, this disclosure provides for the replacement of one or more memory based delay circuits like circuit 41 of
The down sample unit and the up sample unit pair may comprise a cascaded integration combiner (CIC) decimator and a CIC interpolator, although this disclosure also contemplates other types of down sample unit and up sample unit pairs. As shown in
The CIC decimator/interpolator pair represented in
Due to the bit growth characteristics of the CIC circuit, proper scaling may also be needed to achieve the unit gain. Scaling amplifiers 52 and 54 may be used for this purpose. The low pass frequency response of a CIC circuit may also help stabilize active noise cancellation by suppressing high frequency quantization noise. The draw backs of using a CIC circuit may include small aliasing effects of CIC decimator 51 and/or CIC interpolator 53 and possibly in-band signal drop. However, by selecting CIC parameters that minimize the aliasing effect and in-band signal drop, the aliasing effect and in-band signal drop can become negligible. Different CIC parameters are discussed below.
The circuit of
Again, this disclosure proposes to use of a CIC decimator/interpolator pair as a variable delay which generates delay in proportion to down sampling factor R. In this case, one can increase delay by increasing the down sampling factor R according to decimation factor (K) growth. Overall, the CIC based delay may reduce hardware area relative to convention memory-based delay circuits when implemented in digital application specific integrated circuit (ASIC). Also, a CIC decimator/interpolator pair may achieve a side effect of low pass filtering which can enhance stability of infinite impulse response (IIR) filtering.
A down sample unit and up sample unit pair (e.g., the CIC decimator/interpolator pair) may be arranged in series. In the circuit of
As shown in
Delay element 707 and adder 708 form a first combiner, and delay element 709 and adder 710 form a second combiner. Thus, elements 707, 708, 709 and 710 form a two stage combiner. Element 711 comprises a sigma-delta modulator. Additional details of a sigma delta modulator are discussed below with respect to
Element 808 comprises an up sampler that up samples the data rate by a factor, e.g., by a factor of 32. Convert unit 809 converts the input data bitwidth for adder 810. Adder 810 and delay element 811 form a first integrator, and adder 813 and delay element 814 form a second integrator. Convert unit 812 is located between the first and second integrators to adjust the output of the first integrator for adder 813. Thus, elements 810, 811, 812, 813 and 814 form a two stage integrator. Element 815 comprise a sigma-delta modulator. Additional details of a sigma delta modulator are discussed below with respect to
More generally, CIC integrator 53 may comprise N digital integrator stages operating at the high over sampling frequency (OSF) rate, where N is an integer. Each stage may be implemented as a one-pole filter with a unity feedback coefficient. The comb section (e.g., sections 803 to 806) of the circuit shown in
The equivalent transfer function of the CIC delay circuit described herein (e.g., a CIC decimator and CIC interpolator pair) referenced to the OSF sampling rate may be given by:
wherein H(Z) is the transfer function of CIC delay circuit,
H1(Z) is the transfer function of interpolator section of the CIC delay circuit,
Hc(Z) is the transfer function of comb section of the CIC delay circuit,
Z is a z-transform variable,
R is down sampling or upsampling ratio of CIC delay circuit,
M is differential delay number of comb section in CIC delay circuit, and
N is number of integer delay circuit stages/differentiation stages of CIC delay circuit.
The frequency response of the CIC circuit may be functionally equivalent to a cascade of N stage finite impulse response (FIR) filters which exhibit constant group delay.
The parameters of a CIC circuit may be tuned to control the delay. An IIR filter tap delay comes from the sum of the CIC filter decimator and interpolator pair. The delay from CIC decimator and interpolator may be respectively given by:
Delay=MRN/2, where R=8*dm, dm=Fs*OSF/(8*64000)
where N is the number of integration stages, R is the down sampling ration and M is the differential delay, and Fs is the baseband sampling frequency.
Thus, the delay of a CIC pair may be given by:
Delay of CIC pair=MRN
Thus, the delay of the CIC circuit may be tuned by controlling three parameters: number of integration stages N, down sampling ratio R and differential delay M. The differential delay M may control spectral null locations of the CIC circuit. Spectral null locations are the frequencies where the filter gain approaches zero.
Accordingly, the total delay of a CIC decimator/interpolator pair is function of M, R, and N. For hardware design, it may be easiest to use a fixed number for M and N while making R variable. In this case, by controlling the down/up sampling ratio R for both CIC decimator and interpolator, the delay of the CIC pair can be properly tuned to the desirable delay. Especially when used with a decimated FIR/IIR filter, a CIC pair may be useful to support multiple sampling rates. When the over-sampling rate changes, the delay may be increased or decreased such that the CIC circuit delay is equivalent to that of a constant base-band filter structure.
The CIC circuits may need units to provide bit width scaling as bit widths grow. Many CIC filters exhibit DC gains. Accordingly, scaling factors may be applied at the output of decimator and interpolator to achieve the overall unit gain of the CIC circuit. In this case, for the decimator:
G=(RM)2=(8*dm*M)2=dm2*210, Bmax=Bin+N(log2RM)−1
Thus, in this case, the bit width of decimator is:
3+2(log2192*4)−1)=21
In this case, for the interpolator:
B
j
=B
in+log2Gj. B1=24, B2=25, B3=26, B4=37.
The gain at the last stage may be:
G=RM
2=(8*dm)*M2=dm*27.
Active noise cancellation decimator output bits, e.g., the output of a CIC decimator, can be truncated to save hardware area while maintaining the overall noise level. The CIC decimator output may be scaled down by the following
(dm)2/cicscale
Similarly, the CIC interpolator output is scaled down by
dm*cicscale*217, where cicscale is a function of dm as follows:
This scaling may be performed by scaling amplifiers 52 and 54 shown in
Generally, the second order sigma delta modulator shown in
The variable dm is the ratio of OSF to 512 kHz mentioned above. The value for dm̂2/cic_scale is represented under unit 905 and under amplifier 909 of
Thus, this disclosure defines a CIC circuit for filtering and first order sigma delta modulators for scaling in the audio path. CIC circuits can cause aliasing errors around nulls for both the CIC decimator and the CIC interpolator. The power response relative to the down sampled frequency (Fs/R) of the CIC filter may be given by:
In this case,
The nulls in the spectrum may be controlled by differential delay M. For CIC decimators, regions around every null can be folded back to the pass band. i.e. the signals with frequencies after the pass band can be added back to the signals inside the pass band. For CIC interpolators, imaging may occur around every null. By increasing stage number N, the circuit may reduce the aliasing error at the expense of increasing the pass band drooping and total filter delay. Modified CIC filter structures may be used to shape the circuit response to further reduce the aliasing induced error.
Again, a first order sigma delta modulator may be used for scaling to avoid truncation related audio defects. The sigma delta modulator may slightly affect audio quality, such as by generating limit cycles, or by exhibiting tonal behaviors with dc or zero inputs. Certain measures can be used to improve the stability of sigma delta modulators, such as using higher order sigma delta modulators, adding dithering or small perturbations to the quantizer or the input, and/or using integrators that exhibit local chaotic behavior.
In accordance with this disclosure, signal processing for audio noise cancellation is performed in the digital domain. An analog signal may be transformed from analog into digital format by one or more analog to digital converters (DACs). In this case, the signal magnitude is sampled at a regular rate, which may be referred to as a sampling rate. The signal amplitude may be quantized and stored. This form of audio signal conversion is commonly known as pulse code modulation (PCM). In PCM, a signal is a recorded binary code with a typical resolution of 12 or more bits. On the other hand, a sigma delta modulator may convert analog signals into discrete time signals of low resolution (e.g., 1-4 bits) but with high sampling rate, commonly called over sampling. The over sampling rate (OSR) is usually the sampling rate multiplied by a factor (called over sampling factor or OSF).
Signals in the over sampled format are commonly known as pulse density modulation (PDM) samples. Signal processing in the PCM domain has the advantage of simplicity in implementation. However, the analog to digital conversion step in producing PCM data typically has a processing delay of at least a few samples. This delay may be too long for some time critical applications, such as active noise cancellation. On the other hand, processing signals in the PDM domain offers the advantage of very low processing latency due to its high sampling rate.
Let xt be the signal in PCM, a filter with coefficients (B0, B1, . . . , Bn, A0, A1, . . . , An) (A0=1) being applied to the signal xt to give output yt. In this case:
y
t
=B
0
x
t
+B
1
x
t−1
+B
2
x
t−2
+ . . . +B
n
x
t−n
−A
1
y
t−1
−A
2
y
t−2
− . . . −A
n
y
t−n
When a z-transform is applied, this equation above can be expressed in the z-domain as
where X(z) and Y(z) are the z-transform of xt and yt respectively.
Let ut and vt be the input and output signals in PDM domain with an oversampling factor R. If the only operations are modification of frequency under SR/2, filtering can be performed with the same filter coefficients. Therefore, the expression above in the z-domain for PDM samples may be:
where U(z) and V(z) are the z-transform of ut and vt respectively and R represents the oversampling factor. Thus, R represent how many times the signal is oversampled in the PDM domain, as compared to signal in the PCM domain. In ANC, xt is the PCM domain noise signal measured (input of ANC control), and yt is anti-noise signal computed by an ANC control circuit. X(z) and Y(z) correspond to the input noise and anti-noise signals in z-transform domain. In PDM domain, the z-transform input and output signal are represented by U(z) and V(z). The modification of input signal to generate the output signal is represented by the quotients involving B's and A's.
Adders 114A-114H combine the output of amplifiers 111A-111H with the output of amplifiers 113A-113G and memory based delay circuits 112A-112G as illustrated. Memory based delay circuits 112A-112G provide one sample delays between each successive stage of the circuit, as the samples are processed. Thus, the different stages of the circuit are separated by memory based delay circuits 112A-112G. An input sample is filtered by each filter stage, but as a given sample moves through the stages along memory based delay circuits 112A-112G, the filtering accumulates to provide a desirable anti-noise effect in the output.
As noted herein, such memory based delay circuits 112A-112G may be undesirable from an implementation standpoint. Instead of using tap delay lines to store the intermediate output from each filter tap, an alternative of this disclosure is to use CIC decimator/interpolator pair that has the desired delay collectively.
Specifically,
Adders 124A-124H combine the output of amplifiers 121A-121H with the output of amplifiers 123A-123G and CIC delay circuits 122A-122G as illustrated. CIC delay circuits 122A-122G provide one sample delays between each successive stage of the circuit, as the samples are processed. Thus, the different stages of the circuit are separated by CIC delay circuits 122A-122G rather than memory based delay circuits. An input sample is filtered by each filter stage, but as a given sample moves through the stages along CIC delay circuits 122A-122G, the filtering accumulates to provide a desirable anti-noise effect in the output.
Again, although filtering in the PDM domain offers the advantage of very low processing latency, one drawback is the large amount of memory elements required to store the over-sampled data in the time delay line. Since the low latency requirement only applies to the B1 coefficient and all other coefficients are associated with some algorithmic delay, other coefficients can be applied to signal at a sampling rate lower than the OSR. This can be achieved by a scheme of hybrid filtering in both PCM and PDM domain, as depicted in
In the example in
Adders 134A-134G combine the output of amplifiers 131A-131G with the output of amplifiers 133A-133G and memory based delay circuits 132A-132G as illustrated. Memory based delay circuits 132A-132G provide eight sample delays between each successive stage of the circuit, as the samples are processed. Once the output of adder 134G is up converted back to the PDM domain via CIC up sampler 138, the output of CIC up sampler 138 is combined with the output of amplifier 131H to produce the circuit output, which may comprise anti-noise.
An alternative scheme of hybrid filtering (e.g., filtering in the PCM and PDM domains) is also possible as depicted in
In particular,
Amplifiers 141A-141i and amplifiers 143A-143G may define the application of filter taps to the samples. For example, amplifiers 141A-141i and amplifiers 143A-143G may comprise digital multiplier circuits that multiply the input signal by a gain factor. The gain factors may be selected to achieve the desired signal amplification needed for active noise cancellation. Notably, amplifier 141i operates on samples in the PDM domain, while the other amplifiers operate on samples in the PCM domain. Element 145 may comprise a CIC decimator and element 146 may comprise a CIC interpolator, and these elements 145 and 146 may be tuned to achieve a desired delay between the application of filter 141i on a sample in the PDM domain and the application of amplifiers 141A-141G on that sample in the PCM domain.
Adders 144A-144G combine the output of amplifiers 141A-141G with the output of amplifiers 143A-143G and memory based delay circuits 142A-142G as illustrated. Similarly, adder 143H combines the output of delay circuit 142G with the output of amplifier 141H. Memory based delay circuits 142A-142G provide eight sample delays between each successive stage of the circuit, as the samples are processed. Once the output of adder 144G is up converted back to the PDM domain via CIC up sampler 146, the output of CIC up sampler 146 is combined with the output of amplifier 141i via adder 144i to produce the circuit output, which may comprise anti-noise.
y
t
=B
0
x
t
+s
t
B0 is the amplifier 151H in
Y(z)=B0X(z)+S(z)
Y(z), X(z) have the same meaning as defined above, and represent the z-transform of the output signal yt and input signal xt. S(z) is the z-transform of the signal st.
Accordingly,
Here Y(z), X(z) , B0, B1, B2, A0, A1, A2, have the same meanings defined above. The newly introduced variables is defined as:
C
0
=B
1
−B
0
A
1
C
1=(B2−B0A2)
C
2=(B3−B0A3).
An implementation of this scheme is depicted in
In the circuit of
The expansion of Y(z)=B0X(z)+S(z) can be repeated for S(z) as
S(z)=z−1(C0X(z)+S1(z))
This is useful in a couple of reasons. First, the signal can be further down sampled from an intermediate sampling rate to a base sampling rate and memory saving can be achieved via this down sampling. Second, the input signal can be down sampled to multiple intermediate sampling rates, each time by a small factor, until the sampling rate is reached. By down sampling with a smaller factor, good anti-aliasing properties may be ensured. In addition, filtering signals with B0 at the over sampling rate (e.g., in the PDM domain) may ensure minimal processing latency. Filtering a signal with C0 at an intermediate sampling rate that is ¼ of the over sampling rate ensures that processing latency associated with coefficient B1 can still be exploited. The processing latencies associated with B2 and B3 may also be exploited and met when filtering at ISR2=ISR/4 and ISR3=ISR2/4, where ISR stands for intermediate sampling rate. Finally, by repeated expansions, an infinite impulse response (IIR) filter is effectively converted into a finite impulse response (FIR) filter, which may offer better stability.
In particular,
Adders 154A-154F combine the output of amplifiers 151A-151F with the output of amplifiers 153A-153G and memory based delay circuits 152A-152G as illustrated. Similarly, adder 154G combines the output of delay circuit 152G with the output of amplifier 151G. Memory based delay circuits 152A-152G provide eight sample delays between each successive stage of the circuit, as the samples are processed. Once the output of adder 154G is up converted back to the PDM domain via CIC up sampler 157, the output of CIC up sampler 157 is combined with the output of amplifier 151H to produce the circuit output, which may comprise anti-noise.
In general, the CIC downsampler may be replaced with a generic FIR filter and a generic downsampler. Moreover, the CIC upsampler may be replaced with a generic upsampler and a generic FIR filter.
In other examples consistent with this disclosure, the CIC decimator described herein may be combined with additional filters, or may be replaced with other types of down sample units to achieve a portion of the desired delay. One such down sample configuration is shown in
FIR filter 161 may be symmetric such that FIR filter 161 provides a constant group delay for all frequencies. The length FIR filter 161 may be set to provide desired delay. Usually, if a delay of N taps is required, the length of the filter would be 2N−1 taps. One example of a feasible FIR filter response is shown by the graphs of
In still other examples, the CIC decimator described above may be replaced with a cascade of FIR filters and down samplers, such as shown in
In yet, another example the CIC decimator described herein may be replaced by a cascade of CIC decimators in order define the amount of delay needed for a given active noise cancellation circuit configuration.
Like the CIC decimators, the CIC interpolators described herein may be combined with additional filters, or may be replaced with other types of up sample units to achieve a portion of the desired delay. One such up sample configuration is shown in
In this case, the FIR filter 232 may perform lowpass filtering to prevent or remove any imaging effects of the in band signal to the out of band high frequency signal in the output during up sampling. Up sampler 231 may insert R−1 zeros between every sample such that the output signal has a sampling rate R times of the input signal.
The length FIR filter 232 may be set to provide desired delay. Usually, if a delay of N taps is required, the length of the filter would be 2N−1 taps. One example of a feasible FIR filter for filter 232 is shown by the graphs of
As with the CIC decimator, the CIC interpolator described above may also be replaced with up samplers and FIR filters, such as shown in
In yet another example the CIC interpolator described herein may be replaced by a cascade of CIC interpolators in order define the amount of delay needed for a given active noise cancellation circuit configuration.
The techniques of this disclosure may be implemented in a wide variety of devices or apparatuses, including a wireless communication device handset such as a mobile phone, an integrated circuit (IC) or a set of ICs (i.e., a chip set). Any components, modules or units have been described provided to emphasize functional aspects and does not necessarily require realization by different hardware units. The techniques described herein may also be implemented in hardware, software, firmware, or any combination thereof. Any features described as modules, units or components may be implemented together in an integrated logic device or separately as discrete but interoperable logic devices. In some cases, various features may be implemented as an integrated circuit device, such as an integrated circuit chip or chipset.
If implemented in software, the techniques may be realized at least in part by a computer-readable medium comprising instructions that, when executed in a processor, performs one or more of the methods described above. The computer-readable medium may comprise a computer-readable storage medium and may form part of a computer program product, which may include packaging materials. The computer-readable storage medium may comprise random access memory (RAM) such as synchronous dynamic random access memory (SDRAM), read-only memory (ROM), non-volatile random access memory (NVRAM), electrically erasable programmable read-only memory (EEPROM), FLASH memory, magnetic or optical data storage media, and the like. The techniques additionally, or alternatively, may be realized at least in part by a computer-readable communication medium that carries or communicates code in the form of instructions or data structures and that can be accessed, read, and/or executed by a computer.
Any of the circuits described herein may be controlled at least in part by a processor that executes instructions stored on a computer-readable storage medium, such as described above. According, this disclosure contemplates a computer-readable storage medium comprising instructions that upon execution in a processor cause the processor to perform active noise cancellation, wherein the instructions cause the processor to process a sample via a down sample unit and an up sample unit, wherein a combined delay associated with processing a sample via the down sample unit and the up sample unit corresponds to a pre-defined delay that is selected to promote active noise cancellation. The combined delay may comprise a tunable parameter of a circuit that includes the down sample unit and the up sample unit, wherein the instructions cause the processor to select the tunable parameter.
The code or instructions may be executed by one or more processors, such as one or more digital signal processors (DSPs), general purpose microprocessors, an application specific integrated circuits (ASICs), field programmable logic arrays (FPGAs), or other equivalent integrated or discrete logic circuitry. Accordingly, the term “processor,” as used herein may refer to any of the foregoing structure or any other structure suitable for implementation of the techniques described herein. In addition, in some aspects, the functionality described herein may be provided within dedicated software modules or hardware modules configured for encoding and decoding, or incorporated in a combined video codec. Also, the techniques could be fully implemented in one or more circuits or logic elements.
The disclosure also contemplates any of a variety of integrated circuit devices that include circuitry to implement one or more of the techniques described in this disclosure. Such circuitry may be provided in a single integrated circuit chip or in multiple, interoperable integrated circuit chips in a so-called chipset. Such integrated circuit devices may be used in a variety of applications, some of which may include use in wireless communication devices, such as mobile telephone handsets.
Various examples have been described in this disclosure. The circuits described herein have exemplary numbers of stages, amplifiers, and down sampling and up sampling ratios illustrated, but different numbers of filter stages, amplifiers, or down sampling and up sampling ratios could be used for other configurations consistent with this disclosure.
Furthermore, although the delay techniques of this disclosure are primarily described in the context of active noise cancellation, the delay techniques may also be used in other circuits (i.e., circuits that do not perform active noise cancellation). For example, the delay techniques using a down sample unit and an up sample unit, rather than memory-based delay circuits, may also be used in low-latency equalization circuits or other circuits.
These and other examples are within the scope of the following claims.