The present invention relates to the field of echo, cancellation, particularly to a device and a method for echo cancellation in joint time-frequency domains.
In speech communication, signals from a receiver can merge into signals received by the transmitter via circuitry reflection and acoustic reflection, and are fed to a remote end, resulting in echo there. Echo may interfere with both sides in communication, impact quality of communication and even cause howling in severe eases, which not only makes communication completely impossible, but also might damage communication equipments.
Echo are typically suppressed in speech communication in order to guarantee communication quality and equipment safety. The principle of echo cancellation is as follows: echo signals are generated from receiver signal mat are electro-acoustically transformed into practical sound signals to be played back, and then reflected by the environment. Both the electro-acoustic conversion process in the receiver and the circumstance reflection may be considered as filtering processes, therefore echo signals may be considered as being generated from receiver signal passing a specific filter.
With traditional methods, a suitable filter is designed to cancel echo so as to eliminate echo signals from receiver signal and prevent echo, from interfering with the communication. Reflection environment in actual environment change in real time, which the filter needs to track. Therefore, adaptive filters are generally used as echo path cancellation filters for echo cancellation. The filler may automatically track variation of echo reflecting environment in real time by comparing a receiver signal and a transmitter signal to obtain an accurate echo path for echo cancellation.
Challenges in designing adaptive filters are as follows: 1. In view of the time-varying actual reflection circumstance, the filter must be able to follow changes in time in case that reflection circumstance changes, which means a rapid reaction speed. 2. In case of complex reflection environment and long echo path, it is required that the filter can reflect details of the reflection environment and faithfully simulate the echo path for better echo cancellation and echo residual as little as possible. 3. The filter should not be interfered with by noises and speech at a near end. Generally speaking, the filter design is desired to be rapid, accurate and robust.
Conventional adaptive filtering is typically implemented in time domain or frequency domain. Frequency domain adaptive filtering includes Fourier Transform adaptive filtering, sub-band adaptive filtering and other adaptive filtering in form of time-frequency transformation such as those disclosed in Patent Applications Nos. 200910025855, 200780001928, 200580003444 and 200610144055. Time domain filters react fast to echo and may track echo environment rapidly. However they have more echo residues. Frequency domain adaptive filtering allows for more delicate filter update and low echo residues, but with slow reaction speed. At the moment the communication environment varies, echo would increase significantly, interfering with communication.
It is difficult for a single filter to address both reaction speed and echo residue concerns. Therefore, multiple filters are employed for collective echo cancellation in echo cancellation systems with high performance. Parallel convergence of multiple filters was adopted in the Patent Application No. 200780020102 in which the one with best echo cancellation performance is selected at any given instant as the primary filter for echo cancellation. Some of the multiple filters have a tracking speed first update strategy and some have an echo path estimation accuracy first update strategy. However, with this method utilizing parallel structure, it's necessary to determine accurately convergence of individual filters with different performance and select a currently optimal filter for switching to the filter at different moments. Therefore, they have disadvantages of hard-to-realize system structure and poor stability due to the complex logic.
To address the above-mentioned problems in prior art, the present invention provides a method and device for echo cancellation in combined time-frequency domains. Said method realizes rapid reaction to echo reflection, environment and low echo residue and improves echo cancellation effect as a whole by using an echo canceller in which a time domain filter and a frequency domain filter are cascaded, canceling a portion of echo first with one of the time domain filter and the frequency domain filter and then subjecting signals that have undergone echo cancellation to echo cancellation again with the other of the time domain filter and the frequency domain filter. At the same time, said device for echo cancellation in combined time-frequency domains has a simple structure and is easy to implement.
According to an aspect of the present invention, a method for echo cancellation in combined time-frequency domains is provided, comprising steps of:
receiving a receiver signal and a transmitter signal that are input:
subjecting, by a first echo canceller, the received transmitter signal to echo cancellation based on the received receiver signal to obtain a first echo-cancelled signal;
subjecting, by a second echo canceller, said first echo-cancelled signal to echo cancellation again based on the received receiver signal to obtain a second echo-cancelled signal;
wherein, said first echo canceller is one of a time domain echo canceller and a frequency domain echo canceller, said second echo canceller is the other one of the time domain echo canceller and the frequency domain echo canceller, said first echo canceller comprises a first filter, and said second echo canceller comprises a second filter, and said first and second filters are a time domain filter or a frequency domain filter corresponding to said first and second echo cancellers respectively, the filter parameter of the second filter is updated based on the receiver signal, the second echo-cancelled signal and the filter parameter of the first filter.
According lo another aspect of the present invention, a device for echo cancellation in joint time-frequency domains is provided, which comprising:
a first echo canceller configured to receive an input receiver signal and an input transmitter signal, subjects the received transmitter signal to echo cancellation based on the received receiver signal to obtain a first echo-can ceiled signal;
a second echo canceller cascaded with the first echo canceller, which is configured to subject said first echo-cancelled signal to echo cancellation again based on the received receiver signal to obtain a second echo-cancelled signal;
wherein said first echo canceller Is one of a time domain echo canceller and a frequency domain echo canceller, said second echo canceller is the other one of the time domain echo canceller and the frequency domain echo canceller, said first echo canceller comprises a first filter, said second echo canceller comprises a second filter, and wherein said first and second filters are a time domain, filter or a frequency domain filter corresponding to said first and second echo cancellers respectively, and
the filter parameter of said second filter is updated based on the receiver signal, said second echo-cancelled signal and the filter parameter of the first filter.
The above features and technical advantages of the present invention will become more apparent and easy-to-understand from the following description of embodiments with reference to accompanying drawings.
a and 1b are block diagrams showing respectively two examples of a device for echo cancellation in joint time-frequency domains according to the first embodiment of the present invention;
a and 3b are block, diagrams showing respectively two examples of a device for echo cancellation in joint time-frequency domains according to the second embodiment of the present invention;
The present invention will be further described in detail hereinafter in. connection with drawings and specific embodiments.
a and 1b are block diagrams of two examples of a device for echo cancellation in joint time-frequency domains according to the first embodiment of the present invention respectively.
As shown in
Wherein, the time domain echo canceller 110 further includes: a time domain filter 111 for calculating a time domain echo signal based on receiver signal and a filter parameter of the time domain filter 111; a time domain filter controller 112 connected with the time domain filter 111 and a frequency domain filter 121 for calculating a update amount for the filter parameter of the time domain filter based on receiver signal and time domain echo-cancelled signals and outputting said update amount to the time domain filter 111 and the frequency filter 121; and an adder 113 for subtracting the time domain echo signal from the transmitter signal received by the time domain echo canceller 110 to obtain time domain echo-cancelled signals.
The frequency domain echo canceller 120 further includes: a frequency domain filter 121 for calculating frequency domain echo signals based on receiver signal and the filter parameter of the frequency domain filter 121; an adder 123 for subtracting frequency domain echo signals output from the frequency domain filler 121 that have been transformed into time domain from time domain echo-cancelled signals received by the frequency domain echo canceller 120, so as to output frequency domain echo-cancelled signals processed by the frequency domain echo canceller 120; a frequency domain filter controller 122 connected with the frequency domain filter 121 for calculating a update amount for the filter parameter of the frequency domain filter 121 based on the receiver signal frequency domain echo-cancelled signals and a update amount for the filter parameter of the time domain filter 111 and outputting the update amount for the filter parameter of the frequency domain filter 121 to the frequency domain, filter 121; a data butler 124 connected with a time-to-frequency domain signal converter 125 for organizing a receiver signal or a frequency domain echo-cancelled signal into data frames; a time-to-frequency domain signal converter 125 connected, with the frequency domain filter 121 or the frequency domain filter controller 122 for converting the received time domain signals having been organized into data frames into frequency domain; and a frequency-to-time domain signal converter 126 connected with the frequency domain filter 121 for converting the received frequency domain signals into time domain.
In the device 100 for echo cancellation in joint time-frequency domains described in the above-mentioned first embodiment, the example shown in
As shown in
First of all the time domain echo canceller 110 subjects the received transmitter signal d to echo cancellation based on the received receiver signal x to obtain time domain echo-cancelled signals et. Specifically, in step S202, the time domain filter 111 convolves receiver signal x with the filter parameter h of the time domain filter 111 to obtain the time domain echo signal, in step S203, the adder 113 subtracts the time domain echo signal from the transmitter signal d to obtain time domain echo-cancelled signals et as shown in equation A wherein n denotes the current instant point.
et(n)=d(n)−x(n)*h(n) Equation 1
In step S204, the time domain filter controller 112 updates the filter parameter of the time domain filter 111 based on receiver signal x and time domain echo-cancelled signals. Specific mode for the update is as follows. The time domain filter controller 112 multiplies et by receiver signal x and then divides the product by the power of x for baseline update amount. Constant c is used as the update step size. Then, the time domain filter controller 112 multiplies the baseline update amount by the update step size to obtain an update amount Δh(l) for the filter parameter h of the time domain filter 111. and outputs the update amount Δh(l) to the time domain filter 111 and the frequency domain filter 121 respectively to complete update. Refer to Equation 2 as the update equation, wherein l denotes a lth weight value of the time domain filter 111, L denotes the length of the time domain filter 111, n denotes current moment, x(n−l+1) denotes sample value at moment n−l+1 of receiver signal x, et(n) denotes time domain echo-cancelled signals at current moment, h(l)new denotes updated filter parameter of the time domain filter, h(l)old denotes the filter parameter of the time domain filter 111 before update, and c denotes a constant.
As can be seen from Equation 2, the time domain filter is updated point by point with a last update speed, which allows keeping up with the echo environment and echo path when they change fast.
Then, the frequency domain echo canceller 120 subjects the time domain echo-cancelled signals et output from the time domain echo canceller to a further echo cancellation based on the received receiver signal x, so as to obtain frequency domain echo-cancelled signal ef. In particular, signals input to the frequency domain echo canceller 120 are receiver signal x and time domain echo signal et, and the receiver signal x constitutes data frames via the data buffer 124. The time-to-frequency domain signal converter 125 converts receiver signal x that has been built into data frames from time domain to frequency domain with, an converting equation as shown in the following formula 3, in which k denotes a frequency point and M denotes the length, of the data buffer 124. The time-to-frequency domain signal converter 125 may be implemented with Fourier Transform or sub-hand filtering. In step S205, the receiver signal X that has been converted into frequency domain is multiplied by a filter parameter H of the frequency domain filter 121 to obtain a frequency domain echo signal Echo in frequency domain form, as shown in the following Equation 4. Next the frequency-to-time domain signal converter 126 converts the frequency domain echo signal Echo from frequency domain to time domain to obtain a frequency domain echo signal in time domain form. The frequency-to-time domain signal converter 126 may realize frequency domain to time domain signal conversion with Fourier Transform or sub-band filtering, in step S206, the adder 123 subtracts the above-mentioned frequency domain echo signal that has been converted into time domain from the time domain echo-cancelled signal et to obtain frequency domain echo-cancelled signal ef, as shown in the following Equation 5, in which 1/M is a constant factor used when converting from frequency domain to time domain.
In step S207, the process of updating the filter parameter H of the frequency domain filter 121 is described: update the filter parameter of the frequency domain filter based on a receiver signal, a frequency echo-cancelled signal and an update amount of the filter parameter of the time domain filter. In particular, the frequency domain echo-cancelled signal ef constitutes data frames via me data buffer 124, The time-to-frequency domain signal converter 125 converts the frequency domain echo-cancelled signal ef that has been built into data frames from time domain to frequency domain form ef with a time-to-frequency domain conversion equation shown in Equation 6. Next, the frequency domain filter controller 122 calculates a coherence function between receiver signal X that has been converted into frequency domain and the frequency domain echo-cancelled signal Ef to determine update step size of the frequency domain filter. The coherence function has a value ranging from 0 to 1. A coherence function of value 1 indicates completely similar signals, meaning that there is echo residue and the frequency domain filter should be updated to update the weight value. A coherence function of value 0 indicates completely different signals, meaning that there is no echo residue and the frequency domain filter needs no modification. The larger the value of the coherence function, the snore quickly the frequency domain filter is updated. Furthermore, since the coherence function is a function of frequency, larger values of coherence function in a certain frequency hand mean that signals in this band have stronger similarity. The frequency domain filter controller 122 calculates the update step size C[k] for the frequency domain filter 121 with the coherence function by means of a method expressed in Equation 7, Ef is multiplied by X and then divided by power of X to obtain the baseline update amount. The baseline update amount is multiplied by the update step size C[k] to obtain an update amount ΔH[k] for the filter parameter of the frequency domain filter 121. Then the frequency domain filter controller 122 adds the update amount ΔH[k] to the preceding filter parameter of the frequency domain filter, and subtracts the update amount Δh(l) for the filter parameter of the time domain filter 111 therefrom to complete the update. The update formula for the frequency domain filter 121 is expressed with Equation 8, in which H(k)new represents the updated filter parameter of the frequency domain filter, H(k)old represents the filter parameter of the frequency domain filter before update.
For
In the process of updating the frequency domain filter, there are two ways to determine whether the tiller needs update. One is to make decision on the basis of similarity between the receiver signal X and the frequency domain echo-cancelled signal Bf output from the frequency domain echo canceller, that Is, the determination mode shown in
In particular, in the example shown in
The frequency domain echo-cancelled signal ef constitutes data frames via the data buffer 124. The time-to-frequency domain signal converter 125 converts the frequency domain echo-cancelled, signal ef that has been built into data frames from, time domain to frequency domain form ef with a time-to-frequency domain conversion equation shown in Equation 6. The resultant frequency domain echo signal Echo obtained in step 205 is built Into data frames through the data buffer 124, and the time-to-frequency domain signal converter 125 converts the frequency domain echo signals Echo that has been built into data frames from, time domain into frequency domain form Echo. Next, the frequency domain filter controller 122 calculates a coherence function between the frequency domain echo signal ECHO and the frequency domain echo-cancelled signal Ef to determine update step size of the frequency domain filter. The coherence function has a value ranging from 0 to 1. A coherence function of value 1 indicates completely similar signals, meaning that there is echo residue and the frequency domain filter should be updated to update the weight value. A coherence function of value 0 indicates completely different signals, meaning that there is no echo residue and the frequency domain filter needs no modification. The larger the value of coherence function, the more quickly the frequency domain filter is updated. Furthermore, since the coherence function is a function of frequency, larger values of coherence function in a certain band means that signals in this segment have stronger similarity.
For the determination mode shown in
In which E( ) represents an operation for calculating a expected value, Y represents the frequency domain form (i.e. the frequency domain echo signal) of the echo estimate signal Y, and k represents a frequency point. Calculation of Y is expressed in Equation 10:
In which k represents a frequency point, n represents a time point and M is the length of the data register.
Next Ef is multiplied by Y and then divided by power of Y to obtain the baseline update amount. The baseline update amount is multiplied, by the update step size C[k] to obtain an update amount ΔH[k] for the filter parameter of the frequency domain filter 121. Then the frequency domain filter controller 122 adds the update amount ΔH[k] to the preceding filter parameter of the frequency domain filter, and subtracts the update amount Δh(l) for the filter parameter of the time domain filter 111 therefrom so as to complete the update.
In the above-mentioned embodiments, the time domain echo canceller is used as a first echo canceller for the first echo cancellation, and the frequency domain echo canceller is cascaded with the time domain echo canceller and used as a second echo canceller for the second echo cancellation on the first echo-cancelled signal that has been subjected to the first echo cancellation.
In addition to that, the time domain echo canceller 320 in the device 300 for echo cancellation in joint time-frequency domains has an identical structure with the time domain echo canceller 110 in the device 100 for echo cancellation in joint time-frequency domains, detail description thereof is therefore omitted.
As shown in
First of all the frequency domain echo canceller 310 subjects the received transmitter signal d to echo cancellation based on the received receiver signal x, so as to obtain frequency domain echo-cancelled signal ef. In particular, the data buffer 314 organizes receiver signal x into data frames. The time-to-frequency domain signal converter 315 converts the receiver signal x that has been built into data frames from time domain into frequency domain with a conversion equation same as the above equation 3. In step S402, the frequency domain titter 311 multiplies the receiver signal X that has been converted into frequency domain by a filter parameter 11 of the frequency domain filter to obtain a frequency domain echo signal Echo, which is same as the above Equation 4. Next, the frequency-to-time domain signal converter 316 converts the frequency domain echo signal Echo from frequency domain into time domain. In step S403, the adder 313 subtracts the frequency domain echo signal Echo that has been converted into time domain from the transmitter signal d to obtain the frequency domain echo-cancel led signal ef, which is expressed in the following Equation 11.
In step S404, the update process for the filter parameter H of the frequency domain filter 121 is described, which is substantially the same as that of the above-mentioned step S207. In particular, the data buffer 314 organizes the frequency domain echo-cancelled signal ef into data frames. The time-to-frequency domain signal converter 315 converts the frequency domain echo-cancelled signal ef that, has been built into data frames from time domain to frequency domain form Ef with a time-to-frequency domain conversion equation same as the above-mentioned Equation 6. The frequency domain filter controller 312 calculates the update step size C[k] for the frequency domain filter 311 by using the coherence function by means of a method same as the above-mentioned Equation 7, Ef is multiplied by X and then divided by the power of X to obtain the baseline update amount. The baseline update amount is multiplied by the update step size C[k] to obtain an update amount ΔH[k] for the filter parameter of the frequency domain filter 311, and then the frequency domain filter controller 312 adds the update amount ΔH[k] to the preceding frequency domain filter to complete the update. The update equation for the frequency domain filter 311 is expressed as Equation 12.
in step S405, the time domain filter 321 convolves receiver signal x with the filter parameter h of the time domain filter to obtain a time domain echo signal. In step S406, the adder 323 subtracts the time domain echo signal from the frequency domain echo-cancelled signal ef to obtain time domain echo-cancelled signal et, wherein the formula used in the calculation is expressed in the following Equation 13, wherein n denotes the current instant point.
et(n)=ef(n)−x(n)*h(n) Equation 13
In step S407. the time domain filter controller 322 updates the filter parameter h of the time domain lifter based on the receiver signal x and the time domain echo-cancelled signal as well as an update amount of the parameter of the frequency domain filter. As for specific update mode, the time domain filter controller 322 multiplies et by the receiver signal x and then divides the product by the power of x, and the quotient, being used as the baseline update amount. Constant c is used as the update step size. The time domain filter controller 322 multiplies the baseline update amount by the update step size to obtain an update amount Δh(l) for the filter parameter h of the time domain filter 321, then outputs the update amount Δh(l) to the time domain filter 321 and adds it to the current filter parameter of the time domain filter to obtain a new filter parameter of the time domain filter, wherein the equation used for the update is the same as the above-mentioned Equation 2.
Preferably, in other embodiments of the present invention, the filter parameter of the time domain filler 321 is not updated independently, hut influenced by the update amount ΔH[k] for the filter parameter of the frequency domain filter 311, so as to optimize the filter parameter h of the time domain filter 321 and enhance its update speed. That is, the update amount ΔH[k] tor the filter parameter of the frequency domain filter 311 is further subtracted from h(l)new calculated with Equation 2 to obtain updated filter parameter of the time domain filter, wherein the method for calculation is expressed as Equation 14.
Again, as for
It can be seen from the above detail description of embodiments of the present invention with reference to drawings that, the method and device for echo cancellation in joint time-frequency domains provided in the present invention make the lime domain echo canceller and the frequency domain echo canceller have complementary effects to each other and have advantages of both time domain filters and frequency domain filters. Frequency domain filters may simulate details of an echo path and at the same time, time domain filters may follow environmental changes rapidly when the echo path changes, which allows both last echo cancellation speed and low echo residue.
With the above teaching of the present invention, those skilled in the art may make various improvements and modifications on the basis of the above-mentioned embodiments, all of which are intended to be in the scope of the present invention. Those skilled in the art should appreciate that the above specific description is only tor the purpose of better understanding the present invention and the scope of the present invention is defined by the claims and their equivalents.
Number | Date | Country | Kind |
---|---|---|---|
201010000560.9 | Jan 2010 | CN | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/CN2010/080115 | 12/22/2010 | WO | 00 | 2/7/2012 |