The following U.S. patent applications are hereby incorporated by reference in their entireties and made part of the present application:
U.S. patent application Ser. No. 09/156,650, titled “Speech Encoder Using Gain Normalization That Combines Open And Closed Loop Gains,” filed Sep. 18, 1998;
Provisional U.S. Patent Application Ser. No. 60/155,321 titled “4 kbits/s Speech Coding,” filed Sep. 22, 1999; and
U.S. patent application Ser. No. 09/574,396 titled “A New Speech Gain Quantization Strategy,” filed May 19, 2000.
The field of the present invention relates generally to the encoding and decoding of speech in voice communication systems and, more particularly to a method and apparatus for handling erroneous or lost frames.
To model basic speech sounds, speech signals are sampled over time and stored in frames as a discrete waveform to be digitally processed. However, in order to increase the efficient use of the communication bandwidth for speech, speech is coded before being transmitted especially when speech is intended to be transmitted under limited bandwidth constraints. Numerous algorithms have been proposed for the various aspects of speech coding. For example, an analysis-by-synthesis coding approach may be performed on a speech signal. In coding speech, the speech coding algorithm tries to represent characteristics of the speech signal in a manner which requires less bandwidth. For example, the speech coding algorithm seeks to remove redundancies in the speech signal. A first step is to remove short-term correlations. One type of signal coding technique is linear predictive coding (LPC). In using a LPC approach, the speech signal value at any particular time is modeled as a linear function of previous values. By using a LPC approach, short-term correlations can be reduced and efficient speech signal representations can be determined by estimating and applying certain prediction parameters to represent the signal. The LPC spectrum, which is an envelope of short term correlations in the speech signal, may be represented, for example, by LSF's (line spectral frequencies). After the removal of short-term correlations in a speech signal, a LPC residual signal remains. This residual signal contains periodicity information that needs to be modeled. The second step in removing redundancies in speech is to model the periodicity information. Periodicity information may be modeled by using pitch prediction. Certain portions of speech have periodicity while other portions do not. For example, the sound “aah” has periodicity information while the sound “shhh” has no periodicity information.
In applying the LPC technique, a conventional source encoder operates on speech signals to extract modeling and parameter information to be coded for communication to a conventional source decoder via a communication channel. One way to code modeling and parameter information into a smaller amount of information is to use quantization. Quantization of a parameter involves selecting the closest entry in a table or codebook to represent the parameter. Thus, for example, a parameter of 0.125 may be represented by 0.1 if the codebook contains 0, 0.1, 0.2, 0.3, etc. Quantization includes scalar quantization and vector quantization. In scalar quantization, one selects the entry in the table or codebook that is the closest approximation to the parameter, as described above. By contrast, vector quantization combines two or more parameters and selects the entry in the table or codebook which is closest to the combined parameters. For example, vector quantization may select the entry in the codebook that is the closest to the difference between the parameters. A codebook used to vector quantize two parameters at once is often referred to as a two-dimensional codebook. A n-dimensional codebook quantizes n parameters at once.
Quantized parameters may be packaged into packets of data which are transmitted from the encoder to the decoder. In other words, once coded, the parameters representing the input speech signal are transmitted to a transceiver. Thus, for example, the LSF's may be quantized and the index into a codebook may be converted into bits and transmitted from the encoder to the decoder. Depending on the embodiment, each packet may represent a portion of a frame of the speech signal, a frame of speech, or more than a frame of speech. At the transceiver, a decoder receives the coded information. Because the decoder is configured to know the manner in which speech signals are encoded, the decoder decodes the coded information to reconstruct a signal for playback that sounds to the human ear like the original speech. However, it may be inevitable that at least one packet of data is lost during transmission and the decoder does not receive all of the information sent by the encoder. For instance, when speech is being transmitted from a cell phone to another cell phone, data may be lost when reception is poor or noisy. Therefore, transmitting the coded modeling and parameter information to the decoder requires a way for the decoder to correct or adjust for lost packets of data. While the prior art describes certain ways of adjusting for lost packets of data such as by extrapolation to try to guess what the information was in the lost packet, these methods are limited such that improved methods are needed.
Besides LSF information, other parameters transmitted to the decoder may be lost. In CELP (Code Excited Linear Prediction) speech coding, for example, there are two types of gain which are also quantized and transmitted to the decoder. The first type of gain is the pitch gain GO, also known as the adaptive codebook gain. The adaptive codebook gain is sometimes referred to, including herein, with the subscript “a” instead of the subscript “p”. The second type of gain is the fixed codebook gain GC. Speech coding algorithms have quantized parameters including the adaptive codebook gain and the fixed codebook gain. Other parameters may, for example, include pitch lags which represent the periodicity of voiced speech. If the speech encoder classifies speech signals, the classification information about the speech signal may also be transmitted to the decoder. For an improved speech encoder/decoder that classifies speech and operates in different modes, see U.S. patent application Ser. No. 09/574,396 titled “A New Speech Gain Quantization Strategy,” filed May 19, 2000, which was previously incorporated herein by reference.
Because these and other parameter information are sent over imperfect transmission means to the decoder, some of these parameters are lost or never received by the decoder. For speech communication systems that transmit a packet of information per frame of speech, a lost packet results in a lost frame of information. In order to reconstruct or estimate the lost information, prior art systems have tried different approaches, depending on the parameter lost. Some approaches simply use the parameter from the previous frame that actually was received by the decoder. These prior art approaches have their disadvantages, inaccuracies and problems. Thus, there is a need for an improved way to correct or adjust for lost information so as to recreate a speech signal as close as possible to the original speech signal.
Certain prior art speech communication systems do not transmit a fixed codebook excitation from the encoder to the decoder in order to save bandwidth. Instead, these systems have a local Gaussian time series generator that uses an initial fixed seed to generate a random excitation value and then updates that seed every time the system encounters a frame containing silence or background noise. Thus, the seed changes for every noise frame. Because the encoder and decoder have the same Gaussian time series generator that uses the same seeds in the same sequence, they generate the same random excitation value for noise frames. However, if a noise frame is lost and not received by the decoder, the encoder and decoder use different seeds for the same noise frame, thereby losing their synchronicity. Thus, there is a need for a speech communication system that does not transmit fixed codebook excitation values to the decoder, but which maintains synchronicity between the encoder and decoder when a frame is lost during transmission.
Various separate aspects of the present invention can be found in a speech communication system and method that has an improved way of handling information lost during transmission from the encoder to the decoder. In particular, the improved speech communication system is able to generate more accurate estimates for the information lost in a lost packet of data. For example, the improved speech communication system is able to handle more accurately lost information such as LSF, pitch lag (or adaptive codebook excitation), fixed codebook excitation and/or gain information. In an embodiment of a speech communication system that does not transmit fixed codebook excitation values to the decoder, the improved encoder/decoder are able to generate the same random excitation values for a given noise frame even if a previous noise frame was lost during transmission.
A first, separate aspect of the present invention is a speech communication system that handles lost LSF information by setting the minimum spacing between LSF's to an increased value and then decreasing the value for subsequent frames in a controlled adaptive manner.
A second, separate aspect of the present invention is a speech communication system that estimates a lost pitch lag by extrapolating from the pitch lags of a plurality of the preceding received frames.
A third, separate aspect of the present invention is a speech communication system that receives the pitch lag of the succeeding received frame and uses curve fitting between the pitch lag of the preceding received frame and the pitch lag of the succeeding received frame to fine tune its estimation of the pitch lag for the lost frame so as to adjust or correct the adaptive codebook buffer prior to its use by subsequent frames.
A fourth, separate aspect of the present invention is a speech communication system that estimates a lost gain parameter for periodic-like speech differently than it estimates a lost gain parameter for non-periodic like speech.
A fifth, separate aspect of the present invention is a speech communication system that estimates a lost adaptive codebook gain parameter differently than it estimates a lost fixed codebook gain parameter.
A sixth, separate aspect of the present invention is a speech communication system that determines a lost adaptive codebook gain parameter for a lost frame of non-periodic like speech based on the average adaptive codebook gain parameter of the subframes of an adaptive number of previously received frames.
A seventh, separate aspect of the present invention is a speech communication system that determines a lost adaptive codebook gain parameter for a lost frame of non-periodic like speech based on the average adaptive codebook gain parameter of the subframes of an adaptive number of previously received frames and the ratio of the adaptive codebook excitation energy to the total excitation energy.
An eighth, separate aspect of the present invention is a speech communication system that determines a lost adaptive codebook gain parameter for a lost frame of non-periodic like speech based on the average adaptive codebook gain parameter of the subframes of an adaptive number of previously received frames, the ratio of the adaptive codebook excitation energy to the total excitation energy, the spectral tilt of the previously received frame and/or energy of the previously received frame.
A ninth, separate aspect of the present invention is a speech communication system that sets a lost adaptive codebook gain parameter for a lost frame of non-periodic like speech to an arbitrarily high number.
A tenth, separate aspect of the present invention is a speech communication system that sets a lost fixed codebook gain parameter to zero for all subframes of a lost frame of non-periodic like speech.
An eleventh, separate aspect of the present invention is a speech communication system that determines a lost fixed codebook gain parameter for the current subframe of the lost frame of non-periodic like speech based on the ratio of the energy of the previously received frame to the energy of the lost frame.
A twelfth, separate aspect of the present invention is a speech communication system that determines a lost fixed codebook gain parameter for the current subframe of the lost frame based on the ratio of the energy of the previously received frame to the energy of the lost frame and then attenuates that parameter to set the lost fixed codebook gain parameters for the remaining subframes of the lost frame.
A thirteenth, separate aspect of the present invention is a speech communication system that sets a lost adaptive codebook gain parameter for the first frame of periodic like speech to be lost after a received frame to an arbitrarily high number.
A fourteenth, separate aspect of the present invention is a speech communication system that sets a lost adaptive codebook gain parameter for the first frame of periodic like speech to be lost after a received frame to an arbitrarily high number and then attenuates that parameter to set the lost adaptive codebook gain parameters for the remaining subframes of the lost frame.
A fifteenth, separate aspect of the present invention is a speech communication system that sets a lost fixed codebook gain parameter for a lost frame of periodic like speech to zero if the average adaptive codebook gain parameter of a plurality of the previously received frames exceeds a threshold.
A sixteenth, separate aspect of the present invention is a speech communication system that determines a lost fixed codebook gain parameter for the current subframe of a lost frame of periodic like speech based on the ratio of the energy of the previously received frame to the energy of the lost frame if the average adaptive codebook gain parameter of a plurality of the previously received frames does not exceed a threshold.
A seventeenth, separate aspect of the present invention is a speech communication system that determines a lost fixed codebook gain parameter for the current subframe of a lost frame based on the ratio of the energy of the previously received frame to the energy of the lost frame and then attenuates that parameter to set the lost fixed codebook gain parameters for the remaining subframes of the lost frame if the average adaptive codebook gain parameter of a plurality of the previously received frames exceeds a threshold.
An eighteenth, separate aspect of the present invention is a speech communication system that randomly generates a fixed codebook excitation for a given frame by using a seed whose value is determined by information in that frame.
A nineteenth, separate aspect of the present invention is a speech communication decoder that after estimating lost parameters in a lost frame and synthesizing the speech, matches the energy of the synthesized speech to the energy of the previously received frame.
A twentieth, separate aspect of the present invention is any of the above separate aspects, either individually or in some combination.
Further separate aspects of the present invention can also be found in a method of encoding and/or decoding a speech signal that practices any of the above separate aspects, either individually or in some combination.
Other aspects, advantages and novel features of the present invention will become apparent from the following Detailed Description Of A Preferred Embodiment, when considered in conjunction with the accompanying figures.
First a general description of the overall speech communication system is described, and then a detailed description of an embodiment of the present invention is provided.
A storage device may be coupled to the communication channel 103 to temporarily store speech information for delayed reproduction or playback, e.g., to perform answering machine functions, voiced email, etc. Likewise, the communication channel 103 might be replaced by such a storage device in a single device embodiment of the communication system 100 that, for example, merely records and stores speech for subsequent playback.
In particular, a microphone 111 produces a speech signal in real time. The microphone 111 delivers the speech signal to an A/D (analog to digital) converter 115. The A/D converter 115 converts the analog speech signal into a digital form and then delivers the digitized speech signal to a speech encoder 117.
The speech encoder 117 encodes the digitized speech by using a selected one of a plurality of encoding modes. Each of the plurality of encoding modes uses particular techniques that attempt to optimize the quality of the resultant reproduced speech. While operating in any of the plurality of modes, the speech encoder 117 produces a series of modeling and parameter information (e.g., “speech parameters”) and delivers the speech parameters to an optional channel encoder 119.
The optional channel encoder 119 coordinates with a channel decoder 131 to deliver the speech parameters across the communication channel 103. The channel decoder 131 forwards the speech parameters to a speech decoder 133. While operating in a mode that corresponds to that of the speech encoder 117, the speech decoder 133 attempts to recreate the original speech from the speech parameters as accurately as possible. The speech decoder 133 delivers the reproduced speech to a D/A (digital to analog) converter 135 so that the reproduced speech may be heard through a speaker 137.
A microphone 155 and an A/D converter 157 deliver a digital voice signal to an encoding system 159. The encoding system 159 performs speech encoding and delivers resultant speech parameter information to the communication channel. The delivered speech parameter information may be destined for another communication device (not shown) at a remote location.
As speech parameter information is received, a decoding system 165 performs speech decoding. The decoding system delivers speech parameter information to a D/A converter 167 where the analog speech output may be played on a speaker 169. The end result is the reproduction of sounds as similar as possible to the originally captured speech.
The encoding system 159 comprises both a speech processing circuit 185 that performs speech encoding and an optional channel processing circuit 187 that performs the optional channel encoding. Similarly, the decoding system 165 comprises a speech processing circuit 189 that performs speech decoding and an optional channel processing circuit 191 that performs channel decoding.
Although the speech processing circuit 185 and the optional channel processing circuit 187 are separately illustrated, they may be combined in part or in total into a single unit. For example, the speech processing circuit 185 and the channel processing circuitry 187 may share a single DSP (digital signal processor) and/or other processing circuitry. Similarly, the speech processing circuit 189 and optional the channel processing circuit 191 may be entirely separate or combined in part or in whole. Moreover, combinations in whole or in part may be applied to the speech processing circuits 185 and 189, the channel processing circuits 187 and 191, the processing circuits 185, 187, 189 and 191, or otherwise as appropriate. Further, each or all of the circuits which control aspects of the operation of the decoder and/or encoder may be referred to as a control logic and may be implemented, for example, by a microprocessor, microcontroller, CPU (central processing unit), ALU (arithmetic logic unit), a co-processor, an ASIC (application specific integrated circuit), or any other kind of circuit and/or software.
The encoding system 159 and the decoding system 165 both use a memory 161. The speech processing circuit 185 uses a fixed codebook 181 and an adaptive codebook 183 of a speech memory 177 during the source encoding process. Similarly, the speech processing circuit 189 uses the fixed codebook 181 and the adaptive codebook 183 during the source decoding process.
Although the speech memory 177 as illustrated is shared by the speech processing circuits 185 and 189, one or more separate speech memories can be assigned to each of the processing circuits 185 and 189. The memory 161 also contains software used by the processing circuits 185, 187, 189 and 191 to perform various functions required in the source encoding and decoding processes.
Before discussing the details of an embodiment of the improvement in speech coding, an overview of the overall speech encoding algorithm is provided at this point. The improved speech encoding algorithm referred to in this specification may be, for example, the eX-CELP (extended CELP) algorithm which is based on the CELP model. The details of the eX-CELP algorithm is discussed in a U.S. patent application assigned to the same assignee, Conexant Systems, Inc., and previously incorporated herein by reference: Provisional U.S. Patent Application Ser. No. 60/155,321 titled “4 kbits/s Speech Coding,” filed Sep. 22, 1999.
In order to achieve toll quality at a low bit rate (such as 4 kilobits per second), the improved speech encoding algorithm departs somewhat from the strict waveform-matching criterion of traditional CELP algorithms and strives to capture the perceptually important features of the input signal. To do so, the improved speech encoding algorithm analyzes the input signal according to certain features such as degree of noise-like content, degree of spiky-like content, degree of voiced content, degree of unvoiced content, evolution of magnitude spectrum, evolution of energy contour, evolution of periodicity, etc., and uses this information to control weighting during the encoding and quantization process. The philosophy is to accurately represent the perceptually important features and allow relatively larger errors in less important features. As a result, the improved speech encoding algorithm focuses on perceptual matching instead of waveform matching. The focus on perceptual matching results in satisfactory speech reproduction because of the assumption that at 4 kbits per second, waveform matching is not sufficiently accurate to capture faithfully all information in the input signal. Consequently, the improved speech encoder performs some prioritizing to achieve improved results.
In one particular embodiment, the improved speech encoder uses a frame size of 20 milliseconds, or 160 samples per second, each frame being divided into either two or three subframes. The number of subframes depends on the mode of subframe processing. In this particular embodiment, one of two modes may be selected for each frame of speech: Mode 0 and Mode 1. Importantly, the manner in which subframes are processed depends on the mode. In this particular embodiment, Mode 0 uses two subframes per frame where each subframe size is 10 milliseconds in duration, or contains 80 samples. Likewise, in this example embodiment, Mode 1 uses three subframes per frame where the first and second subframes are 6.625 milliseconds in duration, or contains 53 samples, and the third subframe is 6.75 milliseconds in duration, or contains 54 samples. In both Modes, a look-ahead of 15 milliseconds may be used. For both Modes 0 and 1, a tenth order Linear Prediction (LP) model may be used to represent the spectral envelope of the signal. The LP model may be coded in the Line Spectrum Frequency (LSF) domain by using, for example, a delayed-decision, switched multi-stage predictive vector quantization scheme.
Mode 0 operates a traditional speech encoding algorithm such as a CELP algorithm. However, Mode 0 is not used for all frames of speech. Instead, Mode 0 is selected to handle frames of all speech other than “periodic-like” speech, as discussed in greater detail below. For convenience, “periodic-like” speech is referred to here as periodic speech, and all other speech is “non-periodic” speech. Such “non-periodic” speech include transition frames where the typical parameters such as pitch correlation and pitch lag change rapidly and frames whose signal is dominantly noise-like. Mode 0 breaks each frame into two subframes. Mode 0 codes the pitch lag once per subframe and has a two-dimensional vector quantizer to jointly code the pitch gain (i.e., adaptive codebook gain) and the fixed codebook gain once per subframe. In this example enbodiment, the fixed codebook contains two pulse sub-codebooks and one Gaussian sub-codebook; the two pulse sub-codebooks have two and three pulses, respectively.
Mode 1 deviates from the traditional CELP algorithm. Mode 1 handles frames containing periodic speech which typically have high periodicity and are often well represented by a smooth pitch tract. In this particular embodiment, Mode 1 uses three subframes per frame. The pitch lag is coded once per frame prior to the subframe processing as part of the pitch pre-processing and the interpolated pitch tract is derived from this lag. The three pitch gains of the subframes exhibit very stable behavior and are jointly quantized using pre-vector quantization based on a mean-squared error criterion prior to the closed loop subframe processing. The three reference pitch gains which are unquantized are derived from the weighted speech and are a byproduct of the frame-based pitch pre-processing. Using the pre-quantized pitch gains, the traditional CELP subframe processing is performed, except that the three fixed codebook gains are left unquantized. The three fixed codebook gains are jointly quantized after subframe processing which is based on a delayed decision approach using a moving average prediction of the energy. The three subframes are subsequently synthesized with fully quantized parameters.
The manner in which the mode of processing is selected for each frame of speech based on the classification of the speech contained in the frame and the innovative way in which periodic speech is processed allows for gain quantization with significantly fewer bits without any significant sacrifice in the perceptual quality of the speech. Details of this manner of processing speech are provided below.
Input speech is read and buffered into frames. Turning to the speech pre-processor 193 of
The high-pass filter 197 eliminates frequencies below a certain cutoff frequency and permits frequencies higher than the cutoff frequency to pass to a noise attenuator 199. In this particular embodiment, the high-pass filter 197 is identical to the input high-pass filter of the G.729 speech coding standard of ITU-T. Namely, it is a second order pole-zero filter with a cut-off frequency of 140 hertz (Hz). Of course, the high-pass filter 197 need not be such a filter and may be constructed to be any kind of appropriate filter known to those of ordinary skill in the art.
The noise attenuator 199 performs a noise suppression algorithm. In this particular embodiment, the noise attenuator 199 performs a weak noise attenuation of a maximum of 5 decibels (dB) of the environmental noise in order to improve the estimation of the parameters by the speech encoding algorithm. The specific methods of enhancing silence, building a high-pass filter 197 and attenuating noise may use any one of the numerous techniques known to those of ordinary skill in the art. The output of the speech pre-processor 193 is pre-processed speech 200.
Of course, the silence enhancer 195, high-pass filter 197 and noise attenuator 199 may be replaced by any other device or modified in a manner known to those of ordinary skill in the art and appropriate for the particular application.
Turning to
A LPC analyzer 260 receives the pre-processed speech signal 200 and estimates the short term spectral envelope of the speech signal 200. The LPC analyzer 260 extracts LPC coefficients from the characteristics defining the speech signal 200. In one embodiment, three tenth-order LPC analyses are performed for each frame. They are centered at the middle third, the last third and the lookahead of the frame. The LPC analysis for the lookahead is recycled for the next frame as the LPC analysis centered at the first third of the frame. Thus, for each frame, four sets of LPC parameters are generated. The LPC analyzer 260 may also perform quantization of the LPC coefficients into, for example, a line spectral frequency (LSF) domain. The quantization of the LPC coefficients may be either scalar or vector quantization and may be performed in any appropriate domain in any manner known in the art.
A classifier 270 obtains information about the characteristics of the pre-processed speech 200 by looking at, for example, the absolute maximum of frame, reflection coefficients, prediction error, LSF vector from the LPC analyzer 260, the tenth order autocorrelation, recent pitch lag and recent pitch gains. These parameters are known to those of ordinary skill in the art and for that reason, are not further explained here. The classifier 270 uses the information to control other aspects of the encoder such as the estimation of signal-to-noise ratio, pitch estimation, classification, spectral smoothing, energy smoothing and gain normalization. Again, these aspects are known to those of ordinary skill in the art and for that reason, are not further explained here. A brief summary of the classification algorithm is provided next.
The classifier 270, with help from the pitch preprocessor 254, classifies each frame into one of six classes according to the dominating feature of the frame. The classes are (1) Silence/background Noise; (2) Noise/Like Unvoiced Speech; (3) Unvoiced; (4) Transition (includes onset); (5) Non-Stationary Voiced; and (6) Stationary Voiced. The classifier 270 may use any approach to classify the input signal into periodic signals and non-periodic signals. For example, the classifier 270 may take the pre-processed speech signal, the pitch lag and correlation of the second half of the frame, and other information as input parameters.
Various criteria can be used to determine whether speech is deemed to be periodic. For example, speech may be considered periodic if the speech is a stationary voiced signal. Some people may consider periodic speech to include stationary voiced speech and non-stationary voiced speech, but for purposes of this specification, periodic speech includes stationary voiced speech. Furthermore, periodic speech may be smooth and stationary speech. A voice speech is considered to be “stationary” when the speech signal does not change more than a certain amount within a frame. Such a speech signal is more likely to have a well defined energy contour. A speech signal is “smooth” if the adaptive codebook gain GP of that speech is greater than a threshold value. For example, if the threshold value is 0.7, a speech signal in a subframe is considered to be smooth if its adaptive codebook gain GP is greater than 0.7. Non-periodic speech, or non-voiced speech, includes unvoiced speech (e.g., fricatives such as the “shhh” sound), transitions (e.g., onsets, offsets), background noise and silence.
More specifically, in the example embodiment, the speech encoder initially derives the following parameters:
Spectral Tilt (estimation of first reflection coefficient 4 times per frame):
where L=80 is the window over which the reflection coefficient is calculated and sk(n) is the kth segment given by
Sk(n)=s(k·40−20+n)·wh(n), n=0,1, . . . 79, (2)
where wh(n) is a 80 sample Hamming window and s(0), s(1), . . . , s(159) is the current frame of the pre-processed speech signal.
Absolute Maximum (tracking of absolute signal maximum, 8 estimates per frame):
χ(k)=max {s(n)|,n=ns(k),ns(k)+1, . . . ,ne(k)−1}, k=0,1, . . . ,7 (3)
where ns(k) and ne(k) is the starting point and end point, respectively, for the search of the kth maximum at time k·160/8 samples of the frame. In general, the length of the segment is 1.5 times the pitch period and the segments overlap. Thus, a smooth contour of the amplitude envelope can be obtained.
The Spectral Tilt, Absolute Maximum, and Pitch Correlation parameters form the basis for the classification. However, additional processing and analysis of the parameters are performed prior to the classification decision. The parameter processing initially applies weighting to the three parameters. The weighting in some sense removes the background noise component in the parameters by subtracting the contribution from the background noise. This provides a parameter space that is “independent” from any background noise and thus is more uniform and improves the robustness of the classification to background noise.
Running means of the pitch period energy of the noise, the spectral tilt of the noise, the absolute maximum of the noise, and the pitch correlation of the noise are updated eight times per frame according to the following equations, Equations 4–7. The following parameters defined by Equations 4–7 are estimated/sampled eight times per frame, providing a fine time resolution of the parameter space:
Running mean of the pitch period energy of the noise:
<EN,P(k)>=α1·<EN,P(k−1)>+(1−α1)·Ep(k), (4)
where EN,p(k) is the normalized energy of the pitch period at time k·160/8 samples of the frame. The segments over which the energy is calculated may overlap since the pitch period typically exceeds 20 samples (160 samples/8).
Running means of the spectral tilt of the noise:
<κN(k)>=α1·<κN(k−1)>+(1−α1)·κ(k mod 2). (5)
Running mean of the absolute maximum of the noise:
<χN(k)>=α1·<XN(k−1)>+(1−α1)·χ(k). (6)
Running mean of the pitch correlation of the noise:
<RN,p(k)>=α1·<RN,p(k−1)>+(1−α1)·Rp. (7)
where Rp is the input pitch correlation for the second half of the frame. The adaptation constant α1 is adaptive, though the typical value is α1=0.99. The background noise to signal ratio is calculated according to
The parametric noise attenuation is limited to 30 dB, i.e.,
γ(k)={γ(k)>0.968?0.968:γ(k)} (9)
The noise free set of parameters (weighted parameters) is obtained by removing the noise component according to the following Equations 10–12:
Estimation of weighted spectral tilt:
κw(k)=κ(k mod 2)−γ(k)·<κN(k)>. (10)
Estimation of weighted absolute maximum:
χw(k)=χ(k)−y(k)·<χN(k)>. (11)
Estimation of weighted pitch correlation:
Rw,p(k)=Rp−γ(k)·<RN,p(k)>. (12)
The evolution of the weighted tilt and the weighted maximum is calculated according to the following Equations 13 and 14, respectively, as the slope of the first order approximation:
Once the parameters of Equations 4 through 14 are updated for the eight sample points of the frame, the following frame-based parameters are calculated from the parameters of Equations 4–14:
Maximum weighted pitch correlation:
Average weighted pitch correlation:
Running mean of average weighted pitch correlation:
where m is the frame number and α2=0.75 is the adaptation constant. Normalized standard deviation of pitch lag:
where Lp(m) is the input pitch lag and μL
Minimum weighted spectral tilt:
Running mean of minimum weighted spectral tilt:
Average weighted spectral tilt:
Minimum slope of weighted tilt:
Accumulated slope of weighted spectral tilt:
Maximum slope of weighted maximum:
Accumulated slope of weighted maximum:
The parameters given by Equations 23, 25, and 26 are used to mark whether a frame is likely to contain an onset, and the parameters given by Equations 16–18, 20–22 are used to mark whether a frame is likely to be dominated by voiced speech. Based on the initial marks, past marks and other information, the frame is classified into one of the six classes.
A more detailed description of the manner in which the classifier 270 classifies the pre-processed speech 200 is described in a U.S. patent application assigned to the same assignee, Conexant Systems, Inc., and previously incorporated herein by reference: Provisional U.S. Patent Application Ser. No. 60/155,321 titled “4 kbits/s Speech Coding,” filed Sep. 22, 1999.
The LSF quantizer 267 receives the LPC coefficients from the LPC analyzer 260 and quantizes the LPC coefficients. The purpose of LSF quantization, which may be any known method of quantization including scalar or vector quantization, is to represent the coefficients with fewer bits. In this particular embodiment, LSF quantizer 267 quantizes the tenth order LPC model. The LSF quantizer 267 may also smooth out the LSFs in order to reduce undesired fluctuations in the spectral envelope of the LPC synthesis filter. The LSF quantizer 267 sends the quantized coefficients Aq (z) 268 to the subframe processing portion 250 of the speech encoder. The subframe processing portion of the speech encoder is mode dependent. Though LSF is preferred, the quantizer 267 can quantize the LPC coefficients into a domain other than the LSF domain.
If pitch pre-processing is selected, the weighted speech signal 256 is sent to the pitch preprocessor 254. The pitch preprocessor 254 cooperates with the open loop pitch estimator 272 in order to modify the weighted speech 256 so that its pitch information can be more accurately quantized. The pitch preprocessor 254 may, for example, use known compression or dilation techniques on pitch cycles in order to improve the speech encoder's ability to quantize the pitch gains. In other words, the pitch preprocessor 254 modifies the weighted speech signal 256 in order to match better the estimated pitch track and thus more accurately fit the coding model while producing perceptually indistinguishable reproduced speech. If the encoder processing circuitry selects a pitch pre-processing mode, the pitch preprocessor 254 performs pitch pre-processing of the weighted speech signal 256. The pitch preprocessor 254 warps the weighted speech signal 256 to match interpolated pitch values that will be generated by the decoder processing circuitry. When pitch pre-processing is applied, the warped speech signal is referred to as a modified weighted speech signal 258. If pitch pre-processing mode is not selected, the weighted speech signal 256 passes through the pitch pre-processor 254 without pitch pre-processing (and for convenience, is still referred to as the “modified weighted speech signal” 258). The pitch preprocessor 254 may include a waveform interpolator whose function and implementation are known to those of ordinary skill in the art. The waveform interpolator may modify certain irregular transition segments using known forward-backward waveform interpolation techniques in order to enhance the regularities and suppress the irregularities of the speech signal. The pitch gain and pitch correlation for the weighted signal 256 are estimated by the pitch preprocessor 254. The open loop pitch estimator 272 extracts information about the pitch characteristics from the weighted speech 256. The pitch information includes pitch lag and pitch gain information.
The pitch preprocessor 254 also interacts with the classifier 270 through the open-loop pitch estimator 272 to refine the classification by the classifier 270 of the speech signal. Because the pitch preprocessor 254 obtains additional information about the speech signal, the additional information can be used by the classifier 270 in order to fine tune its classification of the speech signal. After performing pitch pre-processing, the pitch preprocessor 254 outputs pitch track information 284 and unquantized pitch gains 286 to the mode-dependent subframe processing portion 250 of the speech encoder.
Once the classifier 270 classifies the pre-processed speech 200 into one of a plurality of possible classes, the classification number of the pre-processed speech signal 200 is sent to the mode selector 274 and to the mode-dependent subframe processor 250 as control information 280. The mode selector 274 uses the classification number to select the mode of operation. In this particular embodiment, the classifier 270 classifies the pre-processed speech signal 200 into one of six possible classes. If the pre-processed speech signal 200 is stationary voiced speech (e.g., referred to as “periodic” speech), the mode selector 274 sets mode 282 to Mode 1. Otherwise, mode selector 274 sets mode 282 to Mode 0. The mode signal 282 is sent to the mode dependent subframe processing portion 250 of the speech encoder. The mode information 282 is added to the bitstream that is transmitted to the decoder.
The labeling of the speech as “periodic” and “non-periodic” should be interpreted with some care in this particular embodiment. For example, the frames encoded using Mode 1 are those maintaining a high pitch correlation and high pitch gain throughout the frame based on the pitch track 284 derived from only seven bits per frame. Consequently, the selection of Mode 0 rather than Mode 1 could be due to an inaccurate representation of the pitch track 284 with only seven bits and not necessarily due to the absence of periodicity. Hence, signals encoded using Mode 0 may very well contain periodicity, though not well represented by only seven bits per frame for the pitch track. Therefore, the Mode 0 encodes the pitch track with seven bits twice per frame for a total of fourteen bits per frame in order to represent the pitch track more properly.
Each of the functional blocks on
The mode-dependent subframe processing portion 250 of the speech encoder operates in two modes of Mode 0 and Mode 1.
The quantized parameters representing the speech signal may be packetized and then transmitted in packets of data from the encoder to the decoder. In the example embodiment described next, the speech signal is analyzed frame by frame, where each frame may have at least one subframe, and each packet of data contains information for one frame. Thus, in this example, the parameter information for each frame is transmitted in a packet of information. In other words, there is one packet for each frame. Of course, other variations are possible and depending on the embodiment, each packet could represent a portion of a frame, more than a frame of speech, or a plurality of frames.
LSF
A LSF (line spectral frequency) is a representation of the LPC spectrum (i.e., the short term envelope of the speech spectrum). LSF's can be regarded as particular frequencies at which the speech spectrum is sampled. If, for example, the system uses a 10th order LPC, there would be 10 LSF's per frame. There must be a minimum spacing between consecutive LSF's so that they do not create quasi-unstable filters. For example, if fi is the ith LSF and equals 100 Hz, the (i+1)st LSF, fI+1 must be at least fi+the minimum spacing. For instance, if fi=100 Hz and the minimum spacing is 60 Hz, fI+1 must be at least 160 Hz and can be any frequency greater than 160 Hz. The minimum spacing is a fixed number that does not vary frame by frame and is known to both the encoder and decoder so that they can cooperate.
Let us assume that the encoder uses predictive coding to code the LSF's (as opposed to non-predictive coding) which is necessary to achieve speech communication at low bit rates. In other words, the encoder uses the quantized LSF of a previous frame or frames to predict the LSF of the current frame. The error between the predicted LSF and the true LSF of the current frame which the encoder derives from the LPC spectrum is quantized and transmitted to the decoder. The decoder determines the predicted LSF of the current frame in the same manner that the encoder did. Then by knowing the error which was transmitted by the encoder, the decoder can calculate the true LSF of the current frame. However, what happens if a frame containing LSF information is lost? Turning to
In an example embodiment of the present invention, an improved speech decoder includes a counter that counts the number of good frames that follow the lost frame.
Adaptive Codebook Excitation (Pitch Lag)
The total excitation eT composed of the adaptive codebook excitation and the fixed codebook excitation is described by the following equation:
eT=gp*exp+gc*exc (27)
where gp and gc are the quantized adaptive codebook gain and fixed codebook gain respectively and exp and exc are the adaptive codebook excitation and fixed codebook excitation. A buffer (also called the adaptive codebook buffer) holds eT and its components from the previous frame. Based on the pitch lag parameter in the current frame, the speech communication system selects an eT from the buffer and uses it as exp for the current frame. The values for gp, gc and exc are obtained from the current frame. The exp, gp, gc and exc are then plugged into the formula to calculate an eT for the current frame. The calculated eT and its components are stored for the current frame in the buffer. The process repeats whereby the buffered eT is then used as exp for the next frame. Thus, the feedback nature of this encoding approach (which is replicated by the decoder) is apparent. Because the information in the equation are quantized, the encoder and decoder are synchronized. Note that the buffer is a type of an adaptive codebook (but is different than the adaptive codebook used for gain excitations).
In trying to resolve the first problem, some prior art systems use the pitch lag L1 from the previous good frame 1 as an estimated pitch lag L2′ for the lost frame 2, even though any difference between the estimated pitch lag L2′ and the true pitch lag L2 would be an error.
The second problem is how to prevent the error in estimated pitch lag L2′ from creating errors in subsequent frames. Recall that, as previously discussed, the pitch lag of frame n is used to update the adaptive codebook buffer which in turn is used by subsequent frames. The error between estimated pitch lag L2′ and the true pitch lag L2 would create an error in the adaptive codebook buffer which would then create an error in the subsequently received frames. In other words, the error in the estimated pitch lag L2′ may result in the loss of synchronicity between the adaptive codebook buffer from the encoder's point of view and the adaptive codebook buffer from the decoder's point of view. As a further example, during processing of current lost frame 2, the prior art decoder would use estimate pitch lag L2′ to be pitch lag L1 (which probably differs from true pitch lag L2) to retrieve exp for frame 2. The use of an erroneous pitch lag therefore selects the wrong exp for the frame 2, and this error propagates through the subsequent frames. To resolve this problem in the prior art, when frame 3 is received by the decoder, the decoder now has pitch lag L3 and delta (L3−L2) and can thus reverse calculate what true pitch lag L2 should have been. The true pitch lag L2 is simply pitch lag L3 minus the delta (L3−L2). Thus, the prior art decoder could correct the adaptive codebook buffer that is used by frame 3. Because the lost frame 2 has already been processed with the estimated pitch lag L2′, it is too late to fix lost frame 2.
To solve the second problem, when the improved decoder receives frame 3, the decoder has the correct pitch lag L3. However, as explained above, the adaptive codebook buffer used by frame 3 may be incorrect due to any extrapolation error in estimating pitch lag L2′. The improved decoder seeks to correct errors in estimating pitch lag L2′ in frame 2 from affecting frames after frame 2, but without having to transmit delta pitch lag information. Once the improved decoder obtains pitch lag L3, it uses an interpolation method such as a curve fitting method to adjust or fine tune its prior estimation of pitch lag L2′. By knowing pitch lags L1 and L3, the curve fitting method can estimate L2′ more accurately than when pitch lag L3 was unknown. The result is a fine tuned pitch lag L2″ which is used to adjust or correct the adaptive codebook buffer for use by frame 3. More particularly, the fine tuned pitch lag L2″ is used to adjust or correct the quantized adaptive codebook excitation in the adaptive codebook buffer. Consequently, the improved decoder reduces the number of bits that must be transmitted while fine tuning pitch lag L2′ in a manner which is satisfactory for most cases. Thus, in order to reduce the affect of any error in the estimation of pitch lag L2 on the subsequently received frames, the improved decoder may use the pitch lag L3 of the next frame 3 and the pitch lag L1 of the previously received frame 1 to fine tune the previous estimation of the pitch lag L2 by assuming a smooth pitch contour. The accuracy of this estimation approach based on the pitch lags of the received frames preceding and succeeding the lost frame may be very good because pitch contours are generally smooth for voiced speech.
Gains
During the transmission of frames from the encoder to the decoder, a lost frame also results in lost gain parameters such as the adaptive codebook gain gp and fixed codebook gain gc. Each frame contains a plurality of subframes where each subframe has gain information. Thus, the loss of a frame results in lost gain information for each subframe of the frame. Speech communication systems have to estimate gain information for each subframe of the lost frame. The gain information for one subframe may differ from that of another subframe.
Prior art systems took various approaches to estimate the gains for subframes of the lost frame such as by using the gain from the last subframe of the previous good frame as the gains of each subframe of the lost frame. Another variation was to use the gain from the last subframe of the previous good frame as the gain of the first subframe of the lost frame and to attenuate this gain gradually before it is used as the gains of the next subframes of the lost frame. In other words, for example, if each frame has four subframes and frame 1 is received but frame 2 is lost, the gain parameters in the last subframe of received frame 1 are used as the gain parameters of the first subframe of lost frame 2, the gain parameters are then decreased by some amount and used as the gain parameters of the second subframe of lost frame 2, the gain parameters are decreased again and used as the gain parameters of the third subframe of lost frame 2, and the gain parameters are decreased still further and used as the gain parameters of the last subframe of lost frame 2. Still another approach was to examine the gain parameters of the subframes of a fixed number of previously received frames to calculate average gain parameters which are then used as the gain parameters of the first subframe of lost frame 2 where the gain parameters could be decreased gradually and used as the gain parameters of the remaining subframes of the lost frame. Yet another approach was to derive median gain parameters by examining the subframes of a fixed number of previously received frames and using the median values as the gain parameters of the first subframe of lost frame 2 where the gain parameters could be decreased gradually and used as the gain parameters of the remaining subframes of the lost frame. Notably, the prior art approaches did not perform different recovery methods to the adaptive codebook gains and the fixed codebook gains; they used the same recovery method on both types of gain.
The improved speech communication system may also handle lost gain parameters due to a lost frame. If the speech communication system differentiates between periodic-like speech and non-periodic like speech, the system may handle lost gain parameters differently for each type of speech. Moreover, the improved system handles lost adaptive codebook gains differently than it handles lost fixed codebook gains. Let us first examine the case of non-periodic like speech. To determine an estimated adaptive codebook gain gp, the improved decoder computes an average gp of the subframes of an adaptive number of previously received frames. The pitch lag of the current frame (i.e., the lost frame), which was estimated by the decoder, is used to determine the number of previously received frames to examine. Generally, the larger the pitch lag, the greater the number of previously received frames to use to calculate an average gp. Therefore, the improved decoder uses a pitch synchronized averaging approach to estimate the adaptive codebook gain gp for non-periodic like speech. The improved decoder then calculates a beta β which indicates how good the prediction of gp was, based on the following formula:
β=adaptive codebook excitation energy/total excitation energy eT=∥gp*exp∥2/(∥gp*exp∥2+∥gc*exc∥2) (28)
β varies from 0 to 1 and represents the percentage effect of the adaptive codebook excitation energy on the total excitation energy. The greater the β, the greater the effect of the adaptive codebook excitation energy. Although unnecessary, the improved decoder preferably treats nonperiodic-like speech and periodic-like speech differently.
Otherwise, if the maximum β does not exceed a certain threshold (i.e., a previously received frame contains the onset of speech), step 1010 sets the gp of the current subframe of the lost frame to be the minimum of (I) the average gp determined above and (ii) the arbitrarily selected high number (e.g., 0.95). Another alternative is to set the gp of the current subframe of the lost frame based on the spectral tilt of the previously received frame, the energy of the previously received frame, and the minimum of the average gp determined above and the arbitrarily selected high number (e.g., 0.95). In the case where the maximum β does not exceed a certain threshold, the fixed codebook gain gc is based on the energy of the gain scaled fixed codebook excitation in the previous subframe and the energy of the fixed codebook excitation in the current subframe. Specifically, the energy of the gain scaled fixed codebook excitation in the previous subframe is divided by the energy of the fixed codebook excitation in the current subframe, the result is square rooted and multiplied by an attenuation fraction and set to be gc, as shown in the following formula:
gc=attenuation factor*square root (∥gc*exc∥i−12/∥exc∥i2) (29)
Alternatively, the decoder may derive the gc for the current subframe of the lost frame to be based on the ratio of the energy of the previously received frame to the energy of the current lost frame.
Returning to step 1002, if the current subframe is not the 1st subframe, step 1020 sets the gp of the current subframe of the lost frame to a value that is attenuated or reduced from the gp of the previous subframe. Each gp of the remaining subframes are set to a value further attenuated from the gp of the previous subframe. The gc of the current subframe is calculated in the same manner as it was in step 1010 and formula 29.
Returning to step 1000, if this is not the first lost frame after a good frame, step 1022 calculates the gc of the current subframe in the same manner as it was in step 1010 and formula 29. Step 1022 also sets the gp of the current subframe of the lost frame to a value that is attenuated or reduced from the gp of the previous subframe. Because the decoder estimates the gp and gc differently, the decoder may estimate them more accurately than the prior art systems.
Now let us examine the case of periodic-like speech in accordance with the example flowchart illustrated in
After the decoder estimates the lost parameters (e.g., LSF, pitch lags, gains, classification, etc) in a lost frame and synthesizes the resultant speech, the decoder can match the energy of the synthesized speech of the lost frame with the energy of the previously received frame through extrapolation techniques. This may further improve the accuracy of reproduction of the original speech despite lost frames.
Seed for Generating Fixed Codebook Excitations
In order to save bandwidth, a speech encoder need not transmit a fixed codebook excitation to the decoder during periods of background noise or silence. Instead, both the encoder and decoder can randomly generate an excitation value locally by using a Gaussian time series generator. Both the encoder and decoder are configured to generate the same random excitation value in the same order. As a result, because the decoder can locally generate the same random excitation value that the encoder generated for a given noise frame, the excitation value need not be transmitted from the encoder to the decoder. To generate a random excitation value, the Gaussian time series generator uses an initial seed to generate the first random excitation value and then the generator updates the seed to a new value. Then the generator uses the updated seed to generate the next random excitation value and updates the seed to yet another value.
The improved speech communication system built in accordance with the present invention does not use an initial fixed seed and then update that seed every time the system encounters a noise frame. Instead, the improved encoder and decoder derives the seed for a given frame from parameters in that frame. For example, the spectrum information, energy and/or gain information in the current frame could be used to generate the seed for that frame. For example, one could use the bits representing the spectrum (say 5 bits b1, b2, b3, b4, b5) and the bits representing the energy (say, 3 bits c1, c2, c3) to form a string b1, b2, b3, b4, b5, c1, c2, c3 whose value is the seed. As a numeric example, suppose that the spectrum is represented by 01101 and the energy is represented by 011, then the seed is 01101011. Certainly, other alternative methods of deriving a seed from information in the frame are possible and included within the scope of the invention. Consequently, in the example of
While embodiments and implementations of the subject invention have been shown and described, it should be apparent that many more embodiments and implementations are within the scope of the subject invention. Accordingly, the invention is not to be restricted, except in light of the claims and their equivalents.
Number | Name | Date | Kind |
---|---|---|---|
5699478 | Nahumi | Dec 1997 | A |
5778338 | Jacobs et al. | Jul 1998 | A |
6085158 | Naka | Jul 2000 | A |
6240386 | Thyssen et al. | May 2001 | B1 |
6385578 | Lee et al. | May 2002 | B1 |
6636829 | Benyassine et al. | Oct 2003 | B1 |
Number | Date | Country |
---|---|---|
0 852 376 | Jul 1998 | EP |
0 883 107 | Dec 1998 | EP |