1. Field
This disclosure relates to audio signal processing.
2. Background
Many activities that were previously performed in quiet office or home environments are being performed today in acoustically variable situations like a car, a street, or a café. For example, a person may desire to communicate with another person using a voice communication channel. The channel may be provided, for example, by a mobile wireless handset or headset, a walkie-talkie, a two-way radio, a car-kit, or another communications device. Consequently, a substantial amount of voice communication is taking place using portable audio sensing devices (e.g., smartphones, handsets, and/or headsets) in environments where users are surrounded by other people, with the kind of noise content that is typically encountered where people tend to gather. Such noise tends to distract or annoy a user at the far end of a telephone conversation. Moreover, many standard automated business transactions (e.g., account balance or stock quote checks) employ voice-recognition-based data inquiry, and the accuracy of these systems may be significantly impeded by interfering noise.
For applications in which communication occurs in noisy environments, it may be desirable to separate a desired speech signal from background noise. Noise may be defined as the combination of all signals interfering with or otherwise degrading the desired signal. Background noise may include numerous noise signals generated within the acoustic environment, such as background conversations of other people, as well as reflections and reverberation generated from the desired signal and/or any of the other signals. Unless the desired speech signal is separated from the background noise, it may be difficult to make reliable and efficient use of it. In one particular example, a speech signal is generated in a noisy environment, and speech processing methods are used to separate the speech signal from the environmental noise.
Noise encountered in a mobile environment may include a variety of different components, such as competing talkers, music, babble, street noise, and/or airport noise. As the signature of such noise is typically nonstationary and close to the user's own frequency signature, the noise may be hard to model using traditional single microphone or fixed beamforming type methods. Single-microphone noise reduction techniques typically require significant parameter tuning to achieve optimal performance. For example, a suitable noise reference may not be directly available in such cases, and it may be necessary to derive a noise reference indirectly. Therefore multiple-microphone based advanced signal processing may be desirable to support the use of mobile devices for voice communications in noisy environments.
A method of processing an audio signal according to a general configuration includes calculating, based on information from a first plurality of frames of the audio signal, a series of values of a first voice activity measure. This method also includes calculating, based on information from a second plurality of frames of the audio signal, a series of values of a second voice activity measure that is different from the first voice activity measure. This method also includes calculating, based on the series of values of the first voice activity measure, a boundary value of the first voice activity measure. This method also includes producing, based on the series of values of the first voice activity measure, the series of values of the second voice activity measure, and the calculated boundary value of the first voice activity measure, a series of combined voice activity decisions. Computer-readable storage media (e.g., non-transitory media) having tangible features that cause a machine reading the features to perform such a method are also disclosed.
An apparatus for processing an audio signal according to a general configuration includes means for calculating a series of values of a first voice activity measure, based on information from a first plurality of frames of the audio signal, and means for calculating a series of values of a second voice activity measure that is different from the first voice activity measure, based on information from a second plurality of frames of the audio signal. This apparatus also includes means for calculating a boundary value of the first voice activity measure, based on the series of values of the first voice activity measure, and means for producing a series of combined voice activity decisions, based on the series of values of the first voice activity measure, the series of values of the second voice activity measure, and the calculated boundary value of the first voice activity measure.
An apparatus for processing an audio signal according to another general configuration includes a first calculator configured to calculate a series of values of a first voice activity measure, based on information from a first plurality of frames of the audio signal, and a second calculator configured to calculate a series of values of a second voice activity measure that is different from the first voice activity measure, based on information from a second plurality of frames of the audio signal. This apparatus also includes a boundary value calculator configured to calculate a boundary value of the first voice activity measure, based on the series of values of the first voice activity measure, and a decision module configured to produce a series of combined voice activity decisions, based on the series of values of the first voice activity measure, the series of values of the second voice activity measure, and the calculated boundary value of the first voice activity measure.
The techniques disclosed herein may be used to improve voice activity detection (VAD) in order to enhance speech processing, such as voice coding. The disclosed VAD techniques may be used to improve the accuracy and reliability of voice detection, and thus, to improve functions that depend on VAD, such as noise reduction, echo cancellation, rate coding and the like. Such improvement may be achieved, for example, by using VAD information that may be provided from one or more separate devices. The VAD information may be generated using multiple microphones or other sensor modalities to provide a more accurate voice activity detector.
Use of a VAD as described herein may be expected to reduce speech processing errors that are often experienced in traditional VAD, particularly in low signal-to-noise-ratio (SNR) scenarios, in non-stationary noise and competing voices cases, and other cases where voice may be present. In addition, a target voice may be identified, and such a detector may be used to provide a reliable estimation of target voice activity. It may be desirable to use VAD information to control vocoder functions, such as noise estimation update, echo cancellation (EC), rate-control, and the like. A more reliable and accurate VAD can be used to improve speech processing functions such as the following: noise reduction (NR) (i.e., with more reliable VAD, higher NR may be performed in non-voice segments); voice and non-voiced segment estimation; echo cancellation (EC); improved double detection schemes; and rate coding improvements which allow more aggressive rate coding schemes (for example, a lower rate for non-voice segments).
Unless expressly limited by its context, the term “signal” is used herein to indicate any of its ordinary meanings, including a state of a memory location (or set of memory locations) as expressed on a wire, bus, or other transmission medium. Unless expressly limited by its context, the term “generating” is used herein to indicate any of its ordinary meanings, such as computing or otherwise producing. Unless expressly limited by its context, the term “calculating” is used herein to indicate any of its ordinary meanings, such as computing, evaluating, smoothing, and/or selecting from a plurality of values. Unless expressly limited by its context, the term “obtaining” is used to indicate any of its ordinary meanings, such as calculating, deriving, receiving (e.g., from an external device), and/or retrieving (e.g., from an array of storage elements). Unless expressly limited by its context, the term “selecting” is used to indicate any of its ordinary meanings, such as identifying, indicating, applying, and/or using at least one, and fewer than all, of a set of two or more. Where the term “comprising” is used in the present description and claims, it does not exclude other elements or operations. The term “based on” (as in “A is based on B”) is used to indicate any of its ordinary meanings, including the cases (i) “derived from” (e.g., “B is a precursor of A”), (ii) “based on at least” (e.g., “A is based on at least B”) and, if appropriate in the particular context, (iii) “equal to” (e.g., “A is equal to B”). Similarly, the term “in response to” is used to indicate any of its ordinary meanings, including “in response to at least.”
References to a “location” of a microphone of a multi-microphone audio sensing device indicate the location of the center of an acoustically sensitive face of the microphone, unless otherwise indicated by the context. The term “channel” is used at times to indicate a signal path and at other times to indicate a signal carried by such a path, according to the particular context. Unless otherwise indicated, the term “series” is used to indicate a sequence of two or more items. The term “logarithm” is used to indicate the base-ten logarithm, although extensions of such an operation to other bases are within the scope of this disclosure. The term “frequency component” is used to indicate one among a set of frequencies or frequency bands of a signal, such as a sample of a frequency domain representation of the signal (e.g., as produced by a fast Fourier transform) or a subband of the signal (e.g., a Bark scale or mel scale subband). Unless the context indicates otherwise, the term “offset” is used herein as an antonym of the term “onset.”
Unless indicated otherwise, any disclosure of an operation of an apparatus having a particular feature is also expressly intended to disclose a method having an analogous feature (and vice versa), and any disclosure of an operation of an apparatus according to a particular configuration is also expressly intended to disclose a method according to an analogous configuration (and vice versa). The term “configuration” may be used in reference to a method, apparatus, and/or system as indicated by its particular context. The terms “method,” “process,” “procedure,” and “technique” are used generically and interchangeably unless otherwise indicated by the particular context. The terms “apparatus” and “device” are also used generically and interchangeably unless otherwise indicated by the particular context. The terms “element” and “module” are typically used to indicate a portion of a greater configuration. Unless expressly limited by its context, the term “system” is used herein to indicate any of its ordinary meanings, including “a group of elements that interact to serve a common purpose.”
Any incorporation by reference of a portion of a document shall also be understood to incorporate definitions of terms or variables that are referenced within the portion, where such definitions appear elsewhere in the document, as well as any figures referenced in the incorporated portion. Unless initially introduced by a definite article, an ordinal term (e.g., “first,” “second,” “third,” etc.) used to modify a claim element does not by itself indicate any priority or order of the claim element with respect to another, but rather merely distinguishes the claim element from another claim element having a same name (but for use of the ordinal term). Unless expressly limited by its context, each of the terms “plurality” and “set” is used herein to indicate an integer quantity that is greater than one.
A method as described herein may be configured to process the captured signal as a series of segments. Typical segment lengths range from about five or ten milliseconds to about forty or fifty milliseconds, and the segments may be overlapping (e.g., with adjacent segments overlapping by 25% or 50%) or nonoverlapping. In one particular example, the signal is divided into a series of nonoverlapping segments or “frames”, each having a length of ten milliseconds. A segment as processed by such a method may also be a segment (i.e., a “subframe”) of a larger segment as processed by a different operation, or vice versa.
Existing dual-microphone noise suppression solutions may be insufficiently robust to holding angle variability and/or microphone gain calibration mismatch. The present disclosure provides ways to resolve this issue. Several novel ideas are described herein that can lead to better voice activity detection and/or noise suppression performance.
Features of a configuration as described herein may include one or more (possibly all) of the following: low-frequency noise suppression (e.g., including inter-microphone subtraction and/or spatial processing); normalization of the VAD test statistics to maximize discrimination power for various holding angles and microphone gain mismatch; noise reference combination logic; residual noise suppression based on phase and proximity information in each time-frequency cell as well as frame-by-frame voice activity information; and residual noise suppression control based on one or more noise characteristics (for example, spectral flatness measure of the estimated noise). Each of these items is discussed in the following sections.
It is also expressly noted that any one or more of these tasks shown in
The class of spatially selective filtering operations includes directionally selective filtering operations, such as beamforming and/or blind source separation, and distance-selective filtering operations, such as operations based on source proximity. Such operations can achieve substantial noise reduction with negligible voice impairments.
A typical example of a spatially selective filtering operation includes computing adaptive filters (e.g., based on one or more suitable voice activity detection signals) to remove desired speech to generate a noise channel and/or to remove unwanted noise by performing subtraction of a spatial noise reference and a primary microphone signal.
Removal of low-frequency noise (e.g., noise in a frequency range of 0-500 Hz) poses unique challenges. To obtain a frequency resolution that is sufficient to support discrimination of valleys and peaks related to the harmonic voiced speech structure, it may be desirable to use a fast Fourier transform (FFT) having a length of at least 256 (e.g., for a narrowband signal having a range of about 0-4 kHz). Fourier-domain circular convolution problems may compel the use of short filters, which may hamper effective post-processing of such a signal. The effectiveness of a spatially selective filtering operation may also be limited in the low-frequency range by the microphone distance and in the high frequencies by spatial aliasing. For example, spatial filtering is typically largely ineffective in the range of 0-500 Hz.
During a typical use of a handheld device, the device may be held in various orientations with respect to the user's mouth. The SNR may be expected to differ from one microphone to another for most handset holding angles. However, the distributed noise level may be expected to remain approximately equal from one microphone to another. Consequently, inter-microphone channel subtraction may be expected to improve SNR in the primary microphone channel.
Low-frequency noise suppression may include inter-microphone subtraction and/or spatial processing. One example of a method of reducing noise in a multichannel audio signal includes using an inter-microphone difference for frequencies less than 500 Hz, and using a spatially selective filtering operation (e.g., a directionally selective operation, such as a beamformer) for frequencies greater than 500 Hz.
It may be desirable to use an adaptive gain calibration filter to avoid a gain mismatch between two microphone channels. Such a filter may be calculated according to a low-frequency gain difference between the signals from the primary and secondary microphones. For example, a gain calibration filter M may be obtained over a speech-inactive interval according to an expression such as
where ω denotes frequency, Y1 denotes the primary microphone channel, Y2 denotes the secondary microphone channel, and ∥·∥ denotes a vector norm operation (e.g., an L2-norm).
In most applications the secondary microphone channel may be expected to contain some voice energy, such that the overall voice channel may be attenuated by a simple subtraction process. Consequently, it may be desirable to introduce a make-up gain to scale the voice gain back to its original level. One example of such a process may be summarized by an expression such as
∥Yn(ω)∥=G*(∥Y1(ω)∥−∥M(ω)*Y2(ω)∥), (2)
where Yn denotes the resulting output channel and G denotes an adaptive voice make-up gain factor. The phase may be obtained from the original primary microphone signal.
The adaptive voice make-up gain factor G may be determined by low-frequency voice calibration over [0-500Hz] to avoid introducing reverberation. Voice make-up gain G can be obtained over a speech-active interval according to an expression such as
In the [0-500Hz] band, such inter-microphone subtraction may be preferred to an adaptive filtering scheme. For the typical microphone spacing employed on handset form factors, the low-frequency content (e.g., in the [0-500Hz] range) is usually highly correlated between channels, which may lead in fact to amplification or reverberation of low-frequency content. In a proposed scheme, the adaptive beamforming output Yn is overwritten with the inter-microphone subtraction module below 500 Hz. However, the adaptive null beamforming scheme also produces a noise reference, which is used in a post-processing stage.
Voice activity detection (VAD) is used to indicate the presence or absence of human speech in segments of an audio signal, which may also contain music, noise, or other sounds. Such discrimination of speech-active frames from speech-inactive frames is an important part of speech enhancement and speech coding, and voice activity detection is an important enabling technology for a variety of speech-based applications. For example, voice activity detection may be used to support applications such as voice coding and speech recognition. Voice activity detection may also be used to deactivate some processes during non-speech segments. Such deactivation may be used to avoid unnecessary coding and/or transmission of silent frames of the audio signal, saving on computation and network bandwidth. A method of voice activity detection (e.g., as described herein) is typically configured to iterate over each of a series of segments of an audio signal to indicate whether speech is present in the segment.
It may be desirable for a voice activity detection operation within a voice communications system to be able to detect voice activity in the presence of very diverse types of acoustic background noise. One difficulty in the detection of voice in noisy environments is the very low signal-to-noise ratios (SNRs) that are sometimes encountered. In these situations, it is often difficult to distinguish between voice and noise, music, or other sounds using known VAD techniques.
One example of a voice activity measure (also called a “test statistic”) that may be calculated from an audio signal is signal energy level. Another example of a voice activity measure is the number of zero crossings per frame (i.e., the number of times the sign of the value of the input audio signal changes from one sample to the next). Results of pitch estimation and detection algorithms may also be used to as voice activity measures, as well as results of algorithms that compute formants and/or cepstral coefficients to indicate the presence of voice. Further examples include voice activity measures based on SNR and voice activity measures based on likelihood ratio. Any suitable combination of two or more voice activity measures may also be employed.
A voice activity measure may be based on speech onset and/or offset. It may be desirable to perform detection of speech onsets and/or offsets based on the principle that a coherent and detectable energy change occurs over multiple frequencies at the onset and offset of speech. Such an energy change may be detected, for example, by computing first-order time derivatives of energy (i.e., rate of change of energy over time) over all frequency bands, for each of a number of different frequency components (e.g., subbands or bins). In such case, a speech onset may be indicated when a large number of frequency bands show a sharp increase in energy, and a speech offset may be indicated when a large number of frequency bands show a sharp decrease in energy. Additional description of voice activity measures based on speech onset and/or offset may be found in U.S. patent application Ser. No. 13/XXX,XXX, Attorney Docket No. 100839, filed Apr. 20, 2011, entitled “SYSTEMS, METHODS, AND APPARATUS FOR SPEECH FEATURE DETECTION.”
For an audio signal that has more than one channel, a voice activity measure may be based on a difference between the channels. Examples of voice activity measures that may be calculated from a multi-channel signal (e.g., a dual-channel signal) include measures based on a magnitude difference between channels (also called gain-difference-based, level-difference-based, or proximity-based measures) and measures based on phase differences between channels. For the phase-difference-based voice activity measure, the test statistic used in this example is the average number of frequency bins with the estimated DoA in the range of look direction (also called a phase coherency or directional coherency measure), where DoA may be calculated as a ratio of phase difference to frequency. For the magnitude-difference-based voice activity measure, the test statistic used in this example is the log RMS level difference between the primary and the secondary microphones. Additional description of voice activity measures based on magnitude and phase differences between channels may be found in U.S. Publ. Pat. Appl. No. 2010/00323652, entitled “SYSTEMS, METHODS, APPARATUS, AND COMPUTER-READABLE MEDIA FOR PHASE-BASED PROCESSING OF MULTICHANNEL SIGNAL.”
Another example of a magnitude-difference-based voice activity measure is a low-frequency proximity-based measure. Such a statistic may be calculated as a gain difference (e.g., log RMS level difference) between channels in a low-frequency region, such as below 1 kHz, below 900 Hz, or below 500 Hz.
A binary voice activity decision may be obtained by applying a threshold value to the voice activity measure value (also called a score). Such a measure may be compared to a threshold value to determine voice activity. For example, voice activity may be indicated by an energy level that is above a threshold, or a number of zero crossings that is above a threshold. Voice activity may also be determined by comparing frame energy of a primary microphone channel to an average frame energy.
It may be desirable to combine multiple voice activity measures to obtain a VAD decision. For example, it may be desirable to combine multiple voice activity decisions using AND and/or OR logic. The measures to be combined may have different resolutions in time (e.g., a value for every frame vs. every other frame).
As shown in
It may be desirable to combine the decisions of the onset and offset VAD operations with other VAD decisions using an OR operation. It may be desirable to combine the decisions of the low-frequency proximity-based VAD operation with other VAD decisions using an OR operation.
It may be desirable to vary a voice activity measure or corresponding threshold based on the value of another voice activity measure. Onset and/or offset detection may also be used to vary a gain of another VAD signal, such as a magnitude-difference-based measure and/or a phase-difference-based measure. For example, the VAD statistic may be multiplied by a factor greater than one or increased by a bias value greater than zero (before thresholding), in response to onset and/or offset indication. In one such example, a phase-based VAD statistic (e.g., a coherency measure) is multiplied by a factor ph_mult>1, and a gain-based VAD statistic (e.g., a difference between channel levels) is multiplied by a factor pd_mult>1, if onset detection or offset detection is indicated for the segment. Examples of values for ph_mult include 2, 3, 3.5, 3.8, 4, and 4.5. Examples of values for pd_mult include 1.2, 1.5, 1.7, and 2.0. Alternatively, one or more such statistics may be attenuated (e.g., multiplied by a factor less than one), in response to a lack of onset and/or offset detection in the segment. In general, any method of biasing the statistic in response to onset and/or offset detection state may be used (e.g., adding a positive bias value in response to detection or a negative bias value in response to lack of detection, raising or lowering a threshold value for the test statistic according to the onset and/or offset detection, and/or otherwise modifying a relation between the test statistic and the corresponding threshold).
It may be desirable for the final VAD decision to include results from a single-channel VAD operation (e.g., comparison of frame energy of a primary microphone channel to an average frame energy). In such case, it may be desirable to combine the decisions of the single-channel VAD operation with other VAD decisions using an OR operation. In another example, a VAD decision that is based on differences between channels is combined with the value (single-channel VAD ||onset VAD || offset VAD) using an AND operation.
By combining voice activity measures that are based on different features of the signal (e.g., proximity, direction of arrival, onset/offset, SNR), a fairly good frame-by-frame VAD can be obtained. Because every VAD has false alarms and misses, it may be risky to suppress the signal if the final combined VAD indicates there is no speech. But if the suppression is performed only if all the VADs including single-channel VAD, proximity VAD, phase-based VAD, and onset/offset VAD indicates there is no speech, it may be expected to be reasonably safe. A proposed module T120 as shown in the block diagram of
Although dual-channel VADs are in general more accurate than single-channel techniques, they are typically highly dependent on the microphone gain mismatch and/or the angle at which the user is holding the phone. From
Another approach to dealing with a variable holding angle is to normalize the voice activity measures. Such an approach may be implemented to have the effect of making the VAD threshold a function of statistics that are related to the holding angle, without explicitly estimating the holding angle.
For offline processing, it may be desirable to obtain a suitable threshold by using a histogram. Specifically, by modeling the distribution of a voice activity measure as two Gaussians, a threshold value can be computed. But for real-time online processing, the histogram is typically inaccessible, and estimation of the histogram is often unreliable.
For online processing, a minimum statistics-based approach may be utilized. Normalization of the voice activity measures based on maximum and minimum statistics tracking may be used to maximize discrimination power, even for situations in which the holding angle varies and the gain responses of the microphones are not well-matched.
Task T100 may be configured to calculate the series of values of the first voice activity measure based on a relation between channels of the audio signal. For example, the first voice activity measure may be a phase-difference-based measure as described herein.
Likewise, task T200 may be configured to calculate the series of values of the second voice activity measure based on a relation between channels of the audio signal. For example, the second voice activity measure may be a magnitude-difference-based measure or a low-frequency proximity-based measure as described herein. Alternatively, task T200 may be configured to calculate the series of values of the second voice activity measure based on detection of speech onsets and/or offsets as described herein.
Task T300 may be configured to calculate the boundary value as a maximum value and/or as a minimum value. It may be desirable to implement task T300 to perform minimum tracking as in a minimum statistics algorithm. Such an implementation may include smoothing the voice activity measure, such as first-order IIR smoothing. The minimum of the smoothed measure may be selected from a rolling buffer of length D. For example, it may be desirable to maintain a buffer of D past voice activity measure values, and to track the minimum in this buffer. It may be desirable for the length D of the search window D to be large enough to include non-speech regions (i.e. to bridge active regions) but small enough to allow the detector to respond to nonstationary behavior. In another implementation, the minimum value may be calculated from minima of U sub-windows of length V (where U×V=D). In accordance with the minimum statistics algorithm, it may also be desirable to use a bias compensation factor to weight the boundary value.
As noted above, it may be desirable to use an implementation of the well-known minimum-statistics noise power spectrum estimation algorithm for minimum and maximum smoothed test-statistic tracking. For maximum test-statistic tracking, it may be desirable to use the same minimum-tracking algorithm. In this case, an input suitable for the algorithm may be obtained by subtracting the value of the voice activity measure from an arbitrary fixed large number. The operation may be reversed at the output of the algorithm to obtain the maximum tracked value.
Task T400 may be configured to compare the series of first and second voice activity measures to corresponding thresholds and to combine the resulting voice activity decisions to produce the series of combined voice activity decisions. Task T400 may be configured to warp the test statistics to make a minimum smoothed statistic value of zero and a maximum smoothed statistic value of one according to an expression such as the following:
where st denotes the input test statistic, st′ denotes the normalized test statistic, smin denotes the tracked minimum smoothed test statistic, sMAX denotes the tracked maximum smoothed test statistic, and ξ denotes the original (fixed) threshold. It is noted that the normalized test statistic st′ may have a value outside of the [0, 1] range due to the smoothing.
It is expressly contemplated and hereby disclosed that task T400 may be also be configured to implement the decision rule shown in expression (5) equivalently using the unnormalized test statistic st with an adaptive threshold as follows:
s
t
[ξ□=(sMAX−smin)ξ+smin] (6)
where (SMAX−Smin)ξ+smin denotes an adaptive threshold ξ□ that is equivalent to using a fixed threshold ξ with the normalized test statistic st′.
Although a phase-difference-based VAD is typically immune to differences in the gain responses of the microphones, a magnitude-difference-based VAD is typically highly sensitive to such a mismatch. A potential additional benefit of this scheme is that the normalized test statistic st′ is independent of microphone gain calibration. Such an approach may also reduce sensitivity of a gain-based measure to microphone gain response mismatch. For example, if the gain response of the secondary microphone is 1 dB higher than normal, then the current test statistic st, as well as the maximum statistic sMAX and the minimum statistic smin, will be 1 dB lower. Therefore, the normalized test statistic st′ will be the same.
One issue with the normalization in equation (5) is that although the whole distribution is well-normalized, the normalized score variance for noise-only intervals (black dots) increases relatively for the cases with narrow unnormalized test statistic range. For example,
or, equivalently,
s
t
(sMAX−smin)1-αξ+smin(8)
where 0≦α≦1 is a parameter controlling a trade-off between normalizing the score and inhibiting an increase in the variance of the noise statistics. It is noted that the normalized statistic in expression (7) is also independent of microphone gain variation, since sMAX−smin will be independent of microphone gains.
For a value of α=0, expressions (7) and (8) are equivalent to expressions (5) and (6), respectively. Such a distribution is shown in
The table in
As described above, a tracked minimum value and a tracked maximum value may be used to map a series of values of a voice activity measure to the range [0, 1] (with allowance for smoothing).
Task T400 may also be configured to normalize a voice activity measure based on speech onset and/or offset (e.g., as in expression (5) or (7) above). Alternatively, task T400 may be configured to adapt a threshold value corresponding to the number of frequency bands that are activated (i.e., that show a sharp increase or decrease in energy), such as according to expression (6) or (8) above.
For onset/offset detection, it may be desirable to track the maximum and minimum of the square of ΔE(k,n) (e.g., to track only positive values), where ΔE(k,n) denotes the time-derivative of energy for frequency k and frame n. It may also be desirable to track the maximum as the square of a clipped value of ΔE(k,n) (e.g., as the square of max[0, ΔE(k,n)] for onset and the square of min[0, ΔE(k,n)] for offset). While negative values of ΔE(k,n) for onset and positive values of ΔE(k,n) for offset may be useful for tracking noise fluctuation in minimum statistic tracking, they may be less useful in maximum statistic tracking. It may be expected that the maximum of onset/offset statistics will decrease slowly and rise rapidly.
It may be desirable for a speech processing system to intelligently combine estimation of non-stationary noise and estimation of stationary noise. Such a feature may help the system to avoid introducing artifacts, such as voice attenuation and/or musical noise. Examples of logic schemes for combining noise references (e.g., for combining estimates of stationary and nonstationary noise) are described below.
A method of reducing noise in a multichannel audio signal may include producing a combined noise estimate as a linear combination of at least one estimate of stationary noise within the multichannel signal and at least one estimate of nonstationary noise within the multichannel signal. If we denote the weight for each noise estimate Ni[n] as Wi[n], for example, the combined noise reference can be expressed as a linear combination ΣWi[n]*Ni[n] of weighted noise estimates, where ΣWi[n]≡1. The weights may be dependent on the decision between single- and dual-microphone modes, based on DoA estimation and the statistics on the input signal (e.g., normalized phase coherency measure). For example, it may be desirable to set the weight for a nonstationary noise reference which is based on spatial processing to zero for single-microphone mode. As for another example, it may be desirable for the weight for a VAD-based long-term noise estimate and/or nonstationary noise estimate to be higher for speech-inactive frames where the normalized phase coherency measure is low, because such estimates tend to be more reliable for speech-inactive frames.
It may be desirable in such a method for at least one of said weights to be based on an estimated direction of arrival of the multichannel signal. Additionally or alternatively, it may be desirable in such a method for the linear combination to be a linear combination of weighted noise estimates, and for at least one of said weights to be based on a phase coherency measure of the multichannel signal. Additionally or alternatively, it may be desirable in such a method to nonlinearly combine the combined noise estimate with a masked version of at least one channel of the multichannel signal.
One or more other noise estimates may then be combined with the previously obtained noise reference through a maximum operation T80C. For example, a time-frequency (TF) mask-based noise reference NRTF may be calculated by multiplying the inverse of the TF VAD with the input signal according to an expression such as:
NR
TF[n,k]=(1−TF—VAD[n,k])*s[n,k],
where s denotes the input signal, n denotes a time (e.g., frame) index, and k denotes a frequency (e.g., bin or subband) index. That is, if time frequency VAD is 1 for that time-frequency cell [n,k], the TF mask noise reference for the cell is 0; otherwise, it is the TF mask noise reference for the cell is the input cell itself. It may be desirable for such a TF mask noise reference to be combined with the other noise references through a maximum operation T80C rather than a linear combination.
A conventional dual-microphone noise reference system typically includes a spatial filtering stage followed by a post-processing stage. Such post-processing may include a spectral subtraction operation that subtracts a noise estimate as described herein (e.g., a combined noise estimate) from noisy speech frames in the frequency domain to produce a speech signal. In another example, such post-processing includes a Wiener filtering operation that reduces noise in the noisy speech frames, based on a noise estimate as described herein (e.g., a combined noise estimate), to produce the speech signal.
If more aggressive noise suppression is required, one can consider additional residual noise suppression based on time-frequency analysis and/or accurate VAD information. For example, a residual noise suppression method may be based on proximity information (e.g., inter-microphone magnitude difference) for each time-frequency cell, based on phase difference for each time-frequency cell, and/or based on frame-by-frame VAD information.
A residual noise suppression based on magnitude difference between two microphones may include a gain function based on the threshold and TF gain difference. Such a method is related to time-frequency (TF) gain-difference-based VAD, although it utilizes a soft decision rather than a hard decision.
It may be desirable to perform a method of reducing noise in a multichannel audio signal that includes calculating a plurality of gain factors, each based on a difference between two channels of the multichannel signal in a corresponding frequency component; and applying each of the calculated gain factors to the corresponding frequency component of at least one channel of the multichannel signal. Such a method may also include normalizing at least one of the gain factors based on a minimum value of the gain factor over time. Such normalizing may be based on a maximum value of the gain factor over time.
It may be desirable to perform a method of reducing noise in a multichannel audio signal that includes calculating a plurality of gain factors, each based on a power ratio between two channels of the multichannel signal in a corresponding frequency component during clean speech; and applying each of the calculated gain factors to the corresponding frequency component of at least one channel of the multichannel signal. In such a method, each of the gain factors may be based on a power ratio between two channels of the multichannel signal in a corresponding frequency component during noisy speech.
It may be desirable to perform a method of reducing noise in a multichannel audio signal that includes calculating a plurality of gain factors, each based on a relation between a phase difference between two channels of the multichannel signal in a corresponding frequency component and a desired look direction; and applying each of the calculated gain factors to the corresponding frequency component of at least one channel of the multichannel signal. Such a method may include varying the look direction according to a voice-activity-detection signal.
Analogously to the conventional frame-by-frame proximity VAD, the test statistic for TF proximity VAD in this example is the ratio between the magnitudes of two microphone signals in that TF cell. This statistic may then be normalized using the tracked maximum and minimum value of the magnitude ratio (e.g., as shown in equation (5) or (7) above).
If there is not enough computational budget, instead of computing the maximum and minimum for each band, the global maximum and minimum of log RMS level difference between two microphone signals can be used with an offset parameter whose value is dependent on frequency, frame-by-frame VAD decision, and/or holding angle. As for the frame-by-frame VAD decision, it may be desirable to use a higher value of the offset parameter for speech-active frames for a more robust decision. In this way, the information in other frequencies can be utilized.
It may be desirable to use SMAX−Smin of the proximity VAD in equation (7) as a representation of the holding angle. Since the high-frequency component of speech is likely to be attenuated more for an optimal holding angle (e.g., −30 degrees from the horizontal) as compared with the low-frequency component, it may be desirable to change the spectral tilt of the offset parameter or threshold according to the holding angle.
With this final test statistic st″ after normalization and offset addition, TF proximity VAD can be decided by comparing it with the threshold 4. In the residual noise suppression, it may be desirable to adopt a soft decision approach. For example, one possible gain rule is
G[k]=10−β(ξ′−s
with maximum (1.0) and minimum gain limitation, where ξ′ is typically set to be higher than the hard-decision VAD threshold 4. The tuning parameter β may be used to control the gain function roll-off, with a value that may depend on the scaling adopted for the test statistic and threshold.
Additionally or alternatively, a residual noise suppression based on magnitude difference between two microphones may include a gain function based on the TF gain difference for input signal and that of clean speech. While a gain function based on the threshold and TF gain difference as described in the previous section has its rational, the resulting gain may not be optimal in any sense. We propose an alternative gain function that is based on the assumptions that the ratio of the clean speech power in the primary and secondary microphones in each band would be the same and that the noise is diffused. This method does not directly estimate noise power, but only deals with the power ratio between two microphones of the input signal and that of the clean speech.
We denote the clean speech signal DFT coefficient in the primary microphone signal and in the secondary microphone signal as X1[k] and X2[k], respectively, where k is a frequency bin index. For a clean speech signal, the test statistic for TF proximity VAD is 20 log|X1[k]|−20 log|X2[k]|. For a given form factor, this test statistic is almost constant for each frequency bin. We express this statistic as 10 log f[k], where f[k] may be computed from the clean speech data.
We assume that time difference of arrival may be ignored, as this difference would typically be much less than the frame size. For a noisy speech signal Y, assuming that the noise is diffuse, we may express the primary and secondary microphone signals as Y1[k]=X1[k]+N[k] and Y2[k]=X2[k]+N[k], respectively. In this case the test statistic for TF proximity VAD is 20 log|Y1[k]|−20 log|Y2[k]|, or 10 log g[k], which can be measured. We assume that the noise is uncorrelated with the signals, and use the principle that the power of the sum of two uncorrelated signals is equal in general to the sum of the powers, to summarize these relations as follows:
Using the expressions above, we may obtain relations between powers of X1 and X2 and N, f, and g as follows:
where in practice the value of g[k] is limited to be higher than or equal to 1.0 and lower than or equal to f[k]. Then the gain applied to the primary microphone signal becomes
For the implementation, the value of parameter f[k] is likely to depend on the holding angle. Also, it may be desirable to use the minimum value of the proximity VAD test statistic to adjust g[k] (e.g., to cope with the microphone gain calibration mismatch). Also, it may be desirable to limit the gain G[k] to be higher than a certain minimum value which may be dependent on band SNR, frequency, and/or noise statistic. Note that this gain G[k] should be wisely combined with other processing gains, such as spatial filtering and post-processing.
Additionally or alternatively, a residual noise suppression scheme may be based on time-frequency phase-based VAD. Time-frequency phase VAD is calculated from the direction of arrival (DoA) estimation for each TF cell, along with the frame-by-frame VAD information and holding angle. DoA is estimated from the phase difference between two microphone signals in that band. If the observed phase difference indicates that the cos(DoA) value is out of [−1, 1] range, it is considered to be a missing observation. In this case, it may be desirable for the decision in that TF cell to follow the frame-by-frame VAD. Otherwise, the estimated DoA is examined if it is in the look direction range, and an appropriate gain is applied according to a relation (e.g., a comparison) between the look direction range and the estimated DoA.
It may be desirable to adjust the look direction according to frame-by-frame VAD information and/or estimated holding angle. For example, it may be desirable to use a wider look direction range when the VAD indicates active speech. Also, it may be desirable to use a wider look direction range when the maximum phase VAD test statistic is small (e.g., to allow more signal since the holding angle is not optimal).
If the TF phase-based VAD indicates a lack of speech activity in that TF cell, it may be desirable to suppress the signal by a certain amount which is dependent on the contrast in the phase-based VAD test statistics, i.e., sMAX−smin. It may be desirable to limit the gain to have a value higher than a certain minimum, which may also be dependent on band SNR and/or the noise statistic as noted above.
Using all the information about proximity, direction of arrival, onset/offset, and SNR, a fairly good frame-by-frame VAD can be obtained. It may be risky to suppress the signal if the final combined VAD indicates there is no speech, because every VAD has false alarms and misses. But if the suppression is performed only if all the VADs including single-channel VAD, proximity VAD, phase-based VAD, and onset/offset VAD indicates there is no speech, it may be expected to be reasonably safe. A proposed module T120 as shown in the block diagram of
It is known that different noise suppression techniques may have advantages for different types of noises. For example, spatial filtering is fairly good for competing talker noise, while the typical single-channel noise suppression is strong for stationary noise, especially white or pink noise. One size does not fit all, however. Tuning for competing talker noise, for example, is likely to result in modulated residual noise when the noise has a flat spectrum.
It may be desirable to control a residual noise suppression operation such that the control is based on noise characteristics. For example, it may be desirable to use different tuning parameters for residual noise suppression based on the noise statistics. One example of such a noise characteristic is a measure of the spectral flatness of the estimated noise. Such a measure may be used to control one or more tuning parameters, such as the aggressiveness of each noise suppression module in each frequency component (i.e., subband or bin).
It may be desirable to perform a method of reducing noise in a multichannel audio signal, wherein the method includes calculating a measure of spectral flatness of a noise component of the multichannel signal; and controlling a gain of at least one channel of the multichannel signal based on the calculated measure of spectral flatness.
There are a number of definitions for a spectral flatness measure. One popular measure proposed by Gray and Markel (A spectral-flatness measure for studying the autocorrelation method of linear prediction of speech signals, IEEE Trans. ASSP, 1974, vol. ASSP-22, no. 3, pp. 207-217) may be expressed as follows: Ξ=exp (−μ), where
and V(θ) is the normalized log spectrum. Since V(θ) is the normalized log spectrum, this expression is equivalent to
which is just the mean of the normalized log spectrum in the DFT domain and may be calculated as such. It may also be desirable to smooth the spectral flatness measure over time.
The smoothed spectral flatness measure may be used to control SNR-dependent aggressiveness function of the residual noise suppression and comb filtering. Other types of noise spectrum characteristics can be also used to control the noise suppression behavior.
In general, the VAD strategies described herein (e.g., as in the various implementations of method M100) may be implemented using one or more portable audio sensing devices that each has an array R100 of two or more microphones configured to receive acoustic signals. Examples of a portable audio sensing device that may be constructed to include such an array and to be used with such a VAD strategy for audio recording and/or voice communications applications include a telephone handset (e.g., a cellular telephone handset); a wired or wireless headset (e.g., a Bluetooth headset); a handheld audio and/or video recorder; a personal media player configured to record audio and/or video content; a personal digital assistant (PDA) or other handheld computing device; and a notebook computer, laptop computer, netbook computer, tablet computer, or other portable computing device. Other examples of audio sensing devices that may be constructed to include instances of array R100 and to be used with such a VAD strategy include set-top boxes and audio- and/or video-conferencing devices.
Each microphone of array R100 may have a response that is omnidirectional, bidirectional, or unidirectional (e.g., cardioid). The various types of microphones that may be used in array R100 include (without limitation) piezoelectric microphones, dynamic microphones, and electret microphones. In a device for portable voice communications, such as a handset or headset, the center-to-center spacing between adjacent microphones of array R100 is typically in the range of from about 1.5 cm to about 4.5 cm, although a larger spacing (e.g., up to 10 or 15 cm) is also possible in a device such as a handset or smartphone, and even larger spacings (e.g., up to 20, 25 or 30 cm or more) are possible in a device such as a tablet computer. In a hearing aid, the center-to-center spacing between adjacent microphones of array R100 may be as little as about 4 or 5 mm. The microphones of array R100 may be arranged along a line or, alternatively, such that their centers lie at the vertices of a two-dimensional (e.g., triangular) or three-dimensional shape. In general, however, the microphones of array R100 may be disposed in any configuration deemed suitable for the particular application.
During the operation of a multi-microphone audio sensing device, array R100 produces a multichannel signal in which each channel is based on the response of a corresponding one of the microphones to the acoustic environment. One microphone may receive a particular sound more directly than another microphone, such that the corresponding channels differ from one another to provide collectively a more complete representation of the acoustic environment than can be captured using a single microphone.
It may be desirable for array R100 to perform one or more processing operations on the signals produced by the microphones to produce the multichannel signal MCS that is processed by apparatus A100.
It may be desirable for array R100 to produce the multichannel signal as a digital signal, that is to say, as a sequence of samples. Array R210, for example, includes analog-to-digital converters (ADCs) C10a and C10b that are each arranged to sample the corresponding analog channel. Typical sampling rates for acoustic applications include 8 kHz, 12 kHz, 16 kHz, and other frequencies in the range of from about 8 to about 16 kHz, although sampling rates as high as about 44.1, 48, and 192 kHz may also be used. In this particular example, array R210 also includes digital preprocessing stages P20a and P20b that are each configured to perform one or more preprocessing operations (e.g., echo cancellation, noise reduction, and/or spectral shaping) on the corresponding digitized channel to produce the corresponding channels MCS-1, MCS-2 of multichannel signal MCS. Additionally or in the alternative, digital preprocessing stages P20a and P20b may be implemented to perform a frequency transform (e.g., an FFT or MDCT operation) on the corresponding digitized channel to produce the corresponding channels MCS10-1, MCS10-2 of multichannel signal MCS10 in the corresponding frequency domain. Although
It is expressly noted that the microphones may be implemented more generally as transducers sensitive to radiations or emissions other than sound. In one such example, the microphone pair is implemented as a pair of ultrasonic transducers (e.g., transducers sensitive to acoustic frequencies greater than fifteen, twenty, twenty-five, thirty, forty, or fifty kilohertz or more).
Chip/chipset CS10 includes a receiver which is configured to receive a radio-frequency (RF) communications signal (e.g., via antenna C40) and to decode and reproduce (e.g., via loudspeaker SP10) an audio signal encoded within the RF signal. Chip/chipset CS10 also includes a transmitter which is configured to encode an audio signal that is based on an output signal produced by apparatus A100 and to transmit an RF communications signal (e.g., via antenna C40) that describes the encoded audio signal. For example, one or more processors of chip/chipset CS10 may be configured to perform a noise reduction operation as described above on one or more channels of the multichannel signal such that the encoded audio signal is based on the noise-reduced signal. In this example, device D20 also includes a keypad C10 and display C20 to support user control and interaction.
The methods and apparatus disclosed herein may be applied generally in any transceiving and/or audio sensing application, including mobile or otherwise portable instances of such applications and/or sensing of signal components from far-field sources. For example, the range of configurations disclosed herein includes communications devices that reside in a wireless telephony communication system configured to employ a code-division multiple-access (CDMA) over-the-air interface. Nevertheless, it would be understood by those skilled in the art that a method and apparatus having features as described herein may reside in any of the various communication systems employing a wide range of technologies known to those of skill in the art, such as systems employing Voice over IP (VoIP) over wired and/or wireless (e.g., CDMA, TDMA, FDMA, and/or TD-SCDMA) transmission channels.
It is expressly contemplated and hereby disclosed that communications devices disclosed herein may be adapted for use in networks that are packet-switched (for example, wired and/or wireless networks arranged to carry audio transmissions according to protocols such as VoIP) and/or circuit-switched. It is also expressly contemplated and hereby disclosed that communications devices disclosed herein may be adapted for use in narrowband coding systems (e.g., systems that encode an audio frequency range of about four or five kilohertz) and/or for use in wideband coding systems (e.g., systems that encode audio frequencies greater than five kilohertz), including whole-band wideband coding systems and split-band wideband coding systems.
The foregoing presentation of the described configurations is provided to enable any person skilled in the art to make or use the methods and other structures disclosed herein. The flowcharts, block diagrams, and other structures shown and described herein are examples only, and other variants of these structures are also within the scope of the disclosure. Various modifications to these configurations are possible, and the generic principles presented herein may be applied to other configurations as well. Thus, the present disclosure is not intended to be limited to the configurations shown above but rather is to be accorded the widest scope consistent with the principles and novel features disclosed in any fashion herein, including in the attached claims as filed, which form a part of the original disclosure.
Those of skill in the art will understand that information and signals may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits, and symbols that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
Important design requirements for implementation of a configuration as disclosed herein may include minimizing processing delay and/or computational complexity (typically measured in millions of instructions per second or MIPS), especially for computation-intensive applications, such as playback of compressed audio or audiovisual information (e.g., a file or stream encoded according to a compression format, such as one of the examples identified herein) or applications for wideband communications (e.g., voice communications at sampling rates higher than eight kilohertz, such as 12, 16, 44.1, 48, or 192 kHz).
Goals of a multi-microphone processing system may include achieving ten to twelve dB in overall noise reduction, preserving voice level and color during movement of a desired speaker, obtaining a perception that the noise has been moved into the background instead of an aggressive noise removal, dereverberation of speech, and/or enabling the option of post-processing for more aggressive noise reduction.
An apparatus as disclosed herein (e.g., apparatus A100 and MF100) may be implemented in any combination of hardware with software, and/or with firmware, that is deemed suitable for the intended application. For example, the elements of such an apparatus may be fabricated as electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or logic gates, and any of these elements may be implemented as one or more such arrays. Any two or more, or even all, of the elements of the apparatus may be implemented within the same array or arrays. Such an array or arrays may be implemented within one or more chips (for example, within a chipset including two or more chips).
One or more elements of the various implementations of the apparatus disclosed herein may also be implemented in whole or in part as one or more sets of instructions arranged to execute on one or more fixed or programmable arrays of logic elements, such as microprocessors, embedded processors, IP cores, digital signal processors, FPGAs (field-programmable gate arrays), ASSPs (application-specific standard products), and ASICs (application-specific integrated circuits). Any of the various elements of an implementation of an apparatus as disclosed herein may also be embodied as one or more computers (e.g., machines including one or more arrays programmed to execute one or more sets or sequences of instructions, also called “processors”), and any two or more, or even all, of these elements may be implemented within the same such computer or computers.
A processor or other means for processing as disclosed herein may be fabricated as one or more electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or logic gates, and any of these elements may be implemented as one or more such arrays. Such an array or arrays may be implemented within one or more chips (for example, within a chipset including two or more chips). Examples of such arrays include fixed or programmable arrays of logic elements, such as microprocessors, embedded processors, IP cores, DSPs, FPGAs, ASSPs, and ASICs. A processor or other means for processing as disclosed herein may also be embodied as one or more computers (e.g., machines including one or more arrays programmed to execute one or more sets or sequences of instructions) or other processors. It is possible for a processor as described herein to be used to perform tasks or execute other sets of instructions that are not directly related to a voice activity detection procedure as described herein, such as a task relating to another operation of a device or system in which the processor is embedded (e.g., an audio sensing device). It is also possible for part of a method as disclosed herein to be performed by a processor of the audio sensing device and for another part of the method to be performed under the control of one or more other processors.
Those of skill will appreciate that the various illustrative modules, logical blocks, circuits, and tests and other operations described in connection with the configurations disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. Such modules, logical blocks, circuits, and operations may be implemented or performed with a general-purpose processor, a digital signal processor (DSP), an ASIC or ASSP, an FPGA or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to produce the configuration as disclosed herein. For example, such a configuration may be implemented at least in part as a hard-wired circuit, as a circuit configuration fabricated into an application-specific integrated circuit, or as a firmware program loaded into non-volatile storage or a software program loaded from or into a data storage medium as machine-readable code, such code being instructions executable by an array of logic elements such as a general purpose processor or other digital signal processing unit. A general-purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration. A software module may reside in RAM (random-access memory), ROM (read-only memory), nonvolatile RAM (NVRAM) such as flash RAM, erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), registers, hard disk, a removable disk, a CD-ROM, or any other form of storage medium known in the art. An illustrative storage medium is coupled to the processor such the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an ASIC. The ASIC may reside in a user terminal. In the alternative, the processor and the storage medium may reside as discrete components in a user terminal.
It is noted that the various methods disclosed herein (e.g., method M100 and other methods disclosed by way of description of the operation of the various apparatus described herein) may be performed by an array of logic elements such as a processor, and that the various elements of an apparatus as described herein may be implemented as modules designed to execute on such an array. As used herein, the term “module” or “sub-module” can refer to any method, apparatus, device, unit or computer-readable data storage medium that includes computer instructions (e.g., logical expressions) in software, hardware or firmware form. It is to be understood that multiple modules or systems can be combined into one module or system and one module or system can be separated into multiple modules or systems to perform the same functions. When implemented in software or other computer-executable instructions, the elements of a process are essentially the code segments to perform the related tasks, such as with routines, programs, objects, components, data structures, and the like. The term “software” should be understood to include source code, assembly language code, machine code, binary code, firmware, macrocode, microcode, any one or more sets or sequences of instructions executable by an array of logic elements, and any combination of such examples. The program or code segments can be stored in a processor-readable storage medium or transmitted by a computer data signal embodied in a carrier wave over a transmission medium or communication link.
The implementations of methods, schemes, and techniques disclosed herein may also be tangibly embodied (for example, in one or more computer-readable media as listed herein) as one or more sets of instructions readable and/or executable by a machine including an array of logic elements (e.g., a processor, microprocessor, microcontroller, or other finite state machine). The term “computer-readable medium” may include any medium that can store or transfer information, including volatile, nonvolatile, removable and non-removable media. Examples of a computer-readable medium include an electronic circuit, a semiconductor memory device, a ROM, a flash memory, an erasable ROM (EROM), a floppy diskette or other magnetic storage, a CD-ROM/DVD or other optical storage, a hard disk, a fiber optic medium, a radio frequency (RF) link, or any other medium which can be used to store the desired information and which can be accessed. The computer data signal may include any signal that can propagate over a transmission medium such as electronic network channels, optical fibers, air, electromagnetic, RF links, etc. The code segments may be downloaded via computer networks such as the Internet or an intranet. In any case, the scope of the present disclosure should not be construed as limited by such embodiments.
Each of the tasks of the methods described herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. In a typical application of an implementation of a method as disclosed herein, an array of logic elements (e.g., logic gates) is configured to perform one, more than one, or even all of the various tasks of the method. One or more (possibly all) of the tasks may also be implemented as code (e.g., one or more sets of instructions), embodied in a computer program product (e.g., one or more data storage media such as disks, flash or other nonvolatile memory cards, semiconductor memory chips, etc.), that is readable and/or executable by a machine (e.g., a computer) including an array of logic elements (e.g., a processor, microprocessor, microcontroller, or other finite state machine). The tasks of an implementation of a method as disclosed herein may also be performed by more than one such array or machine. In these or other implementations, the tasks may be performed within a device for wireless communications such as a cellular telephone or other device having such communications capability. Such a device may be configured to communicate with circuit-switched and/or packet-switched networks (e.g., using one or more protocols such as VoIP). For example, such a device may include RF circuitry configured to receive and/or transmit encoded frames.
It is expressly disclosed that the various methods disclosed herein may be performed by a portable communications device such as a handset, headset, or portable digital assistant (PDA), and that the various apparatus described herein may be included within such a device. A typical real-time (e.g., online) application is a telephone conversation conducted using such a mobile device.
In one or more exemplary embodiments, the operations described herein may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, such operations may be stored on or transmitted over a computer-readable medium as one or more instructions or code. The term “computer-readable media” includes both computer-readable storage media and communication (e.g., transmission) media. By way of example, and not limitation, computer-readable storage media can comprise an array of storage elements, such as semiconductor memory (which may include without limitation dynamic or static RAM, ROM, EEPROM, and/or flash RAM), or ferroelectric, magnetoresistive, ovonic, polymeric, or phase-change memory; CD-ROM or other optical disk storage; and/or magnetic disk storage or other magnetic storage devices. Such storage media may store information in the form of instructions or data structures that can be accessed by a computer. Communication media can comprise any medium that can be used to carry desired program code in the form of instructions or data structures and that can be accessed by a computer, including any medium that facilitates transfer of a computer program from one place to another. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technology such as infrared, radio, and/or microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technology such as infrared, radio, and/or microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray Disc™ (Blu-Ray Disc Association, Universal City, Calif.), where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
An acoustic signal processing apparatus as described herein (e.g., apparatus A100 or MF100) may be incorporated into an electronic device that accepts speech input in order to control certain operations, or may otherwise benefit from separation of desired noises from background noises, such as communications devices. Many applications may benefit from enhancing or separating clear desired sound from background sounds originating from multiple directions. Such applications may include human-machine interfaces in electronic or computing devices which incorporate capabilities such as voice recognition and detection, speech enhancement and separation, voice-activated control, and the like. It may be desirable to implement such an acoustic signal processing apparatus to be suitable in devices that only provide limited processing capabilities.
The elements of the various implementations of the modules, elements, and devices described herein may be fabricated as electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or gates. One or more elements of the various implementations of the apparatus described herein may also be implemented in whole or in part as one or more sets of instructions arranged to execute on one or more fixed or programmable arrays of logic elements such as microprocessors, embedded processors, IP cores, digital signal processors, FPGAs, ASSPs, and ASICs.
It is possible for one or more elements of an implementation of an apparatus as described herein to be used to perform tasks or execute other sets of instructions that are not directly related to an operation of the apparatus, such as a task relating to another operation of a device or system in which the apparatus is embedded. It is also possible for one or more elements of an implementation of such an apparatus to have structure in common (e.g., a processor used to execute portions of code corresponding to different elements at different times, a set of instructions executed to perform tasks corresponding to different elements at different times, or an arrangement of electronic and/or optical devices performing operations for different elements at different times).
The present Application for Patent claims priority to Provisional Application No. 61/406,382, entitled “DUAL-MICROPHONE COMPUTATIONAL AUDITORY SCENE ANALYSIS FOR NOISE REDUCTION,” filed Oct. 25, 2010, and assigned to the assignee hereof. The present Application for Patent also claims priority to U.S. patent application Ser. No. 13/092,502, entitled “SYSTEMS, METHODS, AND APPARATUS FOR SPEECH FEATURE DETECTION,” Attorney Docket No. 100839, filed Apr. 22, 2011, and assigned to the assignee hereof.
Number | Date | Country | |
---|---|---|---|
61406382 | Oct 2010 | US |