Information
-
Patent Grant
-
5661813
-
Patent Number
5,661,813
-
Date Filed
Tuesday, October 24, 199529 years ago
-
Date Issued
Tuesday, August 26, 199727 years ago
-
Inventors
-
Original Assignees
-
Examiners
- Kuntz; Curtis
- Chang; Vivian
Agents
- Pollock, Vande Sande & Priddy
-
CPC
-
US Classifications
Field of Search
US
- 381 66
- 381 71
- 381 94
- 379 388
- 379 389
- 379 390
- 379 410
- 379 411
- 379 412
-
International Classifications
-
Abstract
A variation in the cross-correlation between current received signals of different channels is extracted which corresponds to the cross-correlation between previous received signals, and the extracted variation is used as an adjustment vector to iteratively adjust the estimation of the impulse response of each echo path. Furthermore, by additionally providing a function of actively varying the cross-correlation between the received signals to such an extent as not to produce a jarring noise, it is possible to reconstruct acoustic signals by individual loudspeakers and utilize received signal added with the cross-correlation variation to obtain the adjustment vector for an estimated echo path vector.
Description
BACKGROUND OF THE INVENTION
The present invention relates to a method and apparatus for multi-channel acoustic echo cancellation which cancel a room echo that causes howling and presents a psycho-acoustic problem in a teleconference system provided with a multi-receive-channel system.
With the widespread proliferation of ISDN, LAN and similar digital networks and the developments of high efficiency speech and image coding techniques in recent years, much attention is now focused on a TV conference system which allows participants to communicate with each other while watching the other's face and a multi-media communication system using personal computers or workstations which also enables data communications or the like. These systems adopt in many cases a hands-free communication system using loudspeakers and microphones to thereby create a more realistic teleconferencing environment. However, the hands-free communication system is attended with the problem of echo and howling generation; the acoustic echo canceling technique is indispensable to avoiding the problem. In fact, acoustic echo cancellers are widely used, but they are mostly for one-channel use and can cancel only an acoustic echo from one (one channel) loudspeaker to one (one channel) microphone. At present, stereo is not uncommon in many TV broadcast programs and music media, for instance, and there is also a growing demand for a multi-channel hands-free communication system. To meet this requirement, it is necessary to implement a multi-channel acoustic echo canceller which permits cancellation of acoustic echoes from a plurality of speakers (a plurality of channels) to a microphone; in recent years, technical problems and solutions thereto have been investigated very actively toward the realization of such a multi-channel echo canceller.
A description will be given, which reference to FIG. 1, of a one-channel echo canceller. In hands-free communication, speech uttered by a person at a remote place is provided as a received signal to a received signal terminal 11 and is radiated from a loudspeaker 12. In FIG. 1, k indicates discrete time and x(k) a received signal sample value. In the following description, x(k) will be referred to simply as a received signal. An echo canceller 14 cancels an echo y(k) which is produced when the received signal x(k) radiated from the loudspeaker 12 is picked up by a microphone 16 after propagating over an echo path 15. The echo y(k) can be molded by such a convolution as follows: ##EQU1## where h(k,n) is the impulse response indicating the transfer function of the echo path 15 at time k and L is the number of taps, which is a constant preset corresponding to the reverberation time of the echo path 15. At first, received signals x(k) from the current time to L-1 are stored in a received signal storage and vector generating part 17. The L received signals thus stored are outputted as a received signal vector x(k), that is, as
x(k)=[x(k), x(k-1), . . . , x(k-L+1)].sup.T ( 2)
where *.sup.T indicates a transposition. In an estimated echo generating part 18 formed by an FIR filter, the inner product of the received signal vector x(k) of Eq. (2) and an estimated echo path vector h(k), which is a filter coefficient vector provided from an echo path estimating part 19, is calculated as follows:
y(k)=h.sup.T (k)x(k) (3)
As a result, an estimated echo or echo replica y(k) is generated. This inner product calculation is equivalent to such a convolution as Eq. (1). In the echo path estimating part 19, the estimated echo path vector h(k) is generated which is used in the estimated echo generating part 18. The most common algorithm which is used for the echo path estimation is an NLMS (Normalized Least Mean Square) algorithm. With the NLMS algorithm, the received signal vector x(k) at time k and a residual echo e(k), i.e. the following error, obtained by subtracting the estimated echo signal y(k) from the output y(k) of the microphone 16 by a subtractor 21,
e(k)=y(k)-y(k) (4)
are used to calculate an estimated echo path vector h(k+1) which is used at time k+1, by the following equation:
h(k+1)=h(k)+.alpha.e(k)x(k)/{x.sup.T (k)x(k)} (5)
where .alpha. is called a step size parameter, which is used to adjust adaptation within the range of 0<.alpha.<2. By repeating the above processing upon each increment of time k, the estimated echo path vector h(k) in the echo path estimating part 19 gradually converges toward a true echo path vector h(k) whose elements are impulse response sequence h(k, n), (where n=0, 1, 2, . . . , L-1) of the true echo path 15 at time k, that is, toward the following echo path vector:
h(k)=[h(k,0), h(k,1), . . . ., h(k,L-1)].sup.T ( 6)
As the result of this, the residual echo signal e(k) given by Eq. (4) can be reduced.
In general, a teleconferencing system of the type having an N (.gtoreq.2) channel loudspeaker system and an M (.gtoreq.1) channel microphone system employs, for echo cancellation, such a configuration as shown in FIG. 2. That is to say, an echo cancellation system 23 is composed of N-channel echo cancellers 22.sub.1, 22.sub.2, . . . , 22.sub.M for processing N-input-one-output time sequence signals, which are each interposed between all of N channels of the receiving side where received signals x.sub.1 (k) to x.sub.N (k) are provided to input terminals 11.sub.1 to 11.sub.N and are radiated from loudspeakers 12.sub.1 to 12.sub.N and one channel of the sending side composed of microphones 16.sub.1 to 16.sub.H. In this instance, the echo cancellation system has a total of N.times.M echo paths 15.sub.nm (1.ltoreq.n.ltoreq.N, 1.ltoreq.m.ltoreq.M). The N-channel echo cancellers 22.sub.1, 22.sub.2, . . . , 22.sub.M, which are each connected between all of the N channels of the receiving side and one channel of the sending side, have such a configuration as shown in FIG. 3, which is an extended version of the configuration of the echo canceller 14 depicted in FIG. 1. This is described in detail, for example, in B. Widow and S. D. Stearns, "Adaptive Signal processing," Prince-Hall, Inc. pp. 198-200 (1985). Now, consider the N-channel echo canceller 22.sub.m connected to the m-th channel (1.ltoreq.m.ltoreq.M) of the sending side. The echo signal y.sub.m (k) that is picked up the m-th channel microphone 16.sub.m is obtained by adding together respective received signals of all channels at the sending side after propagation over respective echo paths 15.sub.1m to 15Nm. Hence, it is necessary to devise how to make the echo path estimation by evaluating only one residual echo e.sub.m (k) in common to all the receiving side channels. At first, for the received signal X.sub.n (k) of each channel, the following received signal vectors are generated in the received signal storage and vector generating parts (17.sub.1, 17.sub.1, . . . , 17.sub.N): ##EQU2## where L.sub.1, L.sub.2, . . . , L.sub.N are numbers of taps, which are constants preset corresponding to reverberation times of the respective echo paths 15.sub.1m, 15.sub.1m, . . . , 15.sub.Nm. The vectors thus generated are combined in a vector combining part 24 as follows:
x(k)=[x.sub.1.sup.T (k), x.sub.2.sup.T (k), . . . , x.sub.N.sup.T (k)].sup.T ( 8)
Also in the echo path estimating part 19.sub.m, estimated echo path vectors h.sub.1m (k), h.sub.2m (k), . . . , h.sub.Nm (k), which are used to simulate N echo paths between the respective receiving side channels and the m-th sending side channel, are combined as follows:
h.sub.m (k)=[h.sub.1m.sup.T (k), h.sub.2m.sup.T (k), . . . , h.sub.Nm.sup.T (k)].sup.T ( 9)
In the case of using the NLMS algorithm, the updating of the combined estimated echo path vector h.sub.m (k) is done as follows:
h.sub.m (k+1)=h.sub.m (k)+.alpha.e.sub.m (k)x(k)/{x.sup.T (k)x(k)} (10)
In the estimated echo generating part 18.sub.m, an estimated echo y.sub.m (k) for the echo y.sub.m (k) picked up in the m-th sending channel is generated by the following inner product calculation:
y.sub.m (k)=h.sub.m.sup.T (k)x(k) (11)
By combining vectors in the respective channels into one vector, the flow of basic processing becomes the same as in the one-channel echo canceller of FIG. 1.
Of the defects of the conventional echo cancellation system for application to the teleconferencing system composed of an N-channel speaker system and an M-channel microphone system, the defect that the present invention is to solve will be described in connection with a two-channel stereo teleconferencing system. Referring now to FIG. 4, speaker/microphone systems at points A and B which are connected via a network NW respectively comprise two speakers 12a.sub.1, 12a.sub.2 and 12b.sub.1, 12b.sub.2 and two microphones 16a.sub.1, 16a.sub.2 and 16b.sub.1, 16b.sub.2. Between two receiving channels and each sending channel there are provided echo cancellers 22a.sub.i, 22a.sub.2 and 22b.sub.1, 22b.sub.2.
In the case of applying the conventional echo canceller to the stereo teleconferencing system which sends and receives signals between the points A and B over two channels, there is presented a problem that each time a speaker at the point A moves or changes to another, person who becomes a speaker an echo from the point B by the speech at the point A increases even if the echo paths 15.sub.11 and 15.sub.21 remain unchanged. The reason for this is that the echo path impulse responses are not correctly estimated in the echo cancellation system at the Point B side.
To explain this problem, attention is paid to the operation of the echo canceller 22b.sub.1 connected to a first sending channel of the echo cancellation system at the point B. Let two-channel received signal vectors be represented as x.sub.1 (k) and x.sub.2 (k). Letting echo path vectors of true echo paths 15.sub.11 and 15.sub.21 of the respective receiving channels be represented as h.sub.11 (k) and h.sub.21 (k), respectively, an echo y.sub.1 (k) that is picked up by the microphone 16.sub.b1 is given by
y.sub.1 (k)=h.sub.11.sup.T (k)x.sub.1 (k)+h.sub.21.sup.T (k)x.sub.2 (k) (12)
On the other hand, an estimated echo y.sub.1 (k) that is generated in the echo canceller is expressed by the following equation using estimated echo path vectors h.sub.11 (k) and h.sub.21 (k) that are generated in the echo canceller:
y.sub.1 (k)=h.sub.11.sup.T (k)x.sub.1 (k)+h.sub.21.sup.T (k)x.sub.2 (k) (13)
When one speaker speaks or utters speech at the point A, the received signal vectors x.sub.1 (k) and x.sub.2 (k) have a very strong cross-correlation. When the received signal vectors x.sub.1 (k) and x.sub.2 (k) have a constant high cross-correlation, the combined vector {h.sub.11.sup.T (k), h.sub.21.sup.T (k)} as the solution of the following equation (14) exists infinitely, forming a subspace H.sub.x inherent in the cross-correlation between the received signal vectors x.sub.1 (K) and x.sub.2 (k).
y.sub.1 (k)=y.sub.1 (k) (14)
On this account, in the case of using an ordinary iterative error minimization algorithm such as the NLMS algorithm, the combined vector {h.sub.11.sup.T (k), h.sub.21.sup.T (K)} converges to a point in subspace H.sub.x nearest the initial point; in general, it does not converge to the true value {h.sub.11.sup.T (k), h.sub.21.sup.T (k)}.
For simplicity, consider the case where the received signal vectors x.sub.1 (k) and x.sub.1 (k) are expressed by constant scalar values p.sub.1 and p.sub.2 and the source signal vector s(k) as follows:
x.sub.i (k)=p.sub.1 s(k), x.sub.2 (k)=p.sub.2 s(k) (15)
The subspace H.sub.x where [h.sub.11.sup.T (k), h.sub.21.sup.T (k)] is allowed to exist can be regarded as a straight line Al in FIG. 5A which satisfies the following equation:
p.sub.1 h.sub.11 (k)+p.sub.2 h.sub.21 (k)=p.sub.2 h.sub.21 (k) (16)
When the adaptation starts from the initial value (0, 0), the steady-state solution [h.sub.11p.sup.T (k), h.sub.21p.sup.T (k)] is obtained as follows:
h.sub.11p (k)={h.sub.11 (k)+h.sub.21 (k)p.sub.2 /p.sub.1 }p.sub.1.sup.2 /(p.sub.1.sup.2 +p.sub.2.sup.2).noteq.h.sub.11 (k) (17)
h.sub.21p (k)={h.sub.11 (k)p.sub.1 /p.sub.2 +h.sub.21 (k)}p.sub.2.sup.2 /(p.sub.1.sup.2 +p.sub.2.sup.2).noteq.h.sub.21 (k) (18)
Hence, Eq. (16) is no longer satisfied when the rate between the scalar values p.sub.1 and p.sub.2 varies, with the result that no echo can be canceled and the echo increases accordingly.
As above, in the case of applying the conventional echo canceller to the teleconferencing system composed of an N-channel loudspeaker system and an M-channel microphone system, if received signals of the respective channels have a cross-correlation, the echo path impulse responses cannot correctly be estimated--this poses the problem that the echo increase whenever the cross-correlation between the received signal varies.
SUMMARY OF THE INVENTION
It is therefore an object of the present invention to provide a method and apparatus for echo cancellation for a multi-channel teleconferencing system which enable echo paths to be correctly estimated regardless of the cross-correlation between multi-channel received signals, and hence permit cancellation of echoes even if the cross-correlation changes.
In one aspect, the present invention is directed to an N-channel echo cancellation method which comprises the steps of:
(a) radiating an input signal x.sub.n (k) of each channel n (n=1, . . . N) as an acoustic signal by a loudspeaker of each channel, said input signal being inputted as a sample every discrete time k and N being an integer equal to or greater than 2;
(b) picking up said N acoustic signals propagating through N echo paths from said N loudspeaker to one microphone to obtain an echo y(k);
(c) obtaining a combined input signal vector x(k)=[x.sub.1.sup.T (k), x.sub.2.sup.T (k), . . . , x.sub.N.sup.T (k)].sup.T by combining input signal vectors x.sub.n (k) of said N channels, each composed of input signal sequences x.sub.n (k), x.sub.n (k-1), . . . , x.sub.n (k-L.sub.n +1) back to time L.sub.n -1 in each channel n;
(d) generating an estimated echo y(k) by inputting said combined input signal vector x(k) into a combined estimated echo path which has a combined estimated impulse response vector h(k) obtained by combining estimated impulse response vectors h.sub.n (k) (n=1, . . . , N) of N echo paths estimated for said N echo paths, each of said N estimated echo paths having L.sub.n tape;
(e) obtaining a residual echo e(k) by subtracting said estimated echo signal y(k) from said echo y(k) picked up by said one microphone;
(f) extracting a variation in the cross-correlation between said input signals of said respective channels by using said residual echo e(k) and said combined input signal vector x(k);
(g) generating an adjustment vector v(k) on the basis of said variation in said cross-correlation;
(h) adjusting said combined estimated impulse response vector h(k) of said combined estimated echo path by using said adjustment vector v(k) to obtain a combined estimated impulse response vector h(k+1) at the next time k+1; and
(i) repeating said steps (a) to (h) upon each increment of time k.
In another aspect, the present invention is directed to an N-channel echo cancellation method which comprises the steps of:
(a) radiating an input signal x.sub.n (k) of each channel n (n=1, . . . , N) as an acoustic signal by a loudspeaker of each channel, said input signal being inputted as a sample every discrete time k and N being an integer equal to or greater than 2;
(b) picking up said N acoustic signals propagating through N echo paths from N loudspeakers to one microphone to obtain an echo y(k);
(c) obtaining a combined input signal vector x(k)=[x.sub.1.sup.T (k), x.sub.2.sup.T (k), . . . , x.sub.N.sup.T (k)].sup.T by combining input signal vectors x.sub.n (k) of said N channels, each composed of input signal sequences x.sub.n (k), x.sub.n (k-1, . . . , x.sub.n (k-L.sub.n +1) back to time L.sub.n -1 in each channel;
(d) calculating an estimated approximate echo by a convolution z.sup.T (k)x(k) and inputting said combined input signal vector x(k) into a combined estimated approximate echo path which has a combined estimated approximate impulse response vector z(k) obtained by combining estimated approximate impulse response vectors z.sub.n (k) (n=1, . . . , N) of N estimated echo paths for said N echo paths, each of said N estimated echo paths having L.sub.n taps;
(e) calculating an auto-correlation vector r.sub.p-1 (k) of said combined input signal vector x(k);
(f) generating a supplementary estimated echo from said auto-correlation vector r.sub.p-1 (k) and a smoothing coefficient vector s.sub.p-1 (k-1) at time k-1;
(g) calculating the sum of said estimated approximate echo and said supplementary estimated approximate echo and outputting it as an estimated echo y(k) for said echo;
(h) calculating a residual echo e(k) by subtracting said estimated echo y(k) from said echo y(k) picked up by said one microphone;
(i) detecting, as pre-filter coefficients .beta..sub.1, . . . , .beta..sub.p, variations in the cross-correlation between said input signals by using current and previous ones of said residual echo e(k) and said combined input signal vector x(k);
(j) generating a smoothing coefficient vector s.sub.p-1 (k) by smoothing said pre-filter coefficients;
(k) adjusting said estimated approximate impulse response z(k) on the basis of said smoothing coefficient vector s.sub.p-1 (k) and said previous combined input signal vector x(k-p+1) to obtain z(k+1); and
(l) repeating said steps (a) to (k) upon each increment of time k.
In still another aspect, the present invention is directed to an echo cancellation method for a multi-channel teleconferencing system, which comprises the steps of:
(a) adding a variation to the cross-correlation between input signals of respective channels;
(b) radiating, as an acoustic signal, said input signal of each channel added with said variation, by a loudspeaker for each channel;
(c) picking up said acoustic signal propagating through each echo path from said loudspeaker to a microphone;
(d) subtracting an estimated echo from said microphone and calculating an adjustment vector on the basis of the resulting residual echo and said input signal of said each channel added with said variation;
(e) iteratively adjusting the estimation of impulse response of said each echo path by using said adjustment vector;
(f) generating estimated echo paths each having said adjusted impulse response; and
(g) generating said estimated echo by applying a corresponding one of said input signals to each of said estimated echo paths.
The echo cancellers according to the present invention have configurations for performing the steps of the first-, second- and third-mentioned methods, respectively.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a block diagram showing a one-channel echo canceller;
FIG. 2 is a block diagram showing a multi-channel echo canceller system;
FIG. 3 is a block diagram showing a conventional multi-channel echo canceller;
FIG. 4 is a block diagram showing a stereo teleconferencing system;
FIG. 5A is a graph showing an echo path estimating operation when received signals have a cross-correlation;
FIG. 5B is a graph showing an echo path estimating operation when the cross-correction varies;
FIG. 6 is a block diagram illustrating the construction of a multi-channel echo canceller embodying the first-mentioned method of the present invention;
FIG. 7 is a block diagram illustrating the construction of a cross-correlation variation extracting part 31 in FIG. 6;
FIG. 8 is a block diagram illustrating an example of the construction of a cross-correlation variation coefficient calculating part 31A in FIG. 7;
FIG. 9 is a block diagram illustrating an embodiment in which a cross-correlation variation emphasis vector generating part 31B, an adjusting part 32 and an estimated echo generating part 18m in FIG. 7 are formed by a simplified estimated echo generating part 180m using an approximate echo path vector;
FIG. 10 is a block diagram illustrating the construction of the simplified estimated echo generating part 180m in FIG. 9;
FIG. 11 is a block diagram illustrating the configuration of a multi-channel echo canceller embodying the third-mentioned method of the present invention;
FIG. 12 is a block diagram illustrating an example of a digital filter for implementing the third-mentioned method of the present invention;
FIG. 13 is a graph showing the convergence of the estimated echo path vector according to the first- or second-mentioned method of the present invention;
FIG. 14 is a graph showing the convergence characteristic of the estimated echo path vector according to the first- or second-mentioned method of the present invention, with the order p of a projection algorithm used as a parameter;
FIG. 15 is a block diagram illustrating a teleconferencing system which provides a sound image localization function in four-point communications;
FIG. 16 is a graph showing the comparison between a cross-correlation extracting method and a conventional method in terms of the magnitude of an error vector between a true echo path and estimated one in the case of fixed cross-correlation stereo signals being received; and
FIG. 17 is a graph comparing error vectors by a correlation variation extracting method embodying the third-mentioned method of the present invention and a conventional extracting method.
DESCRIPTION OF THE PREFERRED EMBODIMENTS
The first- or second-mentioned method of the present invention will be described concretely. A description will be given first of the operation of the echo path estimating part of the multi-channel echo canceller in the case where the cross-correlation between multi-channel received signals varies.
For brevity, consider that as a variation in the cross-correlation between the two-channel stereo received signals x.sub.1 (k) and x.sub.2 (k) expressed by Eq. (15), the scalar values p.sub.1 and p.sub.2 in Eq. (15) change to q.sub.1 to q.sub.2, where the ratio of q.sub.1 :q.sub.2 is different from that of p.sub.1 :p.sub.2. The estimated echo path vector {h.sub.11.sup.T (k), h.sub.21.sup.T (k)} converges first to {h.sub.11p.sup.T (k), h.sub.21p.sup.T (k)} of Eqs. (17) and (18). Next, when the scalar values p.sub.1 and p.sub.2 change to q.sub.1 and q.sub.2, the estimated echo path vector converges to a point {h.sub.11q.sup.T (k), h.sub.21q.sup.T (k)} of the shortest distance from an initial value {h.sub.11p.sup.T (k), h.sub.21p.sup.T (k)}. This operation is interpreted geometrically as shown in FIG. 5B. Here, the steady-state solution {h.sub.11q.sup.T, h.sub.21q.sup.T } is the intersection of a straight line
q.sub.1 h.sub.11 +q.sub.2 h.sub.21 =q.sub.1 h.sub.11 +q.sub.2 h.sub.21
and its perpendicular line which includes {h.sub.11p.sup.T, h.sub.21p.sup.T }. Accordingly, it is obvious that the norm of filter coefficient error vectors e.sub.p and e.sub.q generally bear a relationship .parallel.e.sub.p .parallel.>.parallel.e.sub.q .parallel.. This means that upon each variation in the cross-correlation between the received signals, the norm of the filter coefficient error vector becomes smaller. That is to say, the variation in the cross-correlation between the multi-channel received signals causes an increase in echo when the echo path estimation is incorrect in the echo canceller, but it can be considered as effective information that permits estimation of the true echo path in the echo path estimating part after the variation in the cross-correlation repeats an infinite number of times. In the past, since such a fact has not been noticed, the cross-correlation between multi-channel received signals has been treated as fixed; therefore, it could have been not supposed that the norm of the error vector becomes small.
As described previously, the present invention extracts and utilizes information on the variation in the cross-correlation between received signals of respective channels. In the present invention, the multi-channel received signal vectors are combined into a single vector. On this account, the variation in the cross-correlation between the received signals of the respective channels appears in the auto-correlation which is the correlation between the current combined received signal vector and the past combined received signal vector. Hence, to remove an unvaried component of the cross-correlation of the received signal of each channel to extract therefrom a varied component of the cross-correlation, it is possible to use a scheme that reduces the auto-correlation of the combined received signal vector, that is, removes its auto-correlation.
This can be done by a decorrelation scheme using a projection algorithm, RLS algorithm or linear prediction, which are applied to the conventional one-channel echo canceller. Of these schemes, the scheme using linear prediction is to linearly predict a speech signal and remove its auto-correlation by using the linear predictive coefficients. The RLS algorithm can be regarded as a specific form of the projection algorithm. Thus, the projection algorithm will be described below as an example of the most practical decorrelation scheme.
The projection algorithm has been proposed as a scheme for improving the convergence speed of a speech or similar signal having a high auto-correlation. The projection algorithm is described in detail in Ozeki and Umeda, "An Adaptive Filtering Algorithm Using an Orthogonal Projection to an Affine Subspace and Its Properties," Journal of Institute of Electronics, Information and Communication Engineers of Japan (A), J67-App. 126-132, (1984-2).
In general, a p-th order projection algorithm for multi-channel inputs adjusts or corrects the estimated echo path vector h(k) in such a manner as to obtain correct outputs y(k), y(k-1), . . . , y(k-p+1) with respect to p previous input signal vectors x(k), x(k-1), . . . , x(k-p+1). That is to say, an estimated echo path vector h(k+1) is calculated which satisfies the following conditions:
x.sup.T (k)h(k+1)=y(k)
x.sup.T (k-1)h(k+1)=y(k-1): x.sup.T (k-p+1)h(k+1)=y(k-p+1) (19)
where
x(k)=[x.sub.1.sup.T (k), x.sub.2.sup.T (k), . . . , x.sub.N.sup.T (k)].sup.T
and ##EQU3## When the number p of the equation is smaller than the number of unknowns (the number of taps), L=L.sub.1 +L.sub.2 + . . . L.sub.N, the solution h(k+1) of the simultaneous equations of Eq. (19) is indefinite. Then, the estimated echo path vector is adjusted or corrected in such a manner as to minimize the magnitude of adjustment .parallel.h(k+1)-h(k).parallel.. The p-th order projection algorithm is expressed by the following equation: ##EQU4## where
x(k)=[x(k), x(k-1), . . . , x(k-p+1)] (22)
e.sub.p (k)={e(k), (1-.alpha.)e(k-1), . . . , (1-.alpha.).sup.p-1 e(k-p+1)].sup.T (23)
e.sub.p (k)=y(k)-h(k) (24)
h(k)=h.sup.T (k)x(k) (25)
g.sub.p (k)=[.beta..sub.1, .beta..sub.2, . . . , .beta..sub.p ].sup.T (26)
+: generalized inverse matrix
-1: inverse matrix.
In the above g.sub.p (k) is a solution of the following simultaneous linear equations with p unknowns
[X.sup.T (k)X(k)]g.sub.p (k)=e.sub.p (k) (27)
and it indicates coefficients of the variation in the cross-correlation between the received signal vectors x.sub.1 (k) to x.sub.N (k) by changes in time k. The second terms having the coefficient .alpha. on the right side of Eq. (21) is the adjustment vector, with which the estimated echo path vector is iteratively updated. For the projection algorithm, there have been proposed several fast calculation methods intended to reduce the computational complexity; such methods are described in detail in Japanese Pat. Appln Nos. 102419.94 and 184742/93. The case where the input/output at the minus time is made zero and p is set at infinity corresponds to the RLS algorithm.
In the case of adjusting the estimated echo path vector h(k) by the conventional NLMS algorithm based on Eq. (10), it is adjusted in the direction of the input signal vector x(k). On the other hand, according to the first method of the present invention, the second term on the right side of the fourth equation of Eq. (21) by the projection algorithm is set as follows:
v(k)=.beta..sub.1 x(k)+.beta..sub.2 x(k-1)+. . . +.beta..sub.p x(k-p+1) (28)
and the estimated echo path vector h(k) is adjusted in the direction of the vector v(k), that is, in the direction in which the correlation to all of p-1 previous combined input signal vectors x(k-1), . . . , x(k-p+1) has been removed from the combined vector x(k) of the multi-channel input signals. In other words, the coefficients .beta..sub.1 to .beta..sub.p are determined so that the vector v(k) becomes a signal having removed similar previous combined input signal vectors from the combined input signal vector. Such coefficients .beta..sub.1 to .beta..sub.p can be obtained by calculating the vector g.sub.p (k) which satisfies Eq. (27). While .alpha.v(k) is used as the adjustment vector in Eq. (21), v(k) will hereinafter be referred to as an adjustment vector. When the combined received signal vector x(k) is a combined vector of multi-channel signal vectors having a high cross-correlation, the vector v(k) of Eq. (28) becomes a vector having the variation in the cross-correlation emphasized, with the non-varying component removed.
As described previously, the prior art does not recognize that when the cross-correlation between multi-channel received signals varies, the norm of the error vector of the estimated filter coefficients (the estimated echo path vector) becomes small; only in increase in echo is recognized in the prior art. Hence, the model is simplified and it is assumed that a state change which causes the variation in the cross-correlation, such as the shift or change of the speaker, does not occur. Accordingly there has not been recognized in the prior art an essential difference between the NLMS algorithm and the projection algorithm as to whether the true transfer function of the echo path can be estimated or not when they are applied to the multi-channel echo canceller; hence, the effectiveness of the projection algorithm in the estimation of the true echo path has not been recognized. According to the present invention, attention is directed to the case where the cross-correlation varies, and the variation is extracted for use as the adjustment vector--this has clarified that the estimated transfer function of the estimated echo path can be made to converge to the true transfer function of the echo path at high speed.
In Eq. (27), X.sub.p.sup.T (k)X.sub.p (k), which is a matrix with p rows and p columns, is a p-th order covariance matrix or auto-correlation matrix and will hereinafter be identified as follows:
R.sub.p (k)=X.sub.p.sup.T (k)X.sub.p (k) (29)
The coefficients .beta..sub.1, .beta..sub.2, . . . , .beta..sub.p in Eq. (28) will hereinafter be referred to as pre-filter coefficients, and a vector using them as elements is expressed by the following equation (30) and will be referred to as pre-filter coefficient vector.
g.sub.p (k)=[.beta..sub.1, .beta..sub.2, . . . , .beta..sub.p ].sup.T (30)
The pre-filter coefficient vector g.sub.p (k) can be calculated by a recursion formula composed of the following two equations: ##EQU5## where a.sub.p (k) is a p-th order forward linear prediction coefficient vector which satisfies a normal equation R.sub.p (k)a.sub.p (k)=[F(k), 0, . . . ,0].sup.T concerning the input signal x(k) and its leading element is 1. F(k) is the minimum value of the sum of forward a posteriori prediction-error squares. b.sub.p (k-1) is a p-th order backward linear prediction coefficient vector which satisfies a normal equation R.sub.p (k-1)b.sub.p (k-1)=[0, . . . , B(k-1)].sup.T, and its last element is 1. B(k-1) is the minimum value of the sum of backward a posteriori prediction-error squares. It is disclosed in J. M. Cioffi and T. Kailath, "Windowed fast transversal adaptive filter algorithms with normalization," IEEE Trans. Acoust., Speech, Signal Processing, vol. ASSP-33, No. 3, pp. 607-625 that the linear prediction coefficient vectors a.sub.p (k), b.sub.p (k-1) and the minimum values of the sum of a posteriori prediction-error squares F(k) and B(k-1) can be calculated at high speed with a small amount of calculation through utilization of, for instance, FTF (Fast Transversal Filter) algorithm. f.sub.p-1 (k) is called a pre-filter conductor coefficient vector and is given by the following equation:
f.sub.p-1 (k)=R.sub.p-1 (k).sup.-1 e.sub.p-1 (k) (33)
By substituted elements of the pre-filter coefficient vector g.sub.p, obtained from Eqs. (31) and (32), into Eq. (28), the adjustment vector v(k) can be calculated with a small amount of calculation.
While in the above the multi-channel projection algorithm has been described in connection with the case where the adjustment vector v(k) is derived from the pre-filter coefficient vector g.sub.p (k) and is used to adjust the estimated transfer function (the estimated echo path vector (h(k) by Eq. (21), it is possible to obtain the estimated echo y.sub.m (k) from the pre-filter coefficient vector g.sub.p (k) at high speed and with less computational complexity instead of calculating the adjustment vector v(k), as described below. At first, the auto-correlation vector r.sub.p-1 (k) of the input signal vector x(k) of each channel is defined by the following equation:
r.sub.p-1 (k)=[x.sup.T (k)x(k-1),x.sup.T (k)x(k-2), . . . ,x.sup.T (k)x(k-p+1)].sup.T (34)
The pre-filter coefficients .beta..sub.i, which are the elements of the pre-filter coefficient vector, are smooth by the following equation to define smoothing coefficients s.sub.i (k): ##EQU6## An approximate transfer function z(k) which approximates the estimated transfer function h(k) is defined by the following equation: ##EQU7## Furthermore, defining by the following equation a smoothing coefficient vector s.sub.p-1 (k-1) which uses the smoothing coefficients s.sub.i (k) (i=1, . . . , p.sub.- 1) of Eq. (35) as its elements:
s.sub.p-1 (k-1)=[s.sub.1 (k-1), s.sub.2 (k-1), . . . , s.sub.p-1 (k-1)].sup.T (37)
the estimated echo y.sub.m (k) can be calculated by the following equation from the inner product r.sub.p-1.sup.T (k)s.sub.p-1 (k-1) and the convolution z.sup.T (k)x(k):
y.sub.m (k)=z.sup.T (k)x(k)+r.sub.p-1.sup.T (k)s.sub.p-1 (k-1) (38)
A description will be given of a concrete procedure of the above-mentioned multi-channel fast projection algorithm for the m-th channel echo y.sub.m (k). Step S1: As initialization processing, the auto-correlation vector of Eq. (36) at time k=0 is set by the following equation:
r.sub.p-1 (0)=[x.sup.T (0)x(-1),x.sup.T (0)x(-2), . . . ,x.sup.T (0)x(-p+1)].sup.T (39)
and the residual echo e.sub.p (k), the pre-filter conductor coefficient vector f.sub.p-1 (k), the smoothing coefficient vector s.sub.p-1 (k) and the minimum values of the sum of a posterior prediction-error squares F(k) and B(k) at time k=0 are respectively set as follows:
e.sub.p (0)=0
f.sub.p-1 (0)=s.sub.p-1 (0)=0
F(0)=B(0)=.delta.
where .delta. is a small positive constant. Step S2: Input signal vectors of N channels are calculated as follows: ##EQU8## The correlation vector at time k-1 is used to calculate the correlation vector at time k by the following equation: ##EQU9## Step S3: The estimated echo y.sub.m (k) is calculated by the following equation:
y.sub.m (k)=z.sub.m.sup.T (k)x(k)+r.sub.p-1.sup.T (k)s.sub.p-1 (k-1) (42)
Step S4: The residual echo e.sub.m (k) is calculated by the following equation:
e.sub.m (k)=y.sub.m (k)-y.sub.m (k) (43)
Step S5:
e.sub.p (k)=[e.sub.m (k),(1-.alpha.)e.sub.m (k-1), . . . ,(1-.alpha.).sup.p-1 e.sub.m (k-p+1)].sup.T (44)
is calculated by the following iterative equation: ##EQU10## where the value * is not required. Step S6: By using the aforementioned fast calculation methods by J. M. Cioffi and T. Kailath for the linear prediction coefficients and the minimum values of the sum of forward and backward a posteriori prediction-error squares, a p-th order forward linear prediction coefficient vector a.sub.p (k), its minimum value of the sum of forward a posteriori prediction-error squares F(k), a p-th order backward linear prediction coefficient vector b.sub.p (k) and its minimum value of the sum of backward a posteriori prediction-error squares B(k) are calculated which satisfy the following equations:
X.sup.T (k)X(k)a.sub.p (k)=[F(k), 0, . . . , 0].sup.T (46)
X.sup.T (k-1)X(k-1)bp(k-1)={0, . . . , B(k-1)].sup.T (47)
where the leading element of the vector a.sub.p (k) and the last element of the vector b.sub.p (k) are both 1s. Step S7: The pre-filter coefficient vector g.sub.p (k) is calculated by the following equation: ##EQU11## Step S8: The pre-filter conductor coefficient vector f.sub.p-1 (k) is calculated by the following equation: ##EQU12## Step S9: The smoothing coefficient vectors s.sub.p-1 (k) and s.sub.p (k) are calculated by the following equation: ##EQU13##
Step S10: The approximate value z.sub.m (k) of the combined estimated echo path vector h.sub.m (k)=[h.sub.1m.sup.T (k), h.sub.2m.sup.T (k), . . . , h.sub.Nm.sup.T (k)].sup.T is updated by the following equation:
z.sub.m (k+1)=z.sub.m (k)+s.sub.p (k)x(k-p+1) (51)
Step S11: Upon each increment of time k, Steps S2 through S10 are repeated.
FIG. 6 illustrates in block form an embodiment of the first method of the present invention applied to the echo canceller 22.sub.m in FIG. 3 which is used in the FIG. 2 teleconferencing system provided with the N-channel loudspeaker system and the M-channel microphone system. The parts corresponding to those in FIG. 3 are identified by the same reference numerals. According to the present invention, a cross-correlation variation extracting part 31 is provided in each of the echo cancellers 22.sub.1 to 22.sub.M in FIG. 2. The received signal x(k) and the residual echo e.sub.m (k) in each channel are inputted into the cross-correlation variation extracting part 31, wherein the adjustment vector v(k) is generated.
In this embodiment, the auto-correlation of the combined received signal vector x(k) is removed using the projection algorithm, by which the variation in the cross-correlation between received signals is extracted to generate the adjustment vector v(k). That is to say, the cross-correlation variation extracting part 31 stores information about the combined received signal vector x(k) and the residual echo e.sub.m (k) defined by Eq. (8), then solves the following equation (52) corresponding to Eq. (27) to obtain g.sub.p (k) and generates, by Eq. (28), a decorrelated vector, i.e. the adjustment vector v(k).
[X.sup.T (k)X(k)g.sub.p (k)=e.sub.m (k) (52)
An adjusting part 32 updates the current combined estimated echo path vector h.sub.m (k) by calculating h.sub.m (k+1) on the basis of Eqs. (21) and (28) using the adjusting vector v(k) as follows:
h.sub.m (k+1)=h.sub.m (k)+.alpha..sub.v (k) (53)
The combined estimated echo path vector h.sub.m (k) thus updated is fed to the estimated echo generating part 18.sub.m.
In this way, the variation in the cross-correlation between multi-channel received signal vectors is extracted in the cross-correlation variation extracting part 31 and new multi-channel signal vectors are generated in which the variation in the cross-correlation between the respective received signal vectors are emphasized. Since such a multi-channel signal vector is fed to the adjusting part 32, it is possible to speed up the estimation of the true echo paths.
FIG. 7 is a block diagram showing a modified form of the cross-correlation variation extracting part, which is formed by a cross-correlation variation coefficient calculating part 31A and a cross-correlation variation emphasized vector generating part 31B and in which the former solves Eq. (27) to obtain the pre-filter coefficient vector g.sub.p expressed by Eq. (30) and the latter calculates the adjustment vector v(k) by Eq. (28). In this case, the cross-correlation variation coefficient calculating part 31A can reduce the amount of calculation of the pre-filter coefficient vector g.sub.p (k) through utilization of linear prediction. That is to say, as shown in FIG. 8, the cross-correlation variation coefficient calculating part 31A is formed by a linear prediction part 31A1, a pre-filter conductor coefficient vector adjusting part 31A2, a pre-filter coefficient vector adjusting part 31A3 and an error signal vector generating part 31A4. The linear prediction part 31A1 calculates the forward linear prediction coefficient vector a.sub.p (k) of the combined input signal vector x(k), the minimum value of the sum of forward a posteriori prediction-error squares F(k), the backward linear prediction coefficient vector b.sub.p (k) of the combined input signal vector x(k) and the minimum value of the sum of backward a posteriori prediction-error squares B(k).
On the other hand, the error signal vector generating part 31A4 holds the p latest error signals (residual echoes) e.sub.m (k), e.sub.m (k-1), . . . , e.sub.m (k-p+1) and iteratively generates the error signal vector e.sub.p (k) of Eq. (44) by Eq. (45). The pre-filter conductor coefficient vector adjusting part 31A2 calculates the pre-filter conductor coefficient vector f.sub.p-1 (k-1) by Eq. (32) and the filter coefficient vector adjusting part 31A3 the pre-filter coefficient vector g.sub.p (k) by Eq. (31). The pre-filter coefficient vector g.sub.p (k) thus obtained is provided to the cross-correlation variation emphasized vector generating part 31B.
FIG. 9 illustrates a configuration which reduces the amount of calculation in the FIG. 6 embodiment by generating the estimated echo y.sub.m (k), instead of calculating the combined estimated echo path vector h.sub.m (k), by using the approximate vector z.sub.m (k) of the vector h.sub.m (k) on the basis of the fast projection algorithm described previously in Steps S1 through S11. In this instance, the echo path estimating part 19.sub.m and the estimated echo generating part 18.sub.m in FIG. 6 are replaced by the cross-correlation variation coefficient calculating part 31A and the simplified estimated echo generating part 180.sub.m ; the former is identical with that shown in FIG. 7 or 8 and the latter corresponds to the set of the cross-correlation variation emphasized vector generating part 31B, the adjusting part 32 and the estimated echo generating part 18.sub.m and, as depicted in FIG. 10, it comprises a correlation calculating part 181, a smoothing coefficient vector adjusting part 182, an approximated echo path adjusting part 183, inner product calculating parts 184 and 185 and an adder 186.
The correlation calculating part 181 calculates the combined input signal vector x(k) and the auto-correlation vector r.sub.p-1 (k) of x(k) by Eqs. (40) and (41). The smoothing coefficient vector adjusting part 182 calculates by Eq. (50) smoothing coefficient vector s.sub.p-1 (k-1) and s.sub.p (k) from the pre-filter coefficient vector g.sub.p (k). The approximated echo path adjusting part 183 calculates by Eq. (51) the approximated echo path vector z.sub.m (k) from s.sub.p (k) and x(k). The inner product calculating part 184 calculates the inner product r.sub.p-1.sup.T (k)s.sub.p-1 (k-1) of the smoothing coefficient vector s.sub.p-1 (k-1) and the correlation vector r.sub.p-1 (k). The inner product calculating part 185 calculates the inner product z.sub.m.sup.T (k)x(k) of the input signal vector x(k) and the approximated echo path vector z.sub.m (k). These inner products are added together by the adder 186 to obtain the estimated echo signal y.sub.m (k).
Next, the third method of the present invention will be described concretely. According to this method, a function of actively changing the cross-correlation between received signals of respective channels are adopted, and the received signals added with the variation in the correlation between them are radiated by loudspeakers and used to derive the adjusted vector of the estimated echo.
The variation in the correlation between received signals of respective channels can be added thereto by (a) filter processing, (b) signal multiplication processing, (c) signal addition processing and (d) pitch shift processing. These methods will hereinafter be described one after another.
(a) Method by Filter Processing
The received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of respective channels are inputted to time-variant filters with different time-variant characteristic, wherein they are convoluted (indicated by *) with impulse response q.sub.1 (k), q.sub.2 (k), . . . , q.sub.N (k) of the filters for conversion into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) which are expressed as follows: ##EQU14## By this, the variation in the cross-correlation between the received signal of respective channels can be added thereto.
(b) Method by Signal Multiplication
The received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of respective channels are multiplied by different functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k) for conversion into signals x.sub.1 (k), x.sub.2 (k), . . . x.sub.N (k) which are expressed as follows: ##EQU15## By this, the variation in the cross-correlation between the received signals can be added thereto.
(c) Method by Signal Addition
The received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of respective channels are added to different functions n.sub.1 (k), n.sub.2 (k), n.sub.N (k), respectively, for conversion into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) which are expressed as follows: ##EQU16## By this, the variation in the cross-correlation between the received signals of respective channels can be added thereto.
(d) Method by Pitch Shift Processing
The frequency characteristics of the received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of respective channels are each subjected to different time-variant frequency axis expansion or compression, that is, by pitch shift processing, by which the signals are converted into x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) signals. By this, the variation in the cross-correlation between the received signals of the respective channels can be added thereto.
FIG. 11 illustrates an embodiment of the third method of the present invention. The parts corresponding to those in FIG. 2 are identified by the same reference numerals. In this embodiment, a cross-correlation variation adding part 24 is provided at the received signal input side. In the cross-correlation variation adding part 24, the received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of the respective channels are converted into x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) by being actively added with the variation in their cross-correlation. These signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) thus converted are radiated from the speakers 12.sub.1, 12.sub.2, . . . , 12.sub.N, while at the same time they are inputted into the echo canceller system 23.
In the implementation of the cross-correlation variation adding part 24, care should be taken not to impair the psycho-acoustic quality of the converted signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) when they are reconstructed as acoustic signals. Next, a description will be given of concrete examples of the above-mentioned methods in the implementation of the cross-correlation variation adding part 24.
(a) Concrete Example of Implementation by Filter Processing
A description will be given of the time-variant filters for converting the received signal x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of the respective channels into those x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) which satisfy Eq. (54), through utilization of the impulse response q.sub.1 (k), q.sub.2 (k), . . . , q.sub.N (k) of the filters having different time-variant characteristics. It is said that amplitude information is mainly important for the psycho-acoustic perception and that phase information is not so important. Hence, it is considered that the psycho-acoustic influence of filter processing would be lessened by implementing the time-variant filter so that the amplitude characteristic remains flat with respect to the frequency of each input signal.
A filter that serves this purpose is an IIR filter which has an all-pass transfer function. The transfer function G(z) of this filter can be expressed as follows:
G(z)=A{z.sup.-K -c.sub.1 z.sup.-(K-1) +. . . +(-1).sup.K-1 c.sub.K-1 z.sup.-1 +(-1).sup.k c.sub.K}.div.{ 1-c.sub.1 z.sup.-1 +. . . +(-1).sup.K-1 c.sub.k-1 z.sup.-1 (K-1)+(-1).sup.K c.sub.k z.sup.-K } (57)
where K is the order. Let the sampling interval and the angular frequency be represented by T and .omega., respectively. No matter what values the filter coefficients c.sub.1, c.sub.2, . . . , c.sub.M are set to take, the denominator and the numerator cancel with each other and the amplitude characteristic equation .vertline.G(e.sup.j.omega.T).vertline. takes a fixed gain A independent of the angular frequency .omega.. On the other hand, the phase characteristic differs with the filter coefficients c.sub.1, c.sub.2, . . . , c.sub.M. When the coefficients c.sub.1, c.sub.2, . . . , c.sub.M are varied with time, a time-variant phase characteristic is provided, but the influence on the amplitude characteristic is very slight.
Now, a description will be given of a secondary all-pass filter which is simple-structured and easy to implement. The configuration of the secondary all-pass filter is described in detail in, for example, Alan V. Oppenheim and Ronald W. Schafer, "DISCRETE-TIME SIGNAL PROCESSING," PRENTICE HALL. For brevity, setting the gain A=1 in Eq. (57), the secondary all-pass transfer function G(z) is given as follows:
G(z)=(z.sup.-2 -c.sub.1 z.sup.-1 +c.sub.2)/(1-c.sub.1 z.sup.-1 +c.sub.2 z.sup.-2) (58)
When configured as a lattice model, the filter having this transfer function can be formed by six adders, two multipliers and two unit delays as shown in FIG. 12. Replacing the coefficients in Eq. (58) by
c.sub.1 =-.gamma..sub.1 (1+.gamma..sub.2) (59)
c.sub.2 =.gamma..sub.2 (60)
the transfer function of Eq. (58) is expressed by the following equation (61) and the response signal to the input signal X(z) is Y(z)=X(z)G(z).
G(z)={z.sup.-2 +.gamma..sub.1 (1+.gamma..sub.2)z.sup.-1 +.gamma..sub.2 }/{1+.gamma..sub.1 (1+.gamma..sub.2)z.sup.-1 +.gamma..sub.2 z.sup.-2 } (61)
An advantage of the lattice-type filter configuration in the present invention is the .gamma..sub.1 and .gamma..sub.2 can be handled as parameters of independent meanings. When the group delay characteristic of the transfer function G(z) of Eq. (61) has a peak, the peak frequency depends virtually only on .gamma..sub.1 and the steepness of the peak depends virtually only on .gamma..sub.2. That is to say, there is no need of varying all of the filter coefficients with time; for instance, only by causing .gamma..sub.1 corresponding to the peak frequency of the group delay characteristic to undergo a different variation for each channel, effective time-variant characteristics can be obtained and the filter configuration can be simplified. By making these time-variant characteristics differ with the channels, it is possible to produce the effect of varying the cross-correlation between the original multi-channel received signals.
(b) Concrete Example of Implementation by Signal Multiplication Processing
A description will be given of functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k) by which the received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of the respective channels are multiplied for conversion into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) which satisfy Eq. (55).
If the functions u.sub.1 (k), u.sub.2 (K), . . . , u.sub.N (k) take both positive and negative values in Eq. (55), it is considered that the quality of the received signals would seriously be degraded regardless of the magnitude of the variation in the functions. Hence, it is desirable that the functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k) always take positive or negative values and that their variations be also limited. Now, consider the case where the functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k) are in such forms as mentioned below. Let the functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k) be expressed by the following equation (62) using different functions .omega..sub.1 (k), .omega..sub.2 (k), . . . , .omega..sub.N (k) each having the maximum amplitude normalized to 1, scaler values k.sub.1, k.sub.2, . . . , k.sub.N (0.ltoreq..parallel.k.sub.1 .parallel., .parallel.k.sub.2 .parallel., . . . , .parallel.k.sub.N .parallel.<1) and gain coefficients A.sub.1, A.sub.2, . . . , A.sub.N, ##EQU17## Since at given time k the following equation holds, the signs of the values u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k) remain unchanged.
-1<k.sub.1 .omega..sub.1 (k), k.sub.2 .omega..sub.2 (k), . . . , k.sub.N .omega..sub.N (k)<1
From the viewpoint of the psycho-acoustic balance, it is desirable that the values of the gain coefficients A.sub.1, A.sub.2, . . . , A.sub.N be equal or take values of the same sign; in this instance, the functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k) all take values of the same sign. Furthermore, the amount of distortion of each processed signal can be adjusted by the scalar values k.sub.1, k.sub.2, . . . , k.sub.N.
Moreover, from the viewpoint of a frequency shift, by setting the functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k) as follows: ##EQU18## and by shifting the frequency characteristics of the received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) through the use of functions .omega..sub.1 (k), .omega..sub.2 (k), . . . , .omega..sub.N (k) which have different time-variant characteristics and vary within certain limited ranges, the variation in the cross-correlation can be added to the original multi-channel received signals.
(c) Concrete Example of Implementation by Signal Addition Processing
A description will be given of function n.sub.1 (k), n.sub.2 (k), . . . , u.sub.N (k) to which the received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of the respective channels are added for conversion into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) which satisfy Eq. (56).
From the viewpoint of the psycho-acoustic influence, it is desirable that the functions n.sub.1 (k), n.sub.2 (k), . . . , n.sub.N (k) be moderately smaller in amplitude value than the received signals x.sub.1 (k) , x.sub.2 (k), . . . , x.sub.N (k) of the respective channels. In view of this, different functions n.sub.r1 (k), n.sub.r2 (k), . . . , n.sub.rN (k), normalized so that the maximum amplitude becomes a rated value A.sub.r of the amplitude of the received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of the respective channels, are multiplied by scalar values .gamma..sub.1,.gamma..sub.2, . . . , .gamma..sub.N, by which the functions n.sub.1 (k), n.sub.2 (k), . . . , n.sub.N (k) are expressed as follows: ##EQU19## Based on the scalar values .gamma..sub.1, .gamma..sub.2, . . . , .gamma..sub.N, it is possible to determine the degree to which the magnitude of the signal to be added to each of the received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) is made smaller than the rated value A.sub.r.
(d) Concrete Example of Implementation by Pitch Shift Processing
A description will be given of an embodiment in which the received signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) of the respective channels are converted into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) by subjecting the frequency characteristics of each received signal to different time-variant frequency axis expansion/compression processing or pitch shift processing.
The pitch shift processing involves time expansion/compression as well as frequency axis expansion/compression and can be processed in the time domain. When the time axis is compressed, interpolation processing is needed to make the duration of the processed signal equal to the duration of the original signal, whereas when the time axis is expanded, the duration of the processed signal becomes longer than the duration of the original signal; hence decimation processing is needed. Such interpolation/decimation processing can be implemented by detecting a silent duration and extending or removing it.
As described above, the methods of the present invention can be applied to the cancellation of echoes to implement a teleconference system of highly realistic presence which permits transmission of acoustic spatial information from either point by using a multi-channel transmission system and terminal equipment provided with multi-channel microphone and loudspeaker systems between two points.
Now, consider a stereo teleconferencing system which connects two points via a two-channel transmission system and uses two-channel microphone and loudspeaker systems as shown in FIG. 4. For instance, when a plurality of speakers alternately speak in their seats at the point A, the stereo speech signals that are picked up by two microphones bear a cross-correlation therebetween dependent on the positional relationship between the speakers and the microphones. When these speech signals are received at the point B and inputted to the conventional echo canceller, the echo path estimation depends on the cross-correlation and hence is incorrect, with the result that a large echo returns to the point A each time the speaker changes. In contrast to this, when the echo cancellation method of the present invention is used, a variation in the cross-correlation between the stereo received signals by the change of the speaker is extracted and used to correct an error in the echo path estimation; thus, it is possible to suppress the echo from increasing whenever the speaker changes. Furthermore, in the case where speech uttered by one person is picked up by a plurality of microphones, even if the speaker speaks at one place, the cross-correlation between the speech signals picked up by the microphone delicately changes. The method of the present invention permits effective utilization of such a slight variation in the cross-correlation between signals.
FIG. 13 is a graph showing the results of computer simulations using stereophonically picked up speech uttered by a speaker with his body or head fixed; the prior art method and this invention method are compared in terms of the error vector between the combined estimated echo path vector generated in the echo path estimating part and the combined true echo path vector as indicated by the curves 13A and 13B. This invention method used the secondary projection algorithm for the extraction of the variation in the cross-correlation. From FIG. 13 it will be seen that this invention method captures even a delicate variation in the cross-correlation between signals, permitting the correction of an error in the echo path estimation. It can be said that the present invention effectively detects a delicate variation between channels through utilization of past data.
FIG. 14 is a graph showing the convergence of the estimated echo path vector in the case of stereophonically picked up speech as in the case of FIG. 13, the order p of the projection algorithm being used as a parameter. The number L of taps was set to 500+500 and the step size .alpha. was set to 0.5. This graph also indicates that the present invention is effective.
Other than a method according to which at a terminal provided with a stereo receiving system, two-channel stereo signals picked up at the other side are received and reconstructed intact as shown in FIG. 4, there is proposed a method for multi-point teleconferencing by which the received signal for each point is freely subjected to sound image localization at the receiving side to provide a comfortable receiving environment. The method of the present invention is also applicable to such multi-point teleconferencing terminals. FIG. 15 illustrates the configuration of a teleconferencing system for four points A, B C and D interconnected via a network. At each point, the sending or microphone system is one-channel (monaural). Now, the point D will be described. Let it be assumed that at the point D, received signals from the points A, B and C are subjected to sound image localization in a received signal processing part 13d so that the signals are localized at the right, center and left with respect to the point D, respectively, by which new two-channel stereo received signals are generated for stereo reconstruction by loudspeakers 12d.sub.1 and 12d.sub.2. Also in this case, if the method of the present invention is used, when the speaker changes to a person at a different point, the echo canceller 22d extracts a variation in the cross-correlation between the stereo received signals and corrects the error as in the above-mentioned case; hence, it is possible to suppress the echo from increasing, as compared with the conventional method.
The curves 16A and 16B in FIG. 16 show the convergence of the error vector in the case of using, as received signals, two-channel signals obtained by picking up speech uttered by one speaker with one microphone and applying the speech through two different time-invariant filters on a computer, that is, in the case where the cross-correlation between the received signal is constant. In this instance, even if the first or second method of the present invention is employed to extract a variation in the cross-correlation between the received signals, since the cross-correlation between the received signals does not vary, echo path estimation is made incorrectly, and hence the effect of echo cancellation is not heightened even compared with that by the conventional method.
By the application of the third method of the present invention, the cross-correlation between the received signals always varies and the echo path estimation is made at all times. The configuration therefor is the same as shown in FIG. 11, and the N-channel echo cancellers 22.sub.1, 22.sub.2, . . . , 22.sub.M are identical in construction with that shown in FIG. 6. The curves 17A and 17B in FIG. 17 indicate the results of computer simulations done on the method of extracting and using the variation in the cross-correlation between received signals in the cases where the same received signals as those used in the case of FIG. 16, that is, stereo signals of a fixed cross-correlation therebetween, were added with and not added with the variation in the cross-correlation, the error vector between the true and estimated echo paths being plotted with the elapse of time. The curve 17A for the case of no variation in the cross-correlation being added is the same as the curve 16B in FIG. 16; in this case, convergence to the true echo path does not take place. On the other hand, in the case where the cross-correlation variation was added, the convergence to the true echo path proceeded and excellent results (the curve 17B) were obtained as is the case with the curve 13B in FIG. 13. The addition of the variation in the cross-correlation to the stereo (two-channel) signals is performed by the signal multiplication processing indicated by Eq. (55), and u.sub.1 (k) and u.sub.2 (k) are set as follows:
u.sub.1 (k)=1+0.05.omega.(k) (65)
u.sub.2 (k)=1-0.05.omega.(k) (66)
where .omega.(k) is a white noise signal having a maximum amplitude of 1.
That is to say, in the case where the conventional echo cancellation method is applied to a teleconferencing system usually composed of a multi-channel loudspeaker system and one or more microphone channels, when received signals of respective channels have a cross-correlation therebetween, incorrect echo path estimation is made, with the result that the echo increases upon each variation in the cross-correlation between the received signals. The first or second method of the present invention extracts and utilizes the variation in the cross-correlation between received signals to correct an error in the echo path estimation, and hence is effective in settling the above-said problem.
The third method of the present invention has the function of adding a variation to the cross-correlation between received signals, and hence does not completely freeze at a wrong solution in the echo path estimation but continues the echo path estimation in the direction in which to reduce the error; thus, the third method is also effective in solving the problem. With the combined use of the first or second and third methods, the first or second method effectively works when the cross-correlation between received signal varies, and when the cross-correlation does not vary, the third method effectively works to make the correction of the estimated echo path to converge in a short time.
It will be apparent that many modifications and variations may be effected without departing from the scope of the novel concepts of the present invention.
Claims
- 1. An N-channel echo cancellation method comprising the steps of:
- (a) radiating an input signal x.sub.n (k) of each channel n, (n=1, . . . N) as an acoustic signal by a loudspeaker of said each channel, said input signal being inputted as a sample every discrete time k and N being an integer equal to or greater than 2;
- (b) picking up, by one microphone, said N acoustic signals propagating thereto over N echo paths from said N loudspeaker to obtain an echo y(k);
- (c) obtaining a combined input signal vector x(k)=[x.sub.1.sup.T (k), x.sub.2.sup.T (k), . . . , x.sub.N.sup.T (k)].sup.T by combining input signal vectors x.sub.n (k) of said N channels, each composed of an input signal sequences x.sub.n (k), x.sub.n (k-1), . . . , x.sub.n (k-L.sub.n +1) counted back to time L.sub.n -1 from said discrete time k in said each channel n;
- (d) generating an estimated echo y(k) by inputting said combined input signal vector x(k) into a combined estimated echo path which has a combined estimated impulse response vector h(k) obtained by combining estimated impulse response vectors h.sub.n (k) (n=1, . . . , N, of N estimated echo paths corresponding to said N echo paths, each of said N estimated echo paths having L.sub.n taps;
- (e) obtaining a residual echo e(k) by subtracting said estimated echo signal y(k) from said echo y(k) obtained in said one microphone;
- (f) extracting a variation in the cross-correlation between said input signals of said N channels on the basis of said residual echo e(k) and said combined input signal vector x(k);
- (g) generating an adjustment vector v(k) on the basis of said cross-correlation variation;
- (h) adjusting said combined estimated impulse response vector h(k) of said combined estimated echo path by said adjustment vector v(k) to obtain a combined estimated impulse vector h(k+1) for use at the next time k+1; and
- (i) repeating said steps (a) to (h) upon each increment of time k.
- 2. The method of claim 1, wherein said step (f) is a step of detecting, as coefficients .beta..sub.1, . . . , .beta..sub.p, a variation in the cross-correlation between said input signals by using previous and current ones of said combined input signal vector x(k) and said step (g) is a step of calculating said adjustment vector v(k) by the following equation:
- v(k)=.beta..sub.1 x(k)+.beta..sub.2 x(k-1)+. . . +.beta..sub.p x(k-p+1),
- where p is an integer equal to or greater than 2 but smaller than L=L.sub.1 +L.sub.2 +. . . +L.sub.N.
- 3. The method of claim 1, wherein, setting p to an integer equal to or greater than 2 but smaller than L=L.sub.1 +L.sub.2 +. . . +L.sub.N, letting a matrix [x(k), x(k-1), . . . ,x(k-p+1)] of P combined input signal vectors counted back from said time k be represented by X(k), letting a pre-filter coefficient vector using pre-filter coefficients .beta..sub.1, . . . , .beta..sub.p as its elements be represented by g.sub.p (k)=[.beta..sub.1, . . . , .beta..sub.p ].sup.T, setting the step size .alpha. in the range of 0<.alpha.<2 and letting a residual echo vector e(k) be defined by the following equation using p residual echoes counted back from said time k:
- e(k)=[e(k),(1-.alpha.)e(k-1), . . . ,(1-.alpha.).sup.p-1 e(k-p+1)].sup.T
- said step (j) includes a step of calculating said pre-filter coefficient vector g.sub.p (k) by solving the following simultaneous linear equations with p unknowns:
- [X.sup.T (k)X(k)]g.sub.p (k)=e(k)
- and calculating said adjustment vector v(k) by the following equation through the use of said pre-filter coefficient vector g.sub.p (k):
- v(k)=.beta..sub.1 x(k)+.beta..sub.2 x(k-1)+. . . +.beta..sub.p x(k-p+1),
- and said step (g) is a step of adjusting said combined estimated impulse response vector h(k) by the following equation:
- h(k+1)=h(k)+.alpha.v(k).
- 4. An N-channel echo cancellation method comprising the steps of:
- (a) radiating an input signal x.sub.n (k) of each channel n, (n=1, . . . N) as an acoustic signal by a loudspeaker of said each channel, said input signal being inputted as a sample every discrete time k and N being an integer equal to or greater than 2;
- (b) picking up, by one microphone, said N acoustic signals propagating thereto over N echo paths from said N loudspeaker to obtain an echo y(k);
- (c) obtaining a combined input signal vector x(k)=[x.sub.1.sup.T (k), x.sub.2.sup.T (k), . . . , x.sub.N.sup.T (k)].sup.T by combining input signal vectors x.sub.n (k) of said N channels, each composed of an input signal sequences x.sub.n (k), x.sub.n (k-1), . . . , x.sub.n (k-L.sub.n +1) counted back to time L.sub.n -1 from said discrete time k in each channel;
- (d) calculating an approximate estimated echo, by a convolution z.sup.T (k)x(k), which is obtained by inputting said combined input signal vector x(k) into a combined approximate estimated echo path which has a approximate estimated impulse response vector z.sub.n (k), n=1, . . . , N of N estimated echo paths corresponding to said N echo paths, each of said N estimated echo paths having L.sub.n taps;
- (e) calculating an auto-correlation vector r.sub.p-1 (k) of said combined input signal vector x(k);
- (f) generating a supplementary estimated echo on the basis of said auto-correlation vector r.sub.p-1 (k) and a smoothing coefficient vector s.sub.p-1 (k-1) at time K-1;
- (g) calculating the sum of said approximate estimated echo and said supplementary estimated echo and outputting it as a combined estimated echo y(k) for said echo y(k);
- (h) calculating a residual echo e(k) by subtracting said combined estimated echo y(k) from said echo y(k) obtained in said one microphone;
- (i) detecting, as pre-filter coefficients .beta..sub.1, . . . , .beta..sub.p, variations in the cross-correlation between said input signals by using current and previous ones of said combined input signal vector x(k) through the use of said residual echo e(k) and said combined input signal vector x(k);
- (j) generating a smoothing coefficient vector s.sub.p-1 (k) by smoothing said pre-filter coefficients .beta..sub.1, . . . , .beta..sub.p ;
- (k) adjusting said approximate estimated impulse response vector z(k) on the basis of said smoothing coefficient vector s.sub.p-1 (k) and said previous combined input signal vector x(k-p+1) to obtain an approximate estimated impulse response vector z(k+1) for use at the next time k+1; and
- (l) repeating said steps (a) to (k) upon each increment of time k.
- 5. The method of claim 4, wherein:
- setting p to an integer equal to or greater than 2 but smaller than L=L.sub.1 +L.sub.2 +. . . ,L.sub.N, said step (e) includes a step of calculating said auto-correlation vector r.sub.p-1 (k) of said combined input signal vector x.sub.n (k) by the following equation:
- r.sub.p-1 (k)=[x.sup.T (k)x(k-1),x.sup.T (k)x(k-2), . . . , x.sup.T (k)x(k-p+1)].sup.T ;
- letting a matrix [x(k),x(k-1), . . . ,x(k-p+1)] of p combined input signal vectors counted back from said discrete time k be represented by X(k), setting the step size .alpha. in the range of 0<.alpha.21 2 and defining a residual echo vector e(k) by the following equation on the basis of p residual echoes counted back from said discrete time k:
- e(k)=[e(k),(1-.alpha.)e(k-1), . . . ,(1-.alpha.).sup.p-1 e(k-p+1)].sup.T,
- said step (i) includes a step of calculating a pre-filter coefficient vector g.sub.p (k)=[.beta..sub.1, . . . ,.beta..sub.p ].sup.T using said pre-filter coefficients .beta..sub.1, . . . , .beta..sub.p as its elements by solving the following simultaneous linear equations with p unknowns:
- [X.sup.T (k)X((k)]g.sub.p (k)=e(k);
- letting a pre-filter conductor coefficient vector be represented by f.sub.p-1 (k), said step (j) includes a step generating smoothing coefficients s.sub.i (k) by smoothing said pre-filter coefficients .beta..sub.i by the following equation: ##EQU20## said step (k) includes a step of adjusting an approximate estimated impulse vector z(k) approximately a combined estimated impulse response vector h(k), by the following equation:
- z(k+1)=z(k)+{.beta..sub.p (k)+.beta..sub.p-1 (k-1)+. . . +.beta..sub.2 (k-p+2)+.beta..sub.1 (k-p+1}x(k-p+1) =z(k)+s.sub.p (k)x(k-p+1); and
- said step (f) includes a step of calculating said smoothing coefficient vector s.sub.p-1 (k-1) using said smoothing coefficients s.sub.i (k) for i=1, . . . , p-1, as its elements, by the following equation:
- s.sub.p-1 (k-1)=[s.sub.1 (k-1),s.sub.2 (k-1), . . . , s.sub.p-1 (k-1)].sup.T
- and calculating said supplementary estimated echo by an inner product r.sub.p-1.sup.T (k)s.sub.p-1 (k-1).
- 6. The method of claim 3 or 5, wherein said step of solving said simultaneous linear equations with p unknown includes a step of calculating a forward linear prediction coefficient vector a.sub.p (k) of said combined input signal vector x(k), its minimum value of the sum of a posteriori prediction-error squares F(k), a backward linear prediction coefficient vector b.sub.p (k) of said vector x(k) and its minimum value of the sum of a posteriori prediction-error squares B(k) and, letting a pre-filter conductor coefficient vector by f.sub.p-1 (k), calculating said pre-filter coefficient vector g.sub.p (k) from a recursion formula composed of the following two equations: ##EQU21##
- 7. The method claim 1 or 4, wherein the step (a) includes the step of:
- (a-1) adding a variation to cross-correlation between received signals of the respective channels to produce the input signals x.sub.n (k) of the respective channels n, where n=1, . . . , N.
- 8. The method of claim 7, wherein, said step (a-1) is a step of applying said input signals to time-variant filters each having a different time-variant characteristic for said each channel, thereby converting said input signals into signals x.sub.1 (k), x.sub.2 (l), . . . , x.sub.x (k) expressed below to add said variation to the cross-correlation between said input signals of said respective channels: ##EQU22## where q.sub.1 (k), q.sub.2 (k), . . . , q.sub.N (k) indicate impulse responses of said time-variant filters and * indicates a convolution.
- 9. The method of claim 7, wherein, said step (a-1) is a step of multiplying said input signals by different functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k), respectively, thereby converting said input signals into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) satisfying the following equations to add said variation to the cross-correlation between said input signals of said respective channels: ##EQU23##
- 10. The method of claim 7, wherein, said step (a-1) is a step of adding said input signals with different functions n.sub.1 (k), n.sub.2 (k), . . . , n.sub.N (k), respectively, thereby converting said input signals into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) satisfying the following equations to add said variation to the cross-correlation between said input signals of said respective channels: ##EQU24##
- 11. The method of claim 7, wherein, said step (a-1) is a step of subjecting frequency characteristics of said input signals to time-variant frequency axis expansion or compression processing different for each channel, thereby converting said input signals into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k), to add said variation to the cross-correlation between said input signals of said respective channels.
- 12. An N-channel echo canceller comprising:
- N loudspeakers for radiating input signals x.sub.n (k), n=1, . . . , N, as acoustic signals of respective channels, said input signals being inputted as samples every discrete time k and N being an integer equal to or greater than 2;
- a microphone for picking up said N acoustic signals propagating thereto over N echo paths from said N loudspeaker to obtain en echo y(k);
- a vector combining part for obtaining a combined input signal vector x(k)=[x.sub.1.sup.T (k), x.sub.2.sup.T (k), . . . , x.sub.N.sup.T (k)].sup.T by combining input signal vectors x.sub.n (k) of said N channels, each composed of an input signal sequence x.sub.n (k), x.sub.n (k-1), . . . , x.sub.n (k-L.sub.n +1) counted L.sub.n -1 back from said discrete time k in each of said N channels;
- an estimated echo generating part which has a combined estimated impulse response vector h(k) obtained by combining estimated impulse response vectors h(k), n=1, . . . , N of N estimated echo paths corresponding to said N echo paths, each of said N estimated echo paths having L.sub.n taps, and into which said combined input signal vector x(k) is inputted to generate an estimated echo y(k);
- a subtractor for obtaining a residual echo e(k) by subtracting said estimated echo y(k) from said echo y(k) provided from said microphone;
- a cross-correlation variation extracting part for extracting a variation in the cross-correlation between said input signals of said N channels on the basis of said residual echo e(k) and said combined input signal vector x(k) and for generating an adjustment vector v(k); and
- an adjusting part for adjusting said combined estimated impulse response vector h(k) by said adjustment vector v(k) to obtain a combined estimated response vector h(k+1) for use at the next time k+1.
- 13. The echo canceller of claim 12, wherein, setting p to an integer equal to or greater than 2 but smaller than L=L.sub.1 +L.sub.2 +. . . +L.sub.N, letting a matrix [x(k),x(k-1), . . . , x(k-p+1)] of p combined input signal vectors counted back from said discrete time k be represented by X(k), letting a pre-filter coefficient vector using pre-filter coefficients .beta..sub.1, . . . , .beta..sub.p as its elements be represented by g.sub.p (k)=[.beta..sub.1, . . . , .beta..sub.p ].sup.T, setting the step size .alpha. in the range of 0<.alpha.<2 and letting a residual echo vector e(k) be defined by the following equation using p residual echoes counted back from said discrete time k:
- e(k)=[e(k),(1-.alpha.)e(k-1), . . . ,(1-.alpha.).sup.p-1 e(k-p+1)].sup.T
- said cross-correlation variation extracting part includes a cross-correlation variation coefficient calculating part for obtaining said pre-filter coefficient vector g.sub.p (k) by solving the following simultaneous linear equation with p unknowns:
- [X.sup.T (k)X(k)]g.sub.p (k)=e(k)
- and a cross-correlation variation emphasized vector generating part for calculating said adjustment vector v(k) by the following equation through the use of said pre-filter coefficient vector g.sub.p (k):
- v(k)=.beta..sub.1 x(k)+.beta..sub.2 x(k-1)+. . . +.beta..sub.p x(k-p+1);
- and said adjusting part includes means for adjusting said combined estimated impulse response vector h(k) by the following equation:
- h(k+1)=h(k)+.alpha.v(k).
- 14. An N-channel echo canceller comprising:
- N loudspeakers for radiating input signals x.sub.n (k), n=1, . . . , N, as acoustic signals of respective channels, said input signals being inputted as samples every discrete time k and N being an integer equal to or greater than 2;
- a microphone for picking up said N acoustic signals propagating thereto over N echo paths from said N loudspeaker to obtain en echo y(k);
- a vector combining part for obtaining a combined input signal vector x(k)=[x.sub.1.sup.T (k), x.sub.2.sup.T (k), . . . , x.sub.N.sup.T (k)].sup.T by combining input signal vectors x.sub.n (k) of said N channels, each composed of an input signal sequence x.sub.n (k), x.sub.n (k-1), . . . , x.sub.n (k-L.sub.n +1) counted L.sub.n -1 back from said discrete time k in each of said N channels;
- an approximate estimated echo path adjusting part which has set therein a combined approximate impulse response vector z(k) obtained by combining approximate estimated impulse response vectors z.sub.n (k), n=1, . . . , N, of N estimated echo paths corresponding to said N echo paths, each of said N estimated echo paths having L.sub.n taps, and into which said combined input signal vector x(k) is inputted to calculate an approximate estimated echo by a convolution z.sup.T (k)x(k);
- a auto-correlation calculating part for calculating an auto-correlation vector r.sub.p-1 (k) of said combined input signal vector x(k);
- an adder for calculating the sum of said approximate estimated echo and a supplementary estimated echo and for outputting it as a combined estimated echo y(k) and said N estimated echo paths corresponding to said N echo paths;
- a subtractor for obtaining a residual echo e(k) by subtracting said combined estimated echo y(k) from said echo y(k) obtained in said microphone;
- a cross-correlation variation coefficient calculating part for detecting, as pre-filter coefficients .beta..sub.1, . . . , .beta..sub.p, variations in the cross-correlation between current and previous ones of said combined input signal vector x(k) through the use of said residual echo e(k) and said combined input signal vector x(k);
- a smoothing coefficient vector generating part for generating a smoothing coefficient vector s.sub.p-1 (k) by smoothing said pre-filter coefficients;
- an approximate estimated echo path adjusting part for adjusting said approximate estimated impulse response vector z(k) on the basis of said smoothing coefficient vector s.sub.p-1 (k) and a previous one of said previous combined input signal vector x(k-p+1) and for outputting an approximate estimated impulse response vector z(k+1) for use at the next time k+1; and
- A convoluting part for calculating the inner product of said auto-correlation vector r.sub.p-1 (k) and said smoothing coefficient vector s.sub.p-1 (k) to obtain said supplementary estimated echo for use at said time k.
- 15. The echo canceller of claim 14, wherein:
- setting p to an integer equal to or greater than 2 but smaller than L=L.sub.1 +L.sub.2 +. . . +L.sub.N, said auto-correlation calculating part includes means for calculating said auto-correlation vector r.sub.p-1 (k) of said combined input signal vector x.sub.n (k) by the following equation:
- r.sub.p-1 (k)=[x.sup.T (x)k-1),x.sup.T (k)x(k-2), . . . , x.sup.T (k)x(k-p+1)].sup.T ;
- letting a matrix [x(k),x(k-1), . . . , x(k-p+1)] of p discrete time k be represented by X(k), setting the step size .alpha. in the range of 0<.alpha.2 and defining a residual echo vector e(k) by the following equation on the basis of p residual echoes counted back from said discrete time k:
- e(k)=[e(k),(1-.alpha.)e(k-1), . . . , (1-.alpha.).sup.p-1 e(k-p+1)].sup.T,
- said cross-correlation variation coefficient calculating part includes means for calculating a pre-filter coefficient vector g.sub.p (k)=[.beta..sub.1, . . . , .beta..sub.p ].sup.T using said pre-filter coefficients .beta..sub.1, . . . , .beta..sub.p as its elements by solving the following simultaneous linear equations with p unknowns:
- [X.sup.T (k)X(k)]g.sub.p (k)=e(k)
- letting a pre-filter conductor coefficient vector be represented by f.sub.p-1 (k), said smoothing coefficient vector generating part includes means for generating smoothing coefficients s.sub.i (k) by smoothing said pre-filter coefficients .beta..sub.1 by the following equation:
- s.sub.i (k)=s.sub.i-1 (k-1)+.alpha..beta..sub.i (k) for 2.ltoreq.i.ltoreq.p =.alpha..beta..sub.i (k) for i=1;
- said approximate estimated echo path adjusting part includes means for adjusting said approximate estimated impulse response vector z(k) approximately a combined estimated impulse response vector h(k), by the following equation:
- z(k+1)=z(k)+{.beta..sub.p (k)+.beta..sub.p-1 (k-1)+. . . +.beta..sub.2 (k-p+2)+.beta..sub.1 (k-p+1)x(k-p+1)}=z(k)+s.sub.p (k)x(k-p+1); and
- said convoluting part includes means for calculating said smoothing coefficient vector s.sub.p-1 using said smoothing coefficients s.sub.i (k) (i=1, . . . , p.sub.- 1) as its elements, by the following equation:
- s.sub.p-1 (k-1)=[s.sub.1 (k-1),s.sub.2 (k-1), . . . , s.sub.p-1 (k-1)].sup.T
- and for calculating said supplementary estimated echo by an inner product r.sub.p-1 (k)s.sub.p-1.sup.T (k-1).
- 16. The echo canceller of claim 13 or 15, wherein said means for calculating said pre-filter coefficient vector g.sub.p (k) by solving said simultaneous linear equation with p unknowns includes means for calculating a forward linear prediction coefficient vector a.sub.p (k) of said combined input signal vector x(k), its minimum value of the sum of a posteriori prediction-error squares F(k), a backward linear prediction coefficient vector b.sub.p (k) of said vector x(k) and its minimum value of the sum of a posteriori prediction-error squares B(k) and for calculating said pre-filter coefficient vector g.sub.p (k) from a recursion formula composed of the following two equations: ##EQU25## where f.sub.p-1 (k) is a pre-filter conductor coefficient vector.
- 17. The echo canceller of claim 12 or 14 further comprising a cross-correlation variation adding part for adding a cross-correlation variation to said input signal of each of said N channels.
- 18. The echo canceller of claim 17, wherein, said cross-correlation variation adding part includes time-variant filter means of different impulse responses q.sub.1 (k), q.sub.2 (k), . . . , q.sub.N (k), for adding said variation to the cross-correlation between said input signals of said respective channels by converting said input signals into signal x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) expressed as follows: ##EQU26## where * indicates a convolution.
- 19. The echo canceller of claim 17, wherein, said cross-correlation variation adding part includes means for adding said variation to the cross-correlation between said input signals of said respective channels by multiplying said input signals by different functions u.sub.1 (k), u.sub.2 (k), . . . , u.sub.N (k), respectively, thereby converting said input signals into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) which satisfy the following equations: ##EQU27##
- 20. The echo canceller of claim 17, wherein, said cross-correlation variation adding part includes means for adding said variation to the cross-correlation between said input signals of said respective channels by adding said input signals with difference functions n.sub.1 (k), n.sub.2 (k), . . . , n.sub.N (k), respectively, thereby converting said input signals to signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k) which satisfy the following equations: ##EQU28##
- 21. The echo canceller of claim 17, wherein said cross-correlation variation adding part includes means for adding said variation to the cross-correlation between said input signals of said respective channels by subjecting frequency characteristics of said input signals to time-variant frequency axis expansion or compression processing different for each channel, thereby converting said input signals into signals x.sub.1 (k), x.sub.2 (k), . . . , x.sub.N (k).
Priority Claims (2)
Number |
Date |
Country |
Kind |
6-262738 |
Oct 1994 |
JPX |
|
7-050002 |
Mar 1995 |
JPX |
|
US Referenced Citations (6)