The present application relates generally to systems and methods for digital signal processing, and more particularly to sample rate conversion, for example, in adaptive noise cancellation systems.
The conversion of digital signals to different sample rates suitable for various digital components and processes is well known. For example, it is common for a digital signal processing system to use different sampling rates depending on a desired signal quality, required bandwidth, latency requirements, processing economy, available silicon area and other considerations. In audio processing systems, different sample rates may be used to achieve low latency and high performance. For example, in a digital adaptive noise cancellation (ANC) system, audio processing and ANC processing may be performed at different sample rates allowing for increased bandwidth of the ANC system (see, e.g., “Understanding Active Noise Cancellation”, Colin H. Hansen, ISBN 0415231922).
There are, however, issues in combining signals with uniform delay in systems using oversampled converter structures. One solution is to perform the processing in the analog domain, thereby circumventing the delay problems associated with digital oversampled processing. However, this will typically have limited ability to adapt over a wide frequency range, and other solutions suffer from a limited frequency resolution and limited attenuation of the undesired noise. Furthermore, these solutions are often sensitive to changes in components and implementation dependent. In view of the foregoing, there is a continued need for improved systems and methods for adaptive noise cancellation processing using oversampled converter structures.
Systems and methods are disclosed herein for providing low latency adaptive noise cancellation (ANC). In various embodiments, a system includes an audio sensor operable to sense environmental noise and generate a noise signal, an audio processing path operable to receive an audio signal, process the audio signal through an interpolation filter, and generate a primary audio signal having a first sample frequency, an adaptive noise cancellation processor operable to receive the noise signal and generate a corresponding an anti-noise signal, a direct interpolator operable to receive the anti-noise signal and generate an upsampled anti-noise signal having the first sample frequency, the direct interpolator comprising a sign extension stage operable to extend most significant bits of the anti-noise signal to avoid overflow, and a limiter operable to provide clipping to reduce a number of bits in the upsampled anti-noise signal, an adder operable to receive and combine the primary audio signal and the upsampled anti-noise signal and generate a combined output signal, and a low latency filter operable to process the combined output signal.
In some embodiments the low latency filter includes a plurality of filters, each performing filtering at a different sample frequency. The low latency filter may include a plurality of lattice wave filters disposed in a cascaded arrangement, wherein each of the plurality of lattice wave filters processes a different frequency band. In some embodiments, the sample frequency is increased in integer steps in each successive filter. The lattice wave filters may include a plurality of delay elements, and direct sampling at a particular output sample frequency may be achieved by interlacing multiple filters. In one implementation, N delay elements are provided in reflector sections (two-port adaptors) and one path is delayed by N/2 delay elements, and another path is directly connected to an input signal, for N equals a sequence of positive integer exponents of two. In another implementation, the lattice wave filter comprises two paths, including one path including a plurality of reflector elements with each reflector element delayed by N unit delays, where N is an integer greater than one, and one path delayed by M delay elements, where M is an integer greater than one. In some embodiments, the adaptive noise cancellation processor is further operable to derive the anti-noise signal by the adaptive cancellation processor, where the filter coefficients are calculated by a filtered-X least mean squares process, either operating in the time- or frequency domain.
In various embodiments, a system includes an audio processing path operable to receive and process a primary audio signal having a first sample frequency, an adaptive noise cancellation path comprising a decimator operable to downsample the primary audio signal to a second sampling frequency, an adaptive noise cancellation processor operable to receive the primary audio signal and a noise signal at the second sample frequency and generate an anti-noise signal having the second sample frequency, and an interpolator operable to upsample the anti-noise signal to the first sample frequency, and an adder operable to combine the anti-noise signal and the primary audio signal at the first sample frequency. The decimator and interpolator each comprise a plurality of filters operable to perform filtering at corresponding plurality of sample frequencies.
In some embodiments, each of the adaptive noise cancellation path and the audio processing path includes oversampled lattice filters comprising a plurality of delay elements arranged to enable uniform delay. The system may further comprise a microphone operable to sense environmental noise and generate corresponding electrical signals, and a low delay decimator to generate the noise signal at the second sample frequency. The system may further comprise an oversampled interpolation filter that has input and output sample frequencies that match the first sample frequency, and is operable to remove aliased images generated by the interpolator in the adaptive noise cancellation path. In some embodiments, each of the plurality of filters comprises a multi-stage lattice wave filter structure where each stage changes an operating sample rate by a factor of two. The decimator and interpolator may each comprise a sign extension stage operable to extend the most significant bits of a received signal to avoid overflow, and a limiter operable to provide clipping to reduce a number of output bits.
In various embodiments, a method comprises sensing environmental noise and generating a noise signal, processing an audio signal through an interpolation filter to generate a primary audio signal having a first sample frequency, generating, from the noise signal, an anti-noise signal having a second sample frequency, directly interpolating the anti-noise signal to generate an upsampled anti-noise signal having the first sample frequency, wherein directly interpolating include extending most significant bits of the anti-noise signal to avoid overflow and multiplying the ANC reference by a gain factor equal to the interpolation factor, and clipping to reduce a number of output bits in the upsampled anti-noise signal, combining the primary audio signal and the upsampled anti-noise signal to produce a combined output signal; and processing the combined output signal through a low latency filter.
In some embodiments, the method further includes applying a plurality of lattice wave filters disposed in a cascaded arrangement, wherein each of the plurality of lattice wave filters processes a different sample frequency that is successively changed in each successive filter. Applying the plurality of lattice wave filters may include applying a plurality of delay elements. Direct sampling at a particular output sample frequency may be achieved by interlacing multiple filters. In various embodiments, decimating the primary audio signal to downsample the primary audio signal to the second sample frequency, and generating, from the noise signal, the anti-noise signal having the second sample frequency may further include analyzing the downsampled primary audio signal. In some embodiments, the method includes generating, from the noise signal, the anti-noise signal having the second sample frequency comprises calculating filter coefficient using a filtered-X least mean squares process.
The scope of the invention is defined by the claims, which are incorporated into this section by reference. A more complete understanding of embodiments of the invention will be afforded to those skilled in the art, as well as a realization of additional advantages thereof, by a consideration of the following detailed description of one or more embodiments. Reference will be made to the appended sheets of drawings that will first be described briefly.
Aspects of the disclosure and their advantages can be better understood with reference to the following drawings and the detailed description that follows. It should be appreciated that like reference numerals are used to identify like elements illustrated in one or more of the figures, wherein showings therein are for purposes of illustrating embodiments of the present disclosure and not for purposes of limiting the same. The components in the drawings are not necessarily to scale, emphasis instead being placed upon clearly illustrating the principles of the present disclosure.
In accordance with various embodiments of the present disclosure, systems and methods for achieving low latency and high-quality audio output in adaptive noise cancellation filters are disclosed.
Noise cancellation and noise reduction techniques are used in a variety of applications to improve user experiences in noisy environments. In one approach a listening device, such as headphones, headsets or ear buds, includes one or more audio sensors to pick up environmental noise and adaptive noise cancellation processing circuitry to generate an anti-noise signal to cancel or reduce the environmental noise for the user. It is desirable for the generated anti-noise signal to be equal to the inverse of the noise disturbance (thereby cancelling the noise) while desired audio, such as the playback from a high-fidelity audio source, is provided with minimal disturbance. To obtain desired attenuation of the environmental noise, ANC systems are designed for low latency processing of the received noise signals to generate an inverted output signal that has a minimal phase shift with respect to the original noise signal to obtain a wide bandwidth of noise cancellation. In many listening environments, a feedback signal having a latency of around 10 μs can be used to obtain a noise reduction bandwidth of around 20 kHz, with the actual obtained bandwidth depending on the topology of the noise cancellation system and the actual acoustics system.
Various embodiments of the present disclosure are directed to noise cancellation systems that use oversampled converters in high-quality audio playback systems. In one embodiment, delta-sigma analog-to-digital converters (ADCs) and digital-to-analog converters (DACs) are used for audio signal processing. As compared to Nyquist sample rate converters, delta-sigma converters utilize a higher sample rate and are generally cheaper to implement because they require less precision in the analog signal components. Therefore, both from a cost and processing perspective, it is often advantageous to perform the noise cancellation at a higher sample rate than required by the Nyquist criterion and this can be used to obtain a wider noise cancellation bandwidth.
One complication with multi-rate signal processing is the possibility of increased latency. In ANC systems, it is desirable to provide a time-accurate reference for the active noise processing system, both of the measured noise (undesired signal) and high fidelity audio (desired signal), in order to generate an anti-noise signal that is in phase with the environmental noise to be cancelled. In some embodiments, lattice wave filters, which are known for low sensitivity to coefficient changes, are used to obtain simplified filter solutions that do not require multiplication. To obtain low latency, a low filter order is desired, but this may have the unfortunate property that the attenuation for out-of-band signals is lower which can be a problem for high-quality audio signals where good out-of-band attenuation is desired.
A system 100 for performing adaptive noise cancellation (ANC) in accordance with embodiments of the present disclosure will now be described with reference to
The low delay ANC processor 106 generates an anti-noise signal corresponding to the environmental noise sensed by the microphone 102. The ANC processor 106 also receives a time-accurate, audio playback signal from the high-quality audio playback processor 108, which is used as an audio reference signal. In various embodiments, the ANC processor 106 uses a time or frequency update of internal filter nodes to adaptively filter the environmental noise from the microphone signal, which may also include desired audio played through a speaker 114. For example, the ANC processor 106 may implement a filtered-x least mean squares (FXLMS) algorithm to adaptively modify filter coefficients to filter out the environmental noise. To obtain a low latency, finite impulse response (FIR) topologies are often used while the filter updates are often performed in the frequency domain to obtain fast adaption even when there is a significant spread among the power spectrum of the noise. This enables fast adaptation even at frequencies where the energy content is significantly smaller than any dominant nodes by separating the signals in the frequency domain. An inverse frequency transform may be used to transform the adapted weights back to the time domain.
The audio playback processor 108 generates the desired audio signal (also referred to herein as the primary audio signal) for playback through an audio output, such as speaker 114. The desired audio signal may be generated from a source file (e.g., recorded music or movie file) or output from another source, such as a near end microphone or an audio signal received from a far end microphone in a voice over IP system. The desired audio signal is combined with the anti-noise signal output by the ANC processor 106 by the adder 110. The summed output of these signals is filtered and upconverted using a low latency interpolator 112 and output to the speaker 114 (sometimes called a receiver).
It will be appreciated that, for simplicity, some standard components are not shown in
In various embodiments of the system 100, both the high-fidelity audio signal and the ANC output signals are represented at the same low sample rate (e.g. 192 kHz) and are therefore both subjected to the same low-fidelity interpolation filter—provided a low latency in the processing path is a design goal. While it is possible to increase the processing sample rate, this will increase power consumption and physical size of the design considerably. Therefore, it is desired to simultaneously be able to combine a high-quality interpolation filter for audio playback and a low latency filter path for the ANC processing (also referred to herein as the adaptive noise cancellation path). This may be implemented as shown in the embodiment of
The system 200 includes a microphone 202, low delay decimator 204 and low delay ANC processor 206 for receiving a noise signal and generating an anti-noise signal. The anti-noise signal is provided to a low latency interpolator 212 to produce the anti-noise signal 218 to be combined with the high-quality audio signal (also referred to herein as the primary audio signal) by adder 210. High-quality audio is provided by high-quality audio playback 208 to the ANC processor 206 for use as the ANC reference signal. As illustrated, the high-quality audio signal and the noise signal are at the same low sample rate (e.g., 192 kHz), suitable for efficient ANC processing. A high-quality interpolator 216 (“high-quality” meaning including sufficient dynamic range, attenuation etc. for the system requirements) increases the sampling rate of the high-quality audio signal for output to the speaker 214 and adds latency to the high-quality audio signal processing path. Because the ANC processor 206 uses a time-accurate audio reference of the audio output, the different signal processing paths of the two signals (output from block 208 and 206) experience a different signal processing path (i.e. through filters 212 and 216 respectively), which creates differences in the internal group delays, leading to less than optimal adaption in the ANC processing unit. The different latencies between blocks 212 and 216 will cause the signals to be out of phase which decreases performance of the noise cancellation. Therefore, the issues with the system of
An embodiment of a system 300 providing time accurate references for the ANC system while providing both a low delay path for the ANC signal and a high-fidelity signal path for the reference audio signal is illustrated in
The low delay interpolator 312 in this embodiment is an oversampled interpolator that operates at the higher sample rate of the initial audio output times N, and removes the aliased images that will be output from the directly interpolated signal from the ANC processor 306, while the original oversampled high-fidelity oversampled audio signal will pass through unchanged since the aliased images have already been removed by the high-quality interpolator. The oversampled interpolator 312 may be implemented by adding extra delay elements inside each filter section, i.e. each filter section includes N, N/2. N/4 etc. times the original delay elements to obtain the same frequency response as the original filter configuration operating at N, N/2, N/4 times lower sample frequency. Furthermore, this filter configuration solves practical implementation problems, because the filter elements are updated at the much higher sample rate of N times the original sample rate, thereby enabling an optimal group delay of the filters. In this case, the theoretical performance may be obtained without introducing extra delays due to a practical register transfer level implementation that often can give delays when transferring values between systems with different sample rates (i.e., difference sample frequencies). Other filter configurations than Lattice Wave filter may be used in the general solution shown in
In various embodiments, the oversampled interpolation filter has same input and output sample frequency, and can also be used as a low latency decimation filter and thereby lower latency further by reducing the input path delay. It is essentially a low pass filter with very low delay and wide bandwidth, and it is possible to add a second decimation path for high-fidelity applications.
For various implementations, the filter may be optimized by first designing a filter with a response that may be ideal from an out-of-band attenuation point of view, and then further optimize the filter by adjusting the coefficients to improve the actual signal-to-noise-ratio (SNR) at the output of the filter, thereby taking the actual noise shaping of the used delta-sigma converters into account. Further, the coefficients may be discretized to remove multiplications in the actual implementation thus lowering silicon area, cost and power consumption significantly.
Embodiments of an oversampled filter implementation 400 will now be described with reference to
To obtain both high audio quality and low uniform path delay of the audio signal and the ANC anti-noise signal, the embodiment of
In the illustrated embodiment, ANC processing is performed at a 192 kHz sample rate. The audio signal is decimated by a factor of N=16 by decimator 418 (i.e., pull out every 16th sample) to generate the 192 kHz reference signal for ANC processing. The ANC processor 406 outputs a 192 kHz anti-noise signal, which is upsampled by a factor of N=16 by interpolator 420 to produce a 3.072 MHz anti-noise signal which is combined with the audio signal by adder 410. In a practical implementation, there may be included a multiplier after interpolator 420 to ensure the low frequency energy levels from section S3 and block 420 are matching. This multiplier is not shown in
It will be appreciated by those skilled in the art that the embodiments disclosed herein provide numerous advantages over conventional systems. The embodiments enable low and well controlled latency, independent filtering of the ANC and audio path and enable the same delay of both paths after the summation point.
In one embodiment, a word length of 24 fraction bits is used to connect directly to conventional audio components, and an internal representation of 25 bits is used that include one overflow bit. In theory, up to two overflow bits may be necessary to avoid overflow under all conditions, but in a practical implementation, one overflow bit may be enough. The audio components may be connected directly to the filter. The ANC processor may be directly connected to the filter. In one embodiment, the least significant bit (LSB) of node X3 (the node X3 is shown in subsequent figures) is set to zero in all the oversampled filters to avoid limit cycles. Tests have shown no significant deterioration in the SNR if only 22 bits are used (instead of 25 bits) given the already limited dynamic range of the chosen delta-sigma converters. It will be appreciated that, although the filter S5 to S8 has been illustrated in the sequence {S5, S6, S7, S8} in
Referring to
The transfer function for this filter can be derived with reference to the node equations as follows:
Y0=X0z−N
X1=X0+X2z−2N=X0+(X1−X3)z−2N=X0+X1z−2N−X3z−2N
X1=(X0−X3z−2N)/(1−z−2N)
X3=X2z−2N+γX1=(X1−X3)z−2N+γX1
X3(1+z−2N)=(z−2N+γ)X1=(z−2N+γ)(X0−X3z−2N)/(1−z−2N)
X3(1+z−2N)(1−z−2N)+X3(z−2N+γ)z−2N=(z−N+γ)X0
X3=(z−2N+γ)X0/(1+γz−2N)
Out=Y0+X3=X0z−N+X3=X0(γ+z−N+z−2N+γz−3N)/(1+γz−2N)
For the filter illustrated in
Out=Y0+X3=X0z−8+X3=X0(γ+z−8+z−16+γz−24)/(1+γz−16).
The value of γ will determine the filter cutoff frequency. The value of γ was first found from maximizing the attenuation in the stopband and minimizing the attenuation in the passband. However, a slightly better value can be found by optimizing the SNR of the output from a given delta-sigma converter structure, because this will also take into account the actual noise-shaping of this converter. After performing this optimization, a value of γ equal to 0.346656 was obtained. Due to the low sensitivity of lattice wave filters, this value may be approximated with a few add/shift operations using the following value: γ=¼+ 1/16+ 1/64+ 1/128. This approximation resulted in a decrease in the SNR of less than 0.1 dB using fixed point arithmetic as compared to using floating point multiplication and the optimal value of γ. In this manner, a full multiplication operation can be replaced with 3 additions while the shifts may be hardwired, thereby saving significant silicon real estate and power. In this implementation a nonlinearity is deliberately introduced by setting the least significant bit (LSB) output from node X3 to zero to avoid limit cycle problems resulting in spurious small amplitude oscillations in the filter. The frequency response and group delay of the eight times oversampled interpolator of
Referring to
Out=Y0+X3=X0z−4+X3=X0(γ+z−4+z−8+γz−12)/(1+γz−8).
This filter behaves like a filter with unit delays running at four times the original sample frequency and allows processing of signals that are oversampled four times. The frequency response and group delay of the interpolator of
Referring to
Out=Y0+X3=X0z−2+X3=X0(γ+z−2+z−4+γz−6)/(1+γz−4).
The frequency response and group delay of the two times oversampled interpolator of
Referring to
Out=Y0+X3=X0z−1+X3=X0(γ+z−1+z−2+γz−3)/(1+γz−2).
The frequency response and group delay of the direct interpolator of
The combined response of the entire filter chain (i.e. sections S5-S8 of
Referring to
Referring to
Referring to
Referring to
Referring to
Various implementation embodiments will now be described with referenced to
In the previous embodiments, a particular structure of an oversampled lattice wave filter has been presented. It is well known within the open literature that many topologies of the original lattice waveform filter exist (see, e.g., L. Gasci, “Explicit Formulas for Lattice Wave Digital Filters”, IEEE Trans. Circuits and Systems, January 1985, FIG. 9, for multiple examples of two-port adaptors). The embodiments should not be limited to the topology described here but also include all that have previously been described, e.g., including the multiple delay elements in these existing structures with an oversampling factor higher than two or the use multiple delay element, where the number is higher than two in general applications.
Where applicable, various embodiments provided by the present disclosure may be implemented using hardware, software, or combinations of hardware and software. Also, where applicable, the various hardware components and/or logic components set forth herein may be combined into composite components comprising software, hardware, and/or both without departing from the scope of the present disclosure. Where applicable, the various hardware components and/or logic components set forth herein may be separated into sub-components comprising software, hardware, or both without departing from the scope of the present disclosure. In addition, where applicable, it is contemplated that software components may be implemented as hardware components and vice versa.
The foregoing disclosure is not intended to limit the present disclosure to the precise forms or particular fields of use disclosed. As such, it is contemplated that various alternate embodiments and/or modifications to the present disclosure, whether explicitly described or implied herein, are possible in light of the disclosure. For example, although the low delay decimators and low delay interpolators disclosed herein are described with reference to adaptive noise cancellation systems, it will be appreciated that the low delay filters disclosed herein may be used in other signal processing systems. Having thus described embodiments of the present disclosure, persons of ordinary skill in the art will recognize that changes may be made in form and detail without departing from the scope of the present disclosure. Thus, the present disclosure is limited only by the claims.
The present application claims the benefit of and priority to U.S. Provisional Patent Application No. 62/579,809, filed Oct. 31, 2017, which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
6442581 | Laroche | Aug 2002 | B1 |
8526628 | Massie | Sep 2013 | B1 |
8611551 | Massie et al. | Dec 2013 | B1 |
20080212791 | Asada | Sep 2008 | A1 |
20100195844 | Christoph | Aug 2010 | A1 |
20100310086 | Magrath et al. | Dec 2010 | A1 |
20110007907 | Park | Jan 2011 | A1 |
20110116654 | Chan | May 2011 | A1 |
20120308025 | Hendrix et al. | Dec 2012 | A1 |
20150010170 | Lindahl | Jan 2015 | A1 |
20160240183 | Noh | Aug 2016 | A1 |
Entry |
---|
Johansson et al., “Design of Bireciprocal Linear Phase Lattice Wave Digital Filters”, Department of Electrical Engineering, Linköping University, S-581 83, Jan. 31, 1996, pp. 1-17, Linköping, Sweden. |
John Knight, “Laboratory 2.0, A 3-Bit Binary Sign-Extended Adder/Subtracter”, Department of Electronics, ELEC 2607, Switching Circuits, Jan. 30, 2008, pp. Lab2-1-Lab2-12, Carleton University, Ottawa, Ontario, Canada. |
Number | Date | Country | |
---|---|---|---|
20190132679 A1 | May 2019 | US |
Number | Date | Country | |
---|---|---|---|
62579809 | Oct 2017 | US |