This invention relates to the use of the magnitude coherence between two input signals for controlling adaptive filters in the processing of the input signals.
Adaptive filters have been widely applied for many years. An adaptive filter comprises a linear filter system with a transfer function between an input signal and an output signal, the transfer function comprising coefficients which can be controlled to optimise some measure of the output signal, for instance to minimise the error between the output signal and a supplied reference signal. An adaptive filter also comprises some adaptation control mechanism to control the coefficients. The coefficients may be initially set to some initial values, and are then controlled to converge over time to the optimum value based on the input signal and reference signal present. As with control loops in general, the adaptation of the coefficients may occur more quickly or more slowly or be over-damped or under-damped based on parameters of the design of the adaptation control mechanism, i.e. based on adaptation parameters or convergence factors of the adaptive filter.
In applications such as speech enhancement and acoustic noise cancellation, adaptive filters can be used to estimate the acoustic echo path for echo cancellation. In the case of a device with multiple microphones operating in a hands-free mode, adaptive filters can be used to model the speech path or interference paths in order to adaptively remove noise from a desired speech signal.
In multi-microphone applications, especially in devices with a small number of closely spaced microphones, each microphone may pick up significant amounts of both the desired speech signal and undesired background noise. The speech and noise components may be separated by using two or more adaptive filters. However it is preferable to adapt some filters when speech is present and to adapt others when only the background noise is present. This adaption mode control may be driven by a signal to noise ratio (SNR) measurement, using a threshold value to determine when speech is present and adapting one or more filters depending on the result of this determination. However, it is difficult to produce an accurate measurement of the signal-to-noise ratio and to thence derive reliable decisions, especially in devices with a small number of microphones or with particularly non-stationary noise conditions.
Another disadvantage of using SNR based mode control is that it assumes that the SNR of a designated voice microphone is always higher than that of a designated noise microphone. This could be true when the device is in use as a handset, when the voice microphone is very close to the user's mouth. However, this is not always true in practice, for example when the device is in use as a speakerphone. For example, the handheld handset could be rotated, or the user could walk around a table on which the handset is positioned with an arbitrary orientation. Or it could be that the voice microphone is physically further away from the user's mouth than the noise microphone, in order to be well separated from the loudspeaker for better echo performance. In these situations, the SNR measured in the voice microphone could be similar to, or even lower than, that of the noise microphone and the false decision made from SNR measurement could finally result in heavy speech distortion.
Other methods involve different methods of speech detection, but these are also difficult to use in the limited conditions imposed by handheld devices.
According to the present invention there is provided a sound processing circuit comprising: a first input for receiving a first input signal, a second input for receiving a second input signal, a first adaptive filter for receiving the first input signal, an error calculation block for calculating an error between the second input signal and the output of the first adaptive filter, and outputting an error signal, a second adaptive filter for receiving the error signal, an output calculation block for subtracting an output of the second adaptive filter from the first input signal to generate an output signal, wherein the adaptation of first and second adaptive filters is controlled based on a magnitude coherence between the first and second input signals.
The respective convergence factors of the first and second adaptive filters may be controlled based on the magnitude coherence. The convergence factor for each adaptive filter may be generated for each frequency bin and time frame of the first and second input signals.
The convergence factors of the first and second adaptive filters may be generated such that, when the convergence factor in one adaptive filter is a maximum convergence factor, the convergence factor in the other adaptive filter is a minimum convergence factor.
The first input signal may contain primarily a target signal and the second input signal may contain primarily ambient noise, such that the first adaptive filter is a noise estimation adaptive filter. The second adaptive filter may be a noise cancellation adaptive filter.
If the magnitude coherence between the first and second input signals is greater than an upper threshold value, the first adaptive filter may be controlled to have a maximum convergence factor, and the second adaptive filter may be controlled to have a minimum convergence factor.
If the magnitude coherence between the first and second input signals is lower than a lower threshold value, the first adaptive filter may be controlled to have a minimum convergence factor, and the second adaptive filter may be controlled to have a maximum convergence factor.
If the magnitude coherence is above a first threshold value for a particular frequency bin and time frame, the first adaptive filter may be controlled to have a maximum convergence factor for that frequency bin and time frame, or if the magnitude coherence is below a second threshold value for a particular frequency bin and time frame, the first adaptive filter may be controlled to have a minimum convergence factor for that frequency bin and time frame.
The first threshold value may be the same as the second threshold value.
Alternatively, the first threshold value may be an upper threshold value while the second threshold value is a lower threshold value, and the upper threshold value is larger than the lower threshold value. In that case, if the magnitude coherence is between the upper and lower threshold values for a particular frequency bin and time frame, the adaptive filter convergence factor may be controlled by generating the convergence factor using a linear relationship, or using a polynomial curve.
If the magnitude coherence is above a third threshold value for a particular frequency bin and time frame, the second adaptive filter may be controlled to have a minimum convergence factor for that frequency bin and time frame, or, if the magnitude coherence is below a fourth threshold value for a particular frequency bin and time frame, the second adaptive filter may be controlled to have a maximum convergence factor for that frequency bin and time frame.
The third threshold value may be the same as the fourth threshold value.
Alternatively, the third threshold value may be an upper threshold value while the fourth threshold value is a lower threshold value, and the upper threshold value is larger than the lower threshold value. In that case, if the magnitude coherence is between the upper and lower threshold values for a particular frequency bin and time frame, the adaptive filter convergence factor may be controlled by generating the convergence factor using a linear relationship, or using a polynomial curve.
The first and second input signals may comprise values in a plurality of frequency bins, and the frequency bins may be grouped into frequency sub-bands and the adaptive filter convergence factor generated for each frequency sub-band.
The magnitude coherence may be a weighted magnitude coherence
According to a second aspect, there is provided a portable device comprising: a first microphone to provide a first input signal, a second microphone to provide a second input signal, and a sound processing circuit, wherein the sound processing circuit comprises: a first adaptive filter for receiving the first input signal, an error calculation block for calculating an error between the second input signal and the output of the first adaptive filter, and outputting an error signal, a second adaptive filter for receiving the error signal, an output calculation block for subtracting an output of the second adaptive filter from the first input signal to generate an output signal, wherein the adaptation of first and second adaptive filters is controlled based on a magnitude coherence between the first and second input signals.
The portable device may further comprise at least one third microphone, and a microphone selection circuit for determining which of the first, second and third microphones are used to provide the first and second input signals.
The microphones may be between 5 cm and 25 cm apart.
The device may be communication device.
According to a further aspect, there is provided a method of controlling a frequency domain adaptive filter, the method comprising: receiving a first input signal and a second input signal, wherein the first and second input signals are in the frequency domain, calculating the magnitude coherence between the first and second signals, and using the magnitude coherence to control the adaptation parameters of the adaptive filter.
The adaptive filter may receive one of the first and second input signals as an input signal to be filtered.
The adaptive filter may receive an error signal indicative of the error between the first and second input signals as an input signal to be filtered.
The step of using the magnitude coherence to control the adaptive filter may comprise using the magnitude coherence to control the adaptive filter adaption convergence factor.
The convergence factor for the adaptive filter may be generated for each frequency bin and time frame of the first and second input signals.
The adaptive filter may be applied for noise estimation, or for noise cancellation.
The method may further comprise, if the magnitude coherence is above a first threshold value for a particular frequency bin and time frame, controlling the adaptive filter to have a maximum convergence factor for that frequency bin and time frame, or, if the magnitude coherence is below a second threshold value for a particular frequency bin and time frame, controlling the adaptive filter to have a minimum convergence factor for that frequency bin and time frame.
The first threshold value may be the same as the second threshold value.
Alternatively, the first threshold value may be an upper threshold value while the second threshold value is a lower threshold value, and the upper threshold value is larger than the lower threshold value. In that case, the method may further comprise: if the magnitude coherence is between the upper and lower threshold values for a particular frequency bin and time frame, controlling the adaptive filter convergence factor by generating the convergence factor using a linear relationship, or using a polynomial curve.
The method may further comprise, if the magnitude coherence is above a third threshold value for a particular frequency bin and time frame, controlling the adaptive filter to have a minimum convergence factor for that frequency bin and time frame, or, if the magnitude coherence is below a fourth threshold value for a particular frequency bin and time frame, controlling the adaptive filter to have a maximum convergence factor for that frequency bin and time frame.
The third threshold value may be the same as the fourth threshold value.
Alternatively, the third threshold value may be an upper threshold value while the fourth threshold value is a lower threshold value, and the upper threshold value is larger than the lower threshold value. In that case, the method may further comprise, if the magnitude coherence is between the upper and lower threshold values for a particular frequency bin and time frame, controlling the adaptive filter convergence factor by generating the convergence factor using a linear relationship, or using a polynomial curve.
The first and second input signals may comprise values in a plurality of frequency bins, and the frequency bins may then be grouped into frequency sub-bands and the adaptive filter convergence factor generated for each frequency sub-band.
The magnitude coherence may be a weighted magnitude coherence
A computer program product is also provide comprising computer readable code, for causing a processing device to perform a method according to the previous aspect.
For a better understanding of the present invention, and to show how it may be put into effect, reference will now be made, by way of example, to the accompanying drawings, in which:
Although embodiments of the invention are described herein with reference to use in a mobile phone device, it will be appreciated that the invention is equally applicable to other devices, such as laptop or tablet computers, games consoles, audio-visual devices, or the like. Embodiments of the invention may be used for noise reduction in the application of video communication, for example using a multi-microphone webcam deployed on the top of a laptop computer or TV set. Embodiments of the invention may be used for speech pre-processing in the application of speech recognition or in the application of controlling a smart device using voice commands. In these use cases, there is a danger that the voice commands will not be picked up accurately or will not be completely picked up in noisy or reverberant environments. Embodiments of the invention may be used to detect speech and clean it for better speech recognition.
In this embodiment illustrated in
In the device configuration illustrated in
The inventor has realised that a superior measure for detecting the presence of speech rather than noise is the magnitude coherence between the respective signals generated by two microphones. This measure is explained in more detail below. If a user is speaking, then the magnitude coherence between the signals generated by the two microphones will be high across a significant part of the frequency band. In contrast, if there is no speech, the magnitude coherence between the signals generated by the two microphones will be low.
In some scenarios, the first source signal T may be a target signal, such as the sound of a user speaking, while the second source signal N may be an ambient noise signal, and the device 100 may be positioned and oriented such that the microphone 101 is close to the user's mouth, meaning that the target signal component Tx detected by the microphone 101 is larger than the noise signal component Nx detected by the microphone 101, and that the target signal component Tx detected by the microphone 101 is larger than the target signal component Ty detected by the microphone 102. However, the embodiments described herein do not depend on these conditions, and are equally applicable when the device 100 is used in positions and orientations where these conditions do not apply.
In some application scenarios, there may be multiple noise sources N1, N2 . . . with respective transfer functions, but the noise sources may still be adequately approximated by a single noise source N and pair of transfer functions FNx, FNy.
The sound processing block 200 accepts the signals X(t) and Y(t) and processes them to provide a signal {tilde over (T)}x, representing an estimate of the original target source signal T (or more precisely of the target source related signal Tx as actually received by the microphone via transfer function FTx).
Note that as used herein the term ‘block’ shall be used to refer to a functional unit or module which may be implemented at least partly by dedicated hardware components such as custom defined circuitry and/or at least partly be implemented by one or more software processors or appropriate code running on a suitable general purpose processor or the like. A block may itself comprise other blocks or functional units.
The signal generated by the microphone 101 will therefore be referred to as the voice reference and the signal generated by the microphone 102 will be referred to as the noise reference. It will be appreciated however, that the signal generated by the microphone 101 will contain a component based on the ambient noise, while the signal generated by the microphone 102 will contain a component based on the user's voice. The signal to noise ratio of each microphone depends on the handset orientation and could varies in real use cases.
The voice and noise signals generated by the microphones 101 and 102 respectively are input into an input signal processing block 201. The input signal processing block 201 may comprise an analogue-to-digital conversion function if the microphone signals may be analogue electrical signals, or may comprise some digital processing of the microphone signals such as conversion from an oversampled 1-bit delta-sigma data stream into a multi-bit representation at a lower sample rate, including any necessary filtering. The time domain signals x(t) and y(t) are then used as the input signals for a sound processing circuit 203.
The sound processing circuit 203 comprises a first input 203A for receiving the first input signal x(t) and a second input 203B for receiving the second input signal y(t). Both inputs contain target speech and ambient noise. In circuit 203, x(t) is assumed as target reference and y(t) is assumed as noise reference. Circuit 203 aims to generate a noise estimation from both inputs and subtract it from the target reference x(t) to enhance the target.
The signal x(t) is input into a first adaptive filter 204 which comprises a filter block 205. The filter 204 is a frequency domain adaptive filter. It first transfers the time domain input to the frequency domain using, typically, a Fast Fourier Transform (FFT) block 205A. The FFT may be generated once per frame, each frame comprising a set of signal samples over some time interval. The frames may be disjoint, i.e. non-overlapping in time, or may overlap by one or more time samples. For example each frame may also include the later half of the previous frame's set of samples. The frequency domain signal is denoted as X(k,l), where k is the frequency bin and l denotes the specific time or frame. The adaptive filter block 205 filters the signal X(k,l) based on a set of filter coefficients hT(k,l) to provide a signal Tye(k,l). It is then transferred back to time domain using Inverse FFT (IFFT) block 205B. The time domain signal, denoted as {tilde over (T)}y, is then subtracted by subtractor 209 from the input signal y(t) to provide an error signal Ñy.
The error signal Ñy is transferred back to frequency domain using FFT block 205c, with the result denoted as Nye(k, l). It is then used to update the coefficients of the adaptive filter 205 based on an adaption control and a specific adaptive algorithm. The adaptive filter inherently can only minimise components of Ñy which are correlated to the input x. So {tilde over (T)}y converges to a close estimation of signal component Ty as shown in Figure A, and Ñy converges to the estimation of Ny in Figure A, i.e., to an estimation of noise components of the signal picked up by microphone 102. The result of the adaptation is that the filtering applied to the input signal x corresponds to the ratio of the acoustic transfer function FTy/FTx.
The noise estimate signal Ñy is input into a second adaptive filter 210. This is a frequency domain adaptive filter. It first transfers the time domain input to frequency domain using, typically, a Fast Fourier Transform block 211A The frequency domain signal is denoted as Nye(k,l), where k is the frequency bin and l denotes the specific time or frame. The adaptive filter block 211 filters the signal Nye(k,l) based on a set of filter coefficients hN(k,l) to provide a signal Nxe(k,l). It is then transferred back to time domain using an Inverse FFT (IFFT) block 211B, with the result denoted as Ñx, and this is then subtracted by a subtractor 213 from the input signal x(t). The error signal {tilde over (T)}x is the output of block 203 and is transferred back to frequency domain using FFT block 211c. It is then used to update the coefficients of adaptive filter 211 based on an adaption control and a specific adaptive algorithm. The adaptive filter inherently can only minimise components of {tilde over (T)}x which are correlated to its input signal Ñy so Ñx converges to a close estimate of signal component Nx of Figure A, i.e. the noise component of the signal picked up by microphone 102, and {tilde over (T)}x converges to correspond to signal component Tx of Figure A., i.e. to correspond to the speech component of the signal picked up by microphone 101. The result of the adaptation is that the filtering applied to the noise estimate input signal Ñy corresponds to the ratio of the acoustic transfer functions FNx/FNy.
It will be noted that, for clarity,
The adaptation control blocks in filter blocks 205 and 211 may control the adaption of the applied filter function in any convenient way, as defined by hard-wired or programmable adaptation parameters. For example, the adaptation control blocks may control the adaption of the filters 205, 211 according to the normalised least mean squares (NLMS) method, where each coefficient hT(k,l) or hN(k,l) is updated in each frame according to the magnitude of the corresponding frequency bin signal component of the error signal Nye or Txe, and according to a respective step size adaptation parameter or convergence factor μT(k,l) or μN(k,l):
hT(k,l+1)=.hT(k,l)+μT(k,l).Nye(k,l)X+/∥X∥2
hN(k,l+1)=.hN(k,l)+μN(k,l).Txe(k,l)Nye(k,l)*/∥Nye(k,l)∥2
where (.)* denotes as complex conjugate and ∥.∥2 represents the power calculation. A high value of convergence factor will give rapid convergence, but there is usually some advantage in reducing the bandwidth so as to make the loop over-damped and smooth out the coefficient values actually used.
Adaptation algorithms other than NLMS may be used, and these may operate with adaptation control parameters or step size adaptation control parameters which control the speed of convergence or gain of the adaptation control loop and may thus be regarded as convergence factors, even if the form of equations used is different from that above.
Thus, the first adaptive filter 204 filters the signal x to form filtered signal {tilde over (T)}y that attempts to represent the target signal Ty as detected by the noise microphone 102. The subtractor 209 subtracts signal {tilde over (T)}y from the signal y comprising Ty and Ny generated by the noise microphone, to generate a signal Ñy that attempts to represent only the noise component Ny. The second adaptive filter 211 forms an output that attempts to represent the noise Nx detected by the voice microphone. The subtractor 213 subtracts the output Ñx of the second adaptive filter from the input signal x to generate a signal {tilde over (T)}x which is intended to be more closely representative of the target signal as received by the voice microphone 101.
The signals X(k,l) and Y(k,l), generated from the input signals x(t) and y(t) by an input signal transform block 202, typically an FFT block, are also input into the control block 207. The control block 207 calculates the magnitude coherence between the signals X(k,l) and Y(k,l) and uses it to generate control signals α(k,l) and β(k,l), comprising adaptation parameters, which are provided to the first and second adaptive filters 205 and 211 respectively. It will be noted that
As noted above, there will typically be a low magnitude coherence between the signals X(k,l) and Y(k,l) when there is no target signal present (for example, when the user of the device is not speaking), and a high magnitude coherence between the signals X(k,l) and Y(k,l) when the target signal is present (for example, when the user of the device is speaking).
Thus a first adaptive filter 204 is provided for receiving the first input signal and generating a filtered version {tilde over (T)}y thereof. An error calculation block 209 calculates the error between the second input signal and the filtered signal {tilde over (T)}y of the first adaptive filter, and outputs an error signal Ñy. A second adaptive filter 210 is provided for receiving the error signal, wherein adaptation parameters of the first and second adaptive filters are controlled based on a magnitude coherence between the first and second input signals.
In particular, the control signals α(k,l) and β(k,l) may control the adaption convergence factors μT(k,l) or μN(k,l) of the first and second adaptive filters respectively. The adaption convergence factor for each adaptive filter may be generated for each frequency bin, or for several frequency bands, and for each time interval of the signals X(k,l) and Y(k,l). The magnitudes of the adaption convergence factors of the first and second adaptive filters determine in each case how quickly the respective filter can converge to the desired value. In some embodiments the control signals may convey other control information or adaptation parameters in addition to or instead of LMS convergence factor, for instance to specify an alternative adaptation algorithm or to disable the filter or reset the coefficients to some default as a fault or overload recovery mode.
In some embodiments, as shown in
In such a case, if the user is not speaking it is beneficial for the first filter to adapt only slowly, or not at all, since there is little relevant information on which it can base any adaptation of its coefficients, whereas the second adaptive filter may be adapted more quickly to take advantage of any short gaps in the speech to improve the accuracy of the noise cancellation, in the absence of any possible spurious response due to residual interference from the voice.
Conversely, if the user is speaking it is beneficial for the first adaptive filter to be adapted more quickly to rapidly acquire a filter response that accurately removes speech components from the noise estimate signal. It is beneficial for the second adaptive filter to adapt only slowly or not at all, to avoid possible mis-adaptation due to interference from the residual voice signal or from artefacts due to the adaptation of the first filter.
The convergence factors for the first and second adaptive filters may be generated such that, when the convergence factor in one adaptive filter is a maximum convergence factor, the convergence factor in the other adaptive filter is a minimum convergence factor. For example, if the user is speaking, or a target signal is present, the convergence factor for the noise estimation adaptive filter, i.e the first adaptive filter, is set to be high, and the convergence factor for the noise cancellation adaptive filter, i.e. the second adaptive filter, is set to be low.
Similarly, if the user is not speaking, or there is no target signal, the convergence factor for the noise estimation adaptive filter, i.e the first adaptive filter, is set to be low, and the convergence factor for the noise cancellation adaptive filter, i.e. the second adaptive filter, is set to be high.
The features in this figure which are similar to those in
The sound processing circuit 203A in this embodiment includes two filters that operate similarly to the circuit 203 shown in
The microphone selection block 301 selects the better of the two noise microphones 1021 and 1022 for use in calculating the operative value of the magnitude coherence. For example, the magnitude coherence may be calculated for the pair of signals x(t) and y(t), and for the pair of signals x(t) and z(t), with a decision then being made to select the pair with the maximum coherence when voice is provisionally detected, or the pair with the minimum coherence when an absence of voice is provisionally detected. The remaining noise microphone signal is effectively discounted. Hence, if the microphone 1021 is selected, then the adaptive filters 2051 and 2111 are supplied with the signals α1(k,l) and β1(k,l). The adaptive filters 2052 and 2112 are deactivated or set to attenuate their output signals to zero, possibly as communicated via other control bits associated with bits of α2(k,l) and/or β2(k,l).
Alternatively, if the microphone 1022 is selected, then the adaptive filters 2052 and 2112 are supplied with the signals α2(k,l) and β2(k,l). The adaptive filters 2051 and 2111 are then deactivated or set to attenuate their output signals to zero possibly communicated via other control bits associated with other bits of α1(k,l) and β1(k,l).
Therefore the signals received at the summing block 306, are a noise reduced voice signal {tilde over (T)}x1 derived by adaptive filter 2101 using a noise estimate signal Ñy derived from microphone 1021 and zero signal from adaptive filter 2102 or a noise reduced voice signal {tilde over (T)}x2 derived by adaptive filter 2102 using a noise estimate signal Ñz derived from microphone 1022 and zero signal from adaptive filter 2101 In this illustrated, the output estimate Tx is the better of the estimates {tilde over (T)}x1 and {tilde over (T)}x2. In some embodiments block 306 may be simply a signal selector or multiplexer, forwarding only the desired adaptive filter output.
In other embodiments, in which the device includes more than two microphones, steps may be taken to select one pair of the microphones, with the signals from those two microphones being supplied to the inputs of a sound processing device such as the sound processing device 200 shown in
A calculation block 401 receives the signals X(k,l) and Y(k,l) and calculates the magnitude coherence between the two signals.
Magnitude coherence, Mcoh(k,l) can be calculated in the frequency domain using the equation:
where SX(k,l), SY(k,l) and SXY(k,l) are smoothed signals calculated from the signals X(k,l) and Y(k,l).
Therefore, the calculation block 401 in
Both signals X(k,l) and Y(k,l) are input into a cross conjugation block 505 which outputs the cross conjugation of the two signals, which is referred to as PXY(k,l).
The signals PX(k,l), PY(k,l) and PXY(k,l) are input into smoothing blocks 507, 509, and 511 respectively. These blocks perform time smoothing on their respective input signals in order to reduce the fluctuations of the instantaneous signals. The smoothing blocks 507, 509 and 511 output the signals SX(k,l), SY(k,l) and SXY(k,l) respectively.
For example, the smoothed signals SX(k,l), SY(k,l) and SXY(k,l) may be calculated as:
S
X(k,l)=δSX(k,l−1)+(1−δ)PX(k,l)
S
Y(k,l)=δSY(k,l−1)+(1−δ)PY(k,l)
S
XY(k,l)=δS(k,l−1)+(1−δ)PXY(k,l),
where 0<δ<1.
It will be appreciated that the magnitude coherence may be calculated without this time smoothing step.
The smoothed signals SX(k,l), SY(k,l) and SXY(k,l) are input into a final calculation block 413 which uses the signals to calculate:
and output this as the magnitude coherence Mcoh(k,l).
In some embodiments there may also be a sub-band grouping block 515, which groups the calculation of the magnitude coherence across a number of frequency bins, hence grouping the frequency bins into sub-bands. For example, larger sub-bands may be used for frequencies outside the frequency range of normal speech for applications where speech is the target signal, as these frequencies are unlikely to ever contain any target signal, and so the requirement for accurate processing is reduced.
Returning to
A weighted magnitude coherence is useful when it becomes difficult to differentiate between speech and noise at low frequency bands. This is because the microphone separation on some devices is not large enough to provide sufficient differentiation. As a result, the low frequency components of the target signal at the two microphones become quite well correlated with each other.
An example of how to implement a weighted magnitude coherence is to determine if the mean value of the magnitude coherence across a band of medium-to-high frequencies is below a predetermined threshold value wtd. If so, then a weighting factor is applied to the magnitude coherence by closing the switch 407 such that the previously calculated magnitude coherence is multiplied by the weighting factor w(l) by the multiplication block 403. In other words, if the magnitude coherence is low in a high frequency band, typically because a target signal is not present in the high frequency bands, then there is a high likelihood that there is no target signal present in some of the lower frequency bands, even though there is high correlation in low frequency bands. Hence the magnitude coherence is adjusted, in such a way that it is more likely to show low coherence in the lower frequency bands if there is low coherence in the higher frequency bands.
In this example implementation of a weighting factor, the following equations can be used to determine the weighted magnitude coherence
In this equation, k1 and k2 are two frequency bins both in the medium-to-high frequency range, hence showing whether the magnitude coherence is high or low for high frequencies as described above. wta(k) is frequency dependent or subband dependent and is pre-defined. The value of w0 can be chosen to be between 0 and 1.
The weighted magnitude coherence is input into an adaptive filter convergence factor generation block 409. It will be appreciated, however, that the raw magnitude coherence could be used instead of the weighted magnitude coherence.
The adaptive filter convergence factor generation block 409 calculates the adaption convergence factor for both the first adaptive filter 205 and the second adaptive filter 211 as shown in
For applications where sub-band grouping is used, the adaptive filter convergence factor is generated for each frequency sub-band, and hence the control signals α(k,l) and β(k,l) will contain instructions for each frequency sub-band rather than each frequency bin.
Specifically,
As previously discussed, if the magnitude coherence is large, the convergence factor for a noise estimation adaptive filter is preferably set to be large and the convergence factor for a noise cancellation adaptive filter is preferably set to be small. By contrast, if the magnitude coherence is small, the convergence factor for a noise estimation adaptive filter is preferably set to be small and the convergence factor for a noise cancellation adaptive filter is preferably set to be large.
In some embodiments, if the magnitude coherence is large, i.e. towards the right hand side of the horizontal axes in
Conversely, if the magnitude coherence is small i.e. towards the left hand side of the horizontal axes in
In particular, in
In some embodiments the threshold values M1 and M2 may be equal. In other embodiments the value of M1 is greater than the value of M2.
In
The third threshold value M3 may be the same as the fourth threshold value M4. Alternatively, the third threshold value M3 may be greater than the fourth threshold value M4.
The respective upper threshold values for the first and second adaptive filters, that is the first and third threshold values M1 and M3, may be the same or different. Similarly, the respective lower threshold values for the first and second adaptive filters, that is the second and fourth threshold values M2 and M4, may be the same or different.
In both
Alternatively, if the magnitude coherence is between the upper and lower threshold values (that is, between M1 and M2 or between M3 and M4) for a particular frequency bin and time interval, the adaptive filter convergence factor, for either the first or second adaptive filter, may be controlled by generating the convergence factor using a non-linear relationship, for example a polynomial curve such as one of the curves shown by the dotted lines 603 or 604 shown in
The rate of convergence factor change can also be easily controlled by altering the differences between the thresholds M1 and M2 or M3 and M4. The closer together the value of the thresholds, the faster the convergence factor change will occur.
In step 701 a sound processing circuit receives a first input signal and a second input signal. The first and second input signals may be in the frequency domain.
In step 703 the sound processing circuit calculates the magnitude coherence between the first and second signals.
In step 705 the sound processing circuit uses the magnitude coherence to control the adaptive filter.
The skilled person will thus recognise that some aspects of the above-described apparatus and methods, for example the calculations performed by the processor may be embodied as processor control code, for example on a non-volatile carrier medium such as a disk, CD- or DVD-ROM, programmed memory such as read only memory (Firmware), or on a data carrier such as an optical or electrical signal carrier. For many applications embodiments of the invention will be implemented on a DSP (Digital Signal Processor), ASIC (Application Specific Integrated Circuit) or FPGA (Field Programmable Gate Array). Thus the code may comprise conventional program code or microcode or, for example code for setting up or controlling an ASIC or FPGA. The code may also comprise code for dynamically configuring re-configurable apparatus such as re-programmable logic gate arrays. Similarly the code may comprise code for a hardware description language such as Verilog™ or VHDL (Very high speed integrated circuit Hardware Description Language). As the skilled person will appreciate, the code may be distributed between a plurality of coupled components in communication with one another. Where appropriate, the embodiments may also be implemented using code running on a field-(re)programmable analogue array or similar device in order to configure analogue hardware
Embodiments of the invention may be arranged as part of an audio processing circuit, for instance an audio circuit which may be provided in a host device. A circuit according to an embodiment of the present invention may be implemented as an integrated circuit. One or more loudspeakers may be connected to the integrated circuit in use.
Embodiments may be implemented in a host device, especially a portable and/or battery powered host device such as a mobile telephone, an audio player, a video player, a PDA, a mobile computing platform such as a laptop computer or tablet and/or a games device for example. Embodiments of the invention may also be implemented wholly or partially in accessories attachable to a host device, for example in detachable speakerphone accessories or external microphone arrays or the like. The host device may comprise memory for storage of code to implement methods embodying the invention. This code may be stored in the memory of the device during manufacture or test or be loaded into the memory at a later time.
It should be noted that the above-mentioned embodiments illustrate rather than limit the invention, and that those skilled in the art will be able to design many alternative embodiments without departing from the scope of the appended claims. The word “comprising” does not exclude the presence of elements or steps other than those listed in a claim, “a” or “an” does not exclude a plurality, and a single feature or other unit may fulfil the functions of several units recited in the claims. Any reference numerals or labels in the claims shall not be construed so as to limit their scope. Terms such as amplify or gain include possibly applying a scaling factor of less than unity to a signal.
There is therefore provided a sound processing circuitry for receiving two input signals in the frequency domain and calculating the magnitude coherence between them for use in controlling the convergence factor or other adaptation parameters of adaptive filters which are used in the processing of the two input signals.
Number | Date | Country | |
---|---|---|---|
Parent | 14879401 | Oct 2015 | US |
Child | 15934182 | US |