In a personal telepresence system or speech communication system, a voice/audio signal can be captured by one omnidirectional microphone. When the environment is noisy, the omnidirectional microphone picks up not only desired voices, but also interferences in the environment, which may lead to impaired voice quality and a low quality user experience.
Systems, processes, devices, apparatuses, algorithms and computer readable medium for suppressing spatial interference can use a dual microphone array for receiving, from a first microphone and a second microphone that are separated by a predefined distance, and that can be configured to receive source signals, respective first and second microphone signals based on received source signals. A phase difference between the first and the second microphone signals can be calculated based on the predefined distance. Angular distances between directions of arrivals (DOAs) of the source signals and the desired capture direction can be calculated based on the phase difference. Directional-filter coefficients can be calculated based on the angular distance. Undesired source signals can be filtered from an output based on the directional-filter coefficients.
A device can include a first microphone and a second microphone that can be separated by a predefined distance, and that can be configured to receive source signals and output respective first and second microphone signals based on received source signals. A signal processor of the device can be configured to: calculate a phase difference between the first and the second microphone signals based on the predefined distance, calculate an angular distance between directions of arrival of the source signals and a desired capture direction based on the phase difference; and calculate directional-filter coefficients based on the angular distance. The signal processor can filter undesired source signals from an output of the signal processor based on the directional-filter coefficients.
The signal processor can be configured to calculate the phase difference by calculating phase differences, between the first and second microphone signals, for a particular short-time frame, across a plurality of discrete subbands of the first and second microphone signals. The signal processor can be configured to calculate the angular distance by calculating angular distances, for a particular short-time frame, across a plurality of discrete subbands of the first and second microphone signals, by applying a trigonometric function to phase differences calculated by the signal processor. The signal processor can be configured to calculate direction-filter coefficients, for a particular short-time frame, across a plurality of discrete subbands of the first and second microphone signals, by applying a trigonometric function to angular distances calculated by the signal processor.
The signal processor can be configured to replace each of the directional-filter coefficients of a first range of subbands with an average value of the directional-filter coefficients for a second range of subbands. The first range of frequency subbands can correspond with 80˜400 Hz, and the second range of frequency subbands can correspond with 2˜3 kHz.
The signal processor can be configured to calculate a global gain using an average of relatively robust subband directional-filter coefficients, and can apply this average as the global to all the calculated subband directional-filter coefficients. The relatively robust subband directional-filter coefficients can correspond with 1˜7 kHz.
The first and the second microphones can be omnidirectional microphones, and the predefined distance can be between 0.5 and 50 cm. The predefined distance can be about 2 cm, and can be 1.7 cm.
The signal processor can be configured to process the first and second microphone signals according to the following equations: X1(n,k)=S1(n,k)·exp(jφ1)+V1(n,k), and X2(n,k)=S2(n,k)·exp(jφ2)+V2(n,k). Here, n denotes a short-time frame, k denotes a subband, and X1,2, S1,2, V1,2 and φ1,2 denote, respectively, the microphone signals, signal amplitudes, noise, and phases of the first and second microphone signals. The signal processor can also be configured to calculate the phase difference according to the following equation: Δφ(n,k)=atan 2{Im[X1(n,k)], Re[X1(n,k)]}−atan 2{Im[X2(n,k)], Re[X2(n,k)]}.
The signal processor can be configured to calculate the angular difference according to the following equation:
The signal processor can be configured to calculate the directional-filter coefficients according to the following equation: G(n,k)={0.5+0.5·cos [β·Δθ(n,k)[}α. Here, G(n,k) denotes the directional coefficient for frame n and subband k, β is a parameter for beamwidth control, and α is a suppression factor.
The signal processor can be configured to improve low-frequency robustness of the calculate directional coefficients by replacing the directional-filter coefficients of a first range of subbands with an average value of the directional-filter coefficients for a second range of subbands. Here, the second range of subbands can include a range of frequencies that are higher than that of the first range of subbands, and the replacing can be in accordance with the following equation: =G(n,k80˜400 Hz)=
The signal processor can be configured to reduce spatial aliasing by calculating a global gain using an average of relatively robust subband directional-filter coefficients, and applying this average as the global to all the calculated subband directional-filter coefficients. Here, the relatively robust subband directional-filter coefficients can correspond with 1˜7 kHz.
A device can also include a first microphone and a second microphone that are separated by a predefined distance, and that are configured to receive source signals and output respective first and second microphone signals based on received source signals. Signal processing means can perform: calculating a phase difference between the first and the second microphone signals based on the predefined distance, calculating an angular distance between directions of arrival of the source signals and a desired capture direction based on the phase difference, and calculating directional-filter coefficients based on the angular distance. The signal processing means can filter undesired source signals from an output thereof based on the directional-filter coefficients.
A method can include receiving, from a first microphone and a second microphone that are separated by a predefined distance, and that are configured to receive source signals, respective first and second microphone signals based on received source signals. A phase difference between the first and the second microphone signals can be calculated based on the predefined distance. An angular distance between directions of arrival of the source signals and a desired capture direction can be calculated based on the phase difference. Directional-filter coefficients can be calculated based on the angular distance. Undesired source signals can be filtered from an output based on the directional-filter coefficients. One or more non-transitory computer readable storage mediums encoded with software comprising computer executable instructions, which when executed by one or more processors, can execute this method.
The foregoing paragraphs have been provided by way of general introduction. The described embodiments, together with the attendant advantages thereof, will be best understood by reference to the following detailed description taken in conjunction with the accompanying drawings.
A more complete appreciation of the disclosure and many of the attendant advantages thereof will be readily obtained as the same becomes better understood by reference to the following detailed description when considered in connection with the accompanying drawings, wherein:
In the drawings, like reference numerals/identifiers designate identical or corresponding parts throughout the several views. Further, the use singular terms, such as “a,” “an,” and the like, carry the meaning of “one or more,” unless expressly stated otherwise.
The following is a listing of references referred to in this application.
A single directional microphone can suppress some environmental interferences. However, the suppression performance is very limited, and it can be difficult to integrate a directional microphone in some systems, such as a laptop computer. Further, such systems can be inherently sensitive to mechanical vibrations.
In a conventional system, a microphone array combined with beamforming algorithms can be utilized, as in document [1]. Microphone array beamformers weight and sum all signals from the microphones, and apply post-filtering techniques to form a spatial beam that can extract the desired voices coming from the desired direction, and at the same time, suppress the spatial interferences coming from other directions.
In personal and mobile voice communication devices, it is desired to have compact microphone arrays with few microphones to achieve directional filtering. Therefore, there have been many studies on compact dual-microphone array beamforming techniques. See, e.g., documents [2]-[6]. Theses documents discuss differential array beamforming (see documents [2]-[5]), superdirectional beamforming (see document [1]), adaptive beamforming (see document [4]), and adaptive beamforming and post filtering (see document [6]).
A dual-microphone array can be implemented in a laptop, such as a ThinkPad W510, which is manufactured by Lenovo (Registered Mark) (Lenovo Group Limited). The ThinkPad W510 includes a dual-microphone array with an audio signal processor provided by Conexant Systems, Inc. An algorithm for the audio signal processor, a dual-microphone array beamforming technique, is presented in document [7].
A traditional dual microphone array beamforming technique can suffer the following drawbacks. There may be high computational complexity or relatively long convergence time, when dealing with broad band audio signals. Beamforming performance and voice quality can degrade when there are microphone deviations (microphone sensitivity/phase mismatch). There can be either microphone self-noise amplification or cut-off at low frequencies. Conventionally, microphone calibration or robust algorithm design are required (see, e.g., documents [5] and [7]-[9]), which may further increase algorithm complexity.
Prior and conventional efforts concentrate on advanced signal models, more optimal array geometries, and more complicated, but intelligent, algorithms to achieve better array processing performance. In the following discussion, an implementation of a simplified signal model, a small microphone array consisting of only two omnidirectional elements, and a low-complexity interference suppression algorithm is described to provide a easy-to-implement and high-performance solution for practical speech communication devices.
Low-Complexity Spatial Interference Suppressor
An algorithm is operated in a short-time frequency domain. For each short-time frame and frequency subband, dual-microphone phase differences are estimated and angular distances between directions of arrival (DOAs) of source signals and the desired capture direction are calculated in a simple, but effective way. Then, the directional-filter coefficients are computed based on the angular distance information, and are applied to the output of the microphone signal processing module, preserving the sound from the desired direction and attenuating the sound from other directions. This directional filtering concept is similar to conventional beamforming methods, but it can be designed and implemented in an efficient measure, given the following signal-model assumption.
In a room acoustic environment, two captured time-domain microphone signals, comprising both the sound from the desired sources and other interfering sounds from other directions (the sound from undesired sources, early reflections, and sensor noise), are decomposed into short-time frequency subbands using analysis filter banks. In order to design an efficient and practical interference suppression algorithm, all of the source signals are assumed to be W-disjoint orthogonal (WDO) for each short-time subband. That is, signals do not overlap for most of the short-time subbands. This assumption is simple, but is reasonable for frequency-domain instantaneous speech mixtures, even in a reverberant environment as described in document [10].
Based on the simplified signal model mentioned above, the microphone signals in short-time frame n and subband k, which can consist of one major source signal and noise, can be written as:
X
1(n,k)=S1(n,k)·exp(jφ1)+V1(n,k), (1)
X
2(n,k)=S2(n,k)·exp(jφ2)+V2(n,k), (2)
where X1,2, S1,2, V1,2 and φ1,2 denote the captured microphone signals, signal amplitudes, noise, and phases of the captured signals at the first and the second microphones, respectively.
When the signal to noise ratio in frame n and subband k is sufficiently high, the phase difference between two microphone channels, Δφ(n,k), can be simply estimated by
Δφ(n,k)=atan 2{Im[X1(n,k)],Re[X1(n,k)]}−atan 2{Im[X2(n,k)],Re[X2(n,k)]}. (3)
Then, the angular distance Δθ(n,k) between source DOAs and the desired direction θ0 are calculated using a triangular property:
where c is the speed of sound, fk is the center frequency of subband k, and d is the distance between two microphones.
In speech communication devices (laptops, telepresence systems, etc.), dual-microphone arrays can be placed in a broadside style with front direction (θ0=0) as the desired direction. In this case, the estimation of the angular distance (4) can be further simplified as:
When the signals incident angle is close to zero (in front), which should be preserved, this approximated solution could estimate Δθ(n,k) fairly precisely, due to the fact that arcsin(θ)≈θ, if the incident angle θ is close to zero. When signals arrive from out-beam directions, the estimating bias for Δθ(n,k) increases. However, since all out-beam signals should be suppressed, precise DOA estimations for these out-beam signals are unnecessary. The approximation error of (5) as a function of different incident angle and frequency bins is illustrated in
Using the obtained angular distance information, the directional-filter coefficients can be obtained by:
G(n,k)={0.5+0.5·cos [β·Δθ(n,k)]}α, (6)
where G(n,k) denotes the directional coefficient for frame n and subband k, which is multiplied to the output of the microphone signal processor (e.g. the output of a single-channel acoustic echo canceller). When the signal is from the desired direction, G(n,k) is approximately a unit value and the signal will be preserved. Otherwise, G(n,k) is low, and the sound is suppressed. β is a parameter for beamwidth control. The higher β, the narrower beamwidth. β can also be used for finding the tradeoff between the beamwidth and algorithm robustness. With lower β, the beam is wider, but in the meantime, the algorithm will be more robust against microphone phase mismatch and desired signal cancellation. α is a suppression factor. A higher α will lead to more aggressive attenuation of the signals from undesired directions. α can also be a variable parameter, which is automatically adjusted in the run time. For instance, on the one hand, when in-beam signals are detected, i.e., Δθ(n,k)≈0 for many subbands at the same short-time frame, α can be set lower to avoid desired-signal cancelling. On the other hand, when in-beam signals are detected only for a few subbands, α can be set higher to suppress environmental interferences more aggressively.
In order to avoid music-tone artifacts in the filtered speech signals, time smoothing and frequency smoothing can be applied to all the obtained coefficients.
Time smoothing is normally implemented using a one-pole low-pass filter, with a variable time constant, e.g., when in-beam signals are detected, the time constant can be set lower (resulting in faster adaptation), otherwise, the time constant can be set higher (resulting in slower adaptation). In this way, a desired speech signal can be better protected, especially for weak speech onset and tail segments.
A simple frequency smoothing can be realized by just (only) limiting the differences between the adjacent subband coefficients below a given threshold (e.g., 12 dB). Other frequency smoothing techniques, which normally use psychoacoustic theories, can also be applied here.
The directional-filter coefficients can be applied to the output of the microphone signal processor for each short-time frame and subband, and the resultant spatial-filtered time-domain signal can be recovered using a synthesis filter bank.
The above process uses only microphone phase information. Therefore, it is robust against all sorts of microphone amplitude mismatches. This can be an advantage over most traditional beamforming methods, where both the phase and amplitude information are needed.
Improving Low-Frequency Robustness
In some personal speech communication devices, small arrays with very short microphone distance (e.g., 1.7 cm) are desired, since they require a small space and can be installed easily. However, from (5), it can be seen that, when microphone distances are very short and microphone phase mismatch exists, the angle estimation for low-frequency subbands may have large errors that lead to poor algorithm robustness, even though the phase mismatch at these subbands is very little.
From an experimental study conducted in an office room environment, it was seen that, using a small array with an approximate 1.7 cm microphone distance, the angle estimation for frequency subbands of above 400 Hz are fairly accurate and robust against normal microphone phase mismatch. Therefore, to deal with a low-frequency poor robustness problem, an averaged filter coefficient is selected across frequency subbands of 2˜3 kHz (the most robust frequency range for speech signals from experiments), to replace the coefficients of low-frequency subbands of 80˜400 Hz.
G(n,k80˜400 Hz)=
where
Reducing Spatial Aliasing
In theory, if a half of the wavelength of one subband sound signal is shorter than the microphone distance, spatial aliasing occurs, and the angle estimator may yield ambiguous results. If the microphone distance is around 2 cm, for instance, all subbands of frequency above 8 kHz will have a spatial aliasing issue. To address this problem, for each short-time frame, a global gain is calculated using the relatively robust subband coefficients, and this gain is applied to all the obtained subband coefficients, i.e.,
G(n,k)=G(n,k)·
In this way, improper directional-filter coefficients resulting from an ambiguity in angle estimations at high frequencies can be effectively addressed.
A microphone array according to exemplary aspects has a small form factor containing 2 microphones, which can only require a small installation space and be easy to integrate. A signal processing algorithm can have a relatively low computational complexity, with a short convergence time. The microphone array can be more robust to a microphone sensitivity mismatch, compared to traditional beamforming techniques. The microphone array can be integrated into the existing echo canceller and noise suppressor in telepresence systems. The microphone array can also work for a wide frequency range and yield good audio quality, avoiding microphone self-noise amplification or desired signal cancelling at low-frequency subbands and reducing spatial aliasing at high-frequency subbands.
A real-time implementation and evaluation was performed with a digital signal processing system, which includes analog to digital signal converters and analyzers. Objective and subjective tests in both anechoic and reverberant environments show better sound quality than a ThinkPad W510 solution, with satisfactory interference suppression performance.
Based on the short-time frequency-domain signal model, a low-complexity but effective dual-microphone array interference suppression has been designed and implemented. A desired sound extraction and interference suppression performance is provided. In addition, the implementation is robust against low-frequency noise amplification and high-frequency spatial alias, which are inherent issues in traditional beamforming approaches.
An exemplary implementation of the aforementioned techniques and/or processes can be embodied in a laptop computer, such as that schematically illustrated in
The laptop computer can include a display, a keyboard, and a track pad. The laptop can include speakers (e.g., SPK 1 and SPK 2) for stereo audio reproduction (or audio reproduction of mono or more than two channel audio reproduction). Additional speakers can also be provided. The laptop can also include a pair of microphones. Exemplary pairs of microphones are shown in
The above-discussed microphones can be omnidirectional microphones, which are displaced by a distance L. The distance L can be 1.7 cm. The distance L is variable between 0.5 and 50 cm, and the distance L is preferably around or about 2 cm (e.g., between 1.5 and 2.4 cm).
As shown in
The microprocessor or aspects thereof, in an alternate embodiment, can include or exclusively include a logic device for augmenting or fully implementing this disclosure. Such a logic device includes, but is not limited to, an application-specific integrated circuit (ASIC), a field programmable gate array (FPGA), a generic-array of logic (GAL), and their equivalents. The microprocessor can be a separate device or a single processing mechanism. Further, this disclosure can benefit form parallel processing capabilities of a multi-cored CPU.
In another aspect, results of processing in accordance with this disclosure can be displayed via a display controller to a monitor. The display controller would then preferably include at least one graphic processing unit, which can be provided by a plurality of graphics processing cores, for improved computational efficiency. Additionally, an I/O (input/output) interface is provided for inputting signals and/or data from microphones (MICS) 1, 2 . . . N and/or cameras (CAMS) 1, 2 . . . M, and for outputting control signals to one or more actuators to control, e.g., a directional alignment of one ore more of the microphones and/or cameras.
Further, as to other input devices, the same can be connected to the I/O interface as a peripheral. For example, a keyboard or a pointing device for controlling parameters of the various processes and algorithms of this disclosure can be connected to the I/O interface to provide additional functionality and configuration options, or control display characteristics. Moreover, the monitor can be provided with a touch-sensitive interface for providing a command/instruction interface.
The above-noted components can be coupled to a network, such as the Internet or a local intranet, via a network interface for the transmission or reception of data, including controllable parameters. A central BUS is provided to connect the above hardware components together and provides at least one path for digital communication there between.
An angular distance is calculated at S708 based on the calculated phase different, and, at S710, directional-filter coefficients are obtained. See equations (4)-(6). Preferably, at S710 also includes (either performed concurrently, as a part of, or after obtaining the direction-filter coefficients) replacing low-frequency coefficients to improve low-frequency robustness. See equation (7). Also preferably, at S712, when a microphone distance is around 2 cm, all subbands of frequency above 8 kHz will have spatial aliasing issues. For each short-time frame, a global gain is calculated using the relatively robust subband coefficients, and is applied to all of the obtained subband coefficients at S712. See equation (8). The resulting coefficients are then applied to microphone outputs to achieve the above-discussed results.
Exemplary implementations have been described. Nonetheless, various modifications may be made without departing from the spirit and scope of this disclosure. For example, advantageous results may be achieved if the steps of the disclosed techniques were performed in a different sequence, if components in the disclosed systems were combined in a different manner, or if the components were replaced or supplemented by other components. The functions, processes and algorithms described herein may be performed in hardware or software executed by hardware, including computer processors and/or programmable circuits configured to execute program code and/or computer instructions to execute the functions, processes and algorithms described herein. Additionally, some implementations may be performed on modules or hardware not identical to those described. Accordingly, other implementations are within the scope that may be claimed.