US 6493664 B1 Abstract Encoding of prototype waveform components applicable to telecommunication systems provides improved voice quality enabling a dual-channel mode of operation which permits more users to communicate over the same physical channel. A prototype word (PW) gain is vector quantized using a vector quantizer (VQ) that explicitly populates a codebook by representative steady state and transient vectors of PW gain for tracking the abrupt variations in speech levels during onsets and other non-stationary events, while maintaining the accuracy of the speech level during stationary conditions.
Claims(19) 1. A frequency domain interpolative coding system for magnitude modeling and quantization of prototype waveforms, comprising:
a linear prediction (LP) front end responsive to an input signal providing LP parameters which are quantized and encoded over predetermined intervals and used to compute a LP residual signal;
an open loop pitch estimator responsive to said LP residual signal;
a pitch quantizer;
a pitch interpolator;
said open loop pitch estimator, said pitch quantizer, and said pitch interpolator yielding a pitch contour within the predetermined interval;
a signal processor responsive to said LP residual signal and the pitch contour for extracting a prototype waveform (PW) for a number of equal sub-intervals within the predetermined interval;
said signal processor computing a PW gain for generating a normalized PW for each sub-interval and a PW gain vector for the predetermined interval;
a low-pass filter for separating the normalized PW into a slowly evolving waveform (SEW) component and a rapidly evolving waveform (REW) component along every pitch harmonic track;
a voicing measure for characterizing the degree of signal periodicity over the predetermined interval, derived from the input signal, PW, SEW and REW characteristics; and
a quantizer for quantization of the variable dimension SEW magnitude vector by a hierarchical approach, comprising fixed dimension vector quantizers (VQs) for each predetermined interval.
2. A system as recited in
3. A system as recited in
4. A system as recited in
5. A system as recited in
6. A system as recited in
7. A method of joint vector quantization of rms and shape components, comprising:
computation of a fixed dimension SEW mean vector by averaging the SEW harmonic magnitudes over a set of sub-bands that span the bandwidth of the input signal;
computation of a variable dimension SEW deviation vector by subtracting the SEW mean from the SEW magnitude vector;
determination of a fixed dimension SEW deviation subvector from the variable dimension SEW deviation vector based on a dynamic frequency selection approach which uses the quantized LP parameter based spectral characteristics of the input signal during the current interval; and
joint quantization of the rms and shape components of the fixed dimension SEW deviation subvector using a frequency weighted distortion measure.
8. A method of fixed dimension quantization of the mean component of the SEW magnitude vector, comprising:
determination of the full dimension SEW deviation vector from the quantized fixed dimension SEW deviation subvector by padding with zero values or the output of the SEW shape predictor;
computation of a full dimension target SEW vector by sub-band computing the difference between the SEW magnitude vector and the reconstructed full dimension SEW deviation vector;
quantization of the fixed dimension SEW mean vector, so that when converted to a full dimension vector by a piecewise-constant construction, a frequency weighted distortion measure is minimized with respect to the target SEW vector; and
selection of a SEW mean codebook from two possible codebooks based on the degree of voicing using the encoded voicing measure.
9. A method as recited in
10. A frequency domain interpolative coding system for magnitude modeling and quantization of prototype waveforms, comprising:
a linear prediction (LP) front end responsive to an input signal providing LP parameters which are quantized and encoded over predetermined intervals and used to compute a LP residual signal;
an open loop pitch estimator responsive to said LP residual signal;
a pitch quantizer;
a pitch interpolator;
said open loop pitch estimator, said pitch quantizer, and said pitch interpolator yielding a pitch contour within the predetermined interval;
a signal processor responsive to said LP residual signal and the pitch contour for extracting a prototype waveform (PW) for a number of equal sub-intervals within the predetermined interval;
said signal processor computing a PW gain for generating a normalized PW for each sub-interval and a PW gain vector for the predetermined interval;
a low-pass filter for separating the normalized PW into a slowly evolving waveform (SEW) component and a rapidly evolving waveform (REW) component along every pitch harmonic track;
a voicing measure for characterizing the degree of signal periodicity over the predetermined interval, derived from input signal, PW, SEW and REW characteristics; and
a fixed dimension vector quantizer for quantization of a variable dimension REW magnitude component using a hierarchical approach for each predetermined interval.
11. A system as recited in
12. A system as recited in
13. A system as recited in
14. A system as recited in
15. A system as recited in
16. A frequency domain interpolative coding method for magnitude modeling and quantization of prototype waveforms, comprising:
a linear prediction (LP) front end responsive to an input signal providing LP parameters which are quantized and encoded over predetermined intervals and used to compute a LP residual signal;
an open loop pitch estimator responsive to said LP residual signal;
a pitch quantizer;
a pitch interpolator;
said open loop pitch estimator, said pitch quantizer, and said pitch interpolator yielding a pitch contour within the predetermined interval;
a signal processor responsive to said LP residual signal and the pitch contour for extracting a prototype waveform (PW) for a number of equal sub-intervals within the predetermined interval;
said signal processor computing a PW gain for generating a normalized PW for each sub-interval and a PW gain vector for the predetermined interval;
a low-pass filter for separating the normalized PW into a slowly evolving waveform (SEW) component and a rapidly evolving waveform (REW) component along every pitch harmonic track;
a voicing measure for characterizing the degree of signal periodicity over the predetermined interval, derived from the input signal, PW, SEW and REW characteristics; and
quantization of the variable dimension SEW magnitude vector by a hierarchical approach, using fixed dimension vector quantizers (VQs) for each predetermined interval.
17. A method as recited in
18. A method as recited in
19. A method as recited in
Description This application is based upon and claims the benefit under 35 U.S.C. §119 of U.S. Provisional Application No. 60/127,780, filed Apr. 5, 1999, which is incorporated by reference. 1. Field of the Invention The present invention proposes novel techniques for modeling, quantization and error concealment of the components of prototype waveform (PW) representation of the speech prediction residual signal, and more particularly to improved coding of the spectral magnitudes of the slowly evolving waveform (SEW) and rapidly evolving waveform (REW) components. Encoding of other components of the PW representation, such as the PW gain vector, the SEW and REW phase spectra are also discussed for completeness, but these are the subjects of separate inventions. These techniques are applicable to low bit rate speech coders operating in the range of 2-4 kbit/s. In this invention, novel techniques are proposed for the quantization of the variable dimension SEW and REW spectral magnitude. 2. Background and Description of Related Art The present invention describes techniques for efficient encoding of the speech signal applicable to speech coders typically operating at bit rates in the range of 2-4 kbit/s. In particular, such techniques are applicable to a representation of the speech prediction error (residual) signal known as the prototype waveform (PW) representation, see, e.g., W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; W. B. Klejin, “Encoding Speech Using Prototype Waveforms”, IEEE Transactions on Speech and Audio Processing, Vol. 1, No. 4, 386-399, 1993. The prototype waveforms are a sequence of complex Fourier transforms evaluated at pitch harmonic frequencies, for pitch period wide segments of the residual, at a series of points along the time axis. Thus, thePW sequence contains information about the spectral characteristics of the residual signal as well as the temporal evolution of these characteristics. A high quality of speech can be achieved at low coding rates by efficiently quantizing the important aspects of the PW sequence. In PW based coders, the PW is separated into a shape component and a level component by computing the RMS (or gain) value of the PW and normalizing the PW to unity RMS value. The normalized PW is decomposed into a slowly evolving waveform (SEW) which contains the periodic component of the residual and a rapidly evolving waveform (REW) which contains the aperiodic component of the residual. As the pitch frequency varies, the dimensions of the PW, SEW and REW vectors also vary, typically in the range 11-61. This invention also proposes novel error concealment techniques for mitigating the effects of frame erasure or packet loss between the speech encoder and the speech decoder due to a degraded transmission medium. W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; W. B. Klejin, “Encoding Speech Using Prototype Waveforms”, IEEE Transactions on Speech and Audio Processing, Vol. 1, No. 4, 386-399, 1993; and J. Hagen and W. B. Klejin, “Waveform Interpolation”, in Modern Methods of Speech Processing, Edited by R. P. Ramachandran and R. Mammone, Kluwer Academic Publishers, 1995, describe the prototype waveform interpolation (PWI) modeling approach. However, the quantization of the PWI model is not specified in detail. The proposed invention pertains to the quantization of the various components of the PWI. The quantization approaches proposed in our invention are novel methods and are not in any way based on or derived from the quantization approaches described in the prior art in W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; W. B. Klejin, “Encoding Speech Using Prototype Waveforms”, IEEE Transactions on Speech and Audio Processing, Vol. 1, No. 4, 386-399, 1993; and J. Hagen and W. B. Klejin, “Waveform Interpolation”, in Modern Methods of Speech Processing, Edited by R. P. Ramachandran and R. Mammone, Kluwer Academic Publishers, 1995. Additionally, W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996, and Y. Shoham, “Very Low Complexity Interpolative Speech Coding at 1.2 to 2.4 kbps”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1997, describe certain quantization schemes for prototype waveform encoding. In the prior art of W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995, and W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996, the PW gain vector is not quantized using a VQ designed by explicit population of steady state and transient codewords. This can result in poor performance during voicing onsets and other transitory events. The variable dimensionality of SEW and REW vectors is addressed by using fixed order analytical function approximations for the REW magnitude shape and by deriving the SEW magnitude approximately from the REW magnitude. The coefficients of the analytical function that provides the best fit to the vector are used to represent the vector for quantization. This approach suffers from three disadvantages: (i) A modeling error is now added to the quantization error, leading to a loss of performance, (ii) analytical function approximation for reasonable orders (5-10) deteriorates with increasing frequency, and (iii) if spectrally weighted distortion metrics are used during VQ, the complexity of these methods becomes formidable. In the prior art of W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; and Y. Shoham, “Very Low Complexity Interpolative Speech Coding at 1.2 to 2.4 kbps”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1997, only a predetermined low frequency sub-band (for e.g., 0-800 Hz band) of the SEW magnitude is encoded. This substantially reduces the dimension of the SEW vector, thereby permitting direct VQ. At the receiver, the remaining upper band is estimated using the REW magnitude spectrum. This method suffers from the disadvantage that if a significant amount of signal energy exists in the upper band, it is reproduced poorly, leading to poor speech quality. This condition can occur for a number of speech sounds, especially for unvoiced speech. A number of prior techniques for encoding phase are in use in PWI based voice coders, see, e.g., W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; W. B. Klejin, “Encoding Speech Using Prototype Waveforms”, IEEE Transactions on Speech and Audio Processing, Vol. 1, No. 4, 386-399, 1993; W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996; J. Hagen and W. B. Klejin, “Waveform Interpolation”, in Modern Methods of Speech Processing, Edited by R. P. Ramachandran and R. Mammone, Kluwer Academic Publishers, 1995; Y. Shoham, “Very Low Complexity Interpolative Speech Coding at 1.2 to 2.4 kbps”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1997. In these prior art, the SEW phase vector is either a random phase (for unvoiced sounds) or is the phase of a fixed pitch cycle waveform (for voiced sounds). This binary characterization of the SEW phase is too simplistic. This method may work for a narrow range of speakers and for clean speech signals. However, this method becomes unsatisfactory as the range of speakers increases and for speech corrupted by background noise. Noisy speech requires varying degrees of randomness in the SEW phase. In prior art of W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; W. B. Klejin, “Encoding Speech Using Prototype Waveforms”, IEEE Transactions on Speech and Audio Processing, Vol. 1, No. 4, 386-399, 1993; W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996, the REW quantization does not employ a normalization of the REW magnitude vectors, whereby the level and shape information are separated. Instead, the REW magnitude vectors are quantized directly. The separation of level and shape, as proposed in this invention, is advantageous, since it allows more accurate quantization of time varying REW level, which is of primary importance. Secondly, in the prior art cited above, REW magnitude quantization is based upon the use of analytical functions to overcome the problem of variable dimensionality. This approach suffers from three disadvantages as mentioned earlier: (i) A modeling error is now added to the quantization error, leading to a loss of performance, (ii) analytical function approximation for reasonable orders (5-10) deteriorates with increasing frequency, and (iii) if spectrally weighted distortion metrics are used during VQ, the complexity of these methods becomes formidable. In the prior art of W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995, and W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996, REW phase is obtained at the receiver using random phase models. Use of a random phase for REW results in reconstructed speech that is excessively rough. This is due to the fact that it is not consistent with the SEW-REW separation model that is employed at the encoder. Consequently, the random phase model results in a REW component that does not conform to certain basic characteristics of the REW at the encoder. As an example, it is possible for the random phase based REW to have a significant amount of energy below 25 Hz, which is not possible for the REW at the encoder. Further, the correlation between SEW and REW due to the overlapping separation filters cannot be directly created when a random phase model is employed. None of the prior art related to PW speech coders address the issue of error concealment that can be applied to the PW model parameters. This invention proposes novel techniques for the modeling, quantization and error concealment, applicable to the components of a PW based voice coder, i.e., the PW gain vector and the variable dimension SEW and REW complex vectors. The prototype waveform (PW) gain is vector quantized using a vector quantizer (VQ) that explicitly populates the codebook by representative steady state and transient vectors of PW gain. This approach is effective in tracking the abrupt variations in speech levels during onsets and other non-stationary events, while maintaining the accuracy of the speech level during stationary conditions. In case of a frame erasure, errors in the PW gain parameter are concealed by estimating the PW gain based on the PW gains of the two preceding error-free frames and gradually decaying this estimate over the duration of the current frame. The rapidly evolving waveform (REW) and slowly evolving waveform (SEW) component vectors are converted to magnitude-phase formats for quantization. The variable dimension SEW magnitude vector is quantized using a hierarchical approach. A fixed dimension SEW mean vector is computed by a sub-band averaging of SEW magnitude spectrum. A SEW deviation vector is computed by subtracting the SEW mean from the SEW magnitude vector. The variable dimension SEW deviation vector is reduced to a fixed dimension subvector of size 10, based on a dynamic frequency selection approach. The SEW deviation subvector and SEW mean vector are vector quantized using a switched predictive VQ. At the decoder, the SEW deviation subvector and the SEW mean vector are combined to construct a full dimension SEW magnitude vector. This hierarchical approach to SEW magnitude quantization emphasizes the accurate representation of the average SEW magnitude level, which is perceptually important. Additionally, the average level gets refined at frequencies that are perceptually significant. In case of a frame erasure, errors in the SEW magnitude are concealed by estimating it using the preceding error-free SEW mean vector. SEW phase information is represented implicitly using a measure of the degree of periodicity of the residual signal. This voicing measure is computed using a weighted root mean square (RMS) value of the SEW, a measure of the variance of SEW and the peak value of the normalized autocorrelation function of the residual signal and is quantized using 3 bits. At the decoder, the SEW phase is computed by a weighted combination of the previous SEW phase vector, a random phase perturbation and a fixed phase vector obtained from a voiced pitch pulse. The relative weights for these components are determined by the quantized voicing measure and the ratio of SEW and REW RMS values. The decoded SEW magnitude and SEW phase are combined to produce a complex SEW vector. The SEW component is passed through a low pass filter to reduce excessive variations and to be consistent with the SEW extraction process at the encoder. The SEW magnitude is preserved after the filtering operation. In case of a frame erasure, the voicing measure is estimated using a voice activity detector (VAD) output and the RMS value of the decoded SEW magnitude vector. The REW magnitude vector sequence is normalized to unity RMS value, resulting in a REW magnitude shape vector and a REW gain vector. The normalized REW magnitude vectors are modeled by a multi-band sub-band model which converts the variable dimension REW magnitude shape vectors to a fixed dimension, e.g., to five dimensional REW sub-band vectors in the described embodiment. The sub-band vectors are averaged over time, resulting in a single average REW sub-band vector for each frame. At the decoder, the full-dimension REW magnitude shape vector is obtained from the REW sub-band vector by a piecewise-constant interpolation. The REW gain vector is estimated using the quantized SEW mean vector. The resulting estimation error has a smaller variance and is efficiently vector quantized. A 5-bit vector quantization is used to encode the estimation error. In case of a frame erasure, the estimate provided by the SEW mean is used as the REW magnitude. The REW phase vector is regenerated at the decoder based on the received REW gain vector and the voicing measure, which determines a weighted mixture of SEW component and a random noise that is passed through a high pass filter to generate the REW component. The weighting is adjusted so as to achieve the desired degree of correlation between the REW and the SEW components. The high pass filter poles are adjusted based on the voicing measure to control the REW component characteristics. At the output the filter, the magnitude of the REW component is scaled to match the received REW magnitude vector. In addition to the error concealment techniques for the PW parameters, this invention also proposes error concealment and recovery techniques for the speech line spectral frequency (LSF) parameters and the pitch period parameter. In the case of a frame error, the LSF's are constructed using the previous error-free LSF vector. During the error recovery process, the LSF's are forced to change smoothly. In the case of pitch period, frame errors are concealed by repeating the preceding error-free pitch period value. Further, during error recovery, the pitch contour is forced to conform to certain smoothness conditions. The invention uses a PW gain VQ design that explicitly populates a partitioned codebook using representative steady state and transient vectors of PW gain, e.g., 75% of the codebook is allocated to representing steady state vectors and the remaining 25% is allocated to representation of transient vectors. This approach allows better tracking of the variations of the residual power levels. This is particularly important at speech onsets during which the speech power levels can change by several orders of magnitude within a 20 ms frame. On the other hand, during steady state frames, the speech power level variation is significantly smaller. Other approaches, see, e.g., W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; W. B. Klejin, “Encoding Speech Using Prototype Waveforms”, IEEE Transactions on Speech and Audio Processing, Vol. 1, No. 4, 386-399, 1993; W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996; J. Hagen and W. B. Klejin, “Waveform Interpolation”, in Modern Methods of Speech Processing, Edited by R. P. Ramachandran and R. Mammone, Kluwer Academic Publishers, 1995; Y. Shoham, “Very Low Complexity Interpolative Speech Coding at 1.2 to 2.4 kbps”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1997, speech gain vectors are not quantized using such a partitioned VQ approach. Consequently, the codebook will be dominated by steady state vectors, and may lead to poor reproduction of speech levels during onsets. The SEW vector determines the characteristics of the voiced segments of speech, and hence is perceptually important. It is quantized in magnitude-phase form. It is important to maintain the correct average level (across frequency) of the SEW magnitude vector. The variation about this average is of secondary importance compared to the average itself. Motivated by this consideration, the present invention uses a hierarchical approach to representing the SEW magnitude vector as the sum of a SEW mean vector and a SEW deviation vector. The SEW mean vector is obtained by a sub-band averaging process, resulting in a 5-dimensional vector. The SEW deviation vector is the difference between the SEW magnitude vector and the SEW mean vector. Compared to the SEW deviation vector, SEW mean vector is quantized more precisely and better protected against channel errors. This hierarchical decomposition into a mean component and a deviation component had the important advantage that the average SEW levels can be preserved better. This is very important in achieving a high-perceived quality of speech, especially during voiced segments. Prior techniques, see, e.g., W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; W. B. Klejin, “Encoding Speech Using Prototype Waveforms”, IEEE Transactions on Speech and Audio Processing, Vol. 1, No. 4, 386-399, 1993; W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996; J. Hagen and W. B. Klejin, “Waveform Interpolation”, in Modern Methods of Speech Processing, Edited by R. P. Ramachandran and R. Mammone, Kluwer Academic Publishers, 1995; Y. Shoham, “Very Low Complexity Interpolative Speech Coding at 1.2 to 2.4 kbps”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1997, have employed non-hierarchical approaches and are likely to result in lower performance and less robustness to channel errors. The dimension of the REW and SEW vectors is a variable that depends upon the pitch frequency, and typically varies in the range 11-61. Existing VQ techniques, such as direct VQ, split VQ and multi-stage VQ are not well suited for variable dimension vectors. Adaptations of these techniques for variable dimension are neither practical from an implementation viewpoint nor satisfactory from a performance viewpoint. These are not practical since the worst case high dimensionality results in a high computational cost and a high storage cost. This usually leads to simplifications such as structured VQ, which result in a loss of performance, making such solutions unsatisfactory for encoding speech at bit rates in the range 2-4 kbit/s. In a prior technique to address the variable dimensionality problem, W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996, analytical functions of a fixed order are used to approximate the variable dimension vectors. The coefficients of the analytical function that provides the best fit to the vectors are used to represent the vectors for quantization. The analytical function approximation is applied to the REW magnitude. The SEW magnitude is derived approximately from the REW magnitude in the 800 Hz-4000 Hz band. The SEW magnitude is explicitly coded only in the 0-800 Hz band. This approach suffers from three disadvantages: (i) A modeling error is now added to the quantization error, leading to a loss of performance, (ii) analytical function approximation for reasonable orders (5-10) deteriorates with increasing frequency, and (iii) if spectrally weighted distortion metrics are used during VQ, the complexity of these methods becomes formidable. This invention proposes a novel solution to this problem which has a reasonable computation and storage cost, and at the same time provides a high level of performance. In this approach, the variable dimension SEW vector is decomposed into two fixed dimension vectors in a hierarchical manner, as the sum of a SEW mean vector and a SEW deviations vector. The SEW mean vector is obtained by a 5-band sub-band averaging and is represented by a 5-dimensional vector. The SEW deviations vector is reduced to a SEW deviation sub-vector of fixed dimension of 10 by selecting the 10 elements that are considered most important for speech quality. The set of selected frequencies varies with the spectral characteristics of speech, but is done in such a way that it needs no explicit transmission. In the absence of channel errors, the decoder can map the SEW deviation sub-vectors to the correct frequencies. The unselected elements of the SEW deviations are not encoded. The full-dimension SEW magnitude vector is reconstructed at the decoder by adding the quantized SEW mean and the SEW deviation components. During voiced segments, the SEW magnitude vector exhibits a certain degree of interframe correlation. In order to exploit this property, the SEW mean vector is quantized using a switched predictive VQ. The SEW deviation sub-vector is quantized using a switched predictive gain-shape quantization. The predictor mode for SEW mean vector and the SEW deviations vector are jointly switched so as to minimize a spectrally weighted distortion between the reconstructed and the original SEW magnitude vectors. At the decoder, the SEW deviation sub-vector and the SEW mean vector are combined to produce the full dimension SEW magnitude vector. Direct encoding of the SEW phase vector leads to unsatisfactory results when a small number of bits are employed. The present invention overcomes this problem by implicitly representing SEW phase using a measure of periodicity called the voicing measure. The voicing measure is computed using a weighted RMS value of the SEW, a measure of variability of SEW and the peak value of the normalized autocorrelation of the residual signal. The voicing measure is also useful in REW phase modeling. The voicing measure is quantized using 3 bits. At the decoder, the SEW phase is computed by a weighted combination of the previous SEW phase vector, a random phase perturbation and a fixed phase vector which corresponds to a voiced pitch pulse. The relative weights for these components are determined by the quantized voicing measure. The decoded SEW magnitude and SEW phase are combined to produce the complex SEW vector. The SEW component is filtered using a low pass filter to suppress excessively rapid variations that can appear due to the random component in SEW phase. The strength of the proposed technique is that it can realize various degrees of voicing in a frequency dependent manner. This results in more natural sounding speech with the right balance of periodicity and roughness both under quiet and noisy ambient conditions. The REW magnitude vector sequence is normalized to unity RMS value, resulting in a REW magnitude shape vector and a REW gain vector. This separates the more important REW level information from the relatively less important REW shape information. Encoding of the REW gain vector serves to track the level of the REW magnitude vector as it varies across the frame. This is important to maintain the correct level of roughness as well as evolution bandwidth (temporal variation) of the random component in the reconstructed speech. The REW gain vector can be closely estimated using the encoded SEW mean vector. Consequently, REW gain is efficiently encoded by quantizing the REW gain estimation error with a small number of bits. Prior techniques, such as, e.g., W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996; Y. Shoham, “Very Low Complexity Interpolative Speech Coding at 1.2 to 2.4 kbps”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1997 did not employ a gain-shape decomposition of REW magnitude or an estimation of REW gain vector using SEW level information. The separation of level and shape is advantageous, since it allows more accurate quantization of time varying REW level, which is of primary importance. Estimation using SEW level improves quantization accuracy. In prior techniques, the entire REW magnitude was modeled using analytical functions. This approach has serious shortcomings as mentioned earlier. The normalized REW magnitude vectors are variable dimension vectors. In order to convert to a fixed dimension representation, these are modeled by a 6-band sub-band model resulting in 6 dimensional REW sub-band vectors. The REW sub-band vectors are averaged across the frame to obtain a single average REW sub-band vector for each frame. The average REW sub-band vector is vector quantized. At the decoder, the full-dimension REW magnitude shape vector is obtained from the REW sub-band vector by a piecewise-constant construction. Prior REW magnitude quantization is based upon the use of analytical functions to overcome the problem of variable dimensionality, W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996. This approach suffers from the disadvantages discussed earlier. The REW phase vector is not explicitly encoded. At the receiver, the complex REW vector is derived using the received REW gain vector, received voicing measure and the received SEW vector. The complex REW component is derived by filtering a weighted sum of the complex SEW component and a white noise signal through a high pass filter. The weighting of SEW and white noise is dependent on the average REW gain value for that frame. The high pass filter is a single-zero, two-pole filter, whose real zero is adjusted based on SEW and REW levels. The complex pole frequency is fixed at 25 Hz (assuming a 50 Hz SEW sampling rate). The pole radius varies from 0.2 to 0.60, depending on the decoded voicing measure. As the periodicity of the frame increases (as indicated by a lower voicing measure), the pole moves closer to the unit circle. At the same time, at the filter input, the weight of the SEW component increases relative to that of the white noise component. This has the effect of creating a REW component having more correlation with SEW and with more of its energy at lower frequencies. At the same time, the presence of the zero at 0.9 ensures that the REW energy diminishes below 25 Hz. The overall result is to create a REW component that has its energy distributed in a manner roughly consistent with the REW extraction process at the encoder and with the relative levels of REW and SEW components. In prior implementations of PWI coding, such as, e.g., W. B. Klejin, Y. Shoham, D. Sen and R. Hagen, “A Low Complexity Waveform Interpolation Coder”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1996; Y. Shoham, “Very Low Complexity Interpolative Speech Coding at 1.2 to 2.4 kbps”, IEEE International Conference on Acoustics, Speech and Signal Processing, 1997, REW phase was obtained at the receiver using random phase models. Use of a random phase for REW results in reconstructed speech that is excessively rough. This is due to the fact that it is not consistent with the SEW-REW separation model that is employed at the encoder. Consequently, the random phase model results in a REW component that does not conform to certain basic characteristics of the REW at the encoder. As an example, the random phase based REW is likely to have a significant amount of energy below 25 Hz, while the REW at encoder does not have a significant amount of energy below 25 Hz. Further, the correlation between SEW and REW due to the overlapping separation filters cannot be directly created when a random phase model is employed. FIG. 1 is a schematic block diagram illustrating the computation of prototype waveforms and extraction of slowly and rapidly evolving waveforms; FIG. 2 is a block diagram illustrating the predictive vector quantization of the SEW deviations sub-vector; FIG. 3 is a block diagram illustrating the predictive vector quantization of SEW sub-band mean vector; FIG. 4 is a neural network structure for the computation of the voicing measure; FIG. 5 is a block diagram illustrating the construction of the SEW phase based on the voicing measure; FIG. 6 is a block diagram illustrating the construction of the REW phase; and FIG. 7 is a block diagram illustrating the reconstruction of the PW and speech signal. In low rate coding of speech signals, it is common to employ linear predictive coding (LPC) or some other equivalent technique to model the short-term spectra of the speech signal. The corrections to the short term spectral model of speech as well as the glottal excitation to the vocal tract are embodied in a prediction error (residual) signal, obtained by filtering the speech signal by an all-zero LPC filter. Hence, in order to reproduce natural sounding speech at the decoder, it is essential to encode the residual signal in such a way that the perceptually important aspects of the residual signal can be reproduced. This invention pertains to a set of methods for efficient encoding of the residual signal for voice coders operating at bit rates in the range of 2-4 kbit/s. In particular, this invention is applicable to a paradigm of speech signal representation known as prototype waveform interpolation (PWI). W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995; W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995. In this paradigm, the perceptually important aspects of the residual signal are represented as temporally evolving spectral characteristics. Specifically, the residual signal is represented by a sequence of prototype waveform (PW) vectors, which contains the time varying spectral characteristics of the residual. The PW vectors are derived by evaluating the complex Fourier transform of residual pitch cycles at the pitch frequency harmonics at a sequence of time instances. The PW is in turn separated into two components: a slowly evolving waveform (SEW) corresponding to the periodic component of the residual and a rapidly evolving waveform (REW) corresponding to the aperiodic component of the residual. For a detailed description of the PWI modeling process and the separation of SEW and REW, see W. B. Klejin and J. Haagen, “Waveform Interpolation for Coding and Synthesis”, in Speech Coding and Synthesis, Edited by W. B. Klejin, K. K. Paliwal, Elsevier, 1995. The discussion in this invention will focus on the methods of quantizing the SEW, REW and PW gain components. The PW gain is vector quantized by an 8-bit vector quantizer (VQ). The VQ is designed using an approach that explicitly populates the codebook by representative steady state and transient vectors of PW gain. 75% of the codebook is allocated to representing steady state vectors and the remaining 25% is allocated to representation of transient vectors. This approach is better able to track the abrupt variations in speech levels during onsets and other non-stationary events, while maintaining the accuracy of the speech level during stationary conditions. The complex SEW vector is quantized in the magnitude-phase form. The variable dimension SEW magnitude vector is quantized using a hierarchical approach, using fixed dimension VQ. A 5-dimension SEW mean vector is computed by a sub-band averaging of SEW magnitude spectrum. A SEW deviation vector is computed by subtracting the SEW mean from the SEW magnitude vector. The variable dimension SEW deviation vector is reduced to a fixed dimension sub-vector of size 10, based on a dynamic frequency selection approach which uses the short term spectral characteristics of speech. The selection is done in such a way that explicit transmission of the frequencies of the selected coefficients is not required. The SEW deviation sub-vector and SEW mean vector are vector quantized. Both these vector quantizations are switched predictive, with the predictor mode being selected jointly so as to minimize a spectrally weighted distortion measure relative to the original SEW magnitude vector. At the decoder, the SEW deviation sub-vector and the SEW mean vector are combined to construct a full dimension SEW magnitude vector. This hierarchical approach to SEW magnitude quantization emphasizes the accurate representation of the average SEW magnitude level, which is perceptually important. Additionally, corrections to the average level are made at frequencies that are perceptually significant. This method also solves the difficult problem of quantizing variable dimension vectors in an effective and efficient manner. The SEW phase information is represented implicitly using a measure of the degree of periodicity of the residual signal. This voicing measure is computed using a weighted root mean square (RMS) value of the SEW, a measure of the variance of SEW and the peak value of the normalized autocorrelation function of the residual signal. The voicing measure is quantized using 3 bits. At the decoder, the SEW phase is computed by a weighted combination of the previous SEW phase vector, a random phase perturbation and a fixed phase vector obtained from a voiced pitch pulse. The relative weights for these components are determined by the quantized voicing measure. The decoded SEW magnitude and SEW phase are combined to produce a complex SEW vector. The REW vector is converted to magnitude-phase form, and only the REW magnitude is explicitly encoded. The REW magnitude vector sequence is normalized to unity RMS value, resulting in a REW magnitude shape vector and a REW gain vector. The normalized REW magnitude vectors are modeled by a 5-band sub-band model. This converts the variable dimension REW magnitude shape vectors to 5 dimensional REW sub-band vectors. These sub-band vectors are averaged across the time, resulting in a single average REW sub-band vector for each frame. This average REW sub-band vector is vector quantized. At the decoder, the full-dimension REW magnitude shape vector is obtained from the REW sub-band vector by a piecewise-constant construction. The quantized SEW mean vector can be used to obtain a good estimate the REW gain vector. The resulting estimation error has a smaller variance and is efficiently vector quantized. A 5-bit vector quantization is used to encode the estimation error. The REW phase vector is regenerated at the decoder based on the received REW gain vector and the voicing measure. These determine a weighted mixture of SEW component and a random noise, which is passed through a high pass filter to generate the REW component. The high pass filter poles are adjusted based on the voicing measure to control the REW component characteristics. The high pass filter zero is adjusted based on SEW and REW levels. At the output of the filter, the magnitude of the REW component is scaled to match the received REW magnitude vector. The SEW corresponds to the quasi-periodic component of the residual. This is a perceptually important component and hence it should be quantized precisely. However, since it varies slowly, it can be transmitted less frequently (typically once/20 ms). The REW component corresponds to the random component in the residual. This is perceptually less important than the SEW, and hence can be quantized coarsely. But since the REW varies more rapidly, and it should be transmitted more frequently than the SEW (typically once/2 ms). The frequency domain interpolative codec design provides a linear prediction (LP) front end whose parameters are quantized and encoded at 20 ms intervals, using the LSF domain using multi-stage VQ with backward prediction. Voice Activity Detection (VAD) with single bit transmission and decoding is used. Open loop pitch extraction is performed at 20 ms intervals and quantized using a scalar quantizer. PW extraction, gain computation, and normalization are performed every 2 ms. Separation of the normalized PW into SEW and REW uses complimentary 21 tap linear phase low-pass and high-pass FIR filters. The PW gain is low pass filtered and decimated by a 2:1 ratio to produce a smoothed or filtered PW gain for a 5 dimensional VQ. The 5 dimensional VQ has two distinct sections, i.e., a section allocated to representing steady “state vectors,” and a section allocated to representation of “transient vectors.” This approach is better able to track the abrupt variations in speech levels during onsets and other non-stationary events, while maintaining the accuracy of the speech level during stationary conditions. Error concealment for the PW gain parameter is carried out by decaying an average measure of PW gain obtained from the last two frames. For subsequent bad frames, the rate of decay is increased. The error recovery limits the received PW gain growth to within an adaptive bound in the first good frame. The quantization of the SEW magnitude uses a mean-RMS-shape method with switched backward prediction and a voicing dependent SEW mean codebook. A voicing measure that characterizes the degree of voicing is derived as the output of a neural network using several input parameters that are correlated to the degree of periodicity of the signal. The SEW phase model uses the pitch frequency contour and the voicing measure in every 20 ms frame to generate the SEW phase as a weighted combination of a fixed phase, the previous SEW phase and a random phase component. The resulting complex SEW signal is low pass filtered to control its evolutionary rate. The quantization of the REW magnitude uses a gain-shape approach. The REW phase model determines REW phase as the phase of the output of an adaptive second order pole-zero filter which is driven by a weighted combination of SEW and noise with random phase but a normalized energy level with respect to the SEW RMS value. Error concealment and recovery methods use the inter-dependency and residual redundancies of the various PW parameters, and adaptive post-processing techniques further enhance the voice quality of the synthesized speech. Adaptive bandwidth broadening is employed for post-processing inactive speech frames to mitigate annoying artifacts due to spurious spectral peaks by (1) computing a measure of VAD likelihood by summing the VAD flags for the preceding, the current and the next two frames (which are available due to the 2 frame look-ahead employed at the encoder), and (2) using the VAD likelihood measure and voicing measure to determine the degree of bandwidth broadening necessary for the interpolated LP synthesis filter coefficients. The VAD likelihood measure error concealment relies on setting the VAD flag for the most recently received frame as 1 thus introducing a bias towards active speech and reducing the possibility or degree of adaptive bandwidth broadening. The error concealment for the LSF's involves discarding the received error vector and using a higher value of the fixed predictor coefficient. The error recovery involves reconstructing the current as well as the previous set of LSF's in such a way that they evolve in the smoothest possible manner, i.e., the previous set is the average of the current LSF's and LSF's two frames ago. The open loop pitch parameter error concealment involves repetition of the previous pitch period and its recovery involves either repetition or averaging to obtain the previous pitch period depending on the number of consecutive bad frames that have elapsed. A schematic block diagram illustrating the computation of the PW, SEW and REW components is presented in FIG. The input speech signal is processed in consecutive non-overlapping blocks of N samples called frames. Let {s(n),0≦n<N} denote the current speech frame, i.e., the block of speech samples that is currently being encoded. In order to compute the SEW and REW corresponding to this speech data, it is necessary to “look-ahead” for the next 2 speech frames, i.e., buffer the frames {s(n),N≦n<2N} and {s(n),2N≦n<3N}. An L Each frame is subdivided into M subframes of length N The LPC parameters are interpolated within each frame to obtain a set of interpolated LPC parameters for every subframe. This interpolation is performed linearly in the LSF domain and the resulting LPC parameters for the frame N≦n<2N are denoted by {a For the m Here, p(M+m) is the pitch period for the m where [ ] indicates the rounding operation, so that p(M+m) is integer valued. From (9.2.1), it is evident that the length of the residual signal exceeds the pitch period p(M+m). So a segment of length p(M+m) can be extracted from {e′ Here, K(M+m) is the harmonic index of the highest frequency pitch harmonic that can be contained within the frequency band of the signal. K(M+m) is given by where, └x┘ denotes the largest integer less than or equal to x. Each new PW vector is phase-aligned with the preceding PW vector in the sequence, by removing a linear phase component from the new PW vector to maximize its correlation to the preceding (phase-aligned) PW vector. Let {P″(M+m,k)} denote the aligned version of the PW vector sequence. A PW gain is computed for each subframe by The aligned PW vectors are normalized by the PW gains, leading to an aligned and normalized PW vector sequence: The alignment and normalization operations ensure that each harmonic of the PW sequence evolves smoothly along the time axis. At a subframe size of 2 ms, the sampling rate of PW is 500 Hz and its evolutionary bandwidth is limited to 250 Hz. The SEW is defined as the component of the PW that occupies the 0-25 Hz band and he REW is defined as the component that occupies the 25-250 Hz band. The SEW can be separated by low-pass filtering (LPF) each harmonic of the PW, using a 21-tap linear phase FIR filter with a nominal cut-off frequency of 25 Hz. The REW is computed by a complimentary high-pass filtering operation or more directly by subtracting the SEW from the PW.
The PW gain sequence is also sampled at 500 Hz. However, the bandwidth of PW gain can be reduced without affecting performance. This is done by filtering {G This allows PW gain to be decimated by rate ½ by dropping all the odd indexed values, resulting in gain values per frame. 9.3 PW Gain Quantization The filtered and decimated PW gain sequence {G
The transformed gain is limited to the range 0-92 by clamping to the maximum or minimum value if it is above or below the range respectively. Conversion to logarithmic domain is advantageous since it corresponds to the scale of loudness of sound perceived by the human ear. A larger dynamic range can be represented in the logarithmic domain. The transformed PW gain vector is vector quantized using an 8-bit, 5-dimensional vector quantizer. The design of the vector quantizer is a novel aspect of this invention. The PW gain sequence can exhibit two distinct modes of behavior. When the signal is stationary, the gain sequence has a small degree of variations across a frame. During non-stationary signals such as voicing onsets, the gain sequence exhibits sharp variations. It is necessary that the vector quantizer is able to capture both types of behavior. On the average, stationary frames far outnumber the non-stationary frames. If a vector quantizer is trained using a database, which does not distinguish between the two types, the training is dominated by stationary frames leading to poor performance for non-stationary frames. To overcome this problem, the vector quantizer design was modified. The PW gain vectors were classified into a stationary class and a non-stationary class. For the 256 level codebook, 192 levels were allocated to represent stationary frames and the remaining 64 were allocated for non-stationary frames. The 192 level codebook is trained using the stationary frames, and the 64 level codebook is trained using the non-stationary frames. The training algorithm is based on the generalized Lloyd algorithm Digital Coding of Waveforms, N. S. Jayant and Peter Noll, Prentice-Hall 1984, with a binary split and random perturbation. In the case of the stationary codebook, the 192 level codebook is derived by performing a ternary split of the 64 level codebook during the training process. This 192 level codebook and the 64 level codebook are concatenated to obtain the 256-level gain codebook. During quantization, no stationary/non-stationary classification is performed. Instead, the entire 256-level codebook is searched to locate the optimal quantized gain vector. The quantizer uses a mean squared error distortion metric:
where {V The odd-indexed elements of the PW gain vector are reconstructed by linearly interpolating between the decoded even-indexed elements: 9.4 SEW Quantization The bandwidth of SEW is limited to 25 Hz by the low-pass filtering operation in (9.2.7). This implies that the sampling rate for SEW can be reduced 500 Hz to 50 Hz, i.e., once each 20 ms frame. Consequently, SEW is decimated by 10:1 and only the SEW vector at the frame edge, i.e., {S(M,k)} is encoded. At the decoder, SEW vectors at frame edges are interpolated to obtain the intermediate SEW vectors. In quantizing the SEW, the following should be noted: 1) SEW is a perceptually important component and has a strong influence on the perceived quality of the reproduced speech during periodic and quasi-periodic frames. It is important to preserve the static as well as the dynamic characteristics of this component. Hence, at low coding rates such as 2-4 kbit/s, a significant fraction of the bits used for coding the residual signal is used for coding the SEW. 2) The dimension of the SEW component is not fixed, but varies with the pitch frequency. The dimension can be rather high when the pitch frequency is small. If the pitch period varies in the range 20-120 samples, the dimension varies in the range 11-61. These two factors together make conventional vector quantization of SEW impractical from a computational as well as a storage perspective. In prior art, some techniques have been proposed to overcome these problems. It is proposed that the magnitude of the SEW vector is estimated as unity minus the REW vector magnitude, where the latter is encoded using analytical function approximations. The phase of the SEW vector is coded as a random phase or a fixed pitch pulse phase based on an unvoiced/voiced decision; only the 0-800 Hz band of the SEW magnitude is encoded. The remaining 800-4000 Hz band is constructed as unity minus REW magnitude. Both these approaches compromise the accuracy of SEW magnitude vector. In this invention, a novel approach is proposed for encoding the SEW. The complex SEW vector is quantized in the magnitude-phase form. In this form, the SEW magnitude information which is perceptually more significant, can be quantized more precisely with a higher number of bits than the phase. The phase information which is relatively less significant can be quantized with fewer bits. To overcome the problems of variable dimension and complexity, the SEW magnitude vector is quantized using a hierarchical mean-gain-shape approach with switched prediction. This approach allows the use of fixed dimension VQ with a moderate number of levels and precise quantization of perceptually important components of the magnitude spectrum. In this approach, the SEW magnitude spectrum is viewed as the sum of two components: (1) a SEW mean component, which is obtained by averaging of the SEW magnitude across frequency, within a 5 band sub-band structure, and (2) a SEW deviation component, which is the difference between the SEW magnitude and the SEW mean. The SEW mean component captures the average level of the SEW magnitude across frequency, which is important to preserve during encoding. The SEW deviation contains the finer structure of the SEW magnitude spectrum and is not important at all frequencies. It is only necessary to preserve the SEW deviation at a small set of frequencies as will be discussed later. The remaining elements of SEW deviation can be discarded, leading to a considerable reduction in the dimensionality of the SEW deviation. 9.4.1 Computation of SEW Mean and SEW Deviation The five sub-bands for computing the SEW mean are 1-400 Hz, 400-800 Hz, 800-1600 Hz, 1600-2400 Hz and 2400-3400 Hz. Based on this band structure, the corresponding discrete frequency band edges can be computed as follows: The SEW mean is computed from the SEW magnitude vector as follows: where, N
The SEW deviation vector is computed by subtracting the SEW mean approximation from the SEW magnitude vector
9.4.2 Selection of SEW Magnitude Deviation Elements The SEW magnitude deviation vector has a dimension of K(M), which varies in the range 11-61 depending on the pitch frequency. In order to quantize this vector, it is desirable to convert it into a fixed dimension vector with a small dimension. This is possible if the elements of this vector can be prioritized in some sense, i.e., if more important elements can be distinguished from less important elements. In such a case, a certain number of important elements can be retained and the rest can be discarded. A criterion that can be used to prioritize these elements can be derived by noting that in general, the spectral components that lie in the vicinity of speech formant peaks are more important than those that lie in regions of lower power spectral amplitude. However, the input speech power spectrum cannot be used directly, since this information is not available to the decoder. Note that the decoder should also be able to map the selected elements to their correct locations in the full dimension vector. To permit this, the power spectrum provided by the quantized LPC parameters, which is an approximation to the speech power spectrum (to within a scale constant) is used. Since the quantized LPC parameters are identical at the encoder and the decoder (in the absence of channel errors), the locations of the selected elements can be deduced correctly at the decoder. The spectral magnitude estimate provided by the quantized LPC parameters can be computed as: However, it is desirable to modify this estimate for the purposes of coefficient selection and spectral weighting as follows: Here, α and β are formant bandwidth expansion factors, which reduce excessive peakiness at the formant frequencies. These must satisfy the constraint:
A typical choice for these parameters is α=0.9 and β=0.75. The modified spectral estimate has been found to result in better performance. The elements {H
Then, the set of N
When the pitch frequency is large, it is possible that some of the SEW mean sub-bands contain a single SEW magnitude harmonic. In this case, this harmonic is entirely represented by the SEW mean and the SEW deviation is guaranteed to be zero valued. It is wasteful to select such components of SEW deviation for encoding. To eliminate this possibility, the sorted order vector μ″ is modified by examining the highest N A second reordering is performed to improve the performance of predictive encoding of SEW deviation vector. For predictive quantization, it is advantageous to order the highest N
This reordering ensures that lower (higher) frequency components are predicted using lower (higher) frequency components as long as the pitch frequency variations are not large. Note that since this reordering is within the subset of selected indices, it does not alter the contents of the set of selected elements, but merely the order in which they are arranged. This set of elements in the SEW deviation vector is selected as the N
Using the selected elements, a N
The remaining elements of the SEW deviation vector, i.e.,
are not encoded. A typical value of N 9.4.3 SEW Deviations Vector Prediction The SEW deviations sub-vector is encoded by a predictive vector quantizer. A first order switched predictor is employed, with the prediction coefficient either α The operation of the predictor is illustrated in FIG. Let {{tilde over (S)} Since only the selected elements of SEW deviations are being encoded, it is necessary to perform prediction (i.e., compute the prediction error) only for the selected elements as follows:
Note that the dimension of the prediction error vector E 9.4.4 Gain-Shape Quantization of the SEW Deviation Prediction Error The SEW magnitude deviation prediction error vector {E Let m* and n* respectively be the gain index and shape codebook index that together minimize the above distortion measure. Then, the encoded SEW deviations prediction error vector is given in terms of the optimal gain and shape vector by
The encoded SEW deviation vector is computed by adding the predicted component and the encoded prediction error vectors: Note that the encoded prediction error makes a contribution only for the selected elements. For the unselected elements, there is no prediction error contribution, which is equivalent to assuming that the encoded prediction error is zero. The unselected elements are determined only by an attenuated version of the predictor state vector, since α 9.4.5 SEW Mean Vector Prediction The SEW mean quantization is performed after the SEW deviation vector is quantized and {{tilde over (S)} In addition to the predictor mode, the SEW mean vector quantization is also switched depending on a parameter known as voicing measure, which will be discussed in Section 9.5. The voicing measure represents the degree of periodicity and is transmitted to the decoder using 3 bits where it is used to derive the SEW and REW phases. Since the SEW level increases with the degree of periodicity, the voicing measure can be exploited in SEW magnitude quantization also. This is done by training two sets of SEW mean codebooks, one set corresponding to a high degree of periodicity (voicing measure ≦0.3) and the second corresponding to a low degree of periodicity (voicing measure >0.3). Both the encoder and the decoder select the codebooks depending on the quantized voicing measure. In the following discussion, it is assumed that the codebook {C A block diagram illustrating the SEW mean vector predictive quantization scheme is presented in FIG. Let {{overscore (S)}
The encoded SEW mean vector for the previous frame is also the state vector for the predictor during the current frame. A target vector can be defined for predictive quantization of SEW mean as:
Let {V Then, for each codevector, a SEW mean estimate is computed as
where MAX(a,b) represents the larger of the two arguments a and b. Here we exploit the a priori knowledge that the SEW mean vector is strictly positive and in fact seldom falls below the value of 0.1. Then, a target vector can be defined for predictive quantization of SEW mean as:
The vector quantizer selects the codevector that minimizes the distortion between the target vector and the SEW mean estimate vector. This is equivalent to minimizing the error that still remains after the quantized SEW deviation component and the SEW mean prediction component have been taken into account. It is precisely this error that must be minimized by the quantization of the SEW mean prediction error. The distortion measure is defined by: The optimal codevector index l* is determined by minimizing the above distortion over all the SEW mean prediction error codevectors in the codebook. The encoded SEW mean vector is reconstructed by adding the optimal codevector to the SEW mean prediction component:
9.4.6 Selection of SEW Prediction Mode As mentioned earlier, the predictor mode for SEW deviation and SEW mean encoding is jointly determined based on the overall distortion achieved. The SEW deviation encoding and SEW mean encoding are carried out first in non-predictive mode, i.e., with α
The prediction mode is encoded using a single bit. The optimal SEW mean, SEW deviation gain and shape indices {l*,m*,n*} are selected as those obtained under the optimal predictor mode. The SEW mean index is coded using 6 bits, SEW deviation gain index using 3 bits and SEW deviation shape is coded using 8 bits. 9.4.7 Reconstruction of the Quantized SEW Magnitude Vector The SEW magnitude vector is reconstructed by adding the quantized SEW mean and the SEW deviation components. Depending upon the prediction mode selected, α
Then the SEW magnitude vector can be reconstructed as
It is possible that due to quantization errors in either the SEW mean or the SEW deviation, the resulting SEW magnitude for some elements assumes negative values, which is invalid. This is corrected by setting such values to a small fraction of the SEW mean value, which is guaranteed to be positive:
This completes the reconstruction of the quantized SEW magnitude vector. 9.5 SEW Phase Representation by Voicing Measure The SEW phase is not quantized directly, but is represented using a voicing measure, which is quantized and transmitted to the decoder. The voicing measure is estimated for each frame based on certain characteristics of the frame. It is a heuristic measure that assigns a degree of periodicity to each frame. The voicing measure for the current frame, denoted by ν(M), occupies the range of values 0≦ν(M)≦1, with 0 indicating a perfectly voiced or periodic frame and 1 indicating a completely unvoiced or aperiodic frame. It serves to indicate the extent to which the SEW phase should be harmonic or randomized, to achieve the right balance between smoothness and roughness of sound. The voicing measure is determined based on three measured characteristics of the current frame. These are, the weighted RMS value of the SEW, the average variance of the SEW harmonics across the frame and the pitch gain. The weighted RMS value of the SEW is computed by: where, The SEW RMS measure is directly proportional to the degree of periodicity of the residual signal. It is also robust to the presence of background noise. Since it is normalized by the weighting function, its values are restricted to the range 0-1. The average variance of the SEW harmonics across the frame is computed as follows. First, the average value of the SEW across the current frame is measured at each harmonic as a complex vector: Next the variance of the SEW across the current frame is measured at each harmonic: Note that this is a normalized variance whose values are restricted to the range 0-1. Finally a weighted average of the variance is obtained by averaging across the harmonics: The SEW variance provides a measure of the degree of variation if SEW. As the periodicity in the frame increases, the variations in the SEW diminish leading to a decrease in the SEW variance as measured above. Consequently, this measure is a good indicator of the degree of periodicity of the signal. The pitch gain is a parameter that is computed as part of the pitch analysis function. It is essentially the value of the peak of the autocorrelation function of the residual signal at the pitch lag. However, to avoid spurious peaks, it is advantageous to compute a composite autocorrelation function, as an average of adjacent residual autocorrelation functions. The details of the computation of the autocorrelation function will not be discussed here, as it is not directly related to the coding of the residual. It will be assumed that {r These three parameters provide a measure of the degree of variation of SEW. As the periodicity in the frame increases, the RMS value of the SEW increases, the variations in the SEW diminish leading to a decrease in the SEW variance, and the pitch gain increases. As the periodicity in the frame decreases, the RMS value of the SEW decreases, the variations in the SEW increase leading to an increase in the SEW variance, and the pitch gain decreases. Any single one of these parameters may give an occasional erroneous indication. However, if all three parameters are considered simultaneously, it is possible to derive a robust and dependable voicing measure, even when the input signal is degraded by background noise. In order to perform this mapping of the 3-dimensional parameter space into a scalar voicing measure, a neural network is employed. The three parameters are linearly transformed to make the parameter range and orientation better suited for processing by the neural network. Let {n The neural network structure is illustrated in FIG. The result of the output layer computation is the voicing measure. This is given by In the above equations, the parameters w The voicing measure is encoded using a 3-bit scalar quantizer. The accuracy of the voicing measure can be improved by using additional parameters which are correlated to the degree of periodicity of the signal. For example, parameters such as relative signal power, a measure of peakiness of the prediction residual, REW rms level and the normalized autocorrelation of the input is signal at unit lag have been found to improve the accuracy of the voicing measure. These parameters can be used as inputs to a second neural network and the outputs of the two neural networks can be combined (e.g., by averaging). Alternately, these parameters can be used in conjunction with the original set of parameters as inputs to a single neural network with a higher number of inputs. In either case, the basic approach outlined above can be directly extended to including other parameter sets as well as other types of classifiers. 9.6 REW Magnitude Quantization The REW contains the aperiodic components in the residual signal. Since REW has a high evolutionary bandwidth, it is necessary to encode the REW many times within a frame. However, since the REW is perceptually less important than SEW, the coding of the REW can be much coarser than that of SEW. The sampling rate of the REW is the same as that of the PW, i.e., 500 Hz. In other words, there are 10 REW vectors/frame. Since the SEW receives a large share of the bits available to code the residual, only a small number of bits are available to code the REW. Consequently, it is necessary to prioritize the information contained in the REW and eliminate unimportant components. The REW is converted into a magnitude-phase form, and the REW phase is not explicitly encoded. At the decoder, the REW phase is derived by a weighted combination of a random phase and SEW phase. The most important aspect of the REW magnitude is its level or RMS value. A correct REW level is necessary to ensure that the correct degree of aperiodicity or roughness is created in the reconstructed signal. The spectral shape of REW magnitude is considered to be of secondary importance relative to the REW level. Based on these considerations, the REW magnitude is decomposed onto a gain component and a normalized shape component as follows: 9.6.1 REW Gain Quantization In order to quantize the REW gain, it is noted that is not altogether independent of SEW level. Since the PW is normalized to unity RMS value (eqn. 9.2.6) and since PW is the sum of SEW and REW (eqn. 9.2.8), it follows that if the SEW level is high, REW level must be low and vice versa. In other words, REW level can be estimated from the SEW level. The SEW level is represented by the SEW mean, and the quantized SEW mean is available at the encoder as well as at the decoder. If the REW gain is estimated using the quantized SEW mean, it is only necessary to transmit the estimation error. In this invention, an approach is presented for estimating the REW gain using the SEW mean, resulting in an estimation error vector which can be quantized much more efficiently that the REW gain itself. A SEW RMS value is computed from the quantized SEW mean vector {{haeck over (S)} The SEW RMS at frame edges are interpolated to obtain the intermediate values: Then, the SEW RMS values are used to estimate the REW gains by
g _{sew}(m))). b 9.6.5 The REW gain estimation error is obtained by
The M-dimensional REW gain estimation error is decimated by a factor of 2:1, in order to reduce VQ complexity and storage. Decimation is performed by dropping the odd-indexed elements. The resulting dimentional vector is quantized using a 5-bit vector quantizer. The vector quantizer minimizes the distortion If the distortion is minimized for the index l Due to quantization error, it is occasionally possible to have a negative valued REW gain element. In such a case, it is replaced by a positive value derived from the SEW mean: The odd-indexed elements of the REW gain vector are reconstructed by interpolating between the decoded even-indexed elements: 9.6.2 REW Shape Quantization The normalized spectral shape of the REW magnitude is given by (9.6.2). The REW magnitude shape determines the distribution of the REW energy across frequency. There are M REW magnitude shape vectors in a frame. The dimensions of these vectors vary with pitch frequency, as in the case of the SEW magnitude vector. The dimensions can be large when the pitch frequency is small. However, since the number of bits available for quantizing REW shape is quite small, it is necessary to reduce this information. It is also desirable to represent REW magnitude shape by a fixed dimensional vector. These objectives can be met by computing an averaged REW magnitude shape vector based on a sub-band averaging process. Both temporal averaging as well as a sub-band averaging across frequency are used to condense the REW shape information. First, each REW magnitude shape vector is reduced to a fixed dimensional vector by averaging across sub-bands. A 5-band sub-band structure is employed resulting in a 5-dimensional REW magnitude shape sub-band vector for each subframe. The five sub-bands are 0-800 Hz, 800-1600 Hz, 1600-2400 Hz, 2400-3200 Hz, and 3200-4000 Hz. Based on this band structure, the corresponding discrete frequency band edges can be computed as follows: The 5-dimensional REW magnitude shape sub-band vector is computed by averaging within each sub-band as follows: where, N′ Based on this averaged vector, a piecewise-constant REW magnitude shape vector can be constructed for the frame edge as follows:
The 5-dimensional average REW magnitude shape sub-band vector is quantized using 6-bit vector quantization. The codebook contains 5-dimensional code vectors of average REW magnitude shape sub-band vector. During the codebook search process, each 5-dimensional code vector is converted to a K(M) +1-dimensional shape vector using (9.6.14) and compared against the original shape vector: Note that a spectrally weighted distortion measure is used to obtain better a match in formant regions. If the above distortion is minimized for the index l
The REW magnitude shape vectors for the subframes within the frame are obtained by linearly interpolating between the quantized REW shape vectors at the frame edges: Finally, the interpolated REW gain and REW magnitude shape vectors are multiplied to obtain a REW magnitude vector at each subframe within the frame:
This completes the reconstruction of the quantized REW magnitude vectors. 9.7 SEW Phase Modeling using the Voicing Measure SEW phase is reconstructed using the quantized voicing measure. A SEW phase vector is constructed for each subframe, by combining contributions from the SEW phase of the previous subframe, a random phase and a fixed phase that is obtained from a residual voiced pitch pulse waveform. The voicing measure In order to prevent excessive randomization of the SEW phase during non-periodic segments, the random phase component is not allowed to change every subframe, but is changed after several subframes depending on the pitch period. Also, the random phase component at a given harmonic index alternates in sign in successive changes. FIG. 5 illustrates the SEW phase construction scheme. FIG. 5 shows a block diagram illustrating the construction of the SEW phase based on the voicing measure At the 1 1. Subframes 1,6 120≧pitch period>90 2. Subframes 1,4,8 90≧pitch period>63 3. Subframes 1,4,6,9 63≧pitch period≧20. However, abrupt changes in the update rate of the random phase, i.e., from 1 The magnitude of the random phase is determined by a random number generator, which is uniformly distributed over a sub-interval in 0−π radians. The sub-interval is determined based on the voicing measure and a ratio of the SEW RMS level to the REW RMS level at the decoder computed for each subframe. This ratio is computed as follows. Let G The sub-interval Here, ν
Next, this phase vector is combined with the decoded SEW magnitude vector and converted from polar to Cartesian form. Similarly, the fixed pitch cycle phase is also combined with the decoded SEW magnitude vector and converted from polar to Cartesian form. These resulting complex vectors are combined in a weighted sum, where the weight α The weighted sum of the complex vectors is formed by
The SEW phase is computed as the phase of the resulting weighted sum {ν(m,k)}: Here, imag(.) denotes the imaginary part of a complex entity and real(.) denotes the real part of a complex entity. It was found that combining the random and fixed phase components in the Cartesian rather than in the polar domain is quite important to obtaining a satisfactory phase vector for the SEW component. 9.8 Reconstruction of SEW The reconstructed SEW magnitude {|S The interpolated SEW magnitudes are combined with the reconstructed SEW phases to reconstruct the complex SEW vectors at every subframe:
9.8.1 Filtering of the SEW component The reconstructed complex SEW component is passed through a low pass filter to reduce any excessive variations and to be consistent with the SEW extraction process at the encoder. The SEW at the encoder has a nominal evolutionary bandwidth of 25 Hz. However, due to modeling errors and the random component in SEW phase it is possible for the SEW at the decoder to have excessively rapid variations. This results in a decoded SEW magnitude that has an evolutionary bandwidth that is higher than 25 Hz. This is undesirable since it produces speech that lacks naturalness during voiced sounds. To overcome this problem, SEW low pass filtered. However, it is not practical to use the linear phase FIR filters that were used at the encoder, since these introduce a delay of one frame. Instead, the low pass filtering is approximated by a second order IIR filter. The filter transfer function is given by: where, The filter as defined above has a complex pole at a frequency of and a radius of 0.9, and a complex zero at a frequency of and a radius of 0.7, to produce a low pass filter characteristic with a cut off of 25 Hz. The SEW filtering operation is represented by:
The filtering operation modifies the SEW magnitude as well as the SEW phase. Modification of the SEW phase is desirable to limit excessive variations due to the random phase component. However, SEW magnitude quantization is more accurate, since a larger number of bits have been used in its quantization. Any modification to SEW magnitude may reduce its accuracy. To overcome this problem, after the filtering operation, the SEW magnitude is reset to the value at the input to the filter: The resulting SEW vector {S 9.9 REW Phase Construction The REW phase vector is not explicitly encoded. The decoder generates a complex REW vector by high pass filtering a weighted sum of the complex SEW vector and a complex white noise signal. The weights of SEW and white noise are dependent on the average REW gain value for that frame. The filter is a single-zero, two-pole filter. The zero is adjusted based on SEW and REW levels. The complex pole frequency is fixed at 25 Hz (assuming a 50 Hz SEW sampling rate). The pole radius varies from 0.2 to 0.60, depending on the decoded voicing measure. As the periodicity of the frame increases (as indicated by a lower voicing measure), the pole moves closer to the unit circle. At the same time, at the filter input, the weight of the SEW component increases relative to that of the white noise component. This has the effect of creating a REW component having more correlation with SEW and with more of its energy at lower frequencies. At the same time, the presence of the real zero ensures that the REW energy diminishes below 25 Hz. The overall result is to create a REW component that (i) has its energy distributed in a manner consistent with the REW extraction process at the encoder and with the relative levels of REW and SEW components, and (ii) to create a correlation between the REW and the SEW for voiced frames. At the filter output, the REW magnitude is restored to its value at the filter input by a magnitude scaling operation. The REW phase construction scheme is illustrated in FIG. FIG. 6 is a block diagram illustrating the construction of the REW phase from the complex SEW vector The transfer function of the high pass filter is given by The filter has a real zero which is adjusted based on the SEW level to REW level ratio. Let G Then the zero is selected according to the following rule: Thus, for aperiodic sounds or for periodic sounds with low SEW-to-REW level ratio, a strong (close to unit circle) is used, thereby suppressing the low frequency component in REW phase. As the SEW-to-REW level ratio increases, the zero becomes weaker, allowing more low frequency, i.e., SEW signal to determine the REW phase. As a result, as SEW becomes stronger relative to REW, REW phase varies more slowly and also becomes more correlated with SEW. However, as the SEW-to-REW level continues to increase beyond 3.25, the zero tends to become stronger. This ensures that for frames with very high levels of SEW, REW does not become completely periodic; instead, a certain minimal degree of randomness is preserved in the REW phase. The denominator parameters are derived from a complex pole pair, whose angle is fixed at but whose radius is modified according to the voicing measure. This results in the following denominator parameters: The radius of the complex pole-pair varies from 0.2 (roughly high pass from 25 Hz) to 0.6 (roughly bandpass around 25 Hz) as the voicing measure varies from 1 (completely unvoiced) to 0 (completely voiced). The input to the filter is derived by a weighted combination of the complex SEW and a white noise signal. This can be expressed as
Here, {r {α α
The filtering operation produces a REW component that roughly conforms to the evolutionary characteristics of the REW at the encoder. However, the magnitude the filtered REW is arbitrary. It is necessary to set the magnitude to the quantized and interpolated REW magnitude. This is accomplished by the following magnitude scaling operation: The resulting REW vector {R 9.10 Reconstruction of the PW Sequence FIG. 7 illustrates the reconstruction of the PW sequence, the reconstruction of the residual signal and the reconstruction of the speech signal. FIG. 7 is a block diagram illustrating the reconstruction of the prototype waveform and speech signals from which reconstructive speech is decoded. The complex SEW vector The PW is reconstructed by adding the reconstructed SEW and REW components:
The out-of-band components, i.e., components below 80 Hz and above 3400 Hz, are attenuated in a piecewise-linear manner: Finally, the RMS value of the PW is restored to the value given by the decoded PW gain from (9.3.3) and (9.3.4).
9.11 Adaptive Bandwidth Broadening In the case of frames that do not contain active speech, it is desirable to modify the LPC parameters so that formant bandwidths are broadened. Sharp spectral resonances during inactive frames, especially for certain background noise conditions leads to annoying artifacts. This can be mitigated by a mild degree of bandwidth broadening that is adapted based on the decoded VAD flag and the decoded voicing measure. The bandwidth expansion is zero during active, periodic frames and progressively increases as the periodicity decreases and the likelihood of voice activity decreases. Let ν
Since the VAD flags are 0 or 1, VAD likelihood is an integer in the range [0-4]. The i
The bandwidth expansion factor is derived using the voicing likelihood and the voicing measure index according to the following matrix:
Let λ be the bandwidth expansion factor from the above matrix for the voicing measure index i
9.12 Reconstruction of the Residual Signal The residual signal is constructed from the PW using an interpolative frequency domain synthesis process. In this process, the PW are linearly interpolated to obtain an interpolated PW for each sample within the subframe. At each sample instant, an inverse DFF is used to compute the time-domain residual sample corresponding to that instant. A linear phase shift is included in this inverse DFF, so that successive samples are advanced within the pitch cycle by the phase increments according to the linearized pitch frequency contour. The synthesis operation for the m Here, θ(n) is the phase of the fundamental harmonic at the n The resulting residual signal {{tilde over (e)}(n)} is processed by an all-pole LPC synthesis filter, constructed using the decoded and interpolated LPC parameters, resulting in the reconstructed speech signal. The first half of the subframe is synthesized using the LPC parameters at the left edge of the subframe and the second half by the LPC parameters at the right edge of the subframe. This is done to be consistent with the manner in which the interpolated LPC parameters are computed. The reconstructed speech signal is processed by an adaptive postfilter to reduce the audibility of the degradation due to quantization. A pole-zero postfilter with an adaptive tilt correction [see, e.g., J. -H. Chen and A. Gersho, “Adaptive Postfiltering for Quality Enhancement of Coded Speech”, IEEE Transactions on Speech and Audio Processing, Vol. 3, No. 1, pp 59-71, January 1995] is employed. As during speech reconstruction, the first half of the subframe is postfiltered by parameters derived from the LPC parameters at the left edge of the subframe. The second half of the subframe is postfiltered by the parameters derived from the LPC parameters at the right edge of the subframe. These two postfilter transfer functions are specified respectively by: The pole-zero postfiltering operation for the first half of the subframe is represented by: The pole-zero postfiltering operation for the second half of the subframe is represented by: Here, α
A typical choice for these parameters is a α The postfilter introduces a low pass frequency tilt to the spectrum of the filtered speech, which leads to a muffling of postfiltered speech. This is corrected by a tilt-correction mechanism, which estimates the spectral tilt introduced by the postfilter and compensates for it by a high frequency emphasis. A tilt correction factor is estimated as the first normalized autocorrelation lag of the impulse response of the postfilter. Let ν The postfilter alters the energy of the speech signal. Hence it is desirable to restore the RMS value of the speech signal at the postfilter output to the RMS value of the speech signal at the postfilter input. The RMS value of the postfilter input speech for each half of the m The RMS value of the postfilter output speech for each half of the m An adaptive gain factor is computed for each half of the m The postfiltered speech is scaled in each half of the m
The resulting scaled postfiltered speech signal {s 9.13 Error Concealment Techniques for Masking Transmission Errors in Encoded Parameters The error concealment procedure consists of “bad frame masking” that takes place when we receive a bad frame and “bad frame recovery” that takes place in the first good frame after one or more consecutive bad frames. The error concealment procedure that we have used utilizes the inter-dependencies of the various parameters and their quantization schemes as well as their staggered use in the synthesis of speech by the FDI decoder to effectively mask bad frames and recover from them in a smooth manner. We assume that a reliable bad frame indicator (BFI) flag is provided with every compressed speech packet. A common way in which such a BFI flag is generated is by use of Cyclic Redundancy Check (CRC) parity bits. CRC parity bits are computed for the compressed speech packet and transmitted along with the packet. At the receive side, the CRC parity bits are recomputed and compared with the received parity bits. The BFI flag is set if there is any difference else it is reset. The error concealment procedure for every parameter is described in the following sections. It is important to note that the error concealment follows the same sequence as decoding of the various parameters, i.e., VAD likelihood, LSF's, pitch, SEW phase, SEW magnitude, REW magnitude gain and REW magnitude shape. In addition to the BFI flag for the current frame and the last frame BFI (LBFI) flag, a bad frame counter (BFC) is also employed in the error concealment procedure. BFC is the number of consecutive bad frames received thus far and is reset to zero after two consecutive good frames at the beginning of the frame prior to all decoder operations. 9.13.1 VAD Likelihood The VAD likelihood for the current speech frame that is being synthesized is computed as the sum of the most recently received VAD flag and the past three VAD flags received in the earlier frames. If we denote the VAD flag and the VAD likelihood corresponding to frame k by ν
The VAD likelihood for the current speech frame is used to adaptively bandwidth broaden the interpolated LP filter coefficients during periods of inactivity and/or low degree of voicing. In the event of a bad frame indication, the masking procedure simply replaces the most recently received VAD flag from the corrupted speech packet by 1, i.e.,
This procedure retains or increases the VAD likelihood which in turn ensures that the degree of adaptive bandwidth broadening is no more than warranted. If the adaptive bandwidth broadening is excessive then the synthesized speech may be distorted and it is therefore important to avoid this. If the degree of adaptive bandwidth broadening is less than warranted then the background noise may be distorted but not the speech itself. It is therefore safer to err on this side. There is no explicit bad frame recovery associated with this parameter. 9.13.2 Line Spectral Frequencies (LSF) The LSFs are decoded from the received speech packet by first reconstructing the error vector e(k) using inverse VQ and then applying the correction due to backward prediction and the long term DC value L
Here, α is the fixed predictor and equals 0.5 and L(k−1) is the state variable of the first order predictor. After the LSF's are reconstructed, they are ordered and stabilized to form L″(k) prior to interpolation and conversion to filter coefficients. Finally, the state variable of the first order predictor is updated as follows:
It needs to be emphasized that the speech is synthesized for frame k−2 uses the filter coefficients that were derived after interpolating L″(k−2) and L″(k−1). In the event of a bad frame indication, the error vector is not reconstructed by inverse VQ using the indices from the corrupted speech packet. Instead it is zeroed out and the fixed predictor is changed from α=0.5 to α=α
The intent here is to reconstruct the LSF's solely on the basis of its previous history and not rely on the received LSF VQ indices in the corrupted speech packet. In the event of several consecutive bad frames, the reconstructed LSF's would slowly converge to the long term DC value L The bad frame recovery focuses on a smooth transition of the LSF parameters. Since the previous LSF's L″(k−1) may be erroneous, we reconstruct them as well in such a way that the following “smoothness” criteria is met:
In most cases, the ordering and stabilization operations do not alter the LSF's. These steps are purely precautionary to ensure that we never encounter unstable filter coefficients. For this reason, we can ignore the effects of these operations and can express the above criteria as follows:
Such a criteria is satisfied by reconstructing L(k) and L(k−1) as follows: The precautionary ordering and stabilization procedure is carried out on both L(k) and L(k−1) which results in L″(k) and L″(k−1). These are then interpolated and then converted to filter coefficients for synthesis. Finally, the state variable of the first order predictor is updated in the usual way, i.e., L′(k)=L″(k)−L 9.13.3 Open Loop Pitch The open loop pitch period lies in the range [20,120] and it is encoded using a 7 bit index in the compressed speech packet. At the decoder, this 7 bit index is used to extract the open loop pitch period P In the event of a bad frame indication, the open loop pitch period P The bad frame recovery procedure is different in the case of recovery from a single bad frame (BFC=1) than from multiple consecutive bad frames (BFC>1). For BFC>1, the old pitch period P 9.13.4 PW Gain The PW gain is vector quantized using a 8 bit 5 dimensional VQ. At the decoder, a 5 dimensional gain vector is decoded from the received 8 bit index. It is then interpolated to form a ten dimensional gain vector to provide PW gains for all ten subframes. In the event of a bad frame indication, the 5 dimensional PW gain vector is obtained by gradually decaying a gain estimate. For the first bad frame, i.e., BFC=1, this gain estimate is computed as the minimum of the average PW gain of the last frame and the average PW gain of the last two frames. Denoting this gain estimate as ĝ
where the decay factor a is chosen to be 0.98. For BFC>1, the gain estimate is chosen to be the last element in the previous PW gain vector. In addition, we choose the decay factor α to be 0.95 for BFC>1. Eventually as BFC→∞, the elements of the PW gain vector decay to zero. The bad frame recovery limits the gain in the first good frame after one or more bad frames to within a bound. This bound g
where g
9.13.5 Voicing Measure The voicing measure lies in the range [0,1] and is encoded using a 3 bit index. Small values of the voicing measure or low values of the voicing measure index correspond to high degree of voicing and vice-versa. The bad frame masking procedure works in two stages. In the first stage we exploit the correlation between the VAD likelihood and the voicing measure index. In the second stage the correlation between the reconstructed spectrally weighted SEW RMS value in the [80-1250] Hz band and the voicing measure is exploited. The reconstruction of SEW magnitude takes place between the two stages. Denoting the voicing measure index for frame k−3 as I Basically, the estimated voicing measure index pushes the previous voicing measure index in the direction of high degree of voicing if the VAD likelihood is high and conversely pushes the voicing measure index in the direction of low degree of voicing if the VAD likelihood is low and leaves the previous voicing measure index unchanged for intermediate values of the VAD likelihood. After the reconstruction of the SEW magnitude, the second stage of bad frame masking computes the reconstructed SEW rms g Basically, the estimated voicing measure index edges lower in the direction of high degree of voicing if the SEW RMS in the low frequency band is high and conversely edges higher in the direction of low degree of voicing if the SEW RMS in the low frequency band is low. There is no explicit bad frame recovery procedure for the voicing measure parameter. 9.13.6 SEW Magnitude The SEW magnitude is quantized using a switched predictive mean-gain-shape VQ. The predictive mode bit which determines the predictor coefficient of the mean VQ and that of the gain-shape VQ, the mean VQ index, the RMS or gain quantization index, and the shape VQ index are all unpacked from the compressed speech packet and used in the reconstruction of the SEW magnitude vector. In the event of a bad frame indication, the SEW magnitude would have to be estimated entirely based on its past history. This is done by forcing the predictive mode bit to 1, increasing the SEW mean predictor coefficient to 0.95 but zeroing out the mean VQ contribution, and zeroing out the SEW rms value. Such a masking procedure makes effective use of the high inter-frame correlation of the SEW mean and the moderate inter-frame correlation of the RMS-shape. Furthermore, the selection of the SEW mean VQ codebook based on the voicing measure does not affect the reconstructed SEW since the mean VQ contribution is zeroed out anyway. As many consecutive corrupt speech packets are received, the SEW RMS-shape contribution decays to zero very quickly since its predictor coefficient is only 0.6 leaving the SEW mean to decay very slowly to zero. There is no explicit bad frame recovery procedure associated with the SEW magnitude. 9.13.7 REW Magnitude Gain The REW magnitude gain is estimated every 4 ms using the quantized SEW mean. Deviations from this estimate are quantized using a 5 dimensional 5 bit VQ. At the receiver, the 5 dimensional correction vector is reconstructed by inverse VQ. The REW magnitude gain estimate is also reconstructed at the decoder and the correction added to it every 4 ms. The REW magnitude gain is interpolated to obtain the intermediate values. In the event of a bad frame indication, the REW magnitude correction vector is discarded and the REW magnitude gain is taken to be the estimate itself. There is no explicit bad frame recovery associated with the REW magnitude gain. While there has been illustrated and described particular embodiments of low rate encoding of prototype waveform components, it will be appreciated that numerous changes and modifications will occur to those skilled in the art. Thus, it is intended that the appended claims define the scope of the invention and cover changes and modifications, which fall within the true state, and scope of the present invention. Patent Citations
Non-Patent Citations
Referenced by
Classifications
Legal Events
Rotate |