-
2014-07-08
12/286,995
2008-10-02
US 8,774,423 B1
2014-07-08
-
-
Ping Lee
Carr & Ferrell LLP
2032-08-24
Smart Summary: A system is designed to improve how signals, like audio, are modified to reduce noise. It starts by receiving an audio signal and checks if certain conditions are met for two coefficients: the adaptation coefficient and a phantom coefficient. If the phantom coefficient meets the conditions, it gets updated based on current observations. The adaptation coefficient is then adjusted in relation to the phantom coefficient, depending on whether it also meets the conditions. Finally, the system produces a modified audio signal that reduces noise while maintaining clarity. 🚀 TL;DR
Systems and methods for controlling adaptivity of signal modification, such as noise suppression, using a phantom coefficient are provided. The process for controlling adaptivity comprises receiving a signal. Determinations may be made of whether an adaptation coefficient satisfies an adaptation constraint and of whether the phantom coefficient satisfies the adaptation constraint. The phantom coefficient may be updated, for example, toward a current observation. The adaptation coefficient may be updated, for example, toward the phantom coefficient, based on whether the phantom coefficient satisfies an adaptation constraint of the signal. A modified signal may be generated by applying the adaptation coefficient to the signal based on whether the adaptation coefficient satisfies the adaptation constraint. Accordingly, the modified signal may be outputted.
Get notified when new applications in this technology area are published.
H04B15/00 IPC
Suppression or limitation of noise or interference
The present application is continuation-in-part of U.S. patent application Ser. No. 12/215,980, filed Jun. 30, 2008 and entitled “System and Method for Providing Noise Suppression Utilizing Null Processing Noise Subtraction,” which is incorporated herein by reference. Additionally, the present application is related to U.S. patent application Ser. No. 12/286,909, filed Oct. 2, 2008, entitled “Self Calibration of Audio Device,” and to U.S. patent application Ser. No. 12/080,115, filed Mar. 31, 2008, entitled “System and Method for Providing Close-Microphone Adaptive Array Processing,” both of which are incorporated herein by reference.
1. Field of Invention
The present invention relates generally to audio processing and more particularly to controlling adaptivity of signal modification using phantom coefficients.
2. Description of Related Art
Currently, there are many methods for modifying signals, such as reducing background noise in an adverse audio environment. One such method is to use a stationary noise suppression system. The stationary noise suppression system will always provide an output noise that is a fixed amount lower than the input noise. Typically, the stationary noise suppression is in the range of 12-13 decibels (dB). The noise suppression is fixed to this conservative level in order to avoid producing speech distortion, which will be apparent with higher noise suppression.
In order to provide higher noise suppression, dynamic noise suppression systems based on signal-to-noise ratios (SNR) have been utilized. This SNR may then be used to determine a suppression value. Unfortunately, SNR, by itself, is not a very good predictor of speech distortion due to existence of different noise types in the audio environment. SNR is a ratio of how much louder speech is than noise. However, speech may be a non-stationary signal which may constantly change and contain pauses. Typically, speech energy, over a period of time, will comprise a word, a pause, a word, a pause, and so forth. Additionally, stationary and dynamic noises may be present in the audio environment. The SNR averages all of these stationary and non-stationary speech and noise. There is no consideration as to the statistics of the noise signal; only what the overall level of noise is.
As these various noise suppression schemes become more advanced, the computations required for satisfactory implementation also increases. The number of computations may be directly related to energy use. This becomes especially important in mobile device applications of noise suppression, since increasing computations may have an adverse effect on battery time.
Embodiments of the present invention overcome or substantially alleviate prior problems associated with signal modification, such as noise suppression and speech enhancement. In exemplary embodiments, the process for controlling adaptivity comprises receiving a signal, such as by one or more microphones. According to some embodiments, a microphone array may receive the signal, wherein the microphone array may comprise a close microphone array or a spread microphone array.
Determinations may be made of whether an adaptation coefficient satisfies an adaptation constraint. Further determinations may be made of whether a phantom coefficient satisfies the adaptation constraint. The phantom coefficient may be updated, for example, toward a current observation. On the other hand, the adaptation coefficient may be updated, for example, toward the phantom coefficient, based on whether the phantom coefficient satisfies an adaptation constraint of the signal. Updating the adaptation coefficient may comprise an iterative process, in accordance with exemplary embodiments.
A modified signal may be generated by applying the adaptation coefficient to the signal based on whether the adaptation coefficient satisfies the adaptation constraint. In exemplary embodiments, the modified signal may be a noise suppressed signal. In other embodiments, however, the modified signal may be a noise subtracted signal. Accordingly, the modified signal may be outputted, for example, to a multiplicative noise suppression system.
FIG. 1 is an environment in which embodiments of the present invention may be practiced.
FIG. 2 is a block diagram of an exemplary audio device implementing embodiments of the present invention.
FIG. 3 is a block diagram of an exemplary audio processing system utilizing a spread microphone array.
FIG. 4 is a block diagram of an exemplary audio processing system utilizing a close microphone array.
FIG. 5a is a block diagram of an exemplary noise subtraction engine.
FIG. 5b is a schematic illustrating the operations of the noise subtraction engine.
FIG. 6 is a block diagram of an exemplary adaptation module.
FIG. 7 is a flowchart of an exemplary method for using a phantom coefficient to influence adaptivity of an adaptation coefficient.
FIG. 8 illustrates an exemplary implementation of the method described in FIG. 7.
The present invention provides exemplary systems and methods for controlling adaptivity of signal modification using a phantom coefficient. In exemplary embodiments, the signal modification relates to adaptive suppression of noise in an audio signal. Embodiments attempt to balance noise suppression with minimal or no speech degradation (i.e., speech loss distortion). According to various embodiments, noise suppression is based on an audio source location and applies a subtractive noise suppression process as opposed to a purely multiplicative noise suppression process.
Embodiments of the present invention may be practiced on any audio device that is configured to receive sound such as, but not limited to, cellular phones, phone handsets, headsets, and conferencing systems. Advantageously, exemplary embodiments are configured to provide improved noise suppression while minimizing speech distortion. While some embodiments of the present invention will be described in reference to operation on a cellular phone, the present invention may be practiced on any audio device.
Referring to FIG. 1, an environment in which embodiments of the present invention may be practiced is shown. A user acts as a audio source 102 to an audio device 104. The exemplary audio device 104 may include a microphone array. The microphone array may comprise a close microphone array or a spread microphone array.
In exemplary embodiments, the microphone array may comprise a primary microphone 106 relative to the audio source 102 and a secondary microphone 108 located a distance away from the primary microphone 106. While embodiments of the present invention will be discussed with regards to having two microphones 106 and 108, alternative embodiments may contemplate any number of microphones or acoustic sensors within the microphone array. In some embodiments, the microphones 106 and 108 may comprise omni-directional microphones.
While the microphones 106 and 108 receive sound (i.e., acoustic signals) from the audio source 102, the microphones 106 and 108 also pick up noise 110. Although the noise 110 is shown coming from a single location in FIG. 1, the noise 110 may comprise any sounds from one or more locations different than the audio source 102, and may include reverberations and echoes. The noise 110 may be stationary, non-stationary, or a combination of both stationary and non-stationary noise.
Referring now to FIG. 2, the exemplary audio device 104 is shown in more detail. In exemplary embodiments, the audio device 104 is an audio receiving device that comprises a processor 202, the primary microphone 106, the secondary microphone 108, an audio processing system 204, and an output device 206. The audio device 104 may comprise further components (not shown) necessary for audio device 104 operations. The audio processing system 204 will be discussed in more details in connection with FIG. 3.
In exemplary embodiments, the primary and secondary microphones 106 and 108 are spaced a distance apart in order to allow for an energy level difference between them. Upon reception by the microphones 106 and 108, the acoustic signals may be converted into electric signals (i.e., a primary electric signal and a secondary electric signal). The electric signals may, themselves, be converted by an analog-to-digital converter (not shown) into digital signals for processing in accordance with some embodiments. In order to differentiate the acoustic signals, the acoustic signal received by the primary microphone 106 is herein referred to as the primary acoustic signal, while the acoustic signal received by the secondary microphone 108 is herein referred to as the secondary acoustic signal.
The output device 206 is any device which provides an audio output to the user. For example, the output device 206 may comprise an earpiece of a headset or handset, or a speaker on a conferencing device. In further embodiments, the output device 206 may transmit the audio output to a receiving audio device.
FIG. 3 is a detailed block diagram of the exemplary audio processing system 204a according to one embodiment of the present invention. In exemplary embodiments, the audio processing system 204a is embodied within a memory device. The audio processing system 204a of FIG. 3 may be utilized in embodiments comprising a spread microphone array.
In operation, the acoustic signals received from the primary and secondary microphones 106 and 108 are converted to electric signals and processed through a frequency analysis module 302. In one embodiment, the frequency analysis module 302 takes the acoustic signals and mimics the frequency analysis of the cochlea (i.e., cochlear domain) simulated by a filter bank. In one example, the frequency analysis module 302 separates the acoustic signals into frequency sub-bands. A sub-band is the result of a filtering operation on an input signal where the bandwidth of the filter is narrower than the bandwidth of the signal received by the frequency analysis module 302. Alternatively, other filters such as short-time Fourier transform (STFT), sub-band filter banks, modulated complex lapped transforms, cochlear models, wavelets, etc., can be used for the frequency analysis and synthesis. Because most sounds (e.g., acoustic signals) are complex and comprise more than one frequency, a sub-band analysis on the acoustic signal determines what individual frequencies are present in the complex acoustic signal during a frame (e.g., a predetermined period of time). According to one embodiment, the frame is 8 ms long. Alternative embodiments may utilize other frame lengths or no frame at all. The results may comprise sub-band signals in a fast cochlea transform (FCT) domain.
Once the sub-band signals are determined, the sub-band signals are forwarded to a noise subtraction engine 304. The exemplary noise subtraction engine 304 is configured to adaptively subtract out a noise component from the primary acoustic signal for each sub-band. As such, output of the noise subtraction engine 304 is a noise subtracted signal comprised of noise subtracted sub-band signals. The noise subtraction engine 304 will be discussed in more detail in connection with FIG. 5a and FIG. 5b. It should be noted that the noise subtracted sub-band signals may comprise desired audio that is speech or non-speech (e.g., music). The results of the noise subtraction engine 304 may be output to the user or processed through a further noise suppression system (e.g., the noise suppression engine 306). For purposes of illustration, embodiments of the present invention will discuss embodiments whereby the output of the noise subtraction engine 304 is processed through a further noise suppression system.
The noise subtracted sub-band signals along with the sub-band signals of the secondary acoustic signal are then provided to the noise suppression engine 306a. According to exemplary embodiments, the noise suppression engine 306a generates a gain mask to be applied to the noise subtracted sub-band signals in order to further reduce noise components that remain in the noise subtracted speech signal. The noise suppression engine 306a is discussed in further detail in U.S. patent application Ser. No. 12/215,980, entitled “System and Method for Providing Noise Suppression Utilizing Null Processing Noise Subtraction,” which has been incorporated by reference.
The gain mask determined by the noise suppression engine 306a may then be applied to the noise subtracted signal in a masking module 308. Accordingly, each gain mask may be applied to an associated noise subtracted frequency sub-band to generate masked frequency sub-bands. As depicted in FIG. 3, a multiplicative noise suppression system 312a comprises the noise suppression engine 306a and the masking module 308.
Next, the masked frequency sub-bands are converted back into time domain from the cochlea domain. The conversion may comprise taking the masked frequency sub-bands and adding together phase shifted signals of the cochlea channels in a frequency synthesis module 310. Alternatively, the conversion may comprise taking the masked frequency sub-bands and multiplying these with an inverse frequency of the cochlea channels in the frequency synthesis module 310. Once conversion is completed, the synthesized acoustic signal may be output to the user.
Referring now to FIG. 4, a detailed block diagram of an alternative audio processing system 204b is shown. In contrast to the audio processing system 204a of FIG. 3, the audio processing system 204b of FIG. 4 may be utilized in embodiments comprising a close microphone array. The functions of the frequency analysis module 302, masking module 308, and frequency synthesis module 310 are identical to those described with respect to the audio processing system 204a of FIG. 3 and will not be discussed in detail.
The sub-band signals determined by the frequency analysis module 302 may be forwarded to the noise subtraction engine 304 and an array processing engine 402. The exemplary noise subtraction engine 304 is configured to adaptively subtract out a noise component from the primary acoustic signal for each sub-band. As such, output of the noise subtraction engine 304 is a noise subtracted signal comprised of noise subtracted sub-band signals. In the present embodiment, the noise subtraction engine 304 also provides a null processing (NP) gain to the noise suppression engine 306a. The NP gain comprises an energy ratio indicating how much of the primary signal has been cancelled out of the noise subtracted signal. If the primary signal is dominated by noise, then NP gain will be large. In contrast, if the primary signal is dominated by speech, NP gain will be close to zero. The noise subtraction engine 304 will be discussed in more detail in connection with FIG. 5a and FIG. 5b below.
In exemplary embodiments, the array processing engine 402 is configured to adaptively process the sub-band signals of the primary and secondary signals to create directional patterns (i.e., synthetic directional microphone responses) for the close microphone array (e.g., the primary and secondary microphones 106 and 108). The directional patterns may comprise a forward-facing cardioid pattern based on the primary acoustic (sub-band) signals and a backward-facing cardioid pattern based on the secondary (sub-band) acoustic signal. In one embodiment, the sub-band signals may be adapted such that a null of the backward-facing cardioid pattern is directed towards the audio source 102. More details regarding the implementation and functions of the array processing engine 402 may be found (referred to as the adaptive array processing engine) in U.S. patent application Ser. No. 12/080,115 entitled “System and Method for Providing Close-Microphone Adaptive Array Processing,” which has been incorporated herein by reference. The cardioid signals (i.e., a signal implementing the forward-facing cardioid pattern and a signal implementing the backward-facing cardioid pattern) are then provided to the noise suppression engine 306b by the array processing engine 402.
The noise suppression engine 306b receives the NP gain along with the cardioid signals. According to exemplary embodiments, the noise suppression engine 306b generates a gain mask to be applied to the noise subtracted sub-band signals from the noise subtraction engine 304 in order to further reduce any noise components that may remain in the noise subtracted speech signal. The noise suppression engine 306b is discussed in further detail in U.S. patent application Ser. No. 12/215,980, entitled “System and Method for Providing Noise Suppression Utilizing Null Processing Noise Subtraction,” which has been incorporated herein by reference.
The gain mask determined by the noise suppression engine 306b may then be applied to the noise subtracted signal in the masking module 308. Accordingly, each gain mask may be applied to an associated noise subtracted frequency sub-band to generate masked frequency sub-bands. Subsequently, the masked frequency sub-bands are converted back into time domain from the cochlea domain by the frequency synthesis module 310. Once conversion is completed, the synthesized acoustic signal may be output to the user. As depicted in FIG. 4, a multiplicative noise suppression system 312b comprises the array processing engine 402, the noise suppression engine 306b, and the masking module 308.
FIG. 5a is a block diagram of an exemplary noise subtraction engine 304. The exemplary noise subtraction engine 304 is configured to suppress noise using a subtractive process. The noise subtraction engine 304 may determine a noise subtracted signal by initially subtracting out a desired component (e.g., the desired speech component) from the primary signal in a first branch, thus resulting in a noise component. Adaptation may then be performed in a second branch to cancel out the noise component from the primary signal. In exemplary embodiments, the noise subtraction engine 304 comprises a gain module 502, an analysis module 504, an adaptation module 506, and at least one summing module 508 configured to perform signal subtraction. The functions of the various modules 502-508 will be discussed in connection with FIG. 5a and further illustrated in operation in connection with FIG. 5b.
Referring to FIG. 5a, the exemplary gain module 502 is configured to determine various gains used by the noise subtraction engine 304. For purposes of the present embodiment, these gains represent energy ratios. In the first branch, a reference energy ratio (g1) of how much of the desired component is removed from the primary signal may be determined. In the second branch, a prediction energy ratio (g2) of how much the energy has been reduced at the output of the noise subtraction engine 304 from the result of the first branch may be determined. Additionally, an energy ratio (i.e., NP gain) may be determined that represents the energy ratio indicating how much noise has been canceled from the primary signal by the noise subtraction engine 304. As previously discussed, NP gain may be used by the AIS generator in the close microphone embodiment to adjust the gain mask.
The exemplary analysis module 504 is configured to perform the analysis in the first branch of the noise subtraction engine 304, while the exemplary adaptation module 506 is configured to control adaptivity in the second branch of the noise subtraction engine 304.
Referring to FIG. 5b, a schematic illustration of the operations of the noise subtraction engine 304 is shown. Sub-band signals of the primary microphone signal c(k) and secondary microphone signal f(k) are received by the noise subtraction engine 304 where k represents a discrete time or sample index (i.e., a frame). c(k) represents a superposition of a speech signal s(k) and a noise signal n(k). f(k) is modeled as a superposition of the speech signal s(k), scaled by a complex-valued coefficient σ, and the noise signal n(k), scaled by a complex-valued coefficient ν. σ represents how much of the noise in the primary signal is in the secondary signal. In exemplary embodiments, ν is unknown since a source of the noise may be dynamic.
In exemplary embodiments, σ is a fixed coefficient that represents a location of the speech (e.g., an audio source location). In accordance with exemplary embodiments, σ may be determined through calibration. Tolerances may be included in the calibration by calibrating based on more than one position. For a close microphone, a magnitude of σ may be close to one. For spread microphones, the magnitude of σ may be dependent on where the audio device 104 is positioned relative to the speaker's mouth. The magnitude and phase of the σ may represent an inter-channel cross-spectrum for a speaker's mouth position at a frequency represented by the respective sub-band (e.g., Cochlea tap). Because the noise subtraction engine 304 may have knowledge of what σ is, the analysis module 504 may apply a to the primary signal (i.e., as(k)+n(k)) and subtract the result from the secondary signal (i.e., σs(k)+ν(k)) in order to cancel out the speech component σs(k) (i.e., the desired component) from the secondary signal resulting in a noise component out of the summing module 508 after the first branch.
If the speaker's mouth position is adequately represented by σ, then f(k)−σc(k)=(ν−σ)n(k). This equation indicates that signal at the output of the summing module 508 being fed into the adaptation module 506 (which, in turn, may apply an adaptation coefficient, α(k), as described further herein) may be devoid of a signal originating from a position represented by σ (e.g., the desired speech signal). In exemplary embodiments, the analysis module 504 applies σ to the secondary signal f(k) and subtracts the result from c(k). A remaining signal (referred to herein as “noise component signal”) from the summing module 508 may be canceled out in the second branch. The adaptation module 506, in accordance with exemplary embodiments, is described further in connection with FIG. 6.
In an embodiment where n(k) is white noise and a cross-correlation between s(k) and n(k) is zero within a frame, adaptation may happen every frame with the noise n(k) being perfectly cancelled and the speech s(k) being perfectly unaffected. However, it is unlikely that these conditions may be met in reality, especially if the frame size is short. As such, it is desirable to apply constraints on adaptation. In exemplary embodiments, the adaptation coefficient, α(k), may be updated on a per-tap/per-frame basis provided that an adaptation constraint is satisfied.
According to exemplary embodiments, the adaptation constraint is satisfied when the reference energy ratio g1 and the prediction energy ratio g2 satisfy the follow condition:
g2·γ>g1/γ
where γ>0. Assuming, for example, that {circumflex over (σ)}(k)=σ, α(k)=1/(ν−σ), and s(k) and n(k) are uncorrelated, the following may be obtained:
g
1
=
E
{
(
s
(
k
)
+
n
(
k
)
)
2
}
v
-
σ
2
·
E
{
n
2
(
k
)
}
=
S
+
N
v
-
σ
2
·
N
and
g
2
=
v
-
σ
2
·
E
{
n
2
(
k
)
}
E
{
s
2
(
k
)
}
=
v
-
σ
2
·
N
S
,
where E{ . . . } is an expected value, S is a signal energy, and N is a noise energy. From the previous three equations, the following may be obtained:
SNR
2
+
SNR
<
γ
2
v
-
σ
4
,
where SNR=S/N. Put in terms of the adaptation coefficient, α(k), the adaptation constraint can be written as:
α4<γ2/SNR2+SNR).
Although the aforementioned adaptation constraint is described herein, any constraint may be used in accordance with various embodiments.
The coefficient γ may be chosen to define a boundary between adaptation and non-adaptation of α. For example, in a case where a far-field source at 90 degrees angle relative to a straight line between the microphones 106 and 108, the signal may have equal power and zero phase shift between both microphones 106 and 108 (e.g., ν=1). As such, if the SNR=1, then γ2|ν−σ|4=2, which is equivalent to γ=sqrt(2)/|1−σ|4.
Lowering γ relative to this value may improve protection of the near-end source from cancellation at the expense of increased noise leakage; raising γ has an opposite effect. It should be noted that in the microphones 106 and 108, ν=1 may not be a good enough approximation of the far-field/90 degrees situation, and may have to be substituted by a value obtained from calibration measurements.
In some instances, such as when the noise is in the same location as the target speech (i.e., σ=ν), the adaptation constraint, g2·γ>g1/γ, may not be met regardless of the SNR, resulting in adaptation never occurring. In order to overcome this, the adaptation module 506 may invoke a “phantom coefficient,” represented herein as β(k). The phantom coefficient, β(k), is unconstrained, meaning that the phantom coefficient, β(k), is always updated with the same time constant as the adaptation coefficient, α(k), regardless of whether the adaptation coefficient, α(k), is updated. In contrast to the adaptation coefficient, α(k), however, the phantom coefficient, β(k), is never applied to any signal. Instead, the phantom coefficient, β(k), is used to refine the update criteria for the adaptation coefficient, α(k), in an event that the adaptation coefficient, α(k), is frozen as non-adaptive (i.e., the adaptation constraint is not satisfied). The updates of both the adaptation coefficient, α(k), and the phantom coefficient, β(k), are described further in connection with FIG. 7 and FIG. 8.
In FIG. 6, a block diagram of the adaptation module 506 is presented in accordance with exemplary embodiments. The adaptation module 506, as mentioned, may be configured to control adaptivity, such as in the second branch of the noise subtraction engine 304. As depicted, the adaptation module 506 comprises a constraint module 602, an update module 604, and a modifier module 606.
The constraint module 602 may be configured to determine whether the adaptation coefficient, α(k), satisfies an adaptation constraint (e.g., g2·γ>g1/γ). Accordingly, the constraint module 602 may also be configured to determine whether a phantom coefficient, β(k), satisfies the adaptation constraint, as described in connection with FIG. 7.
According to various embodiments, the update module 604 is configured to update the adaptation coefficient, α(k), and phantom coefficient, β(k), based on certain criteria. One criterion may be whether or not the adaptation coefficient, α(k), satisfies the adaptation constraint. Another criterion may be whether or not the phantom coefficient, β(k) satisfies the adaptation constraint. In some embodiments, the update module 604 is configured to update the adaptation coefficient, α(k), if the adaptation coefficient, α(k), does not satisfy the adaptation constraint but the phantom coefficient, β(k), does satisfy the adaptation constraint, and to update the phantom coefficient, β(k), regardless of any criteria.
The modifier module 606 is configured to apply the adaptation coefficient, α(k), to the signal in the second branch. In exemplary embodiments, the adaptation module 506 may adapt using one of a common least-squares method in order to cancel the noise component n(k) from the signal c(k). The adaptation coefficient, α(k), may be applied at a frame rate (e.g., 5 frames per second) according to one embodiment.
FIG. 7 is a flowchart 700 of an exemplary method for using the phantom coefficient, β(k), to influence the adaptivity of the adaptation coefficient, α(k). In step 702, a frame of a signal (i.e., a discrete time sample of the signal) is received by the adaptation module 506. In exemplary embodiments, the signal at the output of the summing module 508 of the first branch is fed into the adaptation module 506
In step 704, a determination is made as to whether the adaptation coefficient, α(k), satisfies the adaptation constraint (e.g., g2·γ>g1/γ). According to various embodiments, the constraint module 602 may carry out this determination. If the adaptation coefficient, α(k), does satisfy the adaptation constraint, the adaptation coefficient, α(k), is updated in step 706, which may be carried out by the modifier module 606 in exemplary embodiments. If the adaptation coefficient, α(k), does not satisfy the adaption constraint, however, the method depicted in the flowchart 700 proceeds to step 708.
In step 708, it is determined whether the phantom coefficient, β(k), satisfies the adaptation constraint (e.g., g2·γ>g1/γ). The constraint module 602 may carry out this determination, in accordance with various embodiments. If the phantom coefficient, β(k), does not satisfy the adaptation constraint, the method depicted in the flowchart 700 proceeds directly to step 710. On the other hand, if the phantom coefficient, β(k), does satisfy the adaptation constraint, the method depicted in the flowchart 700 proceeds to step 712.
In step 710, the phantom coefficient, β(k), is updated by one adaptive step towards a current observation, for example, by the update module 604. According to exemplary embodiments, the update of the phantom coefficient may be expressed as:
β(k+1)=β(k)+λ(Oc−β(k)),
where λ is an adaptive step size expressed as a fraction of the distance from the current state of the phantom coefficient, β(k), to the current observation, Oc, such that 0<λ≦1. The updating of the phantom coefficient, β(k), as well as the adaptation coefficient, α(k), is described further in connection with FIG. 8.
In step 712, the adaptation coefficient, α(k), is updated to approach the phantom coefficient, β(k). As mentioned, the adaptation coefficient, α(k), may be updated by the update module 604. In exemplary embodiments, the update of the adaptation coefficient, α(k), will follow an update path defined by previous updates of the phantom coefficient, β(k). The update path merely describes the update history of the phantom coefficient, β(k), as illustrated in FIG. 8.
As depicted in the flowchart 700, some combination of steps 702, 704, 708, 710, and 712 will repeat until the determination in step 704 affirms that the adaptation coefficient, α(k), satisfies the adaptation constraint.
Referring now to FIG. 8, an exemplary implementation 800 generically illustrating the method described by the flowchart 700 is presented. A series of frames 802, comprising Frame 1 through Frame 7, are received sequentially by the adaptation module 506. In Frames 1 through 7, k (i.e., discrete time or sample index) equals 1 through 7, respectively. Additionally, each of the frames 802 comprises a depiction of a current estimate 804, a current observation 806, one or more adaptation coefficients 808 (i.e., α), and one or more phantom coefficients 810 (i.e., β). Those skilled in the art will recognize that the adaptation coefficient 808 and the phantom coefficient 810 may comprise complex values. For illustrative purposes, FIG. 8 represents a special case in which the current observation 806 has no imaginary component. Additionally, initial values of both the adaptation coefficient 808 and the phantom coefficient 810 also have no imaginary components.
To avoid clutter in FIG. 8, the current estimate 804, the current observation 806, the adaptation coefficients 808, and the phantom coefficients 810 are only labeled on Frame 1. It is understood, however, that Frames 2 through 7 also comprise the current estimate 804, the current observation 806, the adaptation coefficients 808, and the phantom coefficients 810. Furthermore, a threshold 812, which may be defined by the adaptation constraint, is also depicted in FIG. 8. As illustrated in FIG. 8, adaptation does not occur when the adaptation coefficient 808 is above the threshold 812 (i.e., the adaptation constraint is not satisfied) and, conversely, adaptation does occur when the adaptation coefficient 808 is below the threshold 812 (i.e., the adaptation constraint is satisfied). In other words, the threshold 812 forms a boundary between not adapting and adapting.
In Frame 1, the current estimate 804 and the current observation 806 are on opposite sides of the threshold 812. In accordance with the exemplary method represented by the flowchart 700, the phantom coefficient 810 is updated towards the current observation 806, but the adaptation coefficient 808 is not, since the adaptation coefficient 808 does not satisfy the adaptation constraint represented by threshold 812 (see, e.g., steps 704, 708, and 710). Accordingly, in Frame 2 and Frame 3, the phantom coefficient 810 is further updated towards the current observation 806, still without updating the adaptation coefficient 808. Although update step lengths are depicted in FIG. 8 as being constant, those skilled in the art will appreciate that, in practice, the update step lengths may decrease as the current observation 806 is approached since, for example, β(k+1)=β(k)+λ(Oc−β(k)), where λ determines the update step length.
In Frame 4, the phantom coefficient 810 satisfies the threshold 812, while the adaptation coefficient 808 still does not. In accordance with step 708, and subsequently step 712 and step 710, both the phantom coefficient 810 and the adaptation coefficient 808 are updated towards the current observation 806 and towards the phantom coefficient 810, respectively, as reflected in Frame 5. In Frame 5 and Frame 6, the phantom coefficient 810 continues to satisfy the threshold 812 resulting in the phantom coefficient 810 being updated towards the current observation 806 and the adaptation coefficient 808 being updated towards the phantom coefficient 810.
In Frame 7, the adaptation coefficient 808 satisfies the threshold 812. Therefore, the adaptation coefficient 808 is applied in the second branch by the adaptation module 506, such as described in connection with FIGS. 7 and 8.
The above-described modules may be comprised of instructions that are stored in storage media such as a machine readable medium (e.g., a computer readable medium). The instructions may be retrieved and executed by the processor 202. Some examples of instructions include software, program code, and firmware. Some examples of storage media comprise memory devices and integrated circuits. The instructions are operational when executed by the processor 202 to direct the processor 202 to operate in accordance with embodiments of the present invention. Those skilled in the art are familiar with instructions, processors, and storage media.
The present invention is described above with reference to exemplary embodiments. It will be apparent to those skilled in the art that various modifications may be made and other embodiments may be used without departing from the broader scope of the present invention. For example, the microphone array discussed herein comprises a primary and secondary microphone 106 and 108. However, alternative embodiments may contemplate utilizing more microphones in the microphone array. Therefore, there and other variations upon the exemplary embodiments are intended to be covered by the present invention.
1. A method for controlling adaptivity of signal modification, comprising:
receiving a signal;
updating a primary adaptation coefficient based on whether the primary adaptation coefficient satisfies an adaptation constraint;
if the primary adaptation coefficient fails to satisfy the adaptation constraint:
updating the primary adaptation coefficient based on whether a secondary adaptation coefficient satisfies the adaptation constraint of the signal, the primary and secondary adaptation coefficients both being based on the signal and updated with the same time constant;
the secondary adaptation coefficient being a phantom coefficient such that the phantom secondary adaptation coefficient is not applied to the signal;
the primary adaptation coefficient being updated toward a current observation if the phantom secondary adaptation coefficient satisfies the adaptation constraint of the signal; and
the primary adaptation coefficient not being updated if the phantom secondary adaptation coefficient does not satisfy the adaptation constraint;
generating a modified signal by applying the primary adaptation coefficient to the signal; and
outputting the modified signal.
2. The method of claim 1, further comprising determining whether the primary adaptation coefficient satisfies the adaptation constraint.
3. The method of claim 1, further comprising determining whether the phantom secondary adaptation coefficient satisfies the adaptation constraint.
4. The method of claim 1, further comprising updating the phantom secondary adaptation coefficient.
5. The method of claim 4, wherein the phantom secondary adaptation coefficient is updated toward the current observation.
6. The method of claim 1, wherein the primary adaptation coefficient is updated toward the phantom secondary adaptation coefficient.
7. The method of claim 1, wherein updating the primary adaptation coefficient comprises an iterative process.
8. The method of claim 1, wherein the modified signal is a noise suppressed signal.
9. The method of claim 1, wherein the modified signal is a noise subtracted signal.
10. The method of claim 1, wherein the modified signal is outputted to a multiplicative noise suppression system.
11. A system for controlling adaptivity of signal modification, comprising:
a microphone configured to receive a signal;
an update module configured to update a primary adaptation coefficient based on whether the primary adaptation coefficient satisfies an adaptation constraint;
wherein if the primary adaptation coefficient fails to satisfy the adaptation constraint, the update module:
updates the primary adaptation coefficient based on whether a secondary adaptation coefficient satisfies the adaptation constraint of the signal, the primary and secondary adaptation coefficients both being based on the signal and updated with the same time constant;
the secondary adaptation coefficient being a phantom coefficient such that the phantom secondary adaptation coefficient is not applied to the signal;
the primary adaptation coefficient being updated toward a current observation and toward the phantom coefficient if the phantom secondary adaptation coefficient satisfies the adaptation constraint of the signal; and
the primary adaptation coefficient not being updated if the phantom secondary adaptation coefficient does not satisfy the adaptation constraint;
a modifier module configured to generate a modified signal by applying the primary adaptation coefficient to the signal; and
an output device configured to output the modified signal.
12. The system of claim 11, further comprising a constraint module configured to determine whether the primary adaptation coefficient satisfies the adaptation constraint.
13. The system of claim 11, further comprising a constraint module configured to determine whether the phantom secondary adaptation coefficient satisfies the adaptation constraint.
14. The system of claim 11, wherein the update module is further configured to update the phantom secondary adaptation coefficient.
15. The system of claim 14, wherein the phantom coefficient secondary adaptation is updated toward a current observation.
16. The system of claim 11, wherein the modified signal is a noise suppressed signal.
17. The system of claim 11, wherein the modified signal is a noise subtracted signal.
18. The system of claim 11, wherein the output device is further configured to output the signal to a multiplicative noise suppression system.
19. A non-transitory machine readable storage medium having embodied thereon a program, the program providing instructions executable by a processor for controlling adaptivity of signal modification, the method comprising:
receiving a signal;
updating a primary adaptation coefficient based on whether the primary adaptation coefficient satisfies an adaptation constraint;
if the primary adaptation coefficient fails to satisfy the adaptation constraint:
updating the primary adaptation coefficient based on whether a secondary adaptation coefficient satisfies an adaptation constraint of the signal, the secondary adaptation coefficient being a phantom coefficient, the primary and secondary adaptation coefficient both being based on the signal and updated with the same time constant;
the secondary adaptation coefficient being a phantom coefficient such that the phantom secondary adaptation coefficient is not applied to the signal;
the primary adaptation coefficient being updated toward a current observation if the phantom secondary adaptation coefficient satisfies the adaptation constraint of the signal; and
the primary adaptation coefficient not being updated if the phantom secondary adaptation coefficient does not satisfy the adaptation constraint;
generating a modified signal by applying the primary adaptation coefficient to the signal; and
outputting the modified signal.
20. A method for controlling adaptivity of signal modification, comprising:
receiving a signal;
updating a primary adaptation coefficient based on whether the primary adaptation coefficient satisfies an adaptation constraint;
if the primary adaptation coefficient fails to satisfy the adaptation constraint:
updating the primary adaptation coefficient based on whether a secondary adaptation coefficient satisfies the adaptation constraint of the signal, the primary and secondary adaptation coefficients both being based on the signal;
the secondary adaptation coefficient not applied to the signal; and
the primary adaptation coefficient being updated toward the secondary adaptation coefficient if the secondary adaptation coefficient satisfies the adaptation constraint of the signal; and
the primary adaptation coefficient not being updated if the secondary adaptation coefficient does not satisfy the adaptation constraint;
generating a modified signal by applying the primary adaptation coefficient to the signal; and
outputting the modified signal.