The present invention relates to a mathematical procedure for enhancing a soft sound source in the presence of one or more loud sound sources and to a new iterative technique for enhancing noisy speech signals under low signal-to-noise-ratio (SNR) environments.
The present invention includes the use of various technologies referenced and described in the documents identified in the following LIST OF REFERENCES, which are cited throughout the specification by the corresponding reference number in brackets:
The entire contents of each of the above references are incorporated herein by reference. The techniques disclosed in the references can be utilized as part of the present invention.
A speech enhancement system is a valuable device in many applications of practical interest such as hearing aids, cell phones, speech recognition systems, surveillance, and forensic applications. Early speech enhancement systems were based on a single channel operation due to their simplicity. Spectral subtraction [1] is a simple and popular single channel speech enhancement technique that achieved marked reduction in background noise. These systems operate in the discrete Fourier domain and process noisy data in frames. An estimate of the noise power spectrum is subtracted from the noisy speech in each frame and data is reconstructed in the time domain by using methods like the overlap-add or overlap-save methods. Although effective in high signal-to-noise-ratio (SNR) scenarios, an annoying artifact of spectral subtraction is an automatic generation of musical tones in the enhanced speech. This effect is particularly prominent in low signal-to-noise-ratios (SNR) (<5 dB) and makes the enhanced speech less understandable to humans. Over the years, several solutions dealing with the problem of musical noise have been proposed in the speech enhancement literature [2], [3], [4], [5], [6]. These techniques employ perceptually constrained criteria to trade-off background noise reduction with speech distortion. However, in low SNR regimes, the problem still persists.
In the early 1990s it was realized that the Karhunen-Loeve transform (KLT), instead of the popular DFT, could be effectively utilized in a speech enhancement system. This was motivated by the fact that KLT provides a signal-dependent basis as opposed to a fixed basis used by the DFT based system. This fact led researchers to propose subspace-based speech enhancement systems in [7] as an alternative to spectral subtraction algorithms. These methods require the eigenvalue decomposition (EVD) of the covariance of the noisy speech and are successful in eliminating musical noise to a large extent. The key idea in subspace-based techniques is to decompose the vector space of noisy speech into two mutually orthogonal subspaces corresponding to signal-plus-noise and noise-only subspaces. The subspaces are identified by performing an eigenvalue decomposition (EVD) of the correlation matrix of the noisy speech vector via the Karhunen-Loéve transform (KLT) in every frame. The components of the noisy speech corresponding to the noise-only subspace are nulled out, whereas components corresponding to the signal-plus-noise subspace are enhanced. Subspace-based algorithms perform better than the spectral-subtraction-based algorithms due to the better signal representation provided by the KLT and offer nearly musical-noise-free enhanced speech. However, the original subspace algorithm is optimal only under the assumption of stationary white noise. In other words, these EVD-based methods are designed for the uncorrelated noise case. For correlated noise scenarios, several extensions of the original subspace method have been proposed in the literature [8][9][10][16][19]. The technique in [8] first identifies whether the current frame is speech-dominated or noise-dominated, and then uses different processing strategies corresponding to each case. The technique in [9] uses a diagonal matrix instead of an identity matrix to approximate the noise power spectrum. The methods in [10][16] use generalized eigenvalue decomposition and quotient (generalized) singular value decomposition, respectively, to account for the correlated nature of the additive noise. Explicit solutions to the linear time-domain and frequency-domain estimators were developed in [19], where the solution matrix whitens the colored noise before the KLT is applied. All of the above methods claim better performance in colored noise scenarios over the original subspace algorithm [7], albeit with higher computational complexity.
Microphone arrays have recently attracted a lot of interest in the signal and speech processing communities [11] due to their ability to exploit both the spatial- and the temporal-domains simultaneously. These multimicrophone systems are capable of coupling a speech enhancement procedure with beamforming [12] to ensure effective mulling of the background noise. Subspace algorithms have recently been extended to the multimicrophone case in [13] via use of the generalized singular value decomposition (GSVD). Specialized algorithms [14], [15] were utilized to compute the GSVD of two matrices corresponding to noise-only data and signal-plus-noise data. An alternate formulation of the GSVD via the use of noise whitening was previously suggested in [16]. The results are promising, but the issue of complexity remains. In a similar vein, the GEVD-based method of [10] can also be extended to the multimicrophone case, however, the need for long filters per channel poses a serious challenge in the implementation of GEVD-based systems. For example, in an n microphone system with L-taps per channel, the direct subspace computations will involve an nL×nL correlation matrix. Specific values of n=4, and L=4 result in a 4096×4096 correlation matrix, which is computationally expensive to handle on most small-form systems. Hence, alternative methods are sought to reduce this computational burden.
Accordingly, one embodiment of the present invention is a speech enhancement method that includes steps of obtaining a speech signal using at least one input microphone, calculating a whitening filter using a silence interval in the obtained speech signal, applying the whitening filter to the obtained speech signal to generate a whitened speech signal in which noise components present in the obtained speech signal are whitened, estimating a clean speech signal by applying a multi-channel filter to the generated whitened speech signal and outputting the clean speech signal via an audio device.
An object of the present invention is the development of a new speech enhancement algorithm based on an iterative methodology to compute the generalized eigenvectors from the spatio-temporal correlation coefficient sequence of the noisy data. The multichannel impulse responses produced by the present procedure closely approximate the subspaces generated from select eigenvectors of the (nL×nL)-dimensional sample autocorrelation matrix of the multichannel data. An advantage of the present technique is that a single filter can represent an entire nL-dimensional signal subspace by multichannel shifts of the corresponding filter impulse responses. In addition, the present technique does not involve dealing with large matrix vector multiplications, nor involve any matrix inversions. These facts make the present scheme very attractive and viable for implementation in real-time systems.
Another object of the present invention is related to a new methodology of processing the noisy speech data in the spatio-temporal domain. The present invention follows a technique that is closely related to the GEVD processing techniques. Similar to the GEVD processing, the first stage in the present method is the noise-whitening of the data, the second stage a spatio-temporal version of the well known power method [17] is used to extract the dominant speech component from the noisy data. A significant benefit of the present method is substantial reduction in the computational complexity. Because the whitening stage is separate in the present method, it is also possible to design invertible multichannel whitening filters whose effect from the output of the power method stage can be removed to nullify the whitening effects from the enhanced speech power spectrum.
A more complete appreciation of the invention and many of the attendant advantages thereof will be readily obtained as the same becomes better understood by reference to the following detailed description when considered in connection with the accompanying drawings, in which like reference numerals refer to identical or corresponding parts throughout the several views, and in which:
One embodiment of the present invention relates to a method of Spatio-Temporal Eigenfiltering using a signal model. For instance, letting s(l) denote a clean speech source signal which is measured at the output of an n-microphone array in the presence of colored noise v(l) at time instant l. The output of the jth microphone is given as
where {hjp} are the coefficients of the acoustic impulse response between the speech source and the jth microphone, and xj(l) and vj(l) are the filtered speech and noise component received at the jth microphone, respectively. The additive noise vj(l) is assumed to be uncorrelated with the clean speech signal and possesses a certain autocorrelation structure. One of the goals of the speech enhancement system is to compute a set of filters wj, j=0, . . . , n−1 such that the speech component of xj(l) is enhanced while the noise component vj(l) is reduced. The filters wj are usually finite impulse response (FIR) filters due to the finite reverberation time of the environment. In fact, acoustic impulse responses decay with time such that only a finite number of tap values hjp in Eq. (1) are essentially non-zero. The vector model of signal corresponding to an n-element microphone array can be written as
y(l)=x(l)+v(l) (2)
where y(l)=[y1(l)y2(l) . . . yn(l)]T, x(l)=[x1(l)x2(l) . . . xn(l)]T, and v(l)=[v1(l)v2(l) . . . vn(l)]T are the observed signal, the clean speech signal and the noise signal respectively.
With regard to Spatio-Temporal Eigenfiltering, a goal is to transform the speech enhancement problem into an iterative multichannel filtering task in which the output of the multichannel filter {Wp(k)} at time instant/and iteration k can be written as
where {Wp(k)} is the n×n multichannel enhancement filter of length L at iteration k, and the n-dimensional signal zk(l) is the output of this multichannel filter. Upon filter convergence for sufficiently large k, one of the signals in zk(l) will contain a close approximation of the original signal xi(l). Equation (3) can further be written by substituting the value of y(l) as
One of the goals of the present invention is to adapt the matrix coefficient sequence {Wp(k)} to maximize the signal-to-noise ratio (SNR) at the system output. To achieve this goal, the power in zk(l) at the kth iteration is given by the following expression for P(k):
where N is the length of the data sequence, the notation tr{.} corresponds to the trace of a matrix, and {Ryp} denotes the multichannel autocorrelation sequence of y and is given by
Note that {Wp(k)} is assumed to be zero outside the range 0≦p≦L, and {Ryp} is assumed to be zero outside the range |p|≦(L/2). Under the assumption of uncorrelated speech and noise, the total signal power can be written as P(k)=Px(k)+Pv(k), where
The problem of SNR maximization in the presence of colored noise is closely related to the problem of the generalized eigenvalue decomposition (GEVD). This problem has also been referred to as oriented principal component analysis (OPCA) [17]. The nomenclature is consistent with the fact that the generalized eigenvectors point in directions which maximize the signal variance and minimize the noise variance. However, since both {Rxp} and {Rvp} are not directly available, the values in {Rvp} are typically estimated during an appropriate silence period of the noisy speech in which there is no speech activity. Letting the number of samples of the noise sequence be denoted as Nv (<<N) then the multichannel autocorrelation sequence corresponding to the noise process can be written as
As for the replacement of {Rxp}, the multichannel autocorrelation sequence {Ryp} is used to find the stationary points of the following spatio-temporal power ratio:
The function J({Wp(k)}) is the spatio-temporal extension of the generalized Rayleigh quotient, and the solution that maximizes equation (10) are the generalized eigenvectors (or eigenfilters) of the multichannel autocorrelation sequence pair ({Rxp}, {Ryp}). For sufficiently many iterations k, the multichannel FIR filter sequence {Wp(k)} is designed to satisfy the following equations:
where Λ and {Wp} denote the generalized eigenvalues and eigenvectors of ({Rxp}, {Ryp}). This solution maximizes the energy of the speech component of the noisy mixture while minimizing the noise energy at the same time.
The present invention also addresses spatio-temporal generalized eigenvalue decomposition. The present method relies on multichannel correlation coefficient sequences of the noisy speech process and noise process defined in (6) and (9). Next, the multichannel convolution operations needed for the update of the filter sequence {Wp} are defined as
In the above set of equations, H(.) denotes a form of multichannel weighting on the autocorrelation sequences necessary to ensure the validity of the autocorrelation sequence for an FIR filtering operations needed in the algorithm update. Through numerical simulations it has been determined that this weighting is necessary both on the autocorrelation sequence itself as well as its filtered version at each iteration of the algorithm. This weighting amounts to multiplying each element of the resultant matrix sequence by a Bartlett window centered at p=q, although other windowing functions common in the digital signal processing literature can also be used. Next, we define the scalar terms
where gijpy(k) and gijpy(k) are the elements of coefficient sequence Gy
where triu[.] with its overline denotes the strictly upper triangular part of its matrix argument and tril[.] denotes the lower triangular part of its matrix argument. In the first instantiation of the invention, the correction term in the update process is defined as
and the final update for the weights become
Typically, step sizes in the range 0.35≦μ≦0.5 have been chosen and appear to work well. The enhanced signal can be obtained from the output of this system as the first element y1(l) of the vector y(l)=[y1(l)y2(l) . . . yn(l)]T at time instant l.
In Table 2 shown in
In addition, in a further embodiment, the present invention addresses an alternate implementation of the previously-described procedure employing a spatio-temporal whitening system with an Iterative Multichannel Noise Whitening Algorithm.
In this embodiment, a two stage speech enhancement system is used, in which the first stage acts as a noise-whitening system and the second stage employs a spatio-temporal power method on the noise-whitened signal to produce the enhanced speech. A significant advantage of the present method is its computational simplicity which makes the algorithm viable for applications on many common computing devices such as cellular telephones, personal digital assistants, portable media players, and other computational devices. Since all the processing is performed on the spatio-temporal correlation coefficient sequences, the method avoids large matrix-vector manipulations.
The first step in the present technique is to whiten the noise component of the observed noisy data. As is common in speech enhancement systems, it is assumed that access to an interval in the noisy speech where the speech is signal is absent is available. Such an interval is often referred to as the silence interval and can be detected by using a speech/silence detector or a voice activity detector (VAD). For purposes of the present invention it is assumed that the speech source is silent for Nv+L+1 sample times from l=Nv(k−1)−(L/2) to l=Nv(k−1)+(L/2). From this noise-only segment, it is possible to compute a whitening filter which is then applied to the rest of the noisy speech in order to whiten the noise component present in it. The present method involves designing a multichannel whitening filter of length L which iteratively whitens the spatio-temporal autocorrelation sequence corresponding to the noise process defined as
where Nv is the number of noise samples used in the computation of the whitening filter. After sufficiently many iterations k, the multichannel FIR filter sequence {Wp(k)} is designed to satisfy the following equation
where I is an n×n identity matrix. Note that {Wp(k)} is assumed to be zero outside the range 0≦p≦L and {Rvp} is assumed to be zero outside the range
The filter coefficient sequence {Wp(k)} can be updated in terms of the following multichannel sequences of length L defined as
and the final update for {Wp} becomes
are the gradient scaling factors [18] chosen to stabilize the algorithm and reduce the sensitivity of the gradient based update on the step size. Typically, step sizes in the range 0.35≦μ≦0.5 have been chosen and appear to work well. In the above set of equations, H(.) denotes a form of multichannel weighting on the autocorrelation sequences as described previously. After the filter convergence we obtain the noise-whitened signal as
Once the noise-whitened vector signal {tilde over (y)}k(l) is obtained, the spatio-temporal power method is applied to this vector signal in order to obtain the enhanced speech.
The present embodiment also includes a spatio-temporal power method which is the second stage in the present technique and involves the design of a multichannel filter {bp(k)}, where {bp(k)} is a (1×n) vector sequence, which upon convergence yields a single channel signal {circumflex over (x)}(l) which closely resembles the clean speech signal s(l) with some delay D. The output of the multichannel filter {bp(k)} at time instant k is given as
As a design criterion for the filter sequence {bp(k)}, the power of the output signal ŝk(l), is maximized, i.e.,
such that
The constraints in (30) correspond to the paraunitary constraints on the filter {bp(k)}. Note that in the conventional power method, unit-norm constraints are often placed on the filter coefficients; however, as a recent simulation study [20] indicates, the paraunitary constraints have beneficial impact not only on the robustness of the algorithms but also on the quality of the output speech. Our method for solving (29)-(30) employs a gradient ascent procedure in which each matrix tap bp is replaced by the derivative of J(bp) with respect to bp, after which the updated coefficient sequence is adjusted to maintain the paraunitary constraints in (30). It can be shown that
where the multichannel autocorrelation sequence Rp is given by
Thus, the first step of our procedure at each iteration sets
At this point, the coefficient sequence {{tilde over (b)}p(k)} needs to be modified to enforce the paraunitary constraints in (30). We modify the coefficient sequence such that
{bp(k+1)}=A({tilde over (b)}0(k){tilde over (b)}1(k), . . . , {tilde over (b)}L(k)),0≦p≦L (34)
where A is a mapping that forces {bp (k+1)} to satisfy (30) at each iteration. Such constraints can be enforced at each iteration by normalizing each complex Fourier-transformed filter weight in each filter channel by its magnitude. After sufficiently many iterations of (33)-(34), the signal ŝk(l) closely resembles the clean speech signal at time instant l. A block diagram of the propose system is shown in
In
All embodiments of the present invention conveniently may be implemented using a conventional general-purpose computer, personal media device, cellular telephone, or micro-processor programmed according to the teachings of the present invention, as will be apparent to those skilled in the computer art. The present invention may also be implemented in an attachment that works with other computational devices, such as a personal headset or recording apparatus that transmits or otherwise makes its processed audio signal available to these other computational devices in its operation. Appropriate software may readily be prepared by programmers of ordinary skill based on the teachings of the present disclosure, as will be apparent to those skilled in the software art.
A computer or other computational device may implement the methods of the present invention, wherein the computer or computational devices housing houses a motherboard which contains a CPU, memory (e.g., DRAM, ROM, EPROM, EEPROM, SRAM, SDRAM, and Flash RAM), and other optional special purpose logic devices (e.g., ASICs) or configurable logic devices (e.g., GAL and reprogrammable FPGA). The computer or computational device also includes plural input devices, (e.g., keyboard and mouse), and a display card for controlling a monitor or other visual display device. Additionally, the computer or computational device may include a floppy disk drive; other removable media devices (e.g. compact disc, tape, electronic flash memory, and removable magneto-optical media); and a hard disk or other fixed high density media drives, connected using an appropriate device bus (e.g., a SCSI bus, an Enhanced IDE bus, an Ultra DMA bus, or another standard communications bus). The computer or computational device may also include an optical disc reader, an optical disc reader/writer unit, or an optical disc jukebox, which may be connected to the same device bus or to another device bus. Computational devices of a similar nature to the above description include, but are not limited to, cellular telephones, personal media devices, or other devices enabled with computational capability using microprocessors or devices with similar numerical computing capability. In addition, devices that interface with such systems can embody the proposed invention through their interaction with the host device.
Examples of computer readable media associated with the present invention include optical discs, hard disks, floppy disks, tape, magneto-optical disks, PROMs (e.g., EPROM, EEPROM, Flash EPROM), DRAM, SRAM, SDRAM, and so on. Stored on any one or on a combination of these computer readable media, the present invention includes software for controlling both the hardware of the computational device and for enabling the computer to interact with a human user. Such software may include, but is not limited to, device drivers, operating systems and user applications, such as development tools. Computer readable medium may store computer program instructions (e.g., computer code devices) which when executed by a computer causes the computer to perform the method of the present invention. The computer code devices of the present invention may be any interpretable or executable code mechanism, including but not limited to, scripts, interpreters, dynamic link libraries, Java classes, and complete executable programs. Moreover, parts of the processing of the present invention may be distributed (e.g., between (1) multiple CPUs or (2) at least one CPU and at least one configurable logic device) for better performance, reliability, and/or cost.
The invention may also be implemented by the preparation of application specific integrated circuits or by interconnecting an appropriate network of conventional component circuits, as will be readily apparent to those skilled in the art.
Numerous modifications and variations of the present invention are possible in light of the above teachings. Of course, the particular hardware or software implementation of the present invention may be varied while still remaining within the scope of the present invention. It is therefore to be understood that within the scope of the appended claims and their equivalents, the invention may be practiced otherwise than as specifically described herein.
This application claims the benefit of priority under 35 U.S.C. §120 from Provisional U.S. Application Ser. No. 61/040,492, filed Mar. 28, 2008, herein incorporated by reference.
The present invention was made in part with U.S. Government support under Contract #2005*N354200*000, Project #100905770351. The U.S. Government may have certain rights to this invention.
Number | Date | Country | |
---|---|---|---|
61040492 | Mar 2008 | US |