1. Field of the Invention
The present invention relates to systems and methods for processing multiple acoustic signals, and more particularly to separating the acoustic signals through filtering.
2. Introduction
Detecting and reacting to an informational signal in a noisy environment is often difficult. In communication where users often talk in noisy environments, it is desirable to separate the user's speech signals from background noise. Background noise may include numerous noise signals generated by the general environment, signals generated by background conversations of other people, as well as reflections, and reverberation generated from each of the signals.
In noisy environments uplink communication can be a serious problem. Most solutions to this noise issue only either work on certain types of noise such as stationary noise, or produce significant audio artifacts that can be as annoying to the user as a noisy signal. All existing solutions have drawbacks concerning source and noise location, and noise type that is trying to be suppressed.
It is the object of this invention to provide a means that will suppress all noise sources independent of their temporal characteristics, location, or movement.
A system, method, and apparatus for separating a speech signal from a noisy acoustic environment. The separation process may include source filtering which may be directional filtering (beamforming), blind source separation, and dual input spectral subtraction noise suppression. The input channels may include two omnidirectional microphones whose output is processed using phase delay filtering to form speech and noise beamforms. Further, the beamforms may be frequency corrected. The beamforming operation generates one channel that is substantially only noise, and another channel that is a combination of noise and speech. A blind source separation algorithm augments the directional separation through statistical techniques. The noise signal and speech signal are then used to set process characteristics at a dual input spectral subtraction noise suppressor (DINS) to efficiently reduce or eliminate the noise component. In this way, the noise is effectively removed from the combination signal to generate a good quality speech signal.
In order to describe the manner in which the above-recited and other advantages and features of the invention can be obtained, a more particular description of the invention briefly described above will be rendered by reference to specific embodiments thereof which are illustrated in the appended drawings. Understanding that these drawings depict only typical embodiments of the invention and are not therefore to be considered to be limiting of its scope, the invention will be described and explained with additional specificity and detail through the use of the accompanying drawings in which:
Additional features and advantages of the invention will be set forth in the description which follows, and in part will be obvious from the description, or may be learned by practice of the invention. The features and advantages of the invention may be realized and obtained by means of the instruments and combinations particularly pointed out in the appended claims. These and other features of the present invention will become more fully apparent from the following description and appended claims, or may be learned by the practice of the invention as set forth herein.
Various embodiments of the invention are discussed in detail below. While specific implementations are discussed, it should be understood that this is done for illustration purposes only. A person skilled in the relevant art will recognize that other components and configurations may be used without parting from the spirit and scope of the invention.
The invention comprises a variety of embodiments, such as a method and apparatus and other embodiments that relate to the basic concepts of the invention.
The omnidirectional microphones 110 receive sound signals approximately equally from any direction around the microphone. The sensing pattern (not shown) shows approximately equal amplitude received signal power from all directions around the microphone. Thus, the electrical output from the microphone is the same regardless of from which direction the sound reaches the microphone.
The front hypercardioid 230 sensing pattern provides a narrower angle of primary sensitivity as compared to the cardioid pattern. Furthermore, the hypercardioid pattern has two points of minimum sensitivity, located at approximately +−140 degrees from the front. As such, the hypercardioid pattern suppresses sound received from both the sides and the rear of the microphone. Therefore, hypercardioid patterns are best suited for isolating instruments and vocalists from both the room ambience and each other.
The rear facing cardioid or rear cardioid 260 sensing pattern (not shown) is directional, providing full sensitivity when the sound source is at the rear of the microphone pair. Sound received at the sides of the microphone pair has about half of the output, and sound appearing at the front of the microphone pair is substantially attenuated. This rear cardioid pattern is created such that the null of the virtual microphone is pointed at the desired speech source (speaker).
In all cases, the beams are formed by filtering one omnidirectional microphone with a phase delay filter, the output of which is then summed with the other omnidirectional microphone signal to set the null locations, and then a correction filter to correct the frequency response of the resulting signal. Separate filters, containing the appropriate frequency-dependent delay are used to create Cardioid 260 and Hypercardioid 230 responses. Alternatively, the beams could be created by first creating forward and rearward facing cardioid beams using the aforementioned process, summing the cardioid signal to create a virtual omnidirectional signal, and taking the difference of the signals to create a bidirectional or dipole filter. The virtual omnidirectional and dipole signals are combined using equation 1 to create a Hypercardioid response.
Hypercardioid=0.25*(omni+3*dipole)  EQ. 1
An alternative embodiment would utilize fixed directivity single element Hypercardioid and Cardioid microphone capsules. This would eliminate the need for the beamforming step in the signal processing, but would limit the adaptability of the system, in that the variation of beamform from one use-mode in the device to another would be more difficult, and a true omnidirectional signal would not be available for other processing in the device. In this embodiment the source filter could either be a frequency corrective filter, or a simple filter with a passband that reduces out of band noise such as a high pass filter, a low pass antialiasing filter, or a bandpass filter.
The speech signal 140 provided by the processed signals from microphones 110 are passed as input to the blind source separation filter 410, in which a processed speech signal 430 and noise signal 420 is output to DINS 440, with the processed speech signal 430 consisting completely or at least essentially of a user's voice which has been separated from the ambient sound (noise) by action of the blind source separation algorithm carried out in the BSS filter 410. Such BSS signal processing utilizes the fact that the sound mixtures picked up by the microphone oriented towards the environment and the microphone oriented towards the speaker consist of different mixtures of the ambient sound and the user's voice, which are different regarding amplitude ratio of these two signal contributions or sources and regarding phase difference of these two signal contributions of the mixture.
The DINS unit 440 further enhances the processed speech signal 430 and noise signal 420, the noise signal 420 is used as the noise estimate of the DINS unit 440. The resulting noise estimate 420 should contain a highly reduced speech signal since remains of the desired speech 460 signal will be disadvantageous to the speech enhancement procedure and will thus lower the quality of the output.
When BSS is not used the output of the directional filtering (240, 250) can be applied directly to the dual channel noise suppressor (DINS), unfortunately the rear facing cardioid pattern 260 only places a partial null on the desired talker, which results in only 3 dB to 6 dB suppression of the desired talker in the noise estimate. For the DINS unit 440 on its own this amount of speech leakage causes unacceptable distortion to the speech after it has been processed. The RDINS is a version of the DINS designed to be more robust to this speech leakage in the noise estimate 250. This robustness is achieved by using two separate noise estimates; one is the continuous noise estimate from the directional filtering and the other is the static noise estimate that could also be used in a single channel noise suppressor.
Method 600 uses the speech beam 240. A continuous speech estimate is obtained from the speech beam 240, the estimate is obtained during both speech and speech free-intervals. The energy level of the speech estimate is calculated in step 610. In step 620, a voice activity detector is used to find the speech-free intervals in the speech estimate for each frame. In step 630, a smoothed static noise estimate is formed from the speech-free intervals in the speech estimate. This static noise estimate will contain no speech as it is frozen for the duration of the desired input speech; however this means that the noise estimate does not capture changes during non-stationary noise. In step 640, the energy of the static noise estimate is calculated. In step 650, a static signal to noise ratio is calculated from the energy of the continuous speech signal 615 and the energy of the static noise estimate. The steps 620 through 650 are repeated for each subband.
Method 700 uses the continuous noise estimate 250. In step 710, a continuous noise estimate is obtained from the noise beam 250, the estimate is obtained during both speech and speech free-intervals. This continuous noise estimate 250 will contain speech leakage from the desired talker due to the imperfect null. In step 720, the energy is calculated for the noise estimate for the subband. In step 730, the continuous signal to noise ratio is calculated for the subband.
Method 800 uses the calculated signal to noise ratio of the continuous noise estimate and the calculated signal to noise ratio of the static noise estimate to determine the noise suppression to use. In step 810, if the continuous SNR is greater than a first threshold, control is passed to step 820 where the suppression is set equal to the continuous SNR. If in step 810 the continuous SNR is not greater than a first threshold, control passes to action 830. In action 830, if the continuous SNR is less than a second threshold, control passes to step 840 where suppression is set to the static SNR. If the continuous SNR is not less than the second threshold, then control passes to step 850 where a weighted average noise suppressor is used. The weighted average is the average of the static and continuous SNR. For lower SNR sub-bands (no/weak speech relative to the noise) the continuous noise estimate is used to determine the amount of suppression so that it is effective during non-stationary noise. For higher SNR sub-bands (strong speech relative to the noise), when the leakage will dominate in the continuous noise estimate, use the static noise estimate to determine the amount of suppression to prevent the speech leakage causing over suppression and distorting the speech. During medium SNR sub-bands combine the two estimates to give a soft switch transition between the above two cases. In step 860 the channel gain is calculated. In step 870, the channel gain is applied to the speech estimate. The steps are repeated for each subband. The channel gains are then applied in the same way as for the DINS so that the channels that have a high SNR are passed while those with a low SNR are attenuated. In this implementation the speech waveform is reconstructed by overlap add of windowed Inverse FFT.
In practice a two way communication device may contain multiple embodiments of this invention which are switched between depending on the usage mode. For example a beamforming operation described in
Embodiments within the scope of the present invention may also include computer-readable media for carrying or having computer-executable instructions or data structures stored thereon. Such computer-readable media can be any available media that can be accessed by a general purpose or special purpose computer. By way of example, and not limitation, such computer-readable media can comprise RAM, ROM, EEPROM, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to carry or store desired program code means in the form of computer-executable instructions or data structures. When information is transferred or provided over a network or another communications connection (either hardwired, wireless, or combination thereof) to a computer, the computer properly views the connection as a computer-readable medium. Thus, any such connection is properly termed a computer-readable medium. Combinations of the above should also be included within the scope of the computer-readable media.
Computer-executable instructions include, for example, instructions and data which cause a general purpose computer, special purpose computer, or special purpose processing device to perform a certain function or group of functions. Computer-executable instructions also include program modules that are executed by computers in stand-alone or network environments. Generally, program modules include routines, programs, objects, components, and data structures, etc. that perform particular tasks or implement particular abstract data types. Computer-executable instructions, associated data structures, and program modules represent examples of the program code means for executing steps of the methods disclosed herein. The particular sequence of such executable instructions or associated data structures represents examples of corresponding acts for implementing the functions described in such steps.
Although the above description may contain specific details, they should not be construed as limiting the claims in any way. Other configurations of the described embodiments of the invention are part of the scope of this invention. For example, the principles of the invention may be applied to each individual user where each user may individually deploy such a system. This enables each user to utilize the benefits of the invention even if any one of the large number of possible applications do not need the functionality described herein. In other words, there may be multiple instances of the method and devices in
Number | Name | Date | Kind |
---|---|---|---|
6167417 | Parra et al. | Dec 2000 | A |
7106876 | Santiago | Sep 2006 | B2 |
20040076305 | Santiago | Apr 2004 | A1 |
20040158821 | Rickard et al. | Aug 2004 | A1 |
20040258255 | Zhang et al. | Dec 2004 | A1 |
20050060142 | Visser et al. | Mar 2005 | A1 |
20050094795 | Rambo | May 2005 | A1 |
20060135085 | Chen | Jun 2006 | A1 |
20070030982 | Jones et al. | Feb 2007 | A1 |
20070055507 | Jin et al. | Mar 2007 | A1 |
20080086260 | Lee et al. | Apr 2008 | A1 |
20090089053 | Wang et al. | Apr 2009 | A1 |
Number | Date | Country |
---|---|---|
1020050115857 | Dec 2005 | KR |
2004053839 | Jun 2004 | WO |
2004083884 | Sep 2004 | WO |
WO2004114644 | Dec 2004 | WO |
2007106399 | Sep 2007 | WO |
Number | Date | Country | |
---|---|---|---|
20090106021 A1 | Apr 2009 | US |