METHOD AND APPARATUS FOR REDUCING ECHO

Information

  • Patent Application
  • 20160189727
  • Publication Number
    20160189727
  • Date Filed
    December 15, 2015
    9 years ago
  • Date Published
    June 30, 2016
    8 years ago
Abstract
The embodiments of the present disclosure provide a method and an apparatus for reducing an echo, which apply a first stage adaptive filter to a downlink reference signal to obtain a first stage filtered signal and a first error signal; after performing a K-path gain process and a K-path pre-distortion process to the downlink reference signal, apply the at least one second stage adaptive filter to a K-path pre-distorted signal to obtain a second stage filtered signal and a second error signal; and perform a minimum value fusion process to the first error signal and the second error signal so as to obtain a residue signal, which is considered as a final output of adaptive echo cancellation. Accordingly, the present disclosure realizes steadily providing a relatively high echo loss under a circumstance that a speaker suffers a relatively great distortion.
Description
CROSS-REFERENCE TO RELATED APPLICATIONS

The present application claims priority to Chinese patent application No. 201410857171.6, filed on Dec. 30, 2014, and entitled “METHOD AND APPARATUS FOR REDUCING ECHO”, the entire disclosure of which is incorporated herein by reference.


TECHNICAL FIELD

The present disclosure generally relates to echo technology, and more particularly, to a method and an apparatus for reducing an echo.


BACKGROUND

In audio systems, due to existence of signal reflecting paths, interference of echoes is inevitable. Echoes in audio communications include electrical echoes and acoustic echoes, where electrical echoes are caused by signal energy reflection generated by impedance mismatch and acoustic echoes refer to voices from a speaker at a listening side are collected by a microphone and transmitted back to a speaking side, where acoustic echoes include direct acoustic echoes and indirect acoustic echoes. Direct acoustic echoes are voices from a speaker directly collected by a microphone, and indirect acoustic echoes are voices from a speaker collected by a microphone, where the voices pass different paths (e.g. a house or any objects in a house) and are reflected one or more times before being collected by the microphone. Echoes suffering channel latency are transmitted back to the speaking end and heard by a teller, so that causing interference on audios at the speaking end, which reduces clarity of the audios and affects quality of audio communications.


In order to cancel impacts on audio communications by echoes, in 1960s, Sondhi from the Bell Laboratory firstly presented that applying adaptive filters to realize cancellation of echoes. Referring to FIG. 1, a block diagram presenting a conventional system for adaptive echo cancellation is provided. Before a speaker 1 at a close end presents a downlink reference signal that is from a remote end, the downlink reference signal passes through an electrical echo path 2 and form an electrical echo; after the speaker 1 at the close end presents the downlink reference signal, the downlink reference signal is received by a microphone via an acoustic echo path 3 and form an acoustic echo. An adaptive filter 4 performs filtering to the downlink reference signal using an echo path model 5, and use a filtered output (namely, a cancellation signal) to cancel out the acoustic echo so that obtaining a residue signal (namely, an error signal), which is transmitted to the remote end. Simultaneously, an adaptive filtering algorithm 6 inside the adaptive filter 4 modifies parameters of the echo path model 5 based on the downlink reference signal and the error signal, so as to attenuate the remaining acoustic echo gradually.


In echo cancellation technologies, since an acoustic echo possesses characteristics that multi-path, long latency, slow attenuation, time-varying, non-linearity, etc., the adaptive filter 4 with good performance for Acoustic Echo Cancellation (AEC) is needed; especially, for hand-held devices with relatively severe non-linearity, the adaptive filter 4 with even better performance is required. Due to miniaturization of hand-held devices, comparing to regular speakers, micro speakers of the hand-held devices is much smaller in size. In order to achieve a required voice volume of hands-free communications, the micro speakers frequently operate in a non-linear domain, so that distortion becomes even more severe. Under this circumstance, the adaptive filter 4 provides a very unstable echo with very small loss, and the echo generally has no loss while facing a jump signal. Accordingly, providing a method and an apparatus for reducing an echo is required, which steadily provide a relatively high echo loss under a circumstance that a speaker suffers a relatively great distortion.


SUMMARY

Regarding to the problem addressed in the background, embodiments of the present disclosure provide a method and an apparatus for reducing an echo, which steadily provide a relatively high echo loss under a circumstance that a speaker suffers a relatively great distortion.


A method for reducing an echo, including:


invoking a first stage adaptive filter corresponding to a downlink reference signal x(t), and performing a first filtering process to the downlink reference signal x(t) so as to obtain a first stage filtered signal y0(t);


subtracting a target signal by the first stage filtered signal y0(t) so as to obtain a first error signal e0(t);


performing a K-path gain process to the downlink reference signal x(t) so as to obtain a K-path pre-processed signal, where K is a positive integer;


performing a pre-distortion process to the K-path pre-processed signal so as to obtain a corresponding K-path pre-distorted signal rk(t) (k=1, 2, . . . , K);


invoking at least one second stage adaptive filter corresponding to the K-path pre-distorted signal, and performing a second filtering process to the K-path pre-distorted signal so as to obtain a corresponding K-path second stage filtered signal yk(t);


subtracting the first error signal e0(t) by the K-path second stage filtered signal yk(t) so as to obtain a second error signal ek(t), where k=1,2, . . . , K;


performing a minimum value fusion process to the first error signal e0(t) and the second error signal ek(t) so as to obtain a residue signal e(t); and


considering the residue signal e(t) as a final output of adaptive echo cancellation.


In some embodiments, if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a time domain model h0,t, the first error signal e0(t) is expressed as:









e
0



(
t
)


=


d


(
t
)


-


y
0



(
t
)




,







y
0



(
t
)


=



h

0
,
t




x


(
t
)



=




m
=
1

M





h

0
,
t




(
m
)




x


(

t
-
M
+
m

)






,




where d(t) is a target signal, y0(t) is the first stage filtered signal, h0,t is a M-order FIR filter at time t, h0,t=[h0,t(1), h0.t(2), . . . , h0,t(M)]T, a superscript T denotes transpose, custom-character denotes convolution, x(t) is the downlink reference signal, t is a time index and M is a number of order.


In some embodiments, if the echo path model is a time domain model h0,t, the echo path model h0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as:






h
0,t−1
=h
0,t
°Δh
0.t,


where Δh0,t that is a M-order vector with M a positive integer, is a term for updating a parameter of the first stage adaptive filter in time domain.


In some embodiments, if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a frequency domain model H0,t, the first error signal e0(t) is expressed as:






e
0(t)=d(t)−y0(t),





[y0(t−(N−M)+1), y0(t−(N−M)+2), . . . , y0(t)]T=[0(N−M)×MI(N−M)×(N−M)]F[H0,t•R0,t],


where d(t) is the target signal, y0(t) is the first stage filtered signal, t is the time index, N is length of a signal frame, M is the number of order, 0(N−M)×M is a (N−M) by M zero matrix, I(N−M)×(N−M) is a (N−M) by (N−M) identity matrix, F is an inverse discrete Fourier transform matrix, denotes a N-order vector at the time t, and R0,t=F[x(t−N+1), x(t−N+2), . . . , x(t)]T.


In some embodiments, if the echo path model is a frequency domain model H0,t, the echo path model H0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as:






H
0,t+1
=H
0,t
+ΔH
0,t,


where ΔH0,t that is a N-order vector with N a positive integer, is a term for updating a parameter of the first stage adaptive filter in frequency domain.


In some embodiments the pre-distortion mapping function employed by the pre-distortion process is expressed as:






r
k(t)=fk(pk(t)),


where rk(t) is the k-th pre-distorted signal, pk(t) is the k-th pre-processed signal, fk(x)≠cx, fk(x)≠c, c is a constant, and k=1,2, . . . , K.


In some embodiments, if an echo path model in the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is a time domain model hk,t, the second error signal is expressed as:









e
k



(
t
)


=



e
0



(
t
)


-


y
k



(
t
)




,







y
k



(
t
)


=



h

k
,
t





r
k



(
t
)



=




m
=
1

M





h

k
,
t




(
m
)





r
k



(

t
-
M
+
m

)






,




where hk,t is a k-th M-order FIR filter at a time t, k=1,2, . . . , K, hk,t=[hk,t(1), hk,t(2), . . . , hk,t(M)]T, the superscript T denotes transpose, custom-character denotes convolution, t is the time index and M is the number of order.


In some embodiments, if the echo path model is a time domain model hk,t, the echo path model hk,t+1 of the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is updated as:






h
k,t+1
=h
k,t+Δhk,t,


