1. Field of the Invention
The present invention relates to an improved technique for digitally encoding a sound signal, in particular but not exclusively a speech signal, in view of transmitting and synthesizing this sound signal. More specifically, the present invention is concerned with a method and device for vector quantizing linear prediction parameters in variable bit rate linear prediction based coding.
2. Brief Description of the Prior Techniques
2.1 Speech Coding and Quantization of Linear Prediction (LP) Parameters:
Digital voice communication systems such as wireless systems use speech encoders to increase capacity while maintaining high voice quality. A speech encoder converts a speech signal into a digital bitstream which is transmitted over a communication channel or stored in a storage medium. The speech signal is digitized, that is, sampled and quantized with usually 16-bits per sample. The speech encoder has the role of representing these digital samples with a smaller number of bits while maintaining a good subjective speech quality. The speech decoder or synthesizer operates on the transmitted or stored bit stream and converts it back to a sound signal.
Digital speech coding methods based on linear prediction analysis have been very successful in low bit rate speech coding. In particular, code-excited linear prediction (CELP) coding is one of the best known techniques for achieving a good compromise between the subjective quality and bit rate. This coding technique is the basis of several speech coding standards both in wireless and wireline applications. In CELP coding, the sampled speech signal is processed in successive blocks of N samples usually called frames, where N is a predetermined number corresponding typically to 10-30 ms. A linear prediction (LP) filter A(z) is computed, encoded, and transmitted every frame. The computation of the LP filter A(z) typically needs a lookahead, which consists of a 5-15 ms speech segment from the subsequent frame. The N-sample frame is divided into smaller blocks called subframes. Usually the number of subframes is three or four resulting in 4-10 ms subframes. In each subframe, an excitation signal is usually obtained from two components, the past excitation and the innovative, fixed-codebook excitation. The component formed from the past excitation is often referred to as the adaptive codebook or pitch excitation. The parameters characterizing the excitation signal are coded and transmitted to the decoder, where the reconstructed excitation signal is used as the input of a LP synthesis filter.
The LP synthesis filter is given by
where ai are linear prediction coefficients and M is the order of the LP analysis. The LP synthesis filter models the spectral envelope of the speech signal. At the decoder, the speech signal is reconstructed by filtering the decoded excitation through the LP synthesis filter.
The set of linear prediction coefficients ai are computed such that the prediction error
e(n)=s(n)−{tilde over (s)}(n) (1)
is minimized, where s(n) is the input signal at time n and {tilde over (s)}(n) is the predicted signal based on the last M samples given by:
Thus the prediction error is given by:
This corresponds in the z-tranform domain to:
E(z)=S(z)A(z)
where A(z) is the LP filter of order M given by:
Typically, the linear prediction coefficients ai are computed by minimizing the mean-squared prediction error over a block of L samples, L being an integer usually equal to or larger than N (L usually corresponds to 20-30 ms). The computation of linear prediction coefficients is otherwise well known to those of ordinary skill in the art. An example of such computation is given in [ITU-T Recommendation G.722.2 “Wideband coding of speech at around 16 kbit/s using adaptive multi-rate wideband (AMR-WB)”, Geneva, 2002].
The linear prediction coefficients ai cannot be directly quantized for transmission to the decoder. The reason is that small quantization errors on the linear prediction coefficients can produce large spectral errors in the transfer function of the LP filter, and can even cause filter instabilities. Hence, a transformation is applied to the linear prediction coefficients ai prior to quantization. The transformation yields what is called a representation of the linear prediction coefficients ai. After receiving the quantized transformed linear prediction coefficients ai, the decoder can then apply the inverse transformation to obtain the quantized linear prediction coefficients. One widely used representation for the linear prediction coefficients a, is the line spectral frequencies (LSF) also known as line spectral pairs (LSP). Details of the computation of the Line Spectral Frequencies can be found in [ITU-T Recommendation G.729 “Coding of speech at 8 kbit/s using conjugate-structure algebraic-code-excited linear prediction (CS-ACELP),” Geneva, March 1996].
A similar representation is the Immitance Spectral Frequencies (ISF), which has been used in the AMR-WB coding standard [ITU-T Recommendation G.722.2 “Wideband coding of speech at around 16 kbit/s using Adaptive Multi-Rate Wideband (AMR-WB)”, Geneva, 2002]. Other representations are also possible and have been used. Without loss of generality, the particular case of ISF representation will be considered in the following description.
The so obtained LP parameters (LSFs, ISFs, etc.), are quantized either with scalar quantization (SQ) or vector quantization (VQ). In scalar quantization, the LP parameters are quantized individually and usually 3 or 4 bits per parameter are required. In vector quantization, the LP parameters are grouped in a vector and quantized as an entity. A codebook, or a table, containing the set of quantized vectors is stored. The quantizer searches the codebook for the codebook entry that is closest to the input vector according to a certain distance measure. The index of the selected quantized vector is transmitted to the decoder. Vector quantization gives better performance than scalar quantization but at the expense of increased complexity and memory requirements.
Structured vector quantization is usually used to reduce the complexity and storage requirements of VQ. In split-VQ, the LP parameter vector is split into at least two subvectors which are quantized individually. In multistage VQ the quantized vector is the addition of entries from several codebooks. Both split VQ and multistage VQ result in reduced memory and complexity while maintaining good quantization performance. Furthermore, an interesting approach is to combine multistage and split VQ to further reduce the complexity and memory requirement. In reference [ITU-T Recommendation G.729 “Coding of speech at 8 kbit/s using conjugate-structure algebraic-code-excited linear prediction (CS-ACELP),” Geneva, March 1996], the LP parameter vector is quantized in two stages where the second stage vector is split in two subvectors.
The LP parameters exhibit strong correlation between successive frames and this is usually exploited by the use of predictive quantization to improve the performance. In predictive vector quantization, a predicted LP parameter vector is computed based on information from past frames. Then the predicted vector is removed from the input vector and the prediction error is vector quantized. Two kinds of prediction are usually used: auto-regressive (AR) prediction and moving average (MA) prediction. In AR prediction the predicted vector is computed as a combination of quantized vectors from past frames. In MA prediction, the predicted vector is computed as a combination of the prediction error vectors from past frames. AR prediction yields better performance. However, AR prediction is not robust to frame loss conditions which are encountered in wireless and packet-based communication systems. In case of lost frames, the error propagates to consecutive frames since the prediction is based on previous corrupted frames.
2.2 Variable Bit-Rate (VBR) Coding:
In several communications systems, for example wireless systems using code division multiple access (CDMA) technology, the use of source-controlled variable bit rate (VBR) speech coding significantly improves the capacity of the system. In source-controlled VBR coding, the encoder can operate at several bit rates, and a rate selection module is used to determine the bit rate used for coding each speech frame based on the nature of the speech frame, for example voiced, unvoiced, transient, background noise, etc. The goal is to attain the best speech quality at a given average bit rate, also referred to as average data rate (ADR). The encoder is also capable of operating in accordance with different modes of operation by tuning the rate selection module to attain different ADRs for the different modes, where the performance of the encoder improves with increasing ADR. This provides the encoder with a mechanism of trade-off between speech quality and system capacity. In CDMA systems, for example CDMA-one and CDMA2000, typically 4 bit rates are used and are referred to as full-rate (FR), half-rate (HR), quarter-rate (QR), and eighth-rate (ER). In this CDMA system, two sets of rates are supported and referred to as Rate Set I and Rate Set II. In Rate Set II, a variable-rate encoder with rate selection mechanism operates at source-coding bit rates of 13.3 (FR), 6.2 (HR), 2.7 (QR), and 1.0 (ER) kbit/s, corresponding to gross bit rates of 14.4, 7.2, 3.6, and 1.8 kbit/s (with some bits added for error detection).
A wideband codec known as adaptive multi-rate wideband (AMR-WB) speech codec was recently selected by the ITU-T (International Telecommunications Union—Telecommunication Standardization Sector) for several wideband speech telephony and services and by 3GPP (Third Generation Partnership Project) for GSM and W-CDMA (Wideband Code Division Multiple Access) third generation wireless systems. An AMR-WB codec consists of nine bit rates in the range from 6.6 to 23.85 kbit/s. Designing an AMR-WB-based source controlled VBR codec for CDMA2000 system has the advantage of enabling interoperation between CDMA2000 and other systems using an AMR-WB codec. The AMR-WB bit rate of 12.65 kbit/s is the closest rate that can fit in the 13.3 kbit/s full-rate of CDMA2000 Rate Set II. The rate of 12.65 kbit/s can be used as the common rate between a CDMA2000 wideband VBR codec and an AMR-WB codec to enable interoperability without transcoding, which degrades speech quality. Half-rate at 6.2 kbit/s has to be added to enable efficient operation in the Rate Set II framework. The resulting codec can operate in few CDMA2000-specific modes, and incorporates a mode that enables interoperability with systems using a AMR-WB codec.
Half-rate encoding is typically chosen in frames where the input speech signal is stationary. The bit savings, compared to full-rate, are achieved by updating encoding parameters less frequently or by using fewer bits to encode some of these encoding parameters. More specifically, in stationary voiced segments, the pitch information is encoded only once a frame, and fewer bits are used for representing the fixed codebook parameters and the linear prediction coefficients.
Since predictive VQ with MA prediction is typically applied to encode the linear prediction coefficients, an unnecessary increase in quantization noise can be observed in these linear prediction coefficients. MA prediction, as opposed to AR prediction, is used to increase the robustness to frame losses; however, in stationary frames the linear prediction coefficients evolve slowly so that using AR prediction in this particular case would have a smaller impact on error propagation in the case of lost frames. This can be seen by observing that, in the case of missing frames, most decoders apply a concealment procedure which essentially extrapolates the linear prediction coefficients of the last frame. If the missing frame is stationary voiced, this extrapolation produces values very similar to the actually transmitted, but not received, LP parameters. The reconstructed LP parameter vector is thus close to what would have been decoded if the frame had not been lost. In this specific case, therefore, using AR prediction in the quantization procedure of the linear prediction coefficients cannot have a very adverse effect on quantization error propagation.
According to the present invention, there is provided a method for quantizing linear prediction parameters in variable bit-rate sound signal coding, comprising receiving an input linear prediction parameter vector, classifying a sound signal frame corresponding to the input linear prediction parameter vector, computing a prediction vector, removing the computed prediction vector from the input linear prediction parameter vector to produce a prediction error vector, scaling the prediction error vector, and quantizing the scaled prediction error vector. Computing a prediction vector comprises selecting one of a plurality of prediction schemes in relation to the classification of the sound signal frame, and computing the prediction vector in accordance with the selected prediction scheme. Scaling the prediction error vector comprises selecting at least one of a plurality of scaling schemes in relation to the selected prediction scheme, and scaling the prediction error vector in accordance with the selected scaling scheme.
Also according to the present invention, there is provided a device for quantizing linear prediction parameters in variable bit-rate sound signal coding, comprising means for receiving an input linear prediction parameter vector, means for classifying a sound signal frame corresponding to the input linear prediction parameter vector, means for computing a prediction vector, means for removing the computed prediction vector from the input linear prediction parameter vector to produce a prediction error vector, means for scaling the prediction error vector, and means for quantizing the scaled prediction error vector. The means for computing a prediction vector comprises means for selecting one of a plurality of prediction schemes in relation to the classification of the sound signal frame, and means for computing the prediction vector in accordance with the selected prediction scheme. Also, the means for scaling the prediction error vector comprises means for selecting at least one of a plurality of scaling schemes in relation to the selected prediction scheme, and means for scaling the prediction error vector in accordance with the selected scaling scheme.
The present invention also relates to a device for quantizing linear prediction parameters in variable bit-rate sound signal coding, comprising an input for receiving an input linear prediction parameter vector, a classifier of a sound signal frame corresponding to the input linear prediction parameter vector, a calculator of a prediction vector, a subtractor for removing the computed prediction vector from the input linear prediction parameter vector to produce a prediction error vector, a scaling unit supplied with the prediction error vector, this unit scaling the prediction error vector, and a quantizer of the scaled prediction error vector. The prediction vector calculator comprises a selector of one of a plurality of prediction schemes in relation to the classification of the sound signal frame, to calculate the prediction vector in accordance with the selected prediction scheme. The scaling unit comprises a selector of at least one of a plurality of scaling schemes in relation to the selected prediction scheme, to scale the prediction error vector in accordance with the selected scaling scheme.
The present invention is further concerned with a method of dequantizing linear prediction parameters in variable bit-rate sound signal decoding, comprising receiving at least one quantization index, receiving information about classification of a sound signal frame corresponding to said at least one quantization index, recovering a prediction error vector by applying the at least one index to at least one quantization table, reconstructing a prediction vector, and producing a linear prediction parameter vector in response to the recovered prediction error vector and the reconstructed prediction vector. Reconstruction of a prediction vector comprises processing the recovered prediction error vector through one of a plurality of prediction schemes depending on the frame classification information.
The present invention still further relates to a device for dequantizing linear prediction parameters in variable bit-rate sound signal decoding, comprising means for receiving at least one quantization index, means for receiving information about classification of a sound signal frame corresponding to the at least one quantization index, means for recovering a prediction error vector by applying the at least one index to at least one quantization table, means for reconstructing a prediction vector, and means for producing a linear prediction parameter vector in response to the recovered prediction error vector and the reconstructed prediction vector. The prediction vector reconstructing means comprises means for processing the recovered prediction error vector through one of a plurality of prediction schemes depending on the frame classification information.
In accordance with a last aspect of the present invention, there is provided a device for dequantizing linear prediction parameters in variable bit-rate sound signal decoding, comprising means for receiving at least one quantization index, means for receiving information about classification of a sound signal frame corresponding to the at least one quantization index, at least one quantization table supplied with said at least one quantization index for recovering a prediction error vector, a prediction vector reconstructing unit, and a generator of a linear prediction parameter vector in response to the recovered prediction error vector and the reconstructed prediction vector. The prediction vector reconstructing unit comprises at least one predictor supplied with recovered prediction error vector for processing the recovered prediction error vector through one of a plurality of prediction schemes depending on the frame classification information.
The foregoing and other objects, advantages and features of the present invention will become more apparent upon reading of the following non restrictive description of illustrative embodiments thereof, given by way of example only with reference to the accompanying drawings.
In the appended drawings:
Although the illustrative embodiments of the present invention will be described in the following description in relation to an application to a speech signal, it should be kept in mind that the present invention can also be applied to other types of sound signals.
Most recent speech coding techniques are based on linear prediction analysis such as CELP coding. The LP parameters are computed and quantized in frames of 10-30 ms. In the present illustrative embodiment, 20 ms frames are used and an LP analysis order of 16 is assumed. An example of computation of the LP parameters in a speech coding system is found in reference [ITU-T Recommendation G.722.2 “Wideband coding of speech at around 16 kbit/s using Adaptive Multi-Rate Wideband (AMR-WB)”, Geneva, 2002]. In this illustrative example, the preprocessed speech signal is windowed and the autocorrelations of the windowed speech are computed. The Levinson-Durbin recursion is then used to compute the linear prediction coefficients ai, i=1, . . . , M from the autocorrelations R(k), k=0, . . . , M, where M is the prediction order.
The linear prediction coefficients ai cannot be directly quantized for transmission to the decoder. The reason is that small quantization errors on the linear prediction coefficients can produce large spectral errors in the transfer function of the LP filter, and can even cause filter instabilities. Hence, a transformation is applied to the linear prediction coefficients ai prior to quantization. The transformation yields what is called a representation of the linear prediction coefficients. After receiving the quantized, transformed linear prediction coefficients, the decoder can then apply the inverse transformation to obtain the quantized linear prediction coefficients. One widely used representation for the linear prediction coefficients ai is the line spectral frequencies (LSF) also known as line spectral pairs (LSP). Details of the computation of the LSFs can be found in reference [ITU-T Recommendation G.729 “Coding of speech at 8 kbit/s using conjugate-structure algebraic-code-excited linear prediction (CS-ACELP),” Geneva, March 1996]. The LSFs consists of the poles of the polynomials:
P(z)=(A(z)+z−(M+1)A(z−1))/(1+z−1)
and
Q(z)=(A(z)−z−(M+1)A(z−1))/(1−z−1)
For even values of M, each polynomial has M/2 conjugate roots on the unit circle (e±jω
where qi=cos (ωi) with ωi being the line spectral frequencies (LSF) satisfying the ordering property 0<ω1<ω2< . . . <ωM<π. In this particular example, the LSFs constitutes the LP (linear prediction) parameters.
A similar representation is the immitance spectral pairs (ISP) or the immitance spectral frequencies (ISF), which has been used in the AMR-WB coding standard. Details of the computation of the ISFs can be found in reference [ITU-T Recommendation G.722.2 “Wideband coding of speech at around 16 kbit/s using Adaptive Multi-Rate Wideband (AMR-WB)”, Geneva, 2002]. Other representations are also possible and have been used. Without loss of generality, the following description will consider the case of ISF representation as a non-restrictive illustrative example.
For an Mth order LP filter, where M is even, the ISPs are defined as the roots of the polynomials:
F1(z)=A(z)+z−MA(z−1)
and
F2(z)=(A(z)−z−MA(z−1))/(1−z−2)
Polynomials F1(z) and F2(z) have M/2 and M/2−1 conjugate roots on the unit circle (e±jω
where qi=cos (ωi) with ωi being the immittance spectral frequencies (ISF), and aM is the last linear prediction coefficient. The ISFs satisfy the ordering property 0<ω1<ω2< . . . <ωM−1<π. In this particular example, the LSFs constitutes the LP (linear prediction) parameters. Thus the ISFs consist of M−1 frequencies in addition to the last linear prediction coefficients. In the present illustrative embodiment the ISFs are mapped into frequencies in the range 0 to ƒs/2, where ƒs is the sampling frequency, using the following relation:
LSFs and ISFs (LP parameters) have been widely used due to several properties which make them suitable for quantization purposes. Among these properties are the well defined dynamic range, their smooth evolution resulting in strong inter and intra-frame correlations, and the existence of the ordering property which guarantees the stability of the quantized LP filter.
In this document, the term “LP parameter” is used to refer to any representation of LP coefficients, e.g. LSF, ISF, Mean-removed LSF, or mean-removed ISF.
The main properties of ISFs (LP (linear prediction) parameters) will now be described in order to understand the quantization approaches used.
With frame lengths of 10 to 30 ms typical in a speech encoder, ISF coefficients exhibit interframe correlation.
pn=A1{circumflex over (x)}n−1+A2{circumflex over (x)}n−2+ . . . +AK{circumflex over (x)}n−K
where Ak are prediction matrices of dimension M×M and K is the predictor order. A simple form for the predictor P (Processor 302) is the use of first order prediction:
pn=A{circumflex over (x)}n−1 (2)
where A is a prediction matrix of dimension M×M, where M is the dimension of LP parameter vector xn. A simple form of the prediction matrix A is a diagonal matrix with diagonal elements α1, α2, . . . , αM, where αt are prediction factors for individual LP parameters. If the same factor α is used for all LP parameters then equation 2 reduces to:
pn=α{circumflex over (x)}n−1 (3)
Using the simple prediction form of Equation (3), then in
{circumflex over (x)}n=ên+α{circumflex over (x)}n−1 (4)
The recursive form of Equation (4) implies that, when using an AR predictive quantizer 300 of the form as illustrated in
This form clearly shows that in principle each past decoded prediction error vector ên−k contributes to the value of the quantized LP parameter vector {circumflex over (x)}n. Hence, in the case of channel errors, which would modify the value of ên received by the decoder relative to what was sent by the encoder, the decoded vector {circumflex over (x)}n obtained in Equation (4) would not be the same at the decoder and at the encoder. Because of the recursive nature of the predictor P, this encoder-decoder mismatch will propagate in the future and affect the next vectors {circumflex over (x)}n+1, {circumflex over (x)}n+2, etc., even if there are no channel errors in the later frames. Therefore, predictive vector quantization is not robust to channel errors, especially when the prediction factors are high (α close to 1 in Equations (4) and (5)).
To alleviate this propagation problem, moving average (MA) prediction can be used instead of AR prediction. In MA prediction, the infinite series of Equation (5) is truncated to a finite number of terms. The idea is to approximate the autoregressive form of predictor P in Equation (4) by using a small number of terms in Equation (5). Note that the weights in the summation can be modified to better approximate the predictor P of Equation (4).
A non-limitative example of MA predictive vector quantizer 400 is shown in
pn=B1ên−1+B2ên−2+ . . . +BKên−K
where Bk are prediction matrices of dimension M×M and K is the predictor order. It should be noted that in MA prediction, transmission errors propagate only into next K frames.
A simple form for the predictor P (Processor 402) is to use first order prediction:
pn=Bên−1 (6)
where B is a prediction matrix of dimension M×M, where M is the dimension of LP parameter vector. A simple form of the prediction matrix is a diagonal matrix with diagonal elements β1, β2, . . . , βM, where βt are prediction factors for individual LP parameters. If the same factor β is used for all LP parameters then Equation (6) reduces to:
pn=β{circumflex over (x)}n−1 (7)
Using the simple prediction form of Equation (7), then in
{circumflex over (x)}n=ên+βên−1 (8)
In the illustrative example of predictive vector quantizer 400 using MA prediction as shown in
While more robust to transmission errors than AR prediction, MA prediction does not achieve the same prediction gain for a given prediction order. The prediction error has consequently a greater dynamic range, and can require more bits to achieve the same coding gain than with AR predictive quantization. The compromise is thus robustness to channel errors versus coding gain at a given bit rate.
In source-controlled variable bit rate (VBR) coding, the encoder operates at several bit rates, and a rate selection module is used to determine the bit rate used for encoding each speech frame based on the nature of the speech frame, for example voiced, unvoiced, transient, background noise. The nature of the speech frame, for example voiced, unvoiced, transient, background noise, etc., can be determined in the same manner as for CDMA VBR. The goal is to attain the best speech quality at a given average bit rate, also referred to as average data rate (ADR). As an illustrative example, in CDMA systems, for example CDMA-one and CDMA2000, typically 4 bit rates are used and are referred to as full-rate (FR), half-rate (HR), quarter-rate (QR), and eighth-rate (ER). In this CDMA system, two sets of rates are supported and are referred to as Rate Set I and Rate Set II. In Rate Set II, a variable-rate encoder with rate selection mechanism operates at source-coding bit rates of 13.3 (FR), 6.2 (HR), 2.7 (QR), and 1.0 (ER) kbit/s.
In VBR coding, a classification and rate selection mechanism is used to classify the speech frame according to its nature (voiced, unvoiced, transient, noise, etc.) and selects the bit rate needed to encode the frame according to the classification and the required average data rate (ADR). Half-rate encoding is typically chosen in frames where the input speech signal is stationary. The bit savings compared to the full-rate are achieved by updating encoder parameters less frequently or by using fewer bits to encode some parameters. Further, these frames exhibit a strong correlation which can be exploited to reduce the bit rate. More specifically, in stationary voiced segments, the pitch information is encoded only once in a frame, and fewer bits are used for the fixed codebook and the LP coefficients. In unvoiced frames, no pitch prediction is needed and the excitation can be modeled with small codebooks in HR or random noise in QR.
Since predictive VQ with MA prediction is typically applied to encode the LP parameters, this results in an unnecessary increase in quantization noise. MA prediction, as opposed to AR prediction, is used to increase the robustness to frame losses; however, in stationary frames the LP parameters evolve slowly so that using AR prediction in this case would have a smaller impact on error propagation in the case of lost frames. This is detected by observing that, in the case of missing frames, most decoders apply a concealment procedure which essentially extrapolates the LP parameters of the last frame. If the missing frame is stationary voiced, this extrapolation produces values very similar to the actually transmitted, but not received LP parameters. The reconstructed LP parameter vector is thus close to what would have been decoded if the frame had not been lost. In that specific case, using AR prediction in the quantization procedure of the LP coefficients cannot have a very adverse effect on quantization error propagation.
Thus, according to a non-restrictive illustrative embodiment of the present invention, a predictive VQ method for LP parameters is disclosed whereby the predictor is switched between MA and AR prediction according to the nature of the speech frame being processed. More specifically, in transient and non-stationary frames MA prediction is used while in stationary frames AR prediction is used. Moreover, since AR prediction results in a prediction error vector en with a smaller dynamic range than MA prediction, it is not efficient to use the same quantization tables for both types of prediction. To overcome this problem, the prediction error vector after AR prediction is properly scaled so that it can be quantized using the same quantization tables as in the MA prediction case. When multistage VQ is used to quantize the prediction error vector, the first stage can be used for both types of prediction after properly scaling the AR prediction error vector. Since it is sufficient to use split VQ in the second stage which doesn't require large memory, quantization tables of this second stage can be trained and designed separately for both types of prediction. Of course, instead of designing the quantization tables of the first stage with MA prediction and scaling the AR prediction error vector, the opposite is also valid, that is, the first stage can be designed for AR prediction and the MA prediction error vector is scaled prior to quantization.
Thus, according to a non-restrictive illustrative embodiment of the present invention, a predictive vector quantization method is also disclosed for quantizing LP parameters in a variable bit rate speech codec whereby the predictor P is switched between MA and AR prediction according to classification information regarding the nature of the speech frame being processed, and whereby the prediction error vector is properly scaled such that the same first stage quantization tables in a multistage VQ of the prediction error can be used for both types of prediction.
An efficient approach for vector quantization is to combine both multi-stage and split VQ which results in a good trade-off between quality and complexity. In a first illustrative example, a two-stage VQ can be used whereby the second stage error vector ê2 is split into several subvectors and quantized with second stage quantizers Q21, Q22, . . . , Q2K, respectively. In an second illustrative example, the input vector can be split into two subvectors, then each subvector is quantized with two-stage VQ using further split in the second stage as in the first illustrative example.
The scaled prediction error vector e′ is then vector quantized (Processor 508) to produce a quantized scaled prediction error vector ê′. In the example of
The prediction vector p is computed in either an MA predictor (Processor 511) or an AR predictor (Processor 512) depending on the frame classification information (for example, as indicated hereinabove, AR if the frame is stationary voiced and MA if the frame is not stationary voiced, selection made by Processor 513). If the frame is stationary voiced then the prediction vector is equal to the output of the AR predictor 512. Otherwise the prediction vector is equal to the output of the MA predictor 511. As explained hereinabove the MA predictor 511 operates on the quantized prediction error vectors from previous frames while the AR predictor 512 operates on the quantized input LP parameter vectors from previous frames. The quantized input LP parameter vector (mean-removed) is constructed by adding the quantized prediction error vector ê to the prediction vector p (Processor 514): {circumflex over (x)}=ê+p .
Of course, despite the fact that only the output of either the MA predictor or the AR predictor is used in a certain frame, the memories of both predictors will be updated every frame, assuming that either MA or AR prediction can be used in the next frame. This is valid for both the encoder and decoder sides.
In order to optimize the encoding gain, some vectors of the first stage, designed for MA prediction, can be replaced by new vectors designed for AR prediction. In a non-restrictive illustrative embodiment, the first stage codebook size is 256, and has the same content as in the AMR-WB standard at 12.65 kbit/s, and 28 vectors are replaced in the first stage codebook when using AR prediction. An extended, first stage codebook is thus formed as follows: first, the 28 first-stage vectors less used when applying AR prediction but usable for MA prediction are placed at the beginning of a table, then the remaining 256−28=228 first-stage vectors usable for both AR and MA prediction are appended in the table, and finally 28 new vectors usable for AR prediction are put at the end of the table. The table length is thus 256+28=284 vectors. When using MA prediction, the first 256 vectors of the table are used in the first stage; when using AR prediction the last 256 vectors of the table are used. To ensure interoperability with the AMR-WB standard, a table is used which contains the mapping between the position of a first stage vector in this new codebook, and its original position in the AMR-WB first stage codebook.
To summarize, the above described non-restrictive illustrative embodiments of the present invention, described in relation to
Although the present invention has been described in the foregoing description in relation to non-restrictive illustrative embodiments thereof, these embodiments can be modified at will, within the scope of the appended claims, without departing from the nature and scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
2415105 | Dec 2002 | CA | national |
This patent application is a continuation of U.S. patent application Ser. No. 11/039,659, filed Jan. 19, 2005 now U.S. Pat. No. 7,149,683, which is a continuation of International Patent Application No.: PCT/CA2003/001985 filed on Dec. 18, 2003, which claims priority from Canadian Patent Application CA2415105, filed on Dec. 24, 2002.
Number | Name | Date | Kind |
---|---|---|---|
5757306 | Nomura | May 1998 | A |
5774839 | Shlomot | Jun 1998 | A |
5848384 | Hollier et al. | Dec 1998 | A |
5956672 | Serizawa | Sep 1999 | A |
6064954 | Cohen et al. | May 2000 | A |
6104992 | Gao et al. | Aug 2000 | A |
6122608 | McCree | Sep 2000 | A |
6141640 | Moo | Oct 2000 | A |
6202045 | Ojala et al. | Mar 2001 | B1 |
6260010 | Gao et al. | Jul 2001 | B1 |
6320907 | Pau et al. | Nov 2001 | B1 |
6415254 | Yasunaga et al. | Jul 2002 | B1 |
6475245 | Gersho et al. | Nov 2002 | B2 |
6505222 | Davis et al. | Jan 2003 | B1 |
6604070 | Gao et al. | Aug 2003 | B1 |
6691092 | Udaya Bhaskar et al. | Feb 2004 | B1 |
6795805 | Bessette et al. | Sep 2004 | B1 |
6885988 | Chen | Apr 2005 | B2 |
6988067 | Kim et al. | Jan 2006 | B2 |
7010482 | Gottesman et al. | Mar 2006 | B2 |
7149683 | Jelinek | Dec 2006 | B2 |
7180892 | Tackin | Feb 2007 | B1 |
7272556 | Aguilar et al. | Sep 2007 | B1 |
20020138260 | Kim et al. | Sep 2002 | A1 |
20030012137 | Abdelilah et al. | Jan 2003 | A1 |
Number | Date | Country | |
---|---|---|---|
20070112564 A1 | May 2007 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11039659 | Jan 2005 | US |
Child | 11604188 | US | |
Parent | PCT/CA03/01985 | Dec 2003 | US |
Child | 11039659 | US |