This invention relates to audio signal processing and, in particular, to a circuit that uses an improved estimate of background noise for generating comfort noise.
As used herein, “telephone” is a generic term for a communication device that utilizes, directly or indirectly, a dial tone from a licensed service provider. As such, “telephone” includes desk telephones (see
There are many sources of noise in a telephone system. Some noise is acoustic in origin while the source of other noise is electronic, the telephone network, for example. As used herein, “noise” refers to any unwanted sound, whether or not the unwanted sound is periodic, purely random, or somewhere in-between. As such, noise includes background music, voices of people other than the desired speaker, tire noise, wind noise, and so on. Automobiles can be especially noisy environments.
As broadly defined, noise could include an echo of the speaker's voice. However, echo cancellation is separately treated in a telephone system and involves modeling the transfer characteristic of a signal path. Moreover, the model is changed or adapted over time as the characteristics, e.g. frequency response and delay or phase shift, of the path change.
A state of the art adaptive echo canceling algorithm alone is not sufficient to cancel an echo completely. A modeling error introduced by the echo canceler will result in a residual echo after the echo cancellation process. This residual echo is annoying to a listener. Residual echo is a problem whether or not there is background noise. Even if the background noise level is greater than the residual echo, the residual echo is annoying because, as the residual echo comes and goes, it is more perceptible to the listener. In most cases, the spectral properties of the residual echo are different from the background noise, making it even more perceptible.
Various techniques, such as residual echo suppresser and non-linear processor, are employed to eliminate the residual echo. Even though a residual echo suppresser works well in a noise free environment, some additional signal processing is needed to make this technique work in a noisy environment. In a noisy environment, the non-linear processing of the residual echo suppresser produces what is known as noise pumping. When the residual echo is suppressed, the additive background noise is also suppressed, resulting in noise pumping. To reduce the annoying effects of noise pumping, comfort noise, matched to the background noise, is inserted when the echo suppresser is activated.
Those of skill in the art recognize that, once an analog signal is converted to digital form, all subsequent operations can take place in one or more suitably programmed microprocessors. Use of the word “signal”, for example, does not necessarily mean either an analog signal or a digital signal. Data in memory, even a single bit, can be a signal.
“Efficiency” in a programming sense is the number of instructions required to perform a function. Few instructions are better or more efficient than many instructions. In languages other than machine (assembly) language, a line of code may involve hundreds of instructions. As used herein, “efficiency” relates to machine language instructions, not lines of code, because the number of instructions that can be executed per unit time determines how long it takes to perform an operation or to perform some function.
In the prior art, estimating noise power is computationally intensive, requiring either rapid calculation or sufficient time to complete a calculation. Rapid calculation requires high clock rates and more electrical power than desired, particularly in battery operated devices. Taking too much time for a calculation can lead to errors because the input signal has changed significantly during calculation.
In view of the foregoing, it is therefore an object of the invention to provide a more efficient system for generating high resolution comfort noise based upon an improved background noise estimator.
Another object of the invention is to provide an efficient system for generating comfort noise that is spectrally matched to background noise.
A further object of the invention is to provide a comfort noise generator that substantially eliminates noise pumping.
The foregoing objects are achieved in this invention in which a background noise estimate based upon a modified Doblinger noise estimate is used for modulating the output of a pseudo-random phase spectrum generator to produce the comfort noise. The circuit for estimating noise includes a smoothing filter having a slower time constant for updating the noise estimate during noise than during speech. The comfort noise generator further includes a circuit to adjust the gain of the comfort noise based upon the amount of noise suppressed. A discrete inverse Fourier transform converts the comfort noise back to the time domain and overlapping windows eliminate artifacts that may have been produced during processing.
A more complete understanding of the invention can be obtained by considering the following detailed description in conjunction with the accompanying drawings, in which:
Because a signal can be analog or digital, a block diagram can be interpreted as hardware, software, e.g. a flow chart, or a mixture of hardware and software. Programming a microprocessor is well within the ability of those of ordinary skill in the art, either individually or in groups.
This invention finds use in many applications where the internal electronics is essentially the same but the external appearance of the device is different.
The various forms of telephone can all benefit from the invention.
A cellular telephone includes both audio frequency and radio frequency circuits. Duplexer 55 couples antenna 56 to receive processor 57. Duplexer 55 couples antenna 56 to power amplifier 58 and isolates receive processor 57 from the power amplifier during transmission. Transmit processor 59 modulates a radio frequency signal with an audio signal from circuit 54. In non-cellular applications, such as speakerphones, there are no radio frequency circuits and signal processor 54 may be simplified somewhat. Problems of echo cancellation and noise remain and are handled in audio processor 60. It is audio processor 60 that is modified to include the invention.
Most modern noise reduction algorithms are based on a technique known as spectral subtraction. If a clean speech signal is corrupted by an additive and uncorrelated noisy signal, then the noisy speech signal is simply the sum of the signals. If the power spectral density (
Noise reduction using spectral subtraction can be written as
Ps(f)=Px(f)−Pn(f),
wherein Ps(f) is the power spectrum of speech, Px(f) is the power spectrum of noisy speech, and Pn(f) is the power spectrum of noise. The frequency response of the subtraction process can be written as follows.
Pn(f) is the power spectrum of the noise estimate and β is a spectral weighting factor based upon subband signal to noise ratio. The clean speech estimate is obtained by
Y(f)=X(f)H(f).
In a single channel noise suppression system, the
71—Analysis Window
The noise reduction process is performed by processing blocks of information. The size of the block is one hundred twenty-eight samples, for example. In one embodiment of the invention, the input frame size is thirty-two samples. Hence, the input data must be buffered for processing. A buffer of size one hundred twenty-eight words is used before windowing the input data.
The buffered data is windowed to reduce the artifacts introduced by block processing in the frequency domain. Different window options are available. The window selection is based on different factors, namely the main lobe width, side lobes levels, and the overlap size. The type of window used in the pre-processing influences the main lobe width and the side lobe levels. For example, the Hanning window has a broader main lobe and lower side lobe levels as compared to a rectangular window. Several types of windows are known in the art and can be used, with suitable adjustment in some parameters such as gain and smoothing coefficients.
The artifacts introduced by frequency domain processing are exacerbated further if less overlap is used. However, if more overlap is used, it will result in an increase in computational requirements. Using a synthesis window reduces the artifacts introduced at the reconstruction stage. Considering all the above factors, a smoothed, trapezoidal analysis window and a smoothed, trapezoidal synthesis window, each with twenty-five percent overlap, are used. For a 128-point discrete Fourier transform, a twenty-five percent overlap means that the last thirty-two samples from the previous frame are used as the first (oldest) thirty-two samples for the current frame.
D, the size of the overlap, equals (2·Dana-Dsyn). If Dana equals 24 and Dsyn equals 16, then D=32. The analysis window, Wana(n), is given by the following.
The synthesis window, Wsyn(n), is given by the following.
The central interval is the same for both windows. For perfect reconstruction, the analysis window and the synthesis window satisfy the following condition.
Wana(n)Wsyn(n)+Wana(n+128-D)Wsyn(n+128-D)=1
in the interval 0≦n<D and
Wana(n)Wsyn(n)=1
in the interval D≦n<96.
The buffered data is windowed using the analysis window
xw(m,n)=x(m,n)*Wana(n)
where x(m,n) is the buffered data at frame m.
72—Forward Discrete Fourier Transform (DFT)
The windowed time domain data is transformed to the frequency domain using the discrete Fourier transform given by the following transform equation.
where xw(m,n) is the windowed time domain data at frame m and X(m,k) is the transformed data at frame m and N is the size of
74—Frequency Domain Processing
The frequency response of the noise suppression circuit is calculated and has several aspects that are illustrated in the block diagram of
81—Power Spectral Density (PSD) Estimation
The power spectral density of the noisy speech is approximated using a first-order recursive filter defined as follows.
Px(m,k)=εsPx(m-1,k)+(1-εs)|X(m,k)|2
where Px(m,k) is the power spectral density of the noisy speech at frame m and Px(m-1,k) is the power spectral density of the noisy speech at frame m-1. |X(m,k)|2is the magnitude spectrum of the noisy speech at frame m and k is the frequency index. εs is a spectral smoothing factor.
82—Bark Band Energy Estimation
Subband based signal analysis is performed to reduce spectral artifacts that are introduced during the noise reduction process. The subbands are based on Bark bands (also called “critical bands”) that model the perception of a human ear. The band edges and the center frequencies of Bark bands in the narrow band speech spectrum are shown in the following Table.
The
The energy of noisy speech in each Bark band is calculated as follows.
The energy of the noise in each Bark band is calculated as follows.
where fH(i) and fL(i) are the spectral bin numbers corresponding to highest and lowest frequency respectively in Bark band i and Px(m,k) and Pn(m,k) are the power spectral density of the noisy speech and noise estimate respectively.
84—Noise Estimation
Rainer Martin was an early proponent of noise estimation based on minimum statistics; see “Spectral Subtraction Based on Minimum Statistics,” Proc. 7th European Signal Processing Conf.,
Even though using a sub-window based search for minimum reduces the computational complexity of Martin's noise estimation method, the search requires large amounts of memory to store the minimum in each sub-window for every subband. Gerhard Doblinger has proposed a computationally efficient algorithm that tracks minimum statistics; see G. Doblinger, “Computationally efficient speech enhancement by spectral minima tracking in subbands,” Proc. 4th European Conf. Speech, Communication and Technology,
Doblinger's noise estimation method tracks minimum statistics using a simple first-order filter requiring less memory. Hence, Doblinger's method is more efficient than Martin's minimum statistics algorithm. However, Doblinger's method overestimates noise during speech frames when compared with the Martin's method, even though both methods have the same convergence time. This overestimation of noise will distort speech during spectral subtraction.
In accordance with the invention, Doblinger's noise estimation method is modified by the additional test inserted in the process, indicated by the thicker lines in
The parameter μ in
89—Spectral Gain Calculation
Modified Weiner Filtering
Various sophisticated spectral gain computation methods are available in the literature. See, for example, Y. Ephraim and D. Malah, “Speech enhancement using a minimum mean-square error short-time spectral amplitude estimator,” IEEE Trans. Acoust. Speech, Signal Processing, vol. ASSP-32, pp. 1109-1121, December 1984; Y. Ephraim and D. Malah, “Speech enhancement using a minimum mean-square error log-spectral amplitude estimator,” IEEE Trans. Acoust. Speech, Signal Processing, vol. ASSP-33 (2), pp. 443-445, April 1985; and I. Cohen, “On speech enhancement under signal presence uncertainty,” Proceedings of the 26th IEEE International Conference on Acoustics, Speech, and Signal Processing, ICASSP-01, Salt Lake City, Utah, pp. 7-11, May 2001.
A closed form of spectral gain formula minimizes the mean square error between the actual spectral amplitude of speech and an estimate of the spectral amplitude of speech. Another closed form spectral gain formula minimizes the mean square error between the logarithm of actual amplitude of speech and the logarithm of estimated amplitude of speech. Even though these algorithms may be optimum in a theoretical sense, the actual performance of these algorithms is not commercially viable in very noisy conditions. These algorithms produce musical tone artifacts that are significant even in moderately noisy environments. Many modified algorithms have been derived from the two outlined above.
It is known in the art to calculate spectral gain as a function of signal to noise ratio based on generalized Weiner filtering; see L. Arslan, A. McCree, V. Viswanathan, “New methods for adaptive noise suppression,” Proceedings of the 26th IEEE International Conference on Acoustics, Speech, and Signal Processing, ICASSP-01, Salt Lake City, Utah, pp. 812-815, May 2001. The generalized Weiner filter is given by
where {circumflex over (P)}s(m,k) is the clean speech power spectrum estimate, {circumflex over (P)}n(m,k) is the power spectrum of the noise estimate and α is the noise suppression factor. There are many ways to estimate the clean speech spectrum. For example, the clean speech spectrum can be estimated as a linear predictive coding model spectrum. The clean speech spectrum can also be calculated from the noisy speech spectrum Px(m,k) with only a gain modification.
where Ex(m) is the noisy speech energy in frame m and En(m) is the noise energy in frame m. Signal to noise ratio, SNR, is calculated as follows.
Substituting the above equations in the generalized Weiner filter formula, one gets
where SNR(m) is the signal to noise ratio in frame number m and α′ is the new noise suppression factor equal to (Ex(m)/En(m))α. The above formula ensures stronger suppression for noisy frames and weaker suppression during voiced speech frames because H(m,k) varies with signal to noise ratio.
Bark Band Based Modified Weiner Filtering
The modified Weiner filter solution is based on the signal to noise ratio of the entire frame, m. Because the spectral gain function is based on the signal to noise ratio of the entire frame, the spectral gain value will be larger during a frame of voiced speech and smaller during a frame of unvoiced speech. This will produce “noise pumping”, which sounds like noise being switched on and off. To overcome this problem, in accordance with another aspect of the invention, Bark band based spectral analysis is performed. Signal to noise ratio is calculated in each band in each frame, as follows.
where Ex(m,i) and En(m,i) are the noisy speech energy and noise energy, respectively, in band i at frame m. Finally, the Bark band based spectral gain value is calculated by using the Bark band
where fL(i) and fH(i) are the spectral bin numbers of the highest and lowest frequency respectively in Bark band i.
One of the drawbacks of spectral subtraction based methods is the introduction of musical tone artifacts. Due to inaccuracies in the noise estimation, some spectral peaks will be left as a residue after spectral subtraction. These spectral peaks manifest themselves as musical tones. In order to reduce these artifacts, the noise suppression factor α′ must be kept at a higher value than calculated above. However, a high value of α′ will result in more voiced speech distortion. Tuning the parameter α′ is a tradeoff between speech amplitude reduction and musical tone artifacts. This leads to a new mechanism to control the amount of noise reduction during speech
The idea of utilizing the uncertainty of signal presence in the noisy spectral components for improving speech enhancement is known in the art; see R. J. McAulay and M. L. Malpass, “Speech enhancement using a soft-decision noise suppression filter,” IEEE Trans. Acoust., Speech, Signal Processing, vol ASSP-28, pp. 137-145, April 1980. After one calculates the probability that speech is present in a noisy environment, the calculated probability is used to adjust the noise suppression factor, α.
One way to detect voiced speech is to calculate the ratio between the noisy speech energy spectrum and the noise energy spectrum. If this ratio is very large, then we can assume that voiced speech is present. In accordance with another aspect of the invention, the probability of speech being present is computed for every Bark band. This Bark band analysis results in computational savings with good quality of speech enhancement. The first step is to calculate the ratio
where Ex(m,i) and En(m,i) have the same definitions as before. The ratio is compared with a threshold, λth, to decide whether or not speech is present. Speech is present when the threshold is exceeded; see
The speech presence probability is computed by a first-order, exponential, averaging (smoothing) filter.
p(m,i)=εpp(m-1,i)+(1-εp)Ip
where εp is the probability smoothing factor and Ip equals one when speech is present and equals zero when speech is absent. The correlation of speech presence in consecutive frames is captured by the filter.
The noise suppression factor, α, is determined by comparing the speech presence probability with a threshold, pth. Specifically, α is set to a lower value if the threshold is exceeded than when the threshold is not exceeded. Again, note that the factor is computed for each band.
Spectral Gain Limiting
Spectral gain is limited to prevent gain from going below a minimum value, e.g. −20 dB. The system is capable of less gain but is not permitted to reduce gain below the minimum. The value is not critical. Limiting gain reduces musical tone artifacts and speech distortion that may result from finite precision, fixed point calculation of spectral gain.
The lower limit of gain is adjusted by the spectral gain calculation process. If the energy in a Bark band is less than some threshold, Eth, then minimum gain is set at −1 dB. If a segment is classified as voiced speech, i.e., the probability exceeds pth, then the minimum gain is set to −1 dB. If neither condition is satisfied, then the minimum gain is set to the lowest gain allowed, e.g. −20 dB. In one embodiment of the invention, a suitable value for Eth is 0.01. A suitable value for pth is 0.1. The process is repeated for each band to adjust the gain in each band.
Spectral Gain Smoothing
In all block-transform based processing, windowing and overlap-add are known techniques for reducing the artifacts introduced by processing a signal in blocks in the frequency domain. The reduction of such artifacts is affected by several factors, such as the width of the main lobe of the window, the slope of the side lobes in the window, and the amount of overlap from block to block. The width of the main lobe is influenced by the type of window used. For example, a Hanning (raised cosine) window has a broader main lobe and lower side lobe levels than a rectangular window.
Controlled spectral gain smoothes the window and causes a discontinuity at the overlap boundary during the overlap and add process. This discontinuity is caused by the time-varying property of the spectral gain function. To reduce this artifact, in accordance with the invention, the following techniques are employed: spectral gain smoothing along a frequency axis, averaged Bark band gain (instead of using instantaneous gain values), and spectral gain smoothing along a time axis.
92—Gain Smoothing Across Frequency
In order to avoid abrupt gain changes across frequencies, the spectral gains are smoothed along the frequency axis using the exponential averaging smoothing filter given by
H′(m, k)=εgfH′(m,k-1)+(1-εgf)H(m,k),
where εgf is the gain smoothing factor across frequency, H(m,k) is the instantaneous spectral gain at spectral bin number k, H′(m,k-1) is the smoothed spectral gain at spectral bin number k-1, and H′(m,k) is the smoothed spectral gain at spectral bin number k.
93—Average Bark Band Gain Computation
Abrupt changes in spectral gain are further reduced by averaging the spectral gains in each Bark band. This implies that all the spectral bins in a Bark band will have the same spectral gain, which is the average among all the spectral gains in that Bark band. The average spectral gain in a band, H′avg(m,k), is simply the sum of the gains in a band divided by the number of bins in the band. Because the bandwidth of the higher frequency bands is wider than the bandwidths of the lower frequency bands, averaging the spectral gain is not as effective in reducing narrow band noise in the higher bands as in the lower bands. Therefore, averaging is performed only for the bands having frequency components less than approximately 1.35 kHz. The limit is not critical and can be adjusted empirically to suit taste, convenience, or other considerations.
94—Gain Smoothing Across Time
In a rapidly changing, noisy environment, a low frequency noise flutter will be introduced in the enhanced output speech. This flutter is a by-product of most spectral subtraction based, noise reduction systems. If the background noise is changes rapidly and the noise estimation is able to adapt to the rapid changes, the spectral gain will also vary rapidly, producing the flutter. The low frequency flutter is reduced by smoothing the spectral gain, H″(m,k) across time using a first-order exponential averaging smoothing filter given by
H″(m,k)=εgtH″(m-1,k)+(1-εgt)H′avg(m,b(i)) for f(k)<1.35 kHz, and
H″(m,k)=εgtH″(m-1,k)+(1-εgt)H′(m,k) for f(k)≧1.35 kHz,
where f(k) is the center frequency of Bark band k, εgt is the gain smoothing factor across time, b(i) is the Bark band number of spectral bin k, H′(m,k) is the smoothed (across frequency) spectral gain at frame index m, H′(m-1,k) is the smoothed (across frequency) spectral gain at frame index m-1, and H′avg(m,k) is the smoothed (across frequency) and averaged spectral gain at frame index m.
Smoothing is sensitive to the parameter εgt because excessive smoothing will cause a tail-end echo (reverberation) or noise pumping in the speech. There also can be significant reduction in speech amplitude if gain smoothing is set too high. A value of 0.1-0.3 is suitable for εgt. As with other values given, a particular value depends upon how a signal was processed prior to this operation; e.g. gains used.
76—Inverse Discrete Fourier Transform
The clean speech spectrum is obtained by multiplying the noisy speech spectrum with the spectral gain function in block 75. This may not seem like subtraction but recall the initial development given above, which concluded that the clean speech estimate is obtained by
Y(f)=X(f)H(f).
The subtraction is contained in the multiplier H(f).
The clean speech spectrum is transformed back to time domain using the inverse discrete Fourier transform given by the transform equation
where X(m,k)H(m,k) is the clean speech spectral estimate and s(m,n) is the time domain clean speech estimate at frame m.
77—Synthesis Window
The clean speech is windowed using the synthesis window to reduce the blocking artifacts.
sw(m,n)=s(m,n)*Wsyn(n)
78—Overlap and Add
Finally, the windowed clean speech is overlapped and added with the previous frame, as follows.
where sw(m-1, . . . ) is the windowed clean speech of the previous frame, sw(m,n) is the windowed clean speech of the present frame and D is the amount of overlap, which, as described above, is 32 in one embodiment of the invention.
The modified Doblinger's noise estimation algorithm (
101—Pseudo-Random Phase Spectrum Generation
A First Technique
This circuit produces a random phase frequency spectrum having unity magnitude. One way to generate the phase spectrum Φ(k) of the comfort noise is by using a pseudo-random number generator, which is uniformly distributed in the range [−π, π]. Using the phase spectrum Φ(k), the unity magnitude and random phase frequency spectrum can be obtained by computing sin(Φ(k)) and cos(Φ(k)) and using the formula,
C(k)=cos(Φ(k))+j sin(Φ(k))
where k is the spectral bin number, C(k) is the unity magnitude and random phase frequency spectrum. However, this method is computationally intensive, because it involves computation of sin(Φ(k)) and cos(Φ(k)).
Another method is to first generate the random frequency spectrum (both magnitude and phase are random) by using the pseudo-random generator to generate the real and imaginary parts of this spectrum, and then normalize this spectrum to unity magnitude. This can be written as follows,
where X(k) and Y(k) are the real and the imaginary parts, respectively, of the random frequency spectrum generated using the pseudo-random number generated that is uniformly distributed within the range [−1,1]. Because the real and the imaginary parts of the random frequency spectrum are uniformly distributed, the derived phase spectrum will not be uniform. In fact, the probability density function (
where fΦ(Φ) is the PDF of the generated phase spectrum. The phase spectrum is not uniform in the range [0, π/2]. By selecting the appropriate boundary values of the uniformly distributed random numbers X and Y, it is possible to generate the phase spectrum with a
A Second Technique
A simpler and more efficient way to generate a unit magitude, random phase spectrum is by using an eight phase look-up table. The phase spectrum is selected from one of the eight values in the look-up table using a uniformly distributed, random number. Specifically, the number is uniformly distributed in the range [0,1] and is quantized into eight different values. (A random number in the range 0-0.125 is quantized to 1. A random number in the range 0.126-0.250 is quantized to 2, and so on.) The quantized values are also uniformly distributed and correspond to particular phase shifts, e.g. 45°, 90°, and so on. The number of phases is arbitrary. Eight phases have been found sufficient to generate comfort noise without audible artifacts. This technique is more easily implemented than the first technique because it does not involve division or computing trigonometric functions.
102—Comfort Noise Gain Calculation
Comfort noise gain is calculated as a function of background noise level, noise suppression parameters, and a constant that takes into account other unknown system issues. Specifically, comfort noise gain Gcng(i,k) is calculated as,
Gcng(i,k)=N(k)Gnr(i,k)Fv
where N(k) is the background noise level in spectral bin number k, Gnr(i,k) is the Bark band based gain and is a function of noise suppression amount and Fv is the parameter that can be used to compensate for other unknown factors that may affect the end-to-end phone conversation. For example, the vocoder effects on the comfort noise in a cell phone system is unknown when this block is integrated into a cell phone. The adjustment is made during set-up.
103—Noise Reduction Parameter Based Gain Adjustments
If the noise reduction block is also enabled in a system, care should be taken in setting the comfort noise gain in order to smoothly insert the comfort noise. Specifically, the noise reduction dependent Bark band based comfort noise gain Gnr(i,k) can be written as,
Gnr(i,k)=F1[α(i)]F2[ηmin]
where i is the Bark band number, F1[α(i)] is a function of Bark band based noise suppression factor (see “Modified Weiner Filtering” above) and F2[ηmin] is a function of minimum possible spectral gain (see “Spectral Gain Limiting” above). The function F1[(α(i)] is determined empirically and is given in the following table.
As seen from the table, comfort noise gain, Gcng(i,k), is inversely proportional to the noise suppression parameter.
104—Comfort Noise Frequency Spectrum Generation
The spectrally matched, high resolution, frequency spectrum of the comfort noise is generated by multiplying the unity magnitude frequency spectrum from generator 101 by the comfort noise gain from calculation 102. Specifically, the spectrum CN(m,k) at frame m is obtained as follows.
CN(m,k)=Gcng(i,k)C(m,k)
106—Time Domain Comfort Noise Generation
Finally, the spectrally matched frequency spectrum is transformed to time domain using the inverse DFT. Specifically,
where c(m,n) is the time domain comfort noise at frame m.
107—Windowing
Because the generated comfort noise is random, audible artifacts will be introduced at frame boundaries. In order to reduce the boundary artifacts, the comfort noise c(m,n) must be windowed using any arbitrary window; see above description of “Synthesis Window.” The windowed comfort noise is buffered and the output rate is synchronized with the output rate of the noise reduction algorithm.
The invention thus provides improved comfort noise using a modified Doblinger noise estimate for a more efficient system for generating high resolution comfort noise that is spectrally matched to background noise. The comfort noise generator that substantially eliminates noise pumping by windowing the output.
Having thus described the invention, it will be apparent to those of skill in the art that various modifications can be made within the scope of the invention. For example, the use of the Bark band model is desirable but not necessary. The band pass filters can follow other patterns of progression. Noise suppression can be based on amplitude rather than power spectrum. The comfort noise can be added at several points in the circuit. As illustrated in
This application relates to application Ser. No. 10/830,652, filed Apr. 22, 2004, entitled Noise Suppression Based on Bark Band Weiner Filtering and Modified Doblinger Noise Estimate, assigned to the assignee of this invention, and incorporated by reference herein in its entirety.