where Δhk,t with k=1, 2, . . . , K that is a M-order vector with M a positive integer, is the term for updating the parameter of the at least one second stage adaptive filter in time domain.


In some embodiments, if the echo path model in the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is a frequency domain model Hk,t, the second error signal ek(t) is expressed as:






e
k(t)=e0(t)−yk(t)





[yk(t−(N−M)+1), yk(t−(N−M)+2), . . . , yk(t)]T=[0(N−M)×MI(N−M)×(N−M)]F[Hk,t•Rk,t],


where yk(t) is the second stage filtered signal, t is the time index, N is length of a signal frame, M is the number of order, 0(N−M)×M is the (N−M) by M zero matrix, I(N−M)×(N−M) is the (N−M) by (N−M) identity matrix, F is the inverse discrete Fourier transform matrix, Hk,t denotes a k-th N-order vector at the time t, Rk,t=F[rk(t−N+1), rk(t−N+2), . . . , rk(t)]T, k=1, 2, . . . , K.


In some embodiments, if the echo path model is a frequency domain model Hk,t, the echo path model Hk,t+1 of the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is updated as:






H
k,t+1
=H
k,t
+ΔH
k,t
9 ,


where ΔHk,t that is a N-order vector with N a positive integer, is a term for updating a parameter of the at least one second stage adaptive filter in frequency domain.


In some embodiments, performing a minimum value fusion process to a first error signal e0(t) and a second error signal ek(t) (k=1, 2, . . . , K) so as to obtain a residue signal, including:


mapping the first error signal e0(t) and the second error signal ek(t) (k=1, 2, . . . , K) to corresponding mapping signals respectively using an invertible space mapping method;


computing metrics corresponding to the mapping signals using a preset minimum metric function;


searching for a minimum metric from the metrics; and


mapping a mapping signal corresponding to the minimum metric back to a space in which the first error signal e0(t) and the second error signal ek(t) reside, so as to obtain the residue signal e(t).


An apparatus for reducing an echo, including:


a first stage filtering unit, adapted for invoking a first stage adaptive filter corresponding to a downlink reference signal x(t), and performing a first filtering process to the downlink reference signal x(t) so as to obtain a first stage filtered signal y0(t);


a first subtracting unit, adapted for subtracting a target signal by the first stage filtered signal y0(t) so as to obtain a first error signal e0(t);


a gain unit, adapted for performing a K-path gain process to the downlink reference signal x(t) so as to obtain a K-path pre-processed signal, where K is a positive integer;


a pre-distortion processing unit, adapted for performing a pre-distortion process to the K-path pre-processed signal so as to obtain a corresponding K-path pre-distorted signal rk(t) (k=1, 2, . . . , K);


a second stage filtering unit, adapted for invoking at least one second stage adaptive filter corresponding to the K-path pre-distorted signal, and performing a second filtering process to the K-path pre-distorted signal so as to obtain a corresponding K-path second stage filtered signal yk(t);


a second subtracting unit, adapted for subtracting the first error signal e0(t) by the K-path second stage filtered signal yk(t) so as to obtain a second error signal ek(t), where k=1,2, . . . , K;


a fusion processing unit, adapted for performing a minimum value fusion process to the first error signal e0(t) and the second error signal ek(t) so as to obtain a residue signal e(t); and


an output unit, adapted for considering the residue signal e(t) as a final output of adaptive echo cancellation.


In some embodiments, if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a time domain model h0,t, the first error signal e0(t) is expressed as:









e
0



(
t
)


=


d


(
t
)


-


y
0



(
t
)




,







y
0



(
t
)


=



h

0
,
t




x


(
t
)



=




m
=
1

M





h

0
,
t




(
m
)




x


(

t
-
M
+
m

)






,




where d(t) is a target signal, y0(t) is the first stage filtered signal, h0,t is a M-order FIR filter at time t, h0,t=[h0,t(1), h0,t(2), . . . , h0,t(M)]T, a superscript T denotes transpose, {circle around (x)} denotes convolution, x(t) is the downlink reference signal, t is a time index and M is a number of order.


In some embodiments, if the echo path model is a time domain model h0,t, the echo path model h0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as:






h
0,t+1
=h
0,t
+Δh
0,t,


where Δh0,t that is a M-order vector with M a positive integer, is a term for updating a parameter of the first stage adaptive filter in time domain.


In some embodiments, if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a frequency domain model H0,t, the first error signal e0(t) is expressed as:






e
0(t)=d(t)−y0(t),






[y
0(t−(N−M)+1), y0(t−(N−M)+2), . . . , y0(t)]T=[0(N−M)×MI(N−M)×(N−M)]F−[H0,t•R0,t],


where d(t) is the target signal, y0(t) is the first stage filtered signal, t is the time index, N is length of a signal frame, M is the number of order, 0(N−M)×M is a (N−M) by M zero matrix, I(N−M)×(N−M) is a (N−M) by (N−M) identity matrix, F is an inverse discrete Fourier transform matrix, H0,t denotes a N-order vector at the time t, and R0,t=F[x(t−N+1), x(t−N+2), . . . , x(t)]T.


In some embodiments, if the echo path model is a frequency domain model H0,t, the echo path model H0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as:






H
0,t+1
=H
0,t
+ΔH
0,t,


where ΔH0,t that is a N-order vector with N a positive integer, is a term for updating a parameter of the first stage adaptive filter in frequency domain.


In some embodiments, the pre-distortion mapping function employed by the pre-distortion process is expressed as:






r
k(t)=fk(pk(t)),


where rk(t) is the k-th pre-distorted signal, pk(t) is the k-th pre-processed signal, fk(x)≠cx, fk(x)≠c, c is a constant, and k=1,2, . . . , K.


In some embodiments, if an echo path model in the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is a time domain model hk,t, the second error signal is expressed as:









e
k



(
t
)


=



e
0



(
t
)


-


y
k



(
t
)




,







y
k



(
t
)


=



h

k
,
t





r
k



(
t
)



=




m
=
1

M





h

k
,
t




(
m
)





r
k



(

t
-
M
+
m

)






,




where is a k-th M-order FIR filter at a time t, k=1,2, . . . , K, hk,t=[hk,t(1), hk,t(2), . . . , hk,t(M)]T, the superscript T denotes transpose, custom-character denotes convolution, t is the time index and M is the number of order.


In some embodiments, if the echo path model is a time domain model hk,t, the echo path model hk,t+1 of the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is updated as:






h
k,t+1
=h
k,t
+Δh
k,t,


where Δhk,t with k=1, 2, . . . , K that is a M-order vector with M a positive integer, is the term for updating the parameter of the at least one second stage adaptive filter in time domain.


In some embodiments, if the echo path model in the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is a frequency domain model Hk,t, the second error signal ek(t) is expressed as:






e
k(t)=e0(t)−yk(t),






[y
k(t−(N−M)+1), yk(t−(N−M)+2), . . . , yk(t)]T=[0(N−M)×MI(N−M)×(N−M)]F[Hk,t•Rk,t],


where yk(t) is the second stage filtered signal, t is the time index, N is length of a signal frame, M is the number of order, 0(N−M)×M is the (N−M) by M zero matrix, I(N−M)×(N−M) is the (N−M) by (N−M) identity matrix, F is the inverse discrete Fourier transform matrix, Hk,t denotes a k-th N-order vector at the time t, Rk,t=F[rk(t−N+1), rk(−N+2), . . . , rk(t)]T, k=1, 2, . . . , K.


In some embodiments, if the echo path model is a frequency domain model Hk,t, the echo path model Hk,t+1 of the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is updated as:






H
k,t+1
=H
k,t
+ΔH
k,t,


where ΔHk,t that is a N-order vector with N a positive integer, is a term for updating a parameter of the at least one second stage adaptive filter in frequency domain.


In some embodiments, the fusion processing unit may include:


a mapping sub-unit, adapted for mapping the first error signal e0(t) and the second error signal ek(t) (k=1, 2, . . . , K) to corresponding mapping signals respectively using an invertible space mapping method;


a metric computing sub-unit, adapted for computing metrics corresponding to the mapping signals using a preset minimum metric function;


a searching sub-unit, adapted for searching for a minimum metric from the metrics; and


a residue signal obtaining sub-unit, adapted for mapping a mapping signal corresponding to the minimum metric back to a space in which the first error signal e0(t) and the second error signal ek(t) reside, so as to obtain the residue signal e(t).


