Methods exist for reducing background noise in an adverse audio environment. One such method is to use a stationary noise suppression system. The stationary noise suppression system will always provide an output noise that is a fixed amount lower than the input noise. Typically, the stationary noise suppression is in the range of 12-13 decibels (dB). The noise suppression is fixed to this conservative level in order to avoid producing speech distortion, which will be apparent with higher noise suppression.
Some prior art systems invoke a generalized side-lobe canceller. The generalized side-lobe canceller is used to identify desired signals and interfering signals comprised by a received signal. The desired signals propagate from a desired location and the interfering signals propagate from other locations. The interfering signals are subtracted from the received signal with the intention of cancelling interference.
Previous audio devices have incorporated two microphone systems to reduce noise in an audio signal. A two microphone system can be used to achieve noise cancellation or source localization, but is not suitable for obtaining both. With two widely spaced microphones, it is possible to derive level difference cues for source localization and multiplicative noise suppression. However, with two widely spaced microphones, noise cancelation is limited to dry point sources given the lower coherence of the microphone signals. The two microphones can be closely spaced for improved noise cancellation due to higher coherence between the microphone signals. However, decreasing the spacing results in level cues which are too weak to be reliable for localization.
The present technology involves the combination of two independent but complementary two-microphone signal processing methodologies, an inter-microphone level difference method and a null processing noise subtraction method, which help and complement each other to maximize noise reduction performance. Each two-microphone methodology or strategy may be configured to work in optimal configuration and may share one or more microphones of an audio device.
An exemplary microphone placement may use two sets of two microphones for noise suppression, wherein the set of microphones include two or more microphones. A primary microphone and secondary microphone may be positioned closely spaced to each other to provide acoustic signals used to achieve noise cancellation. A tertiary microphone may be spaced with respect to either the primary microphone or the secondary microphone (or, may be implemented as either the primary microphone or the secondary microphone rather than a third microphone) in a spread-microphone configuration for deriving level cues from audio signals provided by tertiary and primary or secondary microphone. The level cues are expressed via an inter-microphone level difference (ILD) which is used to determine one or more cluster tracking control signals. A noise cancelled primary acoustic signal and the ILD based cluster tracking control signals are used during post filtering to adaptively generate a mask to be applied against a speech estimate signal.
An embodiment for noise suppression may receive two or more signals. The two or more signals may include a primary acoustic signal. A level difference may be determined from any pair of the two or more acoustic signals. Noise cancellation may be performed on the primary acoustic signal by subtracting a noise component from the primary acoustic signal. The noise component may be derived from an acoustic signal other than the primary acoustic signal
An embodiment of a system for noise suppression may include a frequency analysis module, an ILD module, and at least one a noise subtraction module, all of which may be stored in memory and executed by a processor. The frequency analysis module may be executed to receive two or more acoustic signals, wherein the two or more acoustic signals include a primary acoustic signal. The ILD module may be executed to determine a level difference cue from any pair of the two or more acoustic signals. The noise subtraction module may be executed to perform noise cancellation on the primary acoustic signal by subtracting a noise component from the primary acoustic signal. The noise component may be derived from an acoustic signal other than the primary acoustic signal.
An embodiment may include a machine readable medium having embodied thereon a program. The program may provide instructions for a method for suppressing noise as described above.
Two independent but complementary two-microphone signal processing methodologies, an inter-microphone level difference method and a null processing noise subtraction method, can be combined to maximize noise reduction performance. Each two-microphone methodology or strategy may be configured to work in optimal configuration and may share one or more microphones of an audio device.
An audio device may utilize two pairs of microphones for noise suppression. A primary and secondary microphone may be positioned closely spaced to each other and may provide audio signals utilized for achieving noise cancellation. A tertiary microphone may be spaced in spread-microphone configuration with either the primary or secondary microphone and may provide audio signals for deriving level cues. The level cues are encoded in the inter-microphone level difference (ILD) and normalized by a cluster tracker to account for distortions due to the acoustic structures and transducers involved. Cluster tracking and level difference determination are discussed in more detail below.
In some embodiments, the ILD cue from a spread-microphone pair may be normalized and used to control the adaptation of noise cancellation implemented with the primary microphone and secondary microphone. In some embodiments, a post-processing multiplicative mask may be implemented with a post-filter. The post-filter can be derived in several ways, one of which may involve the derivation of a noise reference by null-processing a signal received from the tertiary microphone to remove a speech component.
Embodiments of the present technology may be practiced on any audio device that is configured to receive sound such as, but not limited to, cellular phones, phone handsets, headsets, and conferencing systems. Advantageously, exemplary embodiments are configured to provide improved noise suppression while minimizing speech distortion. While some embodiments of the present technology will be described in reference to operation on a cellular phone, the present technology may be practiced on any audio device.
Referring to
Microphones 106, 108, and 110 may receive sound (i.e., acoustic signals) from the audio source 102 and noise 110. Although the noise 110 is shown coming from a single location in
The positions of microphones 106, 108, and 110 on audio device 104 may vary. For example in
Microphones 106, 108, and 110 are labeled as M1, M2, and M3, respectively. Though microphones M1 and M2 may be illustrated as spaced closer to each other and microphone M3 may be spaced further apart from microphones M1 and M2, any microphone signal combination can be processed to achieve noise cancellation and determine level cues between two audio signals. The designations of M1, M2, and M3 are arbitrary with microphones 106, 108 and 110 in that any of microphones 106, 108 and 110 may be M1, M2, and M3. Processing of the microphone signals is discussed in more detail below with respect to
The three microphones illustrated in
Processor 302 may execute instructions and modules stored in a memory (not illustrated in
Audio processing system 304 may process acoustic signals received by microphones 106, 108 and 110 (M1, M2 and M3) to suppress noise and in the received signals and provide an audio signal to output device 306. Audio processing system 304 is discussed in more detail below with respect to
The output device 306 is any device which provides an audio output to the user. For example, the output device 306 may comprise an earpiece of a headset or handset, or a speaker on a conferencing device.
In operation, acoustic signals are received by microphones M1, M2 and M3, converted to electric signals, and the electric signals are processed through frequency analysis module 402 and 404. In one embodiment, the frequency analysis module 402 takes the acoustic signals and mimics the frequency analysis of the cochlea (i.e., cochlear domain) simulated by a filter bank. Frequency analysis module 402 may separate the acoustic signals into frequency sub-bands. A sub-band is the result of a filtering operation on an input signal where the bandwidth of the filter is narrower than the bandwidth of the signal received by the frequency analysis module 402. Alternatively, other filters such as short-time Fourier transform (STFT), sub-band filter banks, modulated complex lapped transforms, cochlear models, wavelets, etc., can be used for the frequency analysis and synthesis. Because most sounds (e.g., acoustic signals) are complex and comprise more than one frequency, a sub-band analysis on the acoustic signal determines what individual frequencies are present in the complex acoustic signal during a frame (e.g., a predetermined period of time). For example, the length of a frame may be 4 ms, 8 ms, or some other length of time. In some embodiments there may be no frame at all. The results may comprise sub-band signals in a fast cochlea transform (FCT) domain.
The sub-band frame signals are provided from frequency analysis modules 402 and 404 to ILD 406 and null processing noise subtraction (NPNS) module 408. Null processing noise subtraction (NPNS) module 408 may adaptively subtract out a noise component from a primary acoustic signal for each sub-band. As such, output of the NPNS 408 includes sub-band estimates of the noise in the primary signal and sub-band estimates of the speech (in the form of a noise-subtracted sub-band signals) or other desired audio in the in the primary signal.
α,β,γε[1,2,3], α≠β≠γ.
Each of Mα, Mβ, and Mγ can be associated with any of microphones 106, 108 and 110 of
NPNS 422 may receive inputs of sub-band signals of M1 and the output of NPNS 420. When NPNS 422 receives the noise reference output from NPNS 420 (point C is coupled to point A), NPNS 422 performs null processing noise subtraction and generates outputs of a second speech reference output S2 and second noise reference output N2. These outputs are provided as output by NPNS 408 in
Different variations of one or more NPNS modules may be used to implement NPNS 408. In some embodiments, NPNS 408 may be implemented with a single NPNS module 420. In some embodiments, a second implementation of NPNS 408 can be provided within audio processing system 304 wherein point C is connected to point B, such as for example the embodiment illustrated in
An example of null processing noise subtraction as performed by an NPNS module is disclosed in U.S. patent application Ser. No. 12/215,980, entitled “System and Method for Providing Noise Suppression Utilizing Null Processing Noise Subtraction”, filed on Jun. 30, 2008, the disclosure of which is incorporated herein by reference.
Though a cascade of two noise subtraction modules is illustrated in
Returning to
From the calculated energy levels, an inter-microphone level difference (ILD) may be determined by an ILD module 406. ILD module 406 may receive calculated energy information for any of microphones M1, M2 or M3. The ILD module 406 may be approximated mathematically, in one embodiment, as
where E1 is the energy level difference of two of microphones M1, M2 and M3 and E2 is the energy level difference of the microphone not used for E1 and one of the two microphones used for E1. Both E1 and E2 are obtained from energy level estimates. This equation provides a bounded result between −1 and 1. For example, ILD goes to 1 when the E2 goes to 0, and ILD goes to −1 when E1 goes to 0. Thus, when the speech source is close to the two microphone used for E1 and there is no noise, ILD=1, but as more noise is added, the ILD will change. In an alternative embodiment, the ILD may be approximated by
were E1(t,w) is the energy of a speech dominated signal and E2 is the energy of a noise dominated signal. ILD may vary in time and frequency and may be bounded between −1 and 1. ILD1 may be used to determine the cluster tracker realization for signals received by NPNS 420 in
ILD1={ILD(M1,Mi), where iε[2,3]},
wherein M1 represents a primary microphone that is closest to a desired source, such as for example a mouth reference point, and Mi represents a microphone other than the primary microphone. ILD1 can be determined from energy estimates of the framed sub-band signals of the two microphones associated with the input to NPNS 420. In some embodiments, ILD1 is determined as the higher valued ILD between the primary microphone and the other two microphones.
ILD2 may be used to determine the cluster tracker realization for signals received by NPNS 422 in
ILD2={ILD1,ILD(Mi,S1),iε[β,γ];ILD(Mi,N1),iε[α,γ];ILD(Si,N1)}.
Determining energy level estimates and inter-microphone level differences is discussed in more detail in U.S. patent application Ser. No. 11/343,524, entitled “System and method for utilizing inter-microphone level differences for Speech Enhancement,” filed on Jan. 30, 2006, the disclosure of which is incorporated herein by reference.
Cluster tracking module 410 may receive level differences between energy estimates of sub-band framed signals from ILD module 406. ILD module 406 may generate ILD signals from energy estimates of microphone signals, speech or noise reference signals. The ILD signals may be used by cluster tracker 410 to control adaptation of noise cancellation as well as to create a mask by post filter 414. Examples of ILD signals that may be generated by ILD module 406 to control adaptation of noise suppression include ILD1 and ILD2. According to exemplary embodiments, tracking module 410 differentiates (i.e., classifies) noise and distracters from speech and provides the results to NPNS module 408 and post filter module 414.
ILD distortion, in many embodiments, may be created by either fixed (e.g., from irregular or mismatched microphone response) or slowly changing (e.g., changes in handset, talker, or room geometry and position) causes. In these embodiments, the ILD distortion may be compensated for based on estimates for either build-time clarification or runtime tracking. Exemplary embodiments of the present invention enables cluster tracker 410 to dynamically calculate these estimates at runtime providing a per-frequency dynamically changing estimate for a source (e.g., speech) and a noise (e.g., background) ILDs.
Cluster tracker 410 may determine a global summary of acoustic features based, at least in part, on acoustic features derived from an acoustic signal, as well as an instantaneous global classification based on a global running estimate and the global summary of acoustic features. The global running estimates may be updated and an instantaneous local classification is derived based on at least the one or more acoustic features. Spectral energy classifications may then be determined based, at least in part, on the instantaneous local classification and the one or more acoustic features.
In some embodiments, cluster tracker 410 classifies points in the energy spectrum as being speech or noise based on these local clusters and observations. As such, a local binary mask for each point in the energy spectrum is identified as either speech or noise. Cluster tracker 410 may generate a noise/speech classification signal per subband and provide the classification to NPNS 408 to control its canceller parameters (sigma and alpha) adaptation. In some embodiments, the classification is a control signal indicating the differentiation between noise and speech. NPNS 408 may utilize the classification signals to estimate noise in received microphone energy estimate signals, such as Mα, Mβ, and Mγ. In some embodiments, the results of cluster tracker 410 may be forwarded to the noise estimate module 412. Essentially, a current noise estimate along with locations in the energy spectrum where the noise may be located are provided for processing a noise signal within audio processing system 304.
The cluster tracker 410 uses the normalized ILD cue from microphone M3 and either microphone M1 or M2 to control the adaptation of the NPNS implemented by microphones M1 and M2 (or M1, M2 and M3). Hence, the tracked ILD is utilized to derive a sub-band decision mask in post filter module 414 (applied at mask 416) that controls the adaption of the NPNS sub-band source estimate.
An example of tracking clusters by cluster tracker 410 is disclosed in U.S. patent application Ser. No. 12/004,897, entitled “System and method for Adaptive Classification of Audio Sources,” filed on Dec. 21, 2007, the disclosure of which is incorporated herein by reference.
Noise estimate module 412 may receive a noise/speech classification control signal and the NPNS output to estimate the noise N(t,w). Cluster tracker 410 differentiates (i.e., classifies) noise and distracters from speech and provides the results for noise processing. In some embodiments, the results may be provided to noise estimate module 412 in order to derive the noise estimate. The noise estimate determined by noise estimate module 412 is provided to post filter module 414. In some embodiments, post filter 414 receives the noise estimate output of NPNS 408 (output of the blocking matrix) and an output of cluster tracker 410, in which case a noise estimate module 412 is not utilized.
Post filter module 414 receives a noise estimate from cluster tracking module 410 (or noise estimate module 412, if implemented) and the speech estimate output (e.g., S1 or S2) from NPNS 408. Post filter module 414 derives a filter estimate based on the noise estimate and speech estimate. In one embodiment, post filter 414 implements a filter such as a Weiner filter. Alternative embodiments may contemplate other filters. Accordingly, the Weiner filter approximation may be approximated, according to one embodiment, as
, where Ps is a power spectral density of speech and Pn is a power spectral density of noise. According to one embodiment, Pn is the noise estimate, N(t,ω), which may be calculated by noise estimate module 412. In an exemplary embodiment, Ps=E1(t,ω)−βN(t,ω), where E1(t,ω) is the energy at the output of NPNS 408 and N(t,ω)) is the noise estimate provided by the noise estimate module 412. Because the noise estimate changes with each frame, the filter estimate will also change with each frame.
β is an over-subtraction term which is a function of the ILD. β compensates bias of minimum statistics of the noise estimate module 412 and forms a perceptual weighting. Because time constants are different, the bias will be different between portions of pure noise and portions of noise and speech. Therefore, in some embodiments, compensation for this bias may be necessary. In exemplary embodiments, β is determined empirically (e.g., 2-3 dB at a large ILD, and is 6-9 dB at a low ILD).
In the above exemplary Weiner filter equation, α is a factor which further suppresses the estimated noise components. In some embodiments, α can be any positive value. Nonlinear expansion may be obtained by setting α to 2. According to exemplary embodiments, α is determined empirically and applied when a body of W=
falls below a prescribed value (e.g., 12 dB down from the maximum possible value of W, which is unity).
Because the Weiner filter estimation may change quickly (e.g., from one frame to the next frame) and noise and speech estimates can vary greatly between each frame, application of the Weiner filter estimate, as is, may result in artifacts (e.g., discontinuities, blips, transients, etc.). Therefore, optional filter smoothing may be performed to smooth the Wiener filter estimate applied to the acoustic signals as a function of time. In one embodiment, the filter smoothing may be mathematically approximated as
M(t,ω)=λs(t,ω)W+(t,ω)+(1−λs(t,ω))M(t−1,ω)
, where λs is a function of the Weiner filter estimate and the primary microphone energy, E1.
A second instance of the cluster tracker could be used to track the NP-ILD, such as for example the ILD between the NP-NS output (and signal from the microphone M3 or the NPNS output generated by null processing the M3 audio signal to remove the speech). The ILD may provided as follows:
ILD3={ILD1;ILD2;ILD(S2, N2);ILD(Mi,S2),iε[β,γ];ILD(Mi, N2),iε[α,γ];ILD(S2,N1);ILD(S1,N2);ILD(S2,Ń2)},
wherein Ń2 is derived as the output of module 520 in
Next, the speech estimate is converted back into time domain from the cochlea domain by frequency synthesis module 418. The conversion may comprise taking the masked frequency sub-bands and adding together phase shifted signals of the cochlea channels in a frequency synthesis module 410. Alternatively, the conversion may comprise taking the masked frequency sub-bands and multiplying these with an inverse frequency of the cochlea channels in the frequency synthesis module 410. Once conversion is completed, the signal is output to user via output device 306.
The audio processing system 304 of
NPNS 408 in
Post filter module 414 receives a speech estimate from NPNS 408, a noise estimate from NPNS 520, and a speech/noise control signal from cluster tracker 410 to adaptively generate a mask to apply to the speech estimate at multiplier 416. The output of the multiplier is then processed by frequency synthesis module 418 and output by audio processing system 304.
In step 604, the frequency analysis on the primary, secondary and tertiary acoustic signals may be performed. In one embodiment, frequency analysis modules 402 and 404 utilize a filter bank to determine frequency sub-bands for the acoustic signals received by the device microphones.
Noise subtraction and noise suppression may be performed on the sub-band signals at step 606. NPNS modules 408 and 520 may perform the noise subtraction and suppression processing on the frequency sub-band signals received from frequency analysis modules 402 and 404. NPNS modules 408 and 520 then provide frequency sub-band noise estimate and speech estimate to post filter module 414.
Inter-microphone level differences (ILD) are computed at step 608. Computing the ILD may involve generating energy estimates for the sub-band signals from both frequency analysis module 402 and frequency analysis module 404. The output of the ILD is provided to cluster tracking module 410.
Cluster tracking is performed at step 610 by cluster tracking module 410. Cluster tracking module 410 receives the ILD information and outputs information indicating whether the sub-band is noise or speech. Cluster tracking 410 may normalize the speech signal and output decision threshold information from which a determination may be made as to whether a frequency sub-band is noise or speech. This information is passed to NPNS 408 and 520 to decide when to adapt noise cancelling parameters.
Noise may be estimated at step 612. In some embodiments, the noise estimation may performed by noise estimation module 412, and the output of cluster tracking module 410 is used to provide a noise estimate to post filter module 414. In some embodiments, the noise estimate NPNS 408 and/or 520 may determine and provide the noise estimate to post filter module 414.
A filter estimate is generated at step 614 by post filter module 414. In some embodiments, post filter module 414 receives an estimated source signal comprised of masked frequency sub-band signals from NPNS module 408 and an estimation of the noise signal from either null processing module 520 or cluster tracking module 410 (or noise estimate module 412). The filter may be a Weiner filter or some other filter.
A gain mask may be applied in step 616. In one embodiment, the gain mask generated by post filter 414 may be applied to the speech estimate output of NPNS 408 by the multiplicative module 416 on a per sub-band signal basis.
The cochlear domain sub-bands signals may then be synthesized in step 618 to generate an output in time domain. In one embodiment, the sub-band signals may be converted back to the time domain from the frequency domain. Once converted, the audio signal may be output to the user in step 620. The output may be via a speaker, earpiece, or other similar devices.
The above-described modules may be comprised of instructions that are stored in storage media such as a machine readable medium (e.g., a computer readable medium). The instructions may be retrieved and executed by the processor 302. Some examples of instructions include software, program code, and firmware. Some examples of storage media comprise memory devices and integrated circuits. The instructions are operational when executed by the processor 302 to direct the processor 302 to operate in accordance with embodiments of the present technology. Those skilled in the art are familiar with instructions, processors, and storage media.
The present technology is described above with reference to exemplary embodiments. It will be apparent to those skilled in the art that various modifications may be made and other embodiments may be used without departing from the broader scope of the present technology. For example, the functionality of a module discussed may be performed in separate modules, and separately discussed modules may be combined into a single module. Additional modules may be incorporated into the present technology to implement the features discussed as well variations of the features and functionality within the spirit and scope of the present technology. Therefore, there and other variations upon the exemplary embodiments are intended to be covered by the present technology.