From above, the embodiments of the present disclosure provide a method and an apparatus, which employ the first stage adaptive filter corresponding to the downlink reference signal to perform a first stage echo cancellation to an output of echo cancellation so that the first error signal may be obtained; after performing the K-path gain process and the K-path pre-distortion process to the downlink reference signal, employ the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal to perform a second stage echo cancellation to the output of echo cancellation so that the second error signal may be obtained; then, perform the minimum value fusion process to an output of the first stage echo cancellation and an output of the second stage echo cancellation so as to obtain the residue signal, and consider the residue signal as the final output of adaptive echo cancellation. The embodiments of the present disclosure may employ a method for reducing in cascade an echo to minimize the residue signal obtained finally, which means an echo loss may be relatively large, and thus, the present disclosure realizes steadily providing a relatively high echo loss under a circumstance that a speaker suffers a relatively great distortion.





BRIEF DESCRIPTION OF THE DRAWINGS

For better clarifying embodiments of the present disclosure or prior art, a brief description of drawings needed for the description of the embodiments and prior art is provided. Obviously, the drawings which follow are the embodiments of the present disclosure. By taking effort with creativity, those skilled in the art can acquire other drawings based on the drawings provided.



FIG. 1 schematically illustrates a block diagram presenting an conventional adaptive echo cancellation system;



FIG. 2 schematically illustrates a flow diagram presenting a method for reducing an echo according to one embodiment in the present disclosure;



FIG. 3 schematically illustrates a flow diagram presenting a method for performing a minimum value fusion process to a first error signal and a second error signal so as to obtain a residue signal according to one embodiment in the present disclosure;



FIG. 4 schematically illustrates a structural diagram presenting an apparatus for reducing an echo according to one embodiment in the present disclosure; and



FIG. 5 schematically illustrates a structural diagram presenting a fusion process unit according to one embodiment in the present disclosure.





DETAILED DESCRIPTION

Embodiments of the present disclosure provide a method and an apparatus for reducing an echo so as to realize steadily providing a relatively high echo loss under a circumstance that a speaker suffers a relatively great distortion.


Referring to FIG. 2, a flow diagram presenting a method for reducing an echo according to one embodiment of the present disclosure is provided, and the method includes:


S11: invoking a first stage adaptive filter corresponding to a downlink reference signal x(t), and performing a first filtering process to the downlink reference signal x(t) so as to obtain a first stage filtered signal y0(t);


S12: subtracting a target signal by the first stage filtered signal y0(t) so as to obtain a first error signal e0(t), where subtracting the target signal by the first stage filtered signal is for cancelling a linear echo in the target signal;


S13: performing a K-path gain process to the downlink reference signal x(t) so as to obtain a K-path pre-processed signal, where K is a positive integer; the K-path gain process may include: multiplying the downlink reference signal x(t) by a gain gk(k=1, 2, . . . , K) so as to obtain a K-path pre-processed signal pk(t) (k=1, 2, . . . , K), and corresponding formulas are presented in the following:












p
1



(
t
)


=


g
1


x


(
t
)



,









p
2



(
t
)


=


g
2


x


(
t
)



,














p
K



(
t
)


=


g
K


x


(
t
)



,







where the gains 0≦gk<1 for k=1, 2, . . . , K; specifically, the gain is selected not greater than 1 so as to avoid that the downlink reference signal generates an additional overflow distortion in a digital system;


S14: performing a pre-distortion process to the K-path pre-processed signal so as to obtain a corresponding K-path pre-distorted signal rk(t) (k=1, 2, . . . , K);


S15: invoking at least one second stage adaptive filter corresponding to the K-path pre-distorted signal, and performing a second filtering process to the K-path pre-distorted signal so as to obtain a corresponding K-path second stage filtered signal yk(t);


S16: subtracting the first error signal e0(t) by the K-path second stage filtered signal yk(t) so as to obtain a second error signal ek(t) (k=1,2, . . . , K);


S17: performing a minimum value fusion process to the first error signal e0(t) and the second error signal ek(t) so as to obtain a residue signal e(t);


S18: considering the residue signal e(t) as a final output of adaptive echo cancellation.


From above, the first stage adaptive filter corresponding to the downlink reference signal may perform a first stage echo cancellation to an output of echo cancellation so that the first error signal may be obtained; after performing the K-path gain process and the K-path pre-distortion process to the downlink reference signal, the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal may perform a second stage echo cancellation to the output of echo cancellation so that the second error signal may be obtained; then, the minimum value fusion process is performed to an output of the first stage echo cancellation and an output of the second stage echo cancellation so as to obtain the residue signal, and the residue signal is considered as the final output of adaptive echo cancellation. The embodiments of the present disclosure may employ a method for reducing in cascade an echo to minimize the residue signal obtained finally, which means an echo loss may be relatively large, and thus, the embodiments of the present disclosure realizes steadily providing a relatively high echo loss under a circumstance that a speaker suffers a relatively great distortion.


Specifically, an echo path model in an adaptive filter is either a time domain model or a frequency domain model. Regarding to these two models, the embodiments of the present disclosure provide following descriptions about the first stage adaptive filter corresponding to the downlink reference signal x(t) and the first error signal e0(t).


(1) if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a time domain model h0,t, the first error signal e0(t) is expressed as:









e
0



(
t
)


=


d


(
t
)


-


y
0



(
t
)




,







y
0



(
t
)


=



h

0
,
t




x


(
t
)



=




m
=
1

M





h

0
,
t




(
m
)




x


(

t
-
M
+
m

)






,




where d(t) is a target signal, y0(t) is the first stage filtered signal, h0,t is a M-order FIR filter at time t, h0,t=[h0,t(1), h0,t(2), . . . , h0,t(M)]T, a superscript T denotes transpose, {circle around (x)} denotes convolution, x(t) is the downlink reference signal, t is a time index and M is a number of order; the order M may need to satisfy the simulated echo path model; generally, echo attenuation may last 10 ms to 1 s so that the order M ranges from 0.01 fs to fs, where f, is a sampling frequency.


If the echo path model is the time domain model h0,t, the first stage adaptive filter may employ any one from the time domain adaptive filtering algorithms, where the time domain adaptive filtering algorithms include: the Least Mean Square (LMS), the Normalized Least Mean Square (NMLS), the Affine Projection (AP), the Fast Affine Projection (FAP), the Least Square (LS), the Recursive Least Square (RLS), etc.


An embodiment of the present disclosure uses NMLS:











Δ






h

0
,
t



=



μ

h
,
0




[


Δ







h

0
,
t




(
1
)



,

Δ







h

0
,
t




(
2
)



,





,

Δ







h

0
,
t




(
M
)




]


T








Δ







h

0
,
t




(
m
)



=




e
0



(
t
)




x


(

t
-
M
+
m

)




ɛ
+




m
=
1

M




x


(

t
-
M
+
m

)


2








,




where ε is a small positive real number used for avoiding diving by zero, μk,0 is a step length of update, 0<μh,o<2, the superscript T denotes transpose, M is the number of order, and t is the time index.


The echo path model h0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as: h0,t+1=h0,t+Δh0,t.


(2) if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a frequency domain model H0,t, the first error signal e0(t) is expressed as:






e
0(t)=d(t)−y0(t),






[y
0(t−(N−M)+1), y0(t−(N−M)+2), . . . , y0(T)]T=[0(N−M)×MI(N−M)×(N−M)]F[H0,t•R0,t],


where d(t) is the target signal, y0(t) is the first stage filtered signal, t is the time index, N is length of a signal frame, M is the number of order, 0(N−M)×M is a (N−M) by M zero matrix, I(N−M)×(N−M) is a (N−M) by (N−M) identity matrix, F is an inverse discrete Fourier transform matrix, denotes a N-order vector at the time t, and R0,t=F[x(t−N+1), x(t−N+2), . . . , x(t)]T, • denotes dot product, F is a discrete Fourier transform matrix, and the superscript T denotes transpose.


The order M may need to satisfy the simulated echo path model; generally, echo attenuation may last 10 ms to 1 s so that the order M ranges from 0.01 fs to fs, where fs is the sampling frequency, and N may need to be greater than M.


If the echo path model is the frequency domain model H0,t, the first stage adaptive filter may employ any one from the frequency domain adaptive filtering algorithms, where the frequency domain adaptive filtering algorithms include: the Frequency Domain Adaptive Filter (FDAF), the Multi-Delay Adaptive Filter (MDAF), the Windowing Frequency Domain Adaptive Filter (WDAF), etc. A term for updating a parameter of the first stage adaptive filter in frequency domain is ΔH0,t, where ΔH0,t is a N-order vector with N a positive integer.


An embodiment of the present disclosure uses FDAF:








Δ






H

0
,
t



=


μ

H
,
0







R

0
,
t


*



E

0
,
t




ɛ
+

E


[




R

0
,
t




2

]






,




where ε is a small positive real number used for avoiding diving by zero, a superscript * denotes conjugate, μH,0 is a step length of update, 0<μH.0<2,






E
0,t
=F[e
0(t−N+1), e0(t−N+2), . . . , e0(t)]T,






R
0,t
=F[x(t−N+1), x(t−N+2), . . . , x(t)]T,


E[|R0,t|2] is an expectation of an energy spectrum of R0,t, which is generally obtained by employing the regression method that is:






E[|R
0,t|2]=ηE[|R0,t−1|2]+(1−η)|R0,t|2,


where η is an updating factor satisfying 0<η<1.


The echo path model H0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as: H0,t+1=H0,t+ΔH0,t, where ΔH0,t is a N-order vector with N a positive integer.


In order to further improve the aforementioned embodiment, the S14 specifically is: a K-path pre-distortion mapping function may map the K-path pre-processed signal pk(t) into the K-path pre-distorted signal rk(t), where k=1, 2, . . . , K.


The K-path pre-distortion mapping function employed by the pre-distortion process is expressed as: rk(t)=fk(pk(t)), where rk(t) is the k-th pre-distorted signal, pk(t) is the k-th pre-processed signal, fk(x)≠cx, fk(x)≠c, c is a constant, and k=1,2, . . . , K.


For convenience of designing and using the pre-distortion mapping function, normalizing the pre-distortion mapping function as:









r
k



(
t
)


=


x
max




f
k



(



p
k



(
t
)



x
max


)




,




where xmax is a maximum amplitude of the downlink reference signal x(t), −1≦fk(x)≦1, k=1, 2, . . . , K.


There are many pre-distortion mapping functions, the formulas which are common but not limited to, are listed in the following:






f
k(x)=|x|γ30 c,






f
k(x)=sign(x)|x|γ+c,






f
k(x)=sin(cx),






f
k(x)=tan(cx),


and combinations of them, such as:






f
k(x)=a1|x|γ1+a2 sign(x)|x|γ2+a3 sin(c3x)+a4 tan(c4x)+c.


The pre-distortion mapping function may be a piecewise function, such as:








f
k



(
x
)


=

{





x
+

c
1







x


<

x
1









sign


(
x
)






x


γ


+

c
2






x
1




x


<

x
2







c
3





x
2




x






,






where c, c1, c2, c3, c4, γ, γ1, γ2, a1, a2, a3, a4, x1, x2 are all constant real numbers, and sign( ) denotes a sign function.


A reason for multiple pre-distortion mapping functions are needed for obtaining the pre-distorted signal is that distortion of a speaker possesses features of complexity and time-variance, and it is unlikely for one distortion process to effectively approach a distortion portion in an echo signal, so that the embodiments of the present disclosure employ results of different multi-path distortion processes for providing a plenty of selections to a final minimum fusion.


Specifically, an echo path model in an adaptive filter is either a time domain model or a frequency domain model. Regarding to these two models, the embodiments of the present disclosure provide following descriptions about the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal and the second error signal ek(t).


(1) if an echo path model in the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is a time domain model hk,t, the second error signal ek(t) is expressed as:









e
k



(
t
)


=



e
0



(
t
)


-


y
k



(
t
)




,







y
k



(
t
)


=



h

k
,
t





r
k



(
t
)



=




m
=
1

M





h

k
,
t




(
m
)





r
k



(

t
-
M
+
m

)






,




where hk,t is a k-th M-order FIR filter at a time t, hk,t=[hk,t(1),hk,t(2), . . . , hk,t(M)]T, the superscript T denotes transpose, custom-character denotes convolution, t is the time index and M is the number of order.


The order M may need to satisfy the simulated echo path model; generally, echo attenuation may last 10 ms to 1 s so that the order M ranges from 0.01 fs to fs, where fs is the sampling frequency.


If the echo path model is the time domain model hk,t(k=1, 2, . . . , K), the at least one second stage adaptive filter may employ any one from the time domain adaptive filtering algorithms, where the time domain adaptive filtering algorithms include: the Least Mean Square (LMS), the Normalized Least Mean Square (NMLS), the Affine Projection (AP), the Fast Affine Projection (FAP), the Least Square (LS), the Recursive Least Square (RLS), etc. A term for updating a parameter of the at least one second stage adaptive filter in time domain is Δhk,t(k=1, 2, . . . , K), where Δhk,t is a M-order vector with M a positive integer.


An embodiment of the present disclosure employs NMLS:







Δ






h

k
,
t



=



μ

h
,
k




[


Δ







h

k
,
t




(
1
)



,

Δ







h

k
,
t




(
2
)



,





,

Δ







h

k
,
t




(
M
)




]


T









Δ







h

k
,
t




(
m
)



=




e
k



(
t
)





r
k



(

t
-
M
+
m

)




ɛ
+




m
=
1

M





r
k



(

t
-
M
+
m

)


2





,




where ε is a small positive real number used for avoiding diving by zero, μh,0 and μh,k are the step length of update, 0<μh,0<2, 0<μh,k<2, k=1, 2, . . . , K, and t is the time index.


The echo path model hk,t+1 of the at least one second stage adaptive filter corresponding to the pre-distorted signal is updated as: hk,t+1=hk,t+Δhk,t, where the term for updating the parameter of the at least one second stage adaptive filter in time domain is Δhk,t, where Δhk,t is a M-order vector, M is a positive integer, and k=1, 2, . . . , K.


(2) if the echo path model in the at least one second stage adaptive filter corresponding to the pre-distorted signal is a frequency domain model Hk,t, the second error signal ek(t) is expressed as:






e
k(t)=e0(t)−yk(t),






[y
k(t−(N−M)+1), yk(t−(N−M)+2), . . . , yk(t)]T=[0(N−M)×MI(N−M)×(N−M)]F[Hk,t•Rk,t],


where yk(t) is the second stage filtered signal, t is the time index, N is length of a signal frame, M is the number of order, 0(N−M)×M is the (N−M) by M zero matrix, I(N−M)×(N−M) is the (N−M) by (N−M) identity matrix, F is the inverse discrete Fourier transform matrix, Hk,t denotes a k-th N-order vector at the time t, Rk,t=F[rk(t−N+1),rk(t−N+2), . . . , rk(t)]T, k=1, 2, . . . K, y1(t), y2(t), . . . , yK(t) are K-path filtered output signals, • denotes the dot product, F is the discrete Fourier transform matrix, and the superscript T denotes transpose, k=1, 2, . . . K, and K is a positive integer.


The order M may need to satisfy the simulated echo path model; generally, echo attenuation may last 10 ms to 1 s so that the order M ranges from 0.01 fs to fs , where fs is the sampling frequency, and N may need to be greater than M.


If the echo path model is the frequency domain model Hk,t, the at least one second stage adaptive filter may employ any one from the frequency domain adaptive filtering algorithms, where the frequency domain adaptive filtering algorithms include: the Frequency Domain Adaptive Filter (FDAF), the Multi-Delay Adaptive Filter (MDAF), the Windowing Frequency Domain Adaptive Filter (WDAF), etc. A term for updating a parameter of the at least one second stage adaptive filter in frequency domain is ΔHk,t, where ΔHk,t is a N-order vector with N a positive integer.


An embodiment of the present disclosure employs FDAF:








Δ






H

k
,
t



=


μ

H
,
k






R

k
,
t




E

k
,
t




*



ɛ
+

E


[




R

k
,
t




2

]






,




where ε is a small positive real number used for avoiding diving by zero, the superscript * denotes conjugate, μH,k is a step length of update, 0<μH,k<2 for k=1, 2, . . . , K,






E
k,t
=F[e
k(t−N+1), ek(t−N+2), . . . , ek(t)]T,






R
k,t
=F[r
k(t−N+1),rk(t−N+2), . . . , rk(t)]T,


E[|Rk,t|2] is an expectation of an energy spectrum of Rk,t, which is generally obtained by employing the regression method that is:






E[|R
k,t|2]=ηE[|Rk,t−1|2]+(1−η)|Rk,t|2,


where η is a updating factor satisfying 0<η<1.


The echo path model Hk,t+1 of the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is updated as: Hk,t+1=Hk,t+ΔHk,t, where ΔHk,t is a N-order vector with N a positive integer.


In order to further improve the aforementioned embodiment, referring to FIG. 3, the embodiment of the present disclosure provide a flow diagram presenting a method for performing a minimum value fusion process to the first error signal and the second error signal so as to obtain a residue signal, where the S17 may include: S21: mapping the first error signal e0(t) and the second error signal ek(t) (k=1, 2, . . . , K) to corresponding mapping signals respectively using an invertible space mapping method; S22: computing metrics corresponding to the mapping signals using a preset minimum metric function; S23: searching for a minimum metric from the metrics; S24: mapping a mapping signal corresponding to the minimum metric back to a space in which the first error signal e0(t) and the second error signal ek(t) reside, so as to obtain the residue signal e(t).


Regarding to K+1 error signals (including the first error signal e0(t) and the second error signal ek(t) for k=1, 2, . . . , K, due to adaptive filters have different parameter signals, respective remaining echoes are minimum at different time or in different space. The minimum value fusion process may use a spatial mapping method to map the K+1 error signals e0(t), e1(t), . . . , eK(t) to mapping signals S0,t, S1,t, . . . , SK,1, and the preset minimum metric function may be used to compute the metrics v0, v1, . . . , vK corresponding to the mapping signals S0,t, S1,t, . . . , SK,1. A minimum metric vk_min is searched among the metrics, and a k_min-th mapping signal Sk_min,t corresponding to the minimum metric vk_min is mapped back to an original space, in which the K+1 error signals reside, so as to obtain the residue signal e(t). Eventually, the residue signal e(t) is regarded as the final output of adaptive echo cancellation.


In a simplest minimum value fusion process, the spatial mapping method is short-time signal framing that:





Sk,t[ek(t−L+1),ek(t−L+2), . . . , ek(t)], k=0,1,2, . . . , K,


where Sk,t is the mapping signal, and t is the time index.


A minimum metric function is used for computing a short-time extent that:








v
k

=



f

m





i





n




(

S

k
,
t


)


=




l
=
1

L






e
k



(

t
-
L
+
l

)







,

k
=
0

,
1
,
2
,





,
K
,




where vk is the minimum metric, and t is the time index.


Alternatively, a minimum metric function is used for computing a short-time energy that:








v
k

=



f

m





i





n




(

S

k
,
t


)


=




l
=
1

L





e
k



(

t
-
L
+
l

)


2




,

k
=
0

,
1
,
2
,





,
K
,




where vk is the minimum metric, and t is the time index.


In the aforementioned equations, L is expressed as a short-time interval, which is a positive integer, and a value of L is between 0.001 fs and fs, where fs is the sampling frequency.


The mapping signal Sk_min,t corresponding to the minimum short-time extent or the minimum short-time energy is selected, and a set [ek_min(t−L+1), . . . , ek_min(t)] corresponding to the mapping signal Sk_min,t is regards as a set of final residue signals [e(t−L+1), . . . , e(t)].


In some embodiments, the short-time interval may be overlapped so as to perform smoothing process to both ends of the short-time interval.


A more effective minimum fusion process may include: a frequency-domain transform as presented in the following that: Sk,t=TF([ek(t−L+1), . . . , ek(t)]), k=0,1,2, . . . , K, where Sk,tis the mapping signal, TF denotes a frequency-domain transform, L denotes the short-time interval, which is a positive integer, and the value of L is between 0.001 fs and fs, where fs is the sampling frequency.


The frequency-domain transform TF may include but be not limited that the Discrete Fourier Transform (DFT), the Discrete Cosine Transform (DCT), the Karhunen-Loeve (KL) transform, the Modified Discrete Cosine Transform (MDCT), etc. The frequency-domain transform TF may be invertible and an inverse transform is expressed as TF.


The mapping signal Sk,t obtained by the frequency-domain transform is a vector of LF elements. For different mapping methods, LF may be different. In cases of the DFT transform, the DCT transform and the KL transform, LF is generally equal to L, and in a case of the MDCT transform, LF is equal to L/2. The minimum metric function may be a norm of the mapping signal Sk,t[l], l=1, 2, . . . , LF: fmin(x)=|x|, and alternatively, an addition of a weighted absolute value of a real part of a number and a weighted absolute value of an imaginary part of the number:






f
min(x)=λreal|(real(x)|γrealimag|imag(x)|γimag,


where λareal and λimag are weighting factors, which are non-negative real numbers, and γreal and γimag are order numbers, which are non-negative real numbers.


A metric of the mapping signal Sk,t[l], l=1, 2, . . . , LF is obtained using the minimum metric function that: vk,t=fmin(Sk,t[l]), where vk,l is a minimum metric, an integer index l=1, 2, . . . , LF and k=0, 1, 2, . . . , K.


Based on the metric, the mapping signal Sk,l[l], l=1, 2, . . . , LF is fused as a fused signal Sl[l]=Sk_l,t[l], where an integer index l=1, 2, . . . , LF, and k_l satisfies the following equation that: fmin(Sklt[l])=min([v0,1, v1,l, . . . , vK,l]); at last, performing the inverse frequency-domain transform TF, the fused signal Sl[l], l=1, 2, . . . , LF is inversely mapped to obtain the set of final residue signals that [e(t−L+1), . . . , e(t)], where [e(t−L+1), . . . , e(t)]=TF(St).


In some embodiments, the short-time interval may be overlapped so as to perform smoothing process to both ends of the short-time interval.


Specifically, in the aforementioned embodiments of the present disclosure, K is always a positive integer.


Further, in order to prove that the embodiments of the present disclosure realize steadily providing a relatively high echo loss under a circumstance that a speaker suffers a relatively great distortion, practical tests are performed.


A signal sampling frequency is 8000 Hz. The first stage adaptive filter and the at least one second stage adaptive filter both are FDAF. For the second stage, a two-path pre-distortion process is performed, where the gain for each path is 1, and the pre-distortion mapping functions: f1(x)=sign(x)|x|0.1, f2(x)=sign(x)|x|0.2.


The spatial mapping in the minimum fusion process employs DCT mapping, L=320, M=192, N=512, the minimum metric function is obtained by taking absolute value.


Comparing processing results using the method provided in the present disclosure with processing results using a conventional method, it is noted that a signal processed using the method provided in the present disclosure is smaller than a signal processed using the conventional method, and the present disclosure achieves an improvement of more than 4.2 dB.


Corresponding to the aforementioned embodiments of the method for reducing an echo, the embodiments of the present disclosure further provide an apparatus for reducing an echo.


Referring to FIG. 4, a structural diagram presenting an apparatus for reducing an echo according to one embodiment of the present disclosure is provided, and the apparatus includes: a first stage filtering unit 41, adapted for invoking a first stage adaptive filter corresponding to a downlink reference signal x(t), and performing a first filtering process to the downlink reference signal x(t) so as to obtain a first stage filtered signal y0(t); a first subtracting unit 42, adapted for subtracting a target signal by the first stage filtered signal y0(t) so as to obtain a first error signal e0(t), where subtracting the target signal by the first stage filtered signal is for cancelling a linear echo in the target signal; a gain unit 43, adapted for performing a K-path gain process to the downlink reference signal x(t) so as to obtain a K-path pre-processed signal, where K is a positive integer; the K-path gain process may include: multiplying the downlink reference signal x(t) by a gain gk(k=1, 2, . . . , K) so as to obtain a K-path pre-processed signal pk(t) (k=1, 2, . . . , K), and corresponding formulas are presented in the following:









p
1



(
t
)


=


g
1



x


(
t
)




,







p
2



(
t
)


=


g
2



x


(
t
)




,














p
K



(
t
)


=


g
K



x


(
t
)




,




where the gains 0≦gk≦1 for k=1, 2, . . . , K; specifically, the gain is selected not greater than 1 so as to avoid that the downlink reference signal generates an additional overflow distortion in a digital system; a pre-distortion processing unit 44, adapted for performing a pre-distortion process to the K-path pre-processed signal so as to obtain a corresponding K-path pre-distorted signal rk(t) (k=1, 2, . . . , K); a second stage filtering unit 45, adapted for invoking at least one second stage adaptive filter corresponding to the K-path pre-distorted signal, and performing a second filtering process to the K-path pre-distorted signal so as to obtain a corresponding K-path second stage filtered signal yk(t); a second subtracting unit 46, adapted for subtracting the first error signal e0(t) by the K-path second stage filtered signal yk(t) so as to obtain a second error signal ek(t) (k=1,2, . . . , K); a fusion processing unit 47, adapted for performing a minimum value fusion process to the first error signal e0(t) and the second error signal ek(t) so as to obtain a residue signal e(t); an output unit 48, adapted for considering the residue signal e(t) as a final output of adaptive echo cancellation.


From above, the first stage adaptive filter corresponding to the downlink reference signal may perform a first stage echo cancellation to an output of echo cancellation so that the first error signal may be obtained; after performing the K-path gain process and the K-path pre-distortion process to the downlink reference signal, the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal may perform a second stage echo cancellation to the output of echo cancellation so that the second error signal may be obtained; then, the minimum value fusion process is performed to an output of the first stage echo cancellation and an output of the second stage echo cancellation so as to obtain the residue signal, and the residue signal is considered as the final output of adaptive echo cancellation. The embodiments of the present disclosure may employ a method for reducing in cascade an echo to minimize the residue signal obtained finally, which means an echo loss may be relatively large, and thus, the present disclosure realizes steadily providing a relatively high echo loss under a circumstance that a speaker suffers a relatively great distortion.


Specifically, an echo path model in an adaptive filter is either a time domain model or a frequency domain model. Regarding to these two models, the embodiments of the present disclosure provide following descriptions about the first stage adaptive filter corresponding to the downlink reference signal x(t) and the first error signal e0(t).


(1) if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a time domain model h0,t the first error signal e0(t) is expressed as:









e
0



(
t
)


=


d


(
t
)


-


y
0



(
t
)




,







y
0



(
t
)


=



h

0
,
t




x


(
t
)



=




m
=
1

M





h

0
,
t




(
m
)




x


(

t
-
M
+
m

)






,




where d(t) is a target signal, y0(t) is the first stage filtered signal, h0,t is an M-order FIR filter at time t, h0,t=[h0,t(1), h0,t(2), . . . , h0,t(M)]T, a superscript T denotes transpose, custom-character denotes convolution, x(t) is the downlink reference signal, t is a time index and M is a number of order.


The order M may need to satisfy the simulated echo path model; generally, echo attenuation may last 10 ms to 1 s so that the order M ranges from 0.01 fs to fs, where fs is a sampling frequency.


If the echo path model is the time domain model h0,t, the first stage adaptive filter may employ any one from the time domain adaptive filtering algorithms, where the time domain adaptive filtering algorithms include: the Least Mean Square (LMS), the Normalized Least Mean Square (NMLS), the Affine Projection (AP), the Fast Affine Projection (FAP), the Least Square (LS), the Recursive Least Square (RLS), etc. A term for updating a parameter of the first stage adaptive filter in time domain is Δh0,t, where Δh0,t is a M-order vector with M a positive integer.


An embodiment of the present disclosure employs NMLS:







Δ






h

0
,
t



=



μ

h
,
0




[


Δ







h

0
,
t




(
1
)



,

Δ







h

0
,
t




(
2
)



,





,

Δ







h

0
,
t




(
M
)




]


T









Δ







h

0
,
t




(
m
)



=




e
0



(
t
)




x


(

t
-
M
+
m

)




ɛ
+




m
=
1

M




x


(

t
-
M
+
m

)


2





,




where ε is a small positive real number used for avoiding diving by zero, μh,0 is a step length of update, 0<μh,0<2, the superscript T denotes transpose, M is the number of order, and t is the time index.


The echo path model h0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as: h0,t+1=h0,t+Δh0,t.


(2) if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a frequency domain model H0,t, the first error signal e0(t) is expressed as:






e
0(t)=d(t)−y0(t),





[y0(t−(N−M)+1), y0(t−(N−M)+2), . . . , y0(t)]T=[0(N−M)×MI(N−M)×(N−M)]F[H0,t•R0,t],


where d(t) is the target signal, y0(t) is the first stage filtered signal, t is the time index, N is length of a signal frame, M is the number of order, 0(N−M)×M is a (N−M) by M zero matrix, I(N−M)×(N−M) is a (N−M) by (N−M) identity matrix, F is an inverse discrete Fourier transform matrix, denotes a N-order vector at the time t, and R0,t=F[x(t−N+1), x(t−N+2), . . . , x(t)]T, • denotes dot product, F is a discrete Fourier transform matrix, and the superscript T denotes transpose.


The order M may need to satisfy the simulated echo path model; generally, echo attenuation may last 10 ms to 1 so that the order M ranges from 0.01 fs to fs, where fs is the sampling frequency, and N may need to be greater than M.


If the echo path model is the frequency domain model H0,t, the first stage adaptive filter may employ any one from the frequency domain adaptive filtering algorithms, where the frequency domain adaptive filtering algorithms include: the Frequency Domain Adaptive Filter (FDAF), the Multi-Delay Adaptive Filter (MDAF), the Windowing Frequency Domain Adaptive Filter (WDAF), etc. A term for updating a parameter of the first stage adaptive filter in frequency domain is ΔH0,t, where ΔH0,t is a N-order vector with N a positive integer.


The echo path model H0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as: H0,t+1=H0,t+ΔH0,t, where ΔH0,t is a N-order vector with N a positive integer.


A reason for multiple pre-distortion mapping functions are needed for obtaining the pre-distorted signal is that distortion of a speaker possesses features of complexity and time-variance, and it is unlikely for one distortion process to effectively approach a distortion portion in an echo signal, so that the embodiments of the present disclosure employ results of different multi-path distortion processes for providing a plenty of selections to a final minimum fusion.


Specifically, an echo path model in an adaptive filter is either a time domain model or a frequency domain model. Regarding to these two models, the embodiments of the present disclosure provide following descriptions about the at least one second stage adaptive filter corresponding to the pre-distorted signal and the second error signal ek(t).


(1) if an echo path model in the at least one second stage adaptive filter corresponding to the pre-distorted signal is a time domain model hk,t, the second error signal ek(t) is expressed as:









e
k



(
t
)


=



e
0



(
t
)


-


y
k



(
t
)




,







y
k



(
t
)


=



h

k
,
t





r
k



(
t
)



=




m
=
1

M





h

k
,
t




(
m
)





r
k



(

t
-
M
+
m

)






,




where hk,t is a k-th M-order FIR filter at a time t, hk,t=[hk,t(1), hk,t(2), . . . , hk,t(M)]T, the superscript T denotes transpose, {circle around (x)} denotes convolution, t is the time index and M is the number of order.


The order M may need to satisfy the simulated echo path model; generally, echo attenuation may last 10 ms to 1 s so that the order M ranges from 0.01 fs to fs, where fs is the sampling frequency.


If the echo path model is the time domain model hk,t(k=1, 2, . . . , K), the at least one second stage adaptive filter may employ any one from the time domain adaptive filtering algorithms, where the time domain adaptive filtering algorithms include: the Least Mean Square (LMS), the Normalized Least Mean Square (NMLS), the Affine Projection (AP), the Fast Affine Projection (FAP), the Least Square (LS), the Recursive Least Square (RLS), etc. A term for updating a parameter of the at least one second stage adaptive filter in time domain is Δhk,t(k=1, 2, . . . , K), where Δhk,t is a M-order vector with M a positive integer.


The echo path model hk,t+1 of the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is updated as: hk,t+1=hk,t+ΔAhk,t, where the term for updating the parameter of the at least one second stage adaptive filter in time domain is Δhk,t, where Δhk,t is a M-order vector with M a positive integer, and k=1, 2, . . . , K.


(2) if the echo path model in the at least one second stage adaptive filter corresponding to the pre-distorted signal is a frequency domain model Hk,t, the second error signal ek(t) is expressed as:






e
k(t)=e0(t)−yk(t).






[y
k(t−(N−M)+1), yk(t−(N−M)+2), . . . , yk(t)]T=[0(N−M)×MI(N−M)×(N−M)]F[Hk,t•Rk,t],


where yk(t) is the second stage filtered signal, t is the time index, N is length of a signal frame, M is the number of order, 0(N−M)×M is the (N−M) by M zero matrix, I(N−M)×(N−M) is the (N−M) by (N−M) identity matrix, F is the inverse discrete Fourier transform matrix, Hk,t denotes a k-th N-order vector at the time t, Rk,t=F[rk(t−N+1), rk(t−N+2), . . . , rk(t)]T, k=1, 2, . . . , K, y1(t), y2(t), . . . , yK(t) are K-path filtered output signals, • denotes the dot product, F is the discrete Fourier transform matrix, and the superscript T denotes transpose, k=1, 2, . . . , K, and K is a positive integer.


The order M may need to satisfy the simulated echo path model; generally, echo attenuation may last 10 ms to 1 s so that the order M ranges from 0.01 fs to fs, where fs is the sampling frequency, and N may need to be greater than M.


If the echo path model is the frequency domain model Hk,t, the at least one second stage adaptive filter may employ any one from the frequency domain adaptive filtering algorithms, where the frequency domain adaptive filtering algorithms include: the Frequency Domain Adaptive Filter (FDAF), the Multi-Delay Adaptive Filter (MDAF), the Windowing Frequency Domain Adaptive Filter (WDAF), etc. A term for updating a parameter of the at least one second stage adaptive filter in frequency domain is ΔHk,t, where ΔHk,t is a N-order vector with N a positive integer.


The echo path model Hk,t+1 of the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is updated as: Hk,t+1=Hk,t+ΔHk,t, where ΔHk,t is a N-order vector with N a positive integer and k=1, 2, . . . , K.


In order to further improve the aforementioned embodiment, referring to FIG. 5, the embodiment of the present disclosure provide a structural diagram for a fusion processing unit, which may include: a mapping sub-unit 51, adapted for mapping the first error signal e0(t) and the second error signal ek(t) (k=1, 2, . . . , K) to corresponding mapping signals respectively using an invertible space mapping method; a metric computing sub-unit 52, adapted for computing metrics corresponding to the mapping signals using a preset minimum metric function; a searching sub-unit 53, adapted for searching for a minimum metric from the metrics; a residue signal obtaining sub-unit 54, adapted for mapping a mapping signal corresponding to the minimum metric back to a space in which the first error signal e0(t) and the second error signal ek(t) reside, so as to obtain the residue signal e(t).


Regarding to K+1 error signals (including the first error signal e0(t) and the second error signal ek(t) for k=1, 2, . . . , K, due to adaptive filters have different parameter signals, respective remaining echoes are minimum at different time or in different space. The minimum value fusion process may use a spatial mapping method to map the K+1 error signals e0(t), e1(t), . . . , eK(t) to mapping signals S0,t, S1,t, . . . , SK,t, and the preset minimum metric function may be used to compute the metrics v0, v1, . . . , vK corresponding to the mapping signals S0,t, S1,t, . . . , SK,t. A minimum metric vk_min is searched among the metrics, and a k_min-th mapping signal Sk_min,t corresponding to the minimum metric vk_min is mapped back to an original space, in which the K+1 error signals reside, so as to obtain the residue signal e(t). Eventually, the residue signal e(t) is regarded as the final output of adaptive echo cancellation.


In a simplest minimum value fusion process, the spatial mapping method is short-time signal framing that:






S
k,t
[e
k(t−L+1),ek(t−L+2), . . . , ek(t)], k=0,1,2, . . . , K,


where Sk,t is the mapping signal, and t is the time index.


A minimum metric function is used for computing a short-time extent that:








v
k

=



f

m





i





n




(

S

k
,
t


)


=




l
=
1

L






e
k



(

t
-
L
+
l

)







,

k
=
0

,
1
,
2
,





,
K
,




where vk is the minimum metric, and t is the time index.


Alternatively, a minimum metric function is used for computing a short-time energy that:








v
k

=



f

m





i





n




(

S

k
,
t


)


=




l
=
1

L






e
k



(

t
-
L
+
l

)







,

k
=
0

,
1
,
2
,





,
K
,




where vk is the minimum metric, and t is the time index.


In the aforementioned equations, L is expressed as a short-time interval, which is a positive integer, and a value of L is between 0.001 fs and fs, where fs is the sampling frequency.


The mapping signal Sk_min,t corresponding to the minimum short-time extent or the minimum short-time energy is selected, and a set [ek_min(t−L+1), . . . , ek_min(t)] corresponding to the mapping signal Sk_min,t is regards as a set of final residue signals [e(t−L+1), . . . , e(t)].


In some embodiments, the short-time interval may be overlapped so as to perform smoothing process to both ends of the short-time interval.


A more effective minimum fusion process may include: a frequency-domain transform as presented in the following that: Sk,t=TF([ek(t−L+1), . . . , ek(t)]), k=0,1,2, . . . , K, where Sk,t is the mapping signal, TF denotes a frequency-domain transform, L denotes the short-time interval, which is a positive integer, and the value of L is between 0.001 fs and fs, where fs is the sampling frequency.


The frequency-domain transform TF may include but be not limited that the Discrete Fourier Transform (DFT), the Discrete Cosine Transform (DCT), the Karhunen-Loeve (KL) transform, the Modified Discrete Cosine Transform (MDCT), etc. The frequency-domain transform TF may be invertible and an inverse transform is expressed as TF.


The mapping signal Sk,t obtained by the frequency-domain transform is a vector of LF elements. For different mapping methods, LF may be different. In cases of the DFT transform, the DCT transform and the KL transform, LF is generally equal to L, and in a case of the MDCT transform, LF is equal to L/2. The minimum metric function may be a norm of the mapping signal Sk,t[l], l=1, 2, . . . , LF: fmin(x)=|x|, and alternatively, an addition of a weighted absolute value of a real part of a number and a weighted absolute value of an imaginary part of the number:






f
min(x)=λreal|real(x)|γrealimag|imag(x)|γimag,


where λreal and λimag are weighting factors, which are non-negative real numbers, and γreal and γimag are order numbers, which also are non-negative real numbers.


A metric of the mapping signal Sk,t[l], l=1, 2, . . . , LF is obtained using the minimum metric function that: vk,l=fmin(Sk,l[l]), where vk,l is a minimum metric, an integer index l=1, 2, . . . , LF and k=0, 1, 2, . . . , K.


Based on the metric, the mapping signal Sk,l[l], l=1, 2, . . . , LF is fused as a fused signal St[l]=Sk_l,t[l], where an integer index l=1, 2, . . . , LF, and k_l satisfies the following equation that: fmin(Skl,t[l])=min([v0,l, v1,l]); at last, performing the inverse frequency-domain transform TF, the fused signal Sl[l], l=1, 2, . . . , LF is inversely mapped to obtain the set of final residue signals that [e(t-L+1), e(t)], where [e(t−L+1), . . . , e(t)]=TF(St).


In some embodiments, the short-time interval may be overlapped so as to perform smoothing process to both ends of the short-time interval.


Specifically, in the aforementioned embodiments of the present disclosure, K is always a positive integer.


Specifically, for the embodiments of the apparatus for reducing an echo, the working principle of each component refers to the corresponding embodiments of the method for reducing an echo, thus no more repetition is provided.


Based on the aforementioned description of the embodiments of the present disclosure, those skilled in the art can realize and implement the embodiments of the present disclosure. Modifications to the embodiments of the present disclosure are obvious to those skilled in the art. Without departing from the spirit or scope of the disclosure, the principles defined in the present disclosure can be applied to other embodiments. Accordingly, the present disclosure is not limited to the embodiments in the present disclosure but a largest scope in accordance with the principles and novelties disclosed in the present disclosure.

Claims
  • 1. A method for reducing an echo, comprising: invoking a first stage adaptive filter corresponding to a downlink reference signal x(t), and performing a first filtering process to the downlink reference signal x(t) so as to obtain a first stage filtered signal y0(t);subtracting a target signal by the first stage filtered signal y0(t) so as to obtain a first error signal e0(t);performing a K-path gain process to the downlink reference signal x(t) so as to obtain a K-path pre-processed signal, where K is a positive integer;performing a pre-distortion process to the K-path pre-processed signal so as to obtain a corresponding K-path pre-distorted signal rk(t) (k=1, 2, . . . , K);invoking at least one second stage adaptive filter corresponding to the K-path pre-distorted signal, and performing a second filtering process to the K-path pre-distorted signal so as to obtain a corresponding K-path second stage filtered signal yk(t);subtracting the first error signal e0(t) by the K-path second stage filtered signal yk(t) so as to obtain a second error signal ek(t), wherein k=1,2, . . . , K;performing a minimum value fusion process to the first error signal e0(t) and the second error signal ek(t) so as to obtain a residue signal e(t); andconsidering the residue signal e(t) as a final output of adaptive echo cancellation.
  • 2. The method according to claim 1, wherein, if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a time domain model h0,t, the first error signal e0(t) is expressed as:
  • 3. The method according to claim 2, wherein, if the echo path model is a time domain model h0,t, the echo path model h0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as: h0,t−1=h0,t+Δh0,t,wherein Δh0,t is a term for updating a parameter of the first stage adaptive filter in time domain, where Δh0,t is a M-order vector with M a positive integer.
  • 4. The method according to claim 1, wherein, if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a frequency domain model H0,t, the first error signal e0(t) is expressed as: e0(t)=d(t)−y0(t)[y0(t−(N−M)+1), y0(t−(N−M)+2), . . . , y0(t)]T=[0(N−M)×MI(N−M)×(N−M)]F−[H0,t•R0,t],
  • 5. The method according to claim 4, wherein, if the echo path model is a frequency domain model H0,t, the echo path model H0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as: H0,t+1=H0,t+ΔH0,t,wherein ΔH0,t is a term for updating a parameter of the first stage adaptive filter in frequency domain, where ΔH0,t is a N-order vector with N a positive integer.
  • 6. The method according to claim 1, wherein the pre-distortion mapping function employed by the pre-distortion process is expressed as: rk(t)=fk(pk(t)),
  • 7. The method according to claim 1, wherein, if an echo path model in the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is a time domain model hk,t, the second error signal is expressed as:
  • 8. The method according to claim 7, wherein, if the echo path model is a time domain model hk,t, the echo path model hk,t+1 of the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is updated as: hk,t+1=hk,t+Δhk,t,
  • 9. The method according to claim 1, wherein, if the echo path model in the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is a frequency domain model Hk,t the second error signal ek(t) is expressed as: ek(t)=e0(t)−yk(t), [yk(t−(N−M)+1), yk(t−(N−M)+2), . . . , yk(t)]T=[0(N−M)×MI(N−M)×(N−M)]F−[Hk,t™Rk,t].wherein yk(t) is the K-path second stage filtered signal, t is a time index, N is length of a signal frame, M is a number of order, 0(N−M)×M is a (N−M) by M zero matrix, I(N−M)×(N−M) is a (N−M) by (N−M) identity matrix, F− is an inverse discrete Fourier transform matrix, Hk,t denotes a k-th N-order vector at the time t, Rk,t=F[rk(t−N+1), rk(t−N+2), . . . , rk(t)]T, k=1, 2, . . . , K.
  • 10. The method according to claim 9, wherein, if the echo path model is a frequency domain model Hk,t, the echo path model Hk,t+1 of the at least one second stage adaptive filter corresponding to the pre-distorted signal is updated as: Hk,t+1=Hk,t+ΔHk,t,wherein ΔHk,t is a term for updating a parameter of the at least one second stage adaptive filter in frequency domain, ΔHk,t is a N-order vector, and N is a positive integer.
  • 11. The method according to claim 1, wherein performing a minimum value fusion process to the first error signal e0(t) and the second error signal ek(t) (k=1, 2, . . . , K) so as to obtain a residue signal, comprising: mapping the first error signal e0(t) and the second error signal ek(t) (k=1, 2, . . . , K) to corresponding mapping signals respectively using an invertible space mapping method;computing metrics corresponding to the mapping signals using a preset minimum metric function;searching for a minimum metric from the metrics; andmapping a mapping signal corresponding to the minimum metric back to a space in which the first error signal e0(t) and the second error signal ek(t) reside, so as to obtain the residue signal e(t).
  • 12. An apparatus for reducing an echo, comprising: a first stage filtering unit, adapted for invoking a first stage adaptive filter corresponding to a downlink reference signal x(t), and performing a first filtering process to the downlink reference signal x(t) so as to obtain a first stage filtered signal y0(t);a first subtracting unit, adapted for subtracting a target signal by the first stage filtered signal y0(t) so as to obtain a first error signal e0(t);a gain unit, adapted for performing a K-path gain process to the downlink reference signal x(t) so as to obtain a K-path pre-processed signal, where K is a positive integer;a pre-distortion processing unit, adapted for performing a pre-distortion process to the K-path pre-processed signal so as to obtain a corresponding K-path pre-distorted signal rk(t) (k=1, 2, . . . , K);a second stage filtering unit, adapted for invoking at least one second stage adaptive filter corresponding to the K-path pre-distorted signal, and performing a second filtering process to the K-path pre-distorted signal so as to obtain a corresponding second stage K-path filtered signal;a second subtracting unit, adapted for subtracting the first error signal e0(t) by the K-path second stage filtered signal yk(t) so as to obtain a second error signal ek(t), wherein k=1,2, . . . , K;a fusion processing unit, adapted for performing a minimum value fusion process to the first error signal e0(t) and the second error signal ek(t) so as to obtain a residue signal e(t); andan output unit, adapted for considering the residue signal e(t) as a final output of adaptive echo cancellation.
  • 13. The apparatus according to claim 12, wherein, if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a time domain model h0,t, the first error signal e0(t) is expressed as:
  • 14. The apparatus according to claim 13, wherein, if the echo path model is a time domain model h0,t, the echo path model h0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as: h0,t+1=h0,t+Δh0,t,Wherein Δh0,t is a term for updating a parameter of the first stage adaptive filter in time domain, where Δh0,t is a M-order vector with M a positive integer.
  • 15. The apparatus according to claim 12, wherein, if the echo path model in the first stage adaptive filter corresponding to the downlink reference signal x(t) is a frequency domain model H0,t, the first error signal e0(t) is expressed as: e0(t)=d(t)−y0(t),[y0(t−(N−M)+1), y0(t−(N−M)+2), . . . , y0(t)]T=[0(N−M)×MI(N−M)×(N−M)]F−[H0,t•R0,t],wherein d(t) is a target signal, y0(t) is the first stage filtered signal, t is a time index, N is length of a signal frame, M is a number of order, 0(N−M)×M is a (N−M) by M zero matrix, I(N−M)×(N−M) is a (N−M) by (N−M) identity matrix, F− is an inverse discrete Fourier transform matrix, denotes a N-order vector at the time t, and R0,t=F[x(t−N+1), x(t−N+2), . . . , x(t)]T.
  • 16. The apparatus according to claim 15, wherein, if the echo path model is a frequency domain model H0,t, the echo path model H0,t+1 of the first stage adaptive filter corresponding to the downlink reference signal x(t) is updated as: H0,t+1=H0,t+ΔH0,twherein ΔH0,t is a term for updating a parameter of the first stage adaptive filter in frequency domain, where ΔH0,t is a N-order vector with N a positive integer.
  • 17. The apparatus according to claim 12, wherein the pre-distortion mapping function employed by the pre-distortion process is expressed as: rk(t)=fk(pk(t)),wherein rk(t) is the k-th pre-distorted signal, pk(t) is the k-th pre-processed signal, fk(x)≠cx, fk(x)≠c, c is a constant, and k=1,2, . . . , K.
  • 18. The apparatus according to claim 12, wherein, if an echo path model in the at least one second stage adaptive filter corresponding to the pre-distorted signal is a time domain model hk,t, the second error signal is expressed as:
  • 19. The apparatus according to claim 18, wherein, if the echo path model is a time domain model hk,t, the echo path model hk,t+1 of the at least one second stage adaptive filter corresponding to the pre-distorted signal is updated as: Δhk,t+1=hk,t+Δhk,t,wherein Δhk,t is the term for updating the parameter of the at least one second stage adaptive filter in time domain, where Δhk,t is a M-order vector with M a positive integer, and k=1, 2, . . . , K.
  • 20. The apparatus according to claim 12, wherein, if the echo path model in the at least one second stage adaptive filter corresponding to the K-path pre-distorted signal is a frequency domain model Hk,t, the second error signal ek(t) is expressed as: ek(t)=e0(t)−yk(t),[yk(t−(N−M)+1), yk(N−M)+2), . . . , yk(t)]T=[0(N−M)×MI(N−M)×(N−M)]F−[Hk,t•Rk,t],wherein yk(t) is the K-path second stage filtered signal, t is a time index, N is length of a signal frame, M is a number of order, 0(N−M)×M is a (N−M) by M zero matrix, I(N−M)×(N−M) is a (N−M) by (N−M) identity matrix, F− is an inverse discrete Fourier transform matrix, Hk,t denotes a k-th N-order vector at the time t, Rk,t=F[rk(t−N+1), rk(t−N+2), . . . , rk(t)]T, k=1, 2, . . . , K.
  • 21. The apparatus according to claim 20, wherein, if the echo path model is a frequency domain model Hk,t, the echo path model Hk,t+1 of the at least one second stage adaptive filter corresponding to the pre-distorted signal is updated as: Hk,t+1=Hk,t+ΔHk,t,wherein ΔHk,t is a term for updating a parameter of the at least one second stage adaptive filter in frequency domain, ΔHk,t is a N-order vector, and N is a positive integer.
  • 22. The apparatus according to claim 12, wherein the fusion processing unit comprises: a mapping sub-unit, adapted for mapping the first error signal e0(t) and the second error signal ek(t) (k=1,2, . . . , K) to corresponding mapping signals respectively using an invertible space mapping method;a metric computing sub-unit, adapted for computing metrics corresponding to the mapping signals using a preset minimum metric function;a searching sub-unit, adapted for searching for a minimum metric from the metrics; anda residue signal obtaining sub-unit, adapted for mapping a mapping signal corresponding to the minimum metric back to a space in which the first error signal e0(t) and the second error signal ek(t) reside, so as to obtain the residue signal e(t).
Priority Claims (1)
Number Date Country Kind
201410857171.6 Dec 2014 CN national