Methods and devices for source controlled variable bit-rate wideband speech coding

Abstract
Speech signal classification and encoding systems and methods are disclosed herein. The signal classification is done in three steps each of them discriminating a specific signal class. First, a voice activity detector (VAD) discriminates between active and inactive speech frames. If an inactive speech frame is detected (background noise signal) then the classification chain ends and the frame is encoded with comfort noise generation (CNG). If an active speech frame is detected, the frame is subjected to a second classifier dedicated to discriminate unvoiced frames. If the classifier classifies the frame as unvoiced speech signal, the classification chain ends, and the frame is encoded using a coding method optimized for unvoiced signals. Otherwise, the speech frame is passed through to the “stable voiced” classification module. If the frame is classified as stable voiced frame, then the frame is encoded using a coding method optimized for stable voiced signals. Otherwise, the frame is likely to contain a non-stationary speech segment such as a voiced onset or rapidly evolving voiced speech signal. In this case a general-purpose speech coder is used at a high bit rate for sustaining good subjective quality.
Description
FIELD OF THE INVENTION

The present invention relates to digital encoding of sound signals, in particular but not exclusively a speech signal, in view of transmitting and synthesizing this sound signal. In particular, the present invention relates to signal classification and rate selection methods for variable bit-rate (VBR) speech coding.


BACKGROUND OF THE INVENTION

Demand for efficient digital narrowband and wideband speech coding techniques with a good trade-off between the subjective quality and bit rate is increasing in various application areas such as teleconferencing, multimedia, and wireless communications. Until recently, telephone bandwidth constrained into a range of 200-3400 Hz has mainly been used in speech coding applications. However, wideband speech applications provide increased intelligibility and naturalness in communication compared to the conventional telephone bandwidth. A bandwidth in the range 50-7000 Hz has been found sufficient for delivering a good quality giving an impression of face-to-face communication. For general audio signals, this bandwidth gives an acceptable subjective quality, but is still lower than the quality of FM radio or CD that operate on ranges of 20-16000 Hz and 20-20000 Hz, respectively.


A speech encoder converts a speech signal into a digital bit stream, 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.


Code-Excited Linear Prediction (CELP) coding is a well-known technique allowing achieving a good compromise between the subjective quality and bit rate. This coding technique is a 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 L samples usually called frames, where L is a predetermined number corresponding typically to 10-30 ms. A linear prediction (LP) filter is computed and transmitted every frame. The computation of the LP filter typically needs a lookahead, a 5-15 ms speech segment from the subsequent frame. The L-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 the LP filter.


In wireless systems using code division multiple access (CDMA) technology, the use of source-controlled variable bit rate (VBR) speech coding significantly improves the system capacity. In source-controlled VBR coding, the codec 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 (e.g. voiced, unvoiced, transient, background noise). The goal is to attain the best speech quality at a given average bit rate, also referred to as average data rate (ADR). The codec can operate at different modes by tuning the rate selection module to attain different ADRs at the different modes where the codec performance is improved at increased ADRs. The mode of operation is imposed by the system depending on channel conditions. This enables the codec with a mechanism of trade-off between speech quality and system capacity.


Typically, in VBR coding for CDMA systems, an eighth-rate is used for encoding frames without speech activity (silence or noise-only frames). When the frame is stationary voiced or stationary unvoiced, half-rate or quarter-rate are used depending on the operating mode. If half-rate can be used, a CELP model without the pitch codebook is used in unvoiced case and a signal modification is used to enhance the periodicity and reduce the number of bits for the pitch indices in voiced case. If the operating mode imposes a quarter-rate, no waveform matching is usually possible as the number of bits is insufficient and some parametric coding is generally applied. Full-rate is used for onsets, transient frames, and mixed voiced frames (a typical CELP model is usually used). In addition to the source controlled codec operation in CDMA systems, the system can limit the maximum bit-rate in some speech frames in order to send in-band signalling information (called dim-and-burst signalling) or during bad channel conditions (such as near the cell boundaries) in order to improve the codec robustness. This is referred to as half-rate max. When the rate-selection module chooses the frame to be encoded as a full-rate frame and the system imposes for example HR frame, the speech performance is degraded since the dedicated HR modes are not capable of efficiently encoding onsets and transient signals. Another HR (or quarter-rate (QR)) coding model can be provided to cope with these special cases.


As can be seen from the above description, signal classification and rate determination are very essential for efficient VBR coding. Rate selection is the key part for attaining the lowest average data rate with the best possible quality.


OBJECTS OF THE INVENTION

An object of the present invention is to provide an improved signal classification and rate selection methods for a variable-rate wideband speech coding in general; and in particular to provide an improved signal classification and rate selection methods for a variable-rate multi-mode wideband speech coding suitable for CDMA systems.


SUMMARY OF THE INVENTION

The use of source-controlled VBR speech coding significantly improves the capacity of many communications systems, especially wireless systems using CDMA technology. In source-controlled VBR coding, the codec can operate 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 (e.g. voiced, unvoiced, transient, background noise). The goal is to attain the best speech quality at a given average data rate. The codec can operate at different modes by tuning the rate selection module to attain different ADRs at the different modes where the codec performance is improved at increased ADRs. In some systems, the mode of operation is imposed by the system depending on channel conditions. This enables the codec with a mechanism of trade-off between speech quality and system capacity.


A signal classifications algorithm analyzes the input speech signal and classifies each speech frame into one of a set of predetermined classes (e.g. background noise, voiced, unvoiced, mixed voiced, transient, etc.). The rate selection algorithm decides what bit rate and what coding model to be used based on the class of the speech frame and desired. average data rate.


In multi-mode VBR coding, different operating modes corresponding to different average data rates are obtained by defining the percentage of usage of individual bit rates. Thus, the rate selection algorithm decides the bit rate to be used for a certain speech frame based on the nature of speech frame (classification information) and the required average data rate.


In some embodiments, three operating modes are considered. Premium, Standard and Economy modes as discussed in 3GPP2 C.S0030-0, “Selectable Mode Vocoder Service Option for Wideband Spread Spectrum Communication Systems”, 3GPP2 Technical Specification. The Premium mode insures the highest achievable quality using the highest ADR. The Economy mode maximizes the system capacity by using the lowest ADR still allowing for a high quality wideband speech. The Standard mode is a compromise between the system capacity and the speech quality and it uses an ADR between the ADRs of the Premium and the Economy modes.


The multi-mode variable bit rate wideband codec provided to operate in CDMA-one and CDMA2000 systems will be referred to herein as VMR-WB codec.


More specifically, in accordance with a first aspect of the present invention, there is provided a method for digitally encoding a sound comprising:

    • i) providing a signal frame from a sampled version of the sound;
    • ii) determining whether the signal frame is an active speech frame or an inactive speech frame;
    • iii) if the signal frame is an inactive speech frame then encoding the signal frame with background noise low bit-rate coding algorithm;
    • iv) if the signal frame is an active speech frame, determining whether the active speech frame is an unvoiced frame or not;
    • v) if the signal frame is an unvoiced frame then encoding the signal frame using an unvoiced signal coding algorithm; and
    • vi) if the signal frame is not an unvoiced frame then determining whether the signal frame is a stable voiced frame or not;
    • vii) if the signal frame is a stable voiced frame then encoding the signal frame using a stable voiced signal coding algorithm;
    • viii) if the signal frame is not an unvoiced frame and the signal frame is not a stabled voiced frame then encoding the signal frame using a generic signal coding algorithm.


In accordance to a second aspect of the present invention there is also provided a method for digitally encoding a sound comprising:

    • i) providing a signal frame from a sampled version of the sound;
    • ii) determining whether the signal frame is an active speech frame or an inactive speech frame;
    • iii) if the signal frame is an inactive speech frame then encoding the signal frame with background noise low bit-rate coding algorithm;
    • iv) if the signal frame is an active speech frame, determining whether the active speech frame is an unvoiced frame or not;
    • v) if the signal frame is an unvoiced frame then encoding the signal frame using an unvoiced signal coding algorithm; and
    • vi) if the signal frame is not an unvoiced frame then encoding the signal frame with a generic speech coding algorithm.


A method for classification of unvoiced signals where at least three of the following parameters are used to classify unvoiced frame is provided according to a third aspect of the present invention:

    • a) a voicing measure ({overscore (r)}x);
    • b) a spectral tilt measure (et);
    • c) an energy variation within the signal frame (dE); and a relative energy of the signal frame (Erel).


Methods according to the present invention allows VBR codecs capable of operating efficiently within wireless systems based on code division multiple access (CDMA) technology as well as IP-based systems.


Finally, in accordance to a fourth aspect of the present invention, there is provided a device for encoding a sound signal comprising:

    • a speech encoder for receiving a digitized sound signal representative of the sound signal; the digitized sound signal including at least one signal frame; the speech encoder including:
    • a first-level classifier for discriminating between active and inactive speech frames;
    • a comfort noise generator for encoding inactive speech frames;
    • a second-level classifier for discriminating between voiced and unvoiced frames;
    • an unvoiced speech encoder;
    • a third-level classifier for discriminating between stable and unstable voiced frames;
    • a voiced speech optimized encoder; and
    • a generic speech encoder;
    • the speech encoder being configured for outputting a binary representation of coding parameters.


The foregoing and other objects, advantages and features of the present invention will become more apparent upon reading the following non restrictive description of illustrative embodiments thereof, given by way of example only with reference to the accompanying drawings.




BRIEF DESCRIPTION OF THE DRAWINGS

In the appended drawings:



FIG. 1 is a block diagram of a speech communication system illustrating the use of speech encoding and decoding devices in accordance with a first aspect of the present invention;



FIG. 2 is a flowchart illustrating a method for digitally encoding a sound signal according to a first illustrative embodiment of a second aspect of the present invention;



FIG. 3 is a flowchart illustrating a method for discriminating unvoiced frame according to an illustrative embodiment of a third aspect of the present invention;



FIG. 4 is a flowchart illustrating a method for discriminating stable voiced frame according to an illustrative embodiment of a fourth aspect of the present invention;



FIG. 5 is a flowchart illustrating a method for digitally encoding a sound signal in the Premium mode according to a second illustrative embodiment of the second aspect of the present invention;



FIG. 6 is a flowchart illustrating a method for digitally encoding a sound signal in the Standard mode according to a third illustrative embodiment of the second aspect of the present invention;



FIG. 7 is a flowchart illustrating a method for digitally encoding a sound signal in the Economy mode according to a fourth illustrative embodiment of the second aspect of the present invention;



FIG. 8 is a flowchart illustrating a method for digitally encoding a sound signal in the Interoperable mode according to a fifth illustrative embodiment of the second aspect of the present invention;



FIG. 9 is a flowchart illustrating a method for digitally encoding a sound signal in the Premium or Standard mode during half-rate max according to a sixth illustrative embodiment of the second aspect of the present invention;



FIG. 10 is a flowchart illustrating a method for digitally encoding a sound signal in the Economy mode during half-rate max according to a seventh illustrative embodiment of the second aspect of the present invention;



FIG. 11 is a flowchart illustrating a method for digitally encoding a sound signal in the Interoperable mode during half-rate max according to a eighth illustrative embodiment of the second aspect of the present invention; and



FIG. 12 is a flowchart illustrating a method for digitally encoding a sound signal so as to allow interoperation between VMR-WB and AMR-WB codecs, according to an illustrative embodiment of a fifth aspect of the present invention.




DETAILED DESCRIPTION OF THE INVENTION

Turning now to FIG. 1 of the appended drawings, a speech communication system 10 depicting the use of speech encoding and decoding in accordance with an illustrative embodiment of the first aspect of the present invention is illustrated. The speech communication system 10 supports transmission and reproduction of a speech signal across a communication channel 12. The communication channel 12 may comprise for example a wire, optical or fibre link, or a radio frequency link. The communication channel 12 can be also a combination of different transmission media, for example in part fibre link and in part a radio frequency link. The radio frequency link may allow to support multiple, simultaneous speech communications requiring shared bandwidth resources such as may be found in cellular telephony. Alternatively, the communication channel may be replaced by a storage device (not shown) in a single device embodiment of the communication system that records and stores the encoded speech signal for later playback.


The communication system 10 includes an encoder device comprised of a microphone 14, an analog-to-digital converter 16, a speech encoder 18, and a channel encoder 20 on the emitter side of the communication channel 12, and a channel decoder 22, a speech decoder 24, a digital-to-analog converter 26 and a loudspeaker 28 on the receiver side.


The microphone 14 produces an analog speech signal that is conducted to an analog-to-digital (A/D) converter 16 for converting it into a digital form. A speech encoder 18 encodes the digitized speech signal producing a set of parameters that are coded into a binary form and delivered to a channel encoder 20. The optional channel encoder 20 adds redundancy to the binary representation of the coding parameters before transmitting them over the communication channel 12. Also, in some applications such packet-network applications, the encoded frames are packetized before transmission.


In the receiver side, a channel decoder 22 utilizes the redundant information in the received bitstream to detect and correct channel errors occurred in the transmission. A speech decoder 24 converts the bitstream received from the channel decoder 20 back to a set of coding parameters for creating a synthesized speech signal. The synthesized speech signal reconstructed at the speech decoder 24 is converted to an analog form in a digital-to-analog (D/A) converter 26 and played back in a loudspeaker unit 28.


The microphone 14 and/or the A/D converter 16 may be replaced in some embodiments by other speech sources for the speech encoder 18.


The encoder 20 and decoder 22 are configured so as to embody a method for encoding a speech signal according to the present invention as described hereinbelow.


Signal Classification


Turning now to FIG. 2, a method 100 for digitally encoding a speech signal according to a first illustrative embodiment of a first aspect of the present invention is illustrated. The method 100 includes a speech signal classification method according to an illustrative embodiment of a second aspect of the present invention. It is to be noted that the expression speech signal refers to voice signals as well as any multimedia signal that may include a voice portion such as audio with speech content (speech in between music, speech with background music, speech with special sound effects, etc.)


As illustrated in FIG. 2, the signal classification is done in three steps 102, 106 and 110, each of them discriminating a specific signal class. First, in step 102, a first-level classifier in the form of a voice activity detector (VAD) (not shown) discriminates between active and inactive speech frames. If an inactive speech frame is detected then the encoding method 100 ends with the encoding of the current frame with, for example, comfort noise generation (CNG) (step 104). If an active speech frame is detected in step 102, the frame is subjected to a second level classifier (not shown) configured to discriminate unvoiced frames. In step 106, if the classifier classifies the frame as unvoiced speech signal, the encoding method 100 ends in step 108, where the frame is encoded using a coding technique optimized for unvoiced signals. Otherwise, the speech frame is passed in step 110, through a third-level classifier (not shown) in the form of a “stable voiced” classification module (not shown). If the current frame is classified as a stable voiced frame, then the frame is encoded using a coding technique optimized for stable voiced signals (step 112). Otherwise, the frame is likely to contain a non-stationary speech segment such as a voiced onset or rapidly evolving voiced speech signal portion, and the frame is encoded using a general purpose speech coder with high bit rate allowing to sustain good subjective quality (step 114). Note that if the relative energy of the frame is lower than a certain threshold then these frames can be encoded with a generic lower rate coding type to further reduce the average data rate.


The classifiers and encoders may take many forms from an electronic circuitry to a chip processor.


In the following, the classification of different types of speech signal will be explained in more details, and methods for classification of unvoiced and voiced speech will be disclosed.


Discrimination of Inactive Speech Frames (VAD)


The inactive speech frames are discriminated in step 102 using a Voice Activity Detector (VAD). The VAD design is well-known to a person skilled in the art and will not be described herein in more detail. An example of VAD is described in M. Jelinek and F. Labonte, “Robust Signal/Noise Discrimination for Wideband Speech and Audio Coding,” Proc. IEEE Workshop on Speech Coding, pp. 151-153, Delavan, Wis., USA, September 2000.


Discrimination of Unvoiced Active Speech Frames


The unvoiced parts of a speech signal are characterized by missing periodicity and can be further divided into unstable frames, where the energy and the spectrum changes rapidly, and stable frames where these characteristics remain relatively stable.


In step 106, unvoiced frames are discriminated using at least three out of the following parameters:

    • A voicing measure, which may be computed as an averaged normalized correlation ({overscore (r)}x);
    • a spectral tilt measure (et);
    • a signal energy ratio (dE) used to assess the frame energy variation within the frame and thus the frame stability; and
    • the relative energy of the frame.


      Voicing Measure



FIG. 3 illustrates a method 200 for discriminating unvoiced frame according to an illustrative embodiment of a third aspect of the present invention.


The normalized correlation, used to determine the voicing measure, is computed as part of the open-loop pitch search module 214. In the illustrative embodiment of FIG. 3, 20 ms frames are used. The open-loop pitch search module usually outputs the open-loop pitch estimate p every 10 ms (twice per frame). In the method 200, it is also used to output the normalized correlation measures rx. These normalized correlations are computed on the weighted speech and the past weighted speech at the open-loop pitch delay. The weighted speech signal sw(n) is computed in a perceptual weighting filter 212. In this illustrative embodiment, a perceptual weighting filter 212 with fixed denominator, suited for wideband signals, is used. The following relation gives an example of transfer function for the perceptual weighting filter 212:

W(z)=A(z/γ1)/(1−γ2z−1) where 0<γ21≦1

where A(z) is the transfer function of the linear prediction (LP) filter computed in module 218, which is given by the following relation:
A(z)=1+i=1paiz-i


The voicing measure is given by the average correlation {overscore (r)}x which is defined as
r_x=13(rx(0)+rx(1)+rx(2))(1)

where rx(0), rx(1) and rx(2) are respectively the normalized correlation of the first half of the current frame, the normalized correlation of the second half of the current frame, and the normalized correlation of the look-ahead (beginning of next frame).


A noise correction factor re can be added to the normalized correlation in Equation (1) to account for the presence of background noise. In the presence of background noise, the average normalized correlation decreases. However, for the purpose of signal classification, this decrease should not affect the voiced-unvoiced decision, so this is compensated by the addition of re. It should be noted that when a good noise reduction algorithm is used re is practically zero.


In the method 200, a look-ahead of 13 ms is used. The normalized correlation rx(k) is computed as follows
rx(k)=rxyrxx·ryy,whererxy=i=0Lk-1x(tk+i)·x(tk+i-pk)rxx=i=0Lk-1x2(tk+i)ryy=i=0Lk-1x2(tk+i-pk)(2)


In the method 200, the computation of the correlations is as follows. The correlations rx(k) are computed on the weighted speech signal sw(n). The instants tk are related to the current half-frame beginning and are equal to 0, 128 and 256 samples respectively for k=0, 1 and 2, at 12800 Hz sampling rate. The values pk=TOL are the selected open-loop pitch estimates for the half-frames. The length of the autocorrelation computation Lk is dependant on the pitch period. In a first embodiment, the values of Lk are summarized below (for the 12.8 kHz sampling rate):

Lk=80 samples for pk≦62 samples
Lk=124 samples for 62<pk≦122 samples
Lk=230 samples for Pk>122 samples

These lengths assure that the correlated vector length comprises at least one pitch period, which helps for a robust open loop pitch detection. For long pitch periods (p1>122 samples), rx(1) and rx(2) are identical, i.e. only one correlation is computed since the correlated vectors are long enough that the analysis on the look ahead is no longer necessary.


Alternatively, the weighted speech signal can be decimated by 2 to simplify the open loop pitch search. The weighted speech signal can be low-pass filtered before decimation. In this case, the values of Lk are given by

Lk=40 samples for pk≦31 samples
Lk=62 samples for 62 <Pk≦61 samples
Lk=115 samples for pk>samples

Other methods can be used to compute the correlations. For example, only one normalized correlation value can be computed for the whole frame instead of averaging several normalized correlations. Further, the correlations can be computed on signals other than the weighted speech such as the residual signal, the speech signal, or a low-pass filtered residual, speech, or weighted speech signal.


Spectral Tilt


The spectral tilt parameter contains the information about the frequency distribution of energy. In method 200, the spectral tilt is estimated in the frequency domain as a ratio between the energy concentrated in low frequencies and the energy concentrated in high frequencies. However, it can be also estimated in different ways such as a ratio between the two first autocorrelation coefficients of the speech signal.


In the method 200, the discrete Fourier Transform is used to perform the spectral analysis in module 210 of FIG. 10. The frequency analysis and the tilt computation are done twice per frame. 256 points Fast Fourier Transform (FFT) is used with 50 percent overlap. The analysis windows are placed so that the entire lookahead is exploited. The beginning of the first window is placed 24 samples after the beginning of the current frame. The second window is placed 128 samples further. Different windows can be used to weight the input signal for the frequency analysis. A square root of a Hamming window (which is equivalent to a sine window) is used. This window is particularly well suited for overlap-add methods, therefore this particular spectral analysis can be used in an optional noise suppression algorithm based on spectral subtraction and overlap-add analysis/synthesis. Since noise suppression algorithms are believed to be well-known in the art, it will not be described herein in more detail.


The energy in high frequencies and in low frequencies is computed following the perceptual critical bands, see J. D. Johnston, “Transform Coding of Audio Signals Using Perceptual Noise Criteria,” IEEE Jour. on Selected Areas in Communications, vol. 6, no.2, pp. 314-323:


Critical bands={100.0, 200.0, 300.0, 400.0, 510.0, 630.0, 770.0, 920.0, 1080.0, 1270.0, 1480.0, 1720.0, 2000.0, 2320.0, 2700.0, 3150.0, 3700.0, 4400.0, 5300.0, 6350.0} Hz.


The energy in high frequencies is computed as the average of the energies of the last two critical bands

{overscore (E)}h=0.5(ECB(18)+ECB(19))

where ECB(i) are the average energies per critical band computed as
ECB(i)=1NCB(i)k=0NCB(i)-1(XR2(k+ji)+XI2(k+ji)),i=0,,19

where NCB(i) is the number of frequency bins in the ith band and XR(k) and Xl(k) are, respectively, the real and imaginary parts of the kth frequency bin and ji is the index of the first bin in the ith critical band.


The energy in low frequencies is computed as the average of the energies in the first 10 critical bands. The middle critical bands have been excluded from the computation to improve the discrimination between frames with high-energy concentration in low frequencies (generally voiced) and with high-energy concentration in high frequencies (generally unvoiced). In between, the energy content is not characteristic for any of the classes and increases the decision confusion.


The energy in low frequencies is computed differently for long pitch periods and short pitch periods. For voiced female speech segments, the harmonic structure of the spectrum is exploited to increase the voiced-unvoiced discrimination. Thus for short pitch periods, El is computed bin-wise and only frequency bins sufficiently close to the speech harmonics are taken into account in the summation. That is
E_l=1cntk=024EBIN(k)wh(k)

where EBIN(k) are the bin energies in the first 25 frequency bins (the DC component is not considered). Note that these 25 bins correspond to the first 10 critical bands. In the summation above, only terms related to the bins close to the pitch harmonics are considered, so wh(k) is set to 1 if the distance between the bin and the nearest harmonic is not larger than a certain frequency threshold (50 Hz) and is set to 0 otherwise. The counter cnt is the number of the non-zero terms in the summation. Only bins closer than 50 Hz to the nearest harmonics are taken into account. Hence, if the structure is harmonic in low frequencies, only high-energy terms will be included in the sum. On the other hand, if the structure is not harmonic, the selection of the terms will be random and the sum will be smaller. Thus even unvoiced sounds with high energy content in low frequencies can be detected. This processing cannot be done for longer pitch periods, as the frequency resolution is not sufficient. For pitch values larger than 128 or for a priori unvoiced sounds the low frequency energy is computed per critical band as
E_l=110k=09ECB(k)


A priori unvoiced sounds are determined when rx(0)+rx(1)+re<0.6, where the value re is a correction added to the normalized correlation as described above.


The resulting low and high frequency energies are obtained by subtracting estimated noise energy from the values {overscore (E)}l and {overscore (E)}h calculated above. That is

Eh={overscore (E)}h−Nh
El={overscore (E)}l−Nl

where Nh and Nl are the averaged noise energies in the last 2 critical bands and first 10 critical bands respectively. The estimated noise energies have been added to the tilt computation to account for the presence of background noise.


Finally, the spectral tilt is given by
etilt(i)=ElEh


Note that the spectral tilt computation is performed twice per frame to obtain etilt(0) and etilt(1) corresponding to both spectral analysis per frame. The average spectral tilt used in unvoiced frame classification is given by
et=13(eold+etilt(0)+etilt(1))

where eold is the tilt from the second spectral analysis of the previous frame.


Energy Variation dE


The energy variation dE is evaluated on the denoised speech signal s(n), where n=0 corresponds to the current frame beginning. The signal energy is evaluated twice per subframe, i.e. 8 times per frame, based on short-time segments of length 32 samples. Further, the short-term energies of the last 32 samples from the previous frame and the first 32 samples from next frame are also computed. The short-time maximum energies are computed as
Est(1)(j)=maxi=031(s2(i+32j)),j=-1,,8,

where j=−1 and j=8 correspond to the end of previous frame and the beginning of next frame. Another set of 9 maximum energies is computed by shifting the speech indices by 16 samples. That is
Est(2)(j)=maxi=031(s2(i+32j-16)),j=0,,8.


The maximum energy variation dE between consecutive short term segments is computed as the maximum of the following:
Est(1)(0)/Est(1)(-1)ifEst(1)(0)>Est(-1),Est(1)(7)/Est(1)(8)ifEst(1)(7)>Est(8),max(Est(1)(j),Est(1)(j-1))min(Est(1)(j),Est(1)(j-1))forj=1to7max(Est(2)(j),Est(2)(j-1))min(Est(2)(j),Est(2)(j-1))forj=1to8

Alternatively, other methods can be used to evaluate the energy variation in the frame.


Relative Energy Erel


The relative energy of the frame is given by the difference between the frame energy in dB and the long-term average energy. The frame energy is computed as
Et=10log(i=019ECB(i)),dB

where ECB(i) are the average energies per critical band as described above. The long-term average frame energy is given by

{overscore (E)}f=0.99{overscore (E)}f+0.01Et

with initial value {overscore (E)}f=45 dB.


Thus the relative frame energy is given by

Erel=Et−{overscore (E)}f


The relative frame energy is used to identify low energy frames that have not been classified as background noise frames or unvoiced frames. These frames can be encoded with a generic HR encoder in order to reduce the ADR.


Unvoiced Speech Classification


The classification of unvoiced speech frames is based on the parameters described above, namely: the voicing measure {overscore (r)}x, the spectral tilt et, the energy variation within a frame dE, and the relative frame energy Erel. The decision is made based on at least three of these parameters. The decision thresholds are set based on the operating mode (the required average data rate). Basically for operating modes with lower desired data rates, the thresholds are set to favor more unvoiced classification (since a half-rate or a quarter rate coding will be used to encode the frame). Unvoiced frames are usually encoded with unvoiced HR encoder. However, in case of the economy mode, unvoiced QR may also be used in order to further reduce the ADR if additional certain conditions are satisfied.


In Premium mode, the frame is encoded as unvoiced HR if the following condition is satisfied

({overscore (r)}x<th1) AND (et<th2) AND (dE<th3)

where th1−0.5, th2=1, and
th3={-4forEf>340for21<Ef344otherwise


In voice activity decision, a decision hangover is used. Thus, after active speech periods, when the algorithm decides that the frame is an inactive speech frame, a local VAD is set to zero but the actual VAD flag is set to zero only after a certain number of frames are elapsed (the hangover period). This avoids clipping of speech offsets. In both the Standard and Economy modes, if the local VAD is zero, the frame is classified as an unvoiced frame.


In the Standard mode, the frame is encoded as unvoiced HR if local VAD=0 or if the following condition is satisfied:

({overscore (r)}x<th4) AND (et<th5) AND ((dE<th6) OR (Erel<thl))

where th4=0.695, th5=4, th6=40, and th7=−14.


In Economy mode, the frame is declared as an unvoiced frame if local VAD=0 OR if the following condition is satisfied:

({overscore (r)}x<th8) AND (et<th9) AND ((dE<th10) OR (Erel<th11))

where th8=0.695, th9=4, th10=60, and th11=−14.


In Economy mode, unvoiced frames are usually encoded as unvoiced HR. However, they can also be encoded with unvoiced QR if the following further conditions are also satisfied: If the last frame is either unvoiced of background noise frame, and if at the end of the frame the energy is concentrated in high frequencies and no potential voiced onset is detected in the lookahead then the frame is encoded as unvoiced QR. The last two conditions are detected as:

(rx(2)<th12) AND (etilt(1)<th13) where th12=0.73, th13=3.

Note that rx(2) is the normalized correlation in the lookahead and etilt(1) is the tilt in the second spectral analysis which spans the end of the frame and the lookahead.


Of course, other methods than method 200 can be used for discriminating unvoiced frame.


Discrimination of Stable Voiced Speech Frames


In case of Standard and Economy modes, stable voiced frames can be encoded using Voiced HR coding type.


The Voiced HR coding type makes use of signal modification for efficiently encoding stable voiced frames.


Signal modification techniques adjust the pitch of the signal to a predetermined delay contour. Long term prediction then maps the past excitation signal to the present subframe using this delay contour and scaling by a gain parameter. The delay contour is obtained straightforwardly by interpolating between two open-loop pitch estimates, the first obtained in the previous frame and the second in the current frame. Interpolation gives a delay value for every time instant of the frame. After the delay contour is available, the pitch in the subframe to be coded currently is adjusted to follow this artificial contour by warping, changing the time scale of the signal. In discontinuous warping [1, 4, 5], a signal segment is shifted either to the left or to the right without altering the segment length. Discontinuous warping requires a procedure for handling the resulting overlapping or missing signal portions. For reducing artifacts in these operations, the tolerated change in the time scale is kept small. Moreover, warping is typically done using the LP residual signal or the weighted speech signal to reduce the resulting distortions. The use of these signals instead of the speech signal also facilitates detection of pitch pulses and low-power regions in between them, and thus the determination of the signal segments for warping. The actual modified speech signal is generated by inverse filtering. After the signal modification is done for the present subframe, the coding can proceed in conventional manner except the adaptive codebook excitation is generated using the predetermined delay contour.


In the present illustrative embodiment, signal modification is done pitch and frame synchronously, that is, adapting one pitch cycle segment at a time in the current frame such that a subsequent speech frame starts in perfect time alignment with the original signal. The pitch cycle segments are limited by frame boundaries. This prevents time shift translating over frame boundaries simplifying encoder implementation and reducing a risk of artifacts in the modified speech signal. This also simplifies variable bit rate operation between signal modification enabled and disabled coding types, since every new frame starts in time alignment with the original signal.


As illustrated in FIG. 2, if a frame is not classified as inactive speech frame nor as unvoiced frame then it is tested if it is a stable voiced frame (step 110). Classification of stable voiced frames is performed using a closed-loop approach in conjunction with the signal modification procedure used for encoding stable voiced frames.



FIG. 4 illustrates a method 300 for discriminating stable voiced frame according to an illustrative embodiment of a fourth aspect of the present invention.


The sub-procedures in the signal modification yields indicators quantifying the attainable performance of long term prediction in the current frame. If any of these indicators is outside its allowed limits, the signal modification procedure is terminated by one of the logic blocks. In this case, the original signal is preserved intact, and the frame is not classified as stable voiced frame. This integrated logic allows maximizing the quality of the modified speech signal after signal modification and coding at a low bit rate.


The pitch pulse search procedure of step 302 produces several indicators on the periodicity of the current frame. Hence the logic block following it is an important component of the classification logic. The evolution of the pitch-cycle length is observed. The logic block compares the distance of the detected pitch pulse positions against the interpolated open-loop pitch estimate as well as against the distance of previously detected pitch pulses. The signal modification procedure is terminated if the difference to the open-loop pitch estimate or to the previous pitch cycle lengths is too large.


The selection of the delay contour in step 304 gives additional information on the evolution of the pitch cycles and the periodicity of the current speech frame. The signal modification procedure is continued from this block if the condition |dn−dn−1|<0.2dn is fulfilled, where dn and dn-1 are the pitch delays in the present and past frames. This essentially means that only a small delay change is tolerated for classifying the present frame as stable voiced.


When the frames subjected to the signal modification are coded at a low bit rate, the shape of pitch cycle segments is kept similar over the frame to allow faithful signal modeling by long-term prediction and thus coding at a low bit rate without degrading the subjective quality. In the signal modification step 306, the similarity of successive segments can be quantified by the normalized correlation between the current segment and the target signal at the optimal shift. Shifting of the pitch cycle segments maximizing their correlation with the target signal enhances the periodicity and yields a high long-term prediction gain if the signal modification is useful. The success of the procedure is guaranteed by requiring that all the correlation values must be larger than a predefined threshold. If this condition is not fulfilled for all segments, the signal modification procedure is terminated and the original signal is kept intact. In general, a slightly lower gain threshold range can be allowed on male voices with equal coding performance. Gain thresholds can be changed in different operating modes of the VBR codec to adjust the usage of the coding modes that apply the signal modification and thus change the targeted average bit rate.


As described hereinabove, the complete rate selection logic according to the method 100 comprises three steps, each of them discriminating a specific signal class. One of the steps includes the signal modification algorithm as its integral part. First, a VAD discriminates between active and inactive speech frames. If an inactive speech frame is detected, the classification method ends as the frame is regarded as background noise and encoded, for example, with a comfort noise generator. If an active speech frame is detected, the frame is subjected to the second step dedicated to discriminate unvoiced frames. If the frame is classified as unvoiced speech signal, the classification chain ends, and the frame is encoded with a mode dedicated for unvoiced frames. As the last step, the speech frame is processed through the proposed signal modification procedure that enables the modification if the conditions described earlier in this subsection are verified. In this case, the frame is classified as stable voiced frame, the pitch of the original signal is adjusted to an artificial, well-defined delay contour, and the frame is encoded using a specific mode optimized for these types of frames. Otherwise, the frame is likely to contain a non-stationary speech segment such as a voiced onset or rapidly evolving voiced speech signal. These frames typically require a more generic coding model. These frames are usually encoded with a Generic FR coding type. However, if the relative energy of the frame is lower than a certain threshold then these frames can be encoded with a Generic HR coding type to further reduce the ADR.


Speech Coding and Rate Selection for CDMA Multi-Mode VBR Systems


Methods for rate selection and digital encoding of a sound for CDMA multi-mode VBR systems that can operate in Rate Set II will now be described according to illustrated embodiments of the present invention.


The described codec is based on the adaptive multi-rate wideband (AMR-WB) speech codec that was recently selected by the ITU-T (International Telecommunications Union-Telecommunication Standardization Sector) for several wideband speech services and by 3GPP (third generation partnership project) for GSM and W-CDMA third generation wireless systems. AMR-WB codec consists of nine bit rates, namely 6.6, 8.85, 12.65, 14.25, 15.85, 18.25, 19.85, 23.05, and 23.85 kbit/s. An AMR-WB-based source controlled VBR codec for CDMA system allows enabling the interoperation between CDMA and other systems using the AMR-WB codec. The AMR-WB bit rate of 12.65 kbit/si which is the closest rate that can fit in the 13.3 kbit/s full-rate of Rate Set II can be used as the common rate between a CDMA wideband VBR codec and AMR-WB which will enable the interoperability without the need for transcoding (which degrades the speech quality). Lower rate coding types are provided specifically for the CDMA VBR wideband solution to enable the efficient operation in the Rate Set II framework. The codec then can operate in few CDMA-specific modes using all rates but it will have a mode that enables interoperability with systems using the AMR-WB codec.


The coding methods according to embodiments of the present invention are summarized in Table 1 and will be generally referred to as coding types.

TABLE 1Coding types used in the illustrative embodimentswith corresponding bit rates.Coding TypeBit Rate [kbit/s]Bits/20 ms frameGeneric FR13.3266Interoperable FR13.3266Voiced HR6.2124Unvoiced HR6.2124Interoperable HR6.2124Generic HR6.2124Unvoiced QR2.754CNG QR2.754CNG ER1.020


The full-rate (FR) coding types are based on the AMR-WB standard codec at 12.65 kbit/s. The use of the 12.65 kbit/s rate of the AMR-WB codec enables the design of a variable bit rate codec for the CDMA system capable of interoperating with other systems using the AMR-WB codec standard. Extra 13 bits per frame are added to fit in the 13.3 kbit/s full-rate of CDMA Rate Set II. These bits are used to improve the codec robustness in case of erased frames and make essentially the difference between Generic FR and Interoperable FR coding types (they are unused in the Interoperable FR). The FR coding types are based on the algebraic code-excited linear prediction (ACELP) model optimized for general wideband speech signals. It operates on 20 ms speech frames with a sampling frequency of 16 kHz. Before further processing, the input signal is down-sampled to 12.8 kHz sampling frequency and pre-processed. The LP filter parameters are encoded once per frame using 46 bits. Then the frame is divided into four subframes where adaptive and fixed codebook indices and gains are encoded once per subframe. The fixed codebook is constructed using an algebraic codebook structure where the 64 positions in a subframe are divided into 4 tracks of interleaved positions and where 2 signed pulses are placed in each track. The two pulses per track are encoded using 9 bits giving a total of 36 bits per subframe. More details about the AMR-WB codec can be found in the 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. The bit allocations for the FR coding types are given in Table 2.

TABLE 2Bit allocation of Generic and Interoperable full-rateCDMA2000 Rate Set II based on the AMR-WB standard at 12.65 kbit/s.Bits per FrameGenericInteroperableParameterFRFRClass InfoVAD bit1LP Parameters4646Pitch Delay3030Pitch Filtering44Gains2828Algebraic Codebook144144FER protection bits14Unused bits13Total266266


In case of stable voiced frames, the Half-Rate Voiced coding is used. The half-rate voiced bit allocation is given in Table 3. Since the frames to be coded in this communication mode are characteristically very periodic, a substantially lower bit rate suffices for sustaining good subjective quality compared for instance to transition frames. Signal modification is used which allows efficient coding of the delay information using only nine bits per 20-ms frame saving a considerable proportion of the bit budget for other signal-coding parameters. In signal modification, the signal is forced to follow a certain pitch contour that can be transmitted with 9 bits per frame. Good performance of long-term prediction allows using only 12 bits per 5-ms subframe for the fixed-codebook excitation without sacrificing the subjective speech quality. The fixed-codebook is an algebraic codebook and comprises two tracks with one pulse each, whereas each track has 32 possible positions.

TABLE 3Bit allocation of half-rate Generic, Voiced,Unvoiced according to CDMA2000 Rate Set II.Bits per frameGenericVoicedUnvoicedInteroperableParameterHRHRHRHRClass Info1323VAD bit1LP Parameters36364646Pitch Delay13930Pitch Filtering24Gains26262428Algebraic Codebook484852FER protection bitsUnused bits12Total124124124124


In case of unvoiced frames, the adaptive codebook (or pitch codebook) is not used. A 13-bit Gaussian codebook is used in each subframe where the codebook gain is encoded with 6 bits per subframe. It is to be noted that in cases where the average bit rate needs to be further reduced, unvoiced quarter-rate can be used in case of stable unvoiced frames.


A generic half-rate mode is used for low energy segments. This generic HR mode can be also used in maximum half-rate operation as will be explained later. The bit allocation of the Generic HR is shown in the above Table 3.


As an example, for classification information for the different HR coders, in case of Generic HR, 1 bit is used to indicate if the frame is Generic HR or other HR. In case of Unvoiced HR, 2 bits are used for classification: the first bit to indicate that the frame is not Generic HR and the second bit to indicate it is Unvoiced HR and not Voiced HR or Interoperable HR (to be explained later). In case of Voiced HR, 3 bits are used: the first 2 bits indicate that the frame is not Generic or Unvoiced HR, and the third bit indicates whether the frame is Unvoiced or Interoperable HR.


In the Economy mode, most of the unvoiced frames can be encoded using the Unvoiced QR coder. In this case, the Gaussian codebook indices are generated randomly and the gain is encoded with only 5 bits per subframe. Also, the LP filter coefficients are quantized with lower bit rate. 1 bit is used for the discrimination among the two quarter-rate coding types: Unvoiced QR and CNG QR. The bit allocation for unvoiced coding types is given in 6.


The Interoperable HR coding type allows coping with the situations where the CDMA system imposes HR as a maximum rate for a particular frame while the frame has been classified as full rate. The Interoperable HR is directly derived from the full rate coder by dropping the fixed codebook indices after the frame has been encoded as a full rate frame (Table 4). At the decoder side, the fixed codebook indices can be randomly generated and the decoder will operate as if it is in full-rate. This design has the advantage that it minimizes the impact of the forced half-rate mode during a tandem free operation between the CDMA system and other systems using the AMR-WB standard (such as the mobile GSM system or W-CDMA third generation wireless system). As mentioned earlier, the Interoperable FR coding type or CNG QR is used for a tandem-free operation (TFO) with AMR-WB. In the link with the direction from CDMA2000 to a system using AMR-WB codec, when the multiplex sub-layer indicates a request for half-rate mode, the VMR-WB codec will use the Interoperable HR coding type. At the system interface, when an Interoperable HR frame is received, randomly generated algebraic codebook indices are added to the bit stream to output a 12.65 kbit/s rate. The AMR-WB decoder at the receiver side will interpret it as an ordinary 12.65 kbit/s frame. In the other direction, that is in a link from a system using AMR-WB codec to CDMA2000, if at the system interface a half-rate request is received, then the algebraic codebook indices are dropped and mode bits indicating the Interoperable HR frame type are added. The decoder at the CDMA2000 side operates as an Interoperable HR coding type, which is a part of the VMR-WB coding solution. Without the Interoperable HR, a forced half-rate mode would be interpreted as a frame erasure.


The Comfort Noise Generation (CNG) technique is used for processing of inactive speech frames. The CNG eighth rate (ER) coding type is used to encode inactive speech frames when operating within the CDMA system. In a call where an interoperation with AMR-WB speech coding standard is required, the CNG ER cannot be always used as its bit rate is lower than the bit rate necessary to transmit the update information for the CNG decoder in AMR-WB (see 3GPP TS 26.192, “AMR Wideband Speech Codec; Comfort Noise Aspects,” 3GPP Technical Specification). In this case, the CNG QR is used. However, the AMR-WB codec operates often in Discontinuous Transmission Mode (DTX). During discontinuous transmission, the background noise information is not updated every frame. Typically only one frame out of 8 consecutive inactive speech frames is transmitted. This update frame is referred to as Silence Descriptor (SID), see 3GPP TS 26.193: “AMR Wideband Speech Codec; Source Controlled Rate operation,” 3GPP Technical Specification. The DTX operation is not used in the CDMA system where every frame is encoded. Consequently, only SID frames need to be encoded with CNG QR at the CDMA side and the remaining frames can be still encoded with CNG ER to lower the ADR as they are not used by the AMR-WB counterpart. In CNG coding, only the LP filter parameters and a gain are encoded once per frame. The bit allocation for the CNG QR is given in Table 4 and that of CNG ER is given in Table 5.

TABLE 4Bit Allocation for the Unvoiced QR and CNG QR coding typesUnvoicedParameterQRCNG QRSelection bits11LP Parameters3228Gains206Unused bits119Total5454









TABLE 5










Bit Allocation for the CNG ER











CNG ER



Parameter
Bits/Frame














LP Parameters
14



Gain
6



Unused




Total
20











Signal Classification and Rate Selection in the Premium Mode


A method 400 for digitally encoding a sound signal according to a second illustrative embodiment of the second aspect of the present invention is illustrated in FIG. 5. It is to be noted that the method 400 is a specific application of the method 100 in the Premium Mode, which is provided for maximum synthesized speech quality given the available bit rates (it should be noted that the case when the system limits the maximum available rate for a particular frame will be described in a separate subsection). Consequently, most of the active speech frames are encoded at full rate, i.e. 13.3 kb/s.


Similarly to the method 100 illustrated in FIG. 2, a voice activity detector (VAD), discriminates between active and inactive speech frames (step 102). The VAD algorithm can be identical for all modes of operation. If an inactive speech frame is detected (background noise signal) then the classification method stops and the frame is encoded with CNG ER coding type at 1.0 kbit/s according to CDMA Rate Set II (step 402). If an active speech frame is detected, the frame is subjected to a second classifier dedicated to discriminate unvoiced frames (step 404). As the Premium Mode is aimed for the best possible quality, the unvoiced frame discrimination is very severe and only highly stationary unvoiced frames are selected. The unvoiced classification rules and decision thresholds are as given above. If the second classifier classifies the frame as unvoiced speech signal, the classification method stops, and the frame is encoded using Unvoiced HR coding type (step 408) optimized for unvoiced signals (6.2 kbit/s according to CDMA Rate Set II). All other frames are processed with Generic FR coding type, based on the AMR-WB standard at 12.65 kbit/s (step 406).


Signal Classification and Rate Selection in the Standard Mode


A method 500 for digitally encoding a sound signal according to a third illustrative embodiment of the second aspect of the present invention is illustrated in FIG. 6. The method 500 allows the classification of a speech signal and its encoding in Standard mode.


In step 102, a VAD discriminates between active and inactive speech frames. If an inactive speech frame is detected then the classification method stops and the frame is encoded as a CNG ER frame (step 510). If an active speech frame is detected, the frame is subjected to a second-level classifier dedicated to discriminate unvoiced frames (step 404). The unvoiced classification rules and decision thresholds are described above. If the second-level classifier classifies the frame as unvoiced speech signal, the classification method stops, and the frame is encoded with an Unvoiced HR coding type (step 508). Otherwise, the speech frame is passed through to the “stable voiced” classification module (step 502). The discrimination of the voiced frames is an inherent feature of the signal modification algorithm as described hereinabove. If the frame is suitable for signal modification, it is classified as stable voiced frame and encoded with Voiced HR coding type (step 506) in a module optimized for stable voiced signals (6.2 kbit/s according to CDMA Rate Set II). Otherwise, the frame is likely to contain a nonstationary speech segment such as a voiced onset or rapidly evolving voiced speech signal. These frames typically require a high bit rate for sustaining good subjective quality. However, if the energy of the frame is lower than a certain threshold then the frames can be encoded with a Generic HR coding type. Thus, if in step 512 the fourth-level classifier detects a low energy signal the frame is encoded using Generic HR (step 514). Otherwise, the speech frame is encoded as a Generic FR frame (13.3 kbit/s according to CDMA Rate Set II) (step 504).


Signal Classification and Rate Selection in the Economy Mode


A method 600 for digitally encoding a sound signal according to a fourth illustrative embodiment of the first aspect of the present invention is illustrated in FIG. 6. The method 600, which is a four-level classification method, allows the classification of a speech signal and its encoding in the Economy mode.


The Economy Mode allows for maximum system capacity still producing high quality wideband speech. The rate determination logic is similar to Standard mode with the exception that also Unvoiced QR coding type is used and Generic FR use is reduced.


First, in step 102, a VAD discriminates between active and inactive speech frames. If an inactive speech frame is detected then the classification method stops and the frame is encoded as a CNG ER frame (step 402). If an active speech frame is detected, the frame is subjected to a second classifier dedicated to discriminate all unvoiced frames (step 106). The unvoiced classification rules and decision thresholds have been described above. If the second classifier classifies the frame as unvoiced speech signal, the speech frame is passed into the a first third-level classifier (step 602). The third-level classifier checks whether the frame is on a voiced-unvoiced transition using the rules described above. In particular, this third-level classifier tests whether the last frame is either unvoiced of background noise frame, and if at the end of the frame the energy is concentrated in high frequencies and no potential voiced onset is detected in the lookahead. As explained above, the last two conditions are detected as:

(rx(2)<th12) AND (etilt(1)<th13) with th12=0.73, th13=3,

where rx(2) is the correlation in the lookahead and etilt(1) is the tilt in the second spectral analysis which spans the end of the frame and the lookahead.


If the frame contains a voiced-unvoiced transition, the frame is encoded in step 508 with Unvoiced HR coding type. Otherwise, the speech frame is encoded with Unvoiced QR coding type (step 604). Frames not classified as unvoiced are passed through to a “stable voiced” classification module, which is a second third-level classifier (step 110). The discrimination of the voiced frames is an inherent feature of the signal modification algorithm as explained earlier. If the frame is suitable for signal modification, it is classified as stable voiced frame and encoded with Voiced HR in step 506. Similar to the Standard mode, remaining frames (not classified as unvoiced or stable voiced) are tested for low energy content. If a low energy signal is detected in step 512, the frame is encoded in step 514 using Generic HR. Otherwise, the speech frame is encoded as a Generic FR frame (13.3 kbit/s according to CDMA Rate Set II) (step 504).


Signal Classification and Rate Selection in the Interoperable Mode


A method 700 for digitally encoding a sound signal according to a fifth illustrative embodiment of the second aspect of the present invention is illustrated in FIG. 8. The method 700 allows the classification of a speech signal and the encoding in the Interoperable mode.


The Interoperable mode allows for a tandem free operation between the CDMA system and other systems using the AMR-WB standard at 12.65 kbit/s (or lower rates). In absence of rate limitation imposed by the CDMA system, only Interoperable FR and Comfort Noise Generators are used.


First, in step 102, a VAD discriminates between active and inactive speech frames. If an inactive speech frame is detected, a decision is made in step 702 whether the frame should be encoded as a SID frame. As mentioned earlier, the SID frame serves to update the CNG parameters at AMR-WB side during DTX operation (3GPP TS 26.193: “AMR Wideband Speech Codec; Source Controlled Rate operation,” 3GPP Technical Specification). Typically, only one of 8 inactive speech frames are encoded during silence periods. However, after an active speech segment, the SID update must be sent already in the 4th frame (see reference 3GPP TS 26.193: “AMR Wideband Speech Codec; Source Controlled Rate operation,” 3GPP Technical Specification for more details). As the ER is not sufficient to encode a SID frame, SID frames are encoded with CNG QR in step 704. Other than SID inactive frames are encoded with CNG ER in step 402. In the link with the direction from CDMA VMR-WB to AMR-WB in a Tandem Free Operation (TFO), the CNG ER frames are discarded at the system interface as AMR-WB does not make use of them. In the opposite direction, those frames are not available (AMR-WB is generating only SID frames) and are declared as frame erasures. All active speech frames are processed with Interoperable FR coding type (step 706), which is essentially the AMR-WB coding standard at 12.65 kbit/s.


Signal Classification and Rate Selection in Half-Rate Max Operation


A method 800 for digitally encoding a sound signal according to a sixth illustrative embodiment of the second aspect of the present invention is illustrated in FIG. 9. The method 800 allows the classification of a speech signal and the encoding in Half-Rate Max operation for Premium and Standard modes.


As discussed hereinabove, the CDMA system imposes a maximum bit rate for a particular frame. Most often, the maximum bit rate imposed by the system is limited to HR. However, the system can impose also lower rates.


All active speech frames that would conventionally be classified as FR during normal operation are now encoded using HR coding types. The classification and rate selection mechanism classifies then all such voiced frames using Voiced HR (encoded in step 506) and all such unvoiced frames using Unvoiced HR (encoded in step 408). All remaining frames that would be classified as FR during normal operation are encoded using the Generic HR coding type in step 514 except in the Interoperable mode where Interoperable HR coding type is used (step 908 on FIG. 10).


As can be seen on FIG. 9, the signal classification and encoding mechanism is similar to the normal operation in Standard mode. However, the Generic HR (step 514) is used instead of the Generic FR coding (step 406 on FIG. 5) and the thresholds used to discriminate unvoiced and voiced frames are more relaxed to allow as many frames as possible to be encoded using the Unvoiced HR and Voiced HR coding types. Basically, the thresholds for Economy mode are used in case of Premium or Standard mode half-rate max operation.


A method 900 for digitally encoding a sound signal according to a seventh illustrative embodiment of the first aspect of the present invention is illustrated in FIG. 10. The method 900 allows the classification of a speech signal and the encoding in Half-Rate Max operation for the Economy mode. The method 900 in FIG. 10 is similar to the method 600 in FIG. 7 with the exception that all frames that would have been encoded with Generic FR are now encoded with Generic HR (no need for low energy frame classification in half-rate max operation).A method 920 for digitally encoding a sound signal according to a eighth illustrative embodiment of the first aspect of the present invention is illustrated in FIG. 11. The method 920 allows the classification of a speech signal and the rate determination in the Interoperable mode during half-rate max operation. Since the method 920 is very similar to the method 700 from FIG. 8, only the differences between the two methods will be described herein.


In the case of method 920, no signal specific coding types (Unvoiced HR and Voiced HR) can be used as they would not be understandable by AMR-WB counterpart, and also no Generic HR coding can be used. Consequently, all active speech frames in half-rate max operation are encoded using the Interoperable HR coding type.


If the system imposes a lower maximum bit rate than HR, no general coding type is provided to cope with those cases, essentially because those cases are extremely rare and such frames can be declared as frame erasures. However, if the maximum bit rate is limited to QR by the system and the signal is classified as unvoiced, then Unvoiced QR can be used. This is however possible only in CDMA specific modes (Premium, Standard, Economy), as the AMR-WB counterpart is unable to interpret the QR frames.


Efficient Interoperation Between AMR-WB and Rate Set II VMR-WB Codec


A method 1000 for coding a speech signal for interoperation between AMR-WB and VMR-WB codecs will now be described according to an illustrative embodiment of fourth aspect of the present invention with reference to FIG. 12.


More specifically, the method 1000 enables tandem-free operation between the AMR-WB standard codec and the source controlled VBR codec designed, for example, for CDMA2000 systems (referred to here as VMR-WB codec). In an Interoperable mode allowed by the method 1000, the VMR-WB codec makes use of bit rates that can be interpreted by the AMR-WB codec and still fit within the Rate Set II bit rates used in a CDMA codec, for example.


As the bit rate of Rate Set II are the FR 13.3, HR 6.2, QR 2.7, and ER 1.0 kbit/s, then the AMR-WB codec bit rates that can be used are 12.65, 8.85, or 6.6 in the full rate, and the SID frames at 1.75 kbit/s in the quarter rate. AMR-WB at 12.65 kbit/s is the closest in bit rate to CDMA2000 FR 13.3 kbit/s and it is used as the FR codec in this illustrative embodiment. However, when AMR-WB is used in GSM systems the link adaptation algorithm can lower the bit rate to 8.85 or 6.6 kbit/s depending on the channel conditions (in order to allocate more bits to channel coding). Thus, the 8.85 and 6.6 kbit/s bit rates of AMR-WB can be part of the Interoperable mode and can be used at the CDMA2000 receiver in case the GSM system decided to use either of these bit rates. In the illustrative embodiment of FIG. 12, three types of I-FR are used corresponding to AMR-WB rates at 12.65, 8.85, and 6.6 kbit/s and will be denoted I-FR-12, I-FR-8, and I-FR-6, respectively. In I-FR-12, there are 13 unused bits. The first 8 bits are used to distinguish I-FR frames and Generic FR frames (that use the extra bits to improve frame erasure concealment). The other 5 bits are used to signal the three types of I-FR frames. In ordinary operation, I-FR-12 is used and the lower rates are used if required by the GSM link adaptation.


In the CDMA2000 system, the average data rate of the speech codec is directly related to the system capacity. Therefore attaining the lowest ADR possible with a minimal loss in speech quality becomes of significant importance. The AMR-WB codec was mainly designed for GSM cellular systems and third generation wireless based on GSM evolution. Thus an Interoperable mode for CDMA2000 system may result in a higher ADR compared to VBR codec specifically designed for CDMA2000 systems. The main reasons are:

    • The lack of a half rate mode at 6.2 kbit/s in AMR-WB;
    • The bit rate of the SID in AMR-WB is 1.75 kbit/s which doesn't fit in the Rate Set II eighth rate (ER);
    • The VAD/DTX operation of AMR-WB uses several frames of hangover (encoded as speech frames) in order to compute the SID_FIRST frame.


An method for coding a speech signal for interoperation between AMR-WB and VMR-WB codecs allows to overcome the above mentioned limitations and result in reduced ADR of the Interoperable mode such that it is equivalent to CDMA2000 specific modes with comparable speech quality. The methods are described below for both directions of operation: VMR-WB encoding—AMR-WB decoding, and AMR-WB encoding—VMR-WB decoding.


VMR-WB Encoding—AMR-WB Decoding


When encoding at the CDMA VMR-WB codec side, the VAD/DTX/CNG operation of the AMR-WB standard is not required. The VAD is proper to VMR-WB codec and works exactly the same way as in the other CDMA2000 specific modes, i.e. the VAD hangover used is just as long as necessary for not to miss unvoiced stops, and whenever the VAD_flag=0 (background noise classified) CNG encoding is operating.


The VAD/CNG operation is made to be as close as possible to the AMR DTX operation. The VAD/DTX/CNG operation in the AMR-WB codec works as follows. Seven background noise frames after an active speech period are encoded as speech frames but the VAD bit is set to zero (DTX hangover). Then an SID_FIRST frame is sent. In an SID_FIRST frame the signal is not encoded and CNG parameters are derived out of the DTX hangover (the 7 speech frames) at the decoder. It is to be noted that AMR-WB doesn't use DTX hangover after active speech periods which are shorter than 24 frames in order to reduce the DTX hangover overhead. After an SID_FIRST frame, two frames are sent as NO_DATA frames (DTX), followed by an SID_UPDATE frame (1.75 kbit/s). After that, 7 NO_DATA frames are sent followed by an SID_UPDATE frame and so on. This continues until an active speech frame is detected (VAD_flag=1), see 3GPP TS 26.193: “AMR Wideband Speech Codec; Source Controlled Rate operation,” 3GPP Technical Specification.


In the illustrative embodiment of FIG. 12, the VAD in the VMR-WB codec doesn't use DTX hangover. The first background noise frame after an active speech period is encoded at 1.75 kbit/s and sent in QR, then there are 2 frames encoded at 1 kbit/s (eighth rate) and then another frame at 1.75 kbit/s sent in QR. After that, 7 frames are sent in ER followed by one QR frame and so on. This corresponds roughly to AMR-WB DTX operation with the exception that no DTX hangover is used in order to reduce the ADR.


Although the VAD/CNG operation in the VMR-WB codec described in this illustrative embodiment is close to the AMR-WB DTX operation, other methods can be used which can reduce further the ADR. For example, QR CNG frames can be sent less frequently, e.g. once every 12 frames. Further, the noise variations can be evaluated at the encoder and QR CNG frames can be sent only when noise characteristics change (not once every 8 or 12 frames).


In order to overcome the limitation of the non-existence of a half rate at 6.2 kbit/s in the AMR-WB encoder, an Interoperable half rate (I-HR) is provided which includes encoding the frame as a full rate frame then dropping the bits corresponding to the algebraic codebook indices (144 bits per frame in AMR-WB at 12.65 kbit/s). This reduces the bit rate to 5.45 kbit/s which fits in the CDMA2000 Rate Set II half rate. Before decoding, the dropped bits can be generated either randomly (i.e. using a random generator) or pseudo-randomly (i.e. by repeating part of the existing bitstream) or in some predetermined manner. The I-HR can be used when dim-and-burst or half-rate max request is signaled by the CDMA2000 system. This avoids declaring the speech frame as a lost frame. The I-HR can be also used by the VMR-WB codec in Interoperable mode to encode unvoiced frames or frames where the algebraic codebook contribution to the synthesized speech quality is minimal. This results in a reduced ADR. It should be noted that in this case, the encoder can choose frames to be encoded in I-HR mode and thus minimize the speech quality degradation caused by the use of such frames.


As illustrated in FIG. 12, in the direction VMR-WB encoding/AMR-WB decoding, the speech frames are encoded with Interoperable mode of the VMR-WB encoder 1002, which outputs one of the following possible bit rates: I-FR for active speech frames (I-FR-12, I-FR-8, or I-FR-6), I-HR in case of dim-and-burst signaling or, as an option, to encode some unvoiced frames or frames where the algebraic codebook contribution to the synthesized speech quality is minimal, QR CNG to encode relevant background noise frames (one out of eight background noise frames as described above, or when a variation in noise characteristic is detected), and ER CNG frames for most background noise frames (background noise frames not encoded as QR CNG frames). At the system interface, which is in the form of a gateway, the following operations are performed:


First, the validity of the frame received by the gateway from the VMR-WB encoder is tested. If it is not a valid Interoperable mode VMR-WB frame then it is sent as an erasure (speech lost type of AMR-WB). The frame is considered invalid for example if one of the following conditions occurs:

    • If all-zero frame is received (used by the network in case of blank and burst) then the frame is erased;
    • In case of FR frames, if the 13 preamble bits do not correspond to I-FR-12, I-FR-8, or I-FR-6, or if the unused bits are not zero, then the frame is erased. Also, I-FR sets the VAD bit to 1 so if the VAD bit of the received frame is not 1 the frame is erased;
    • In case of HR frames, similar to FR, if the preamble bits do not correspond to I-HR-12, I-HR-8, or I-HR-6, or if the unused bits are not zero, then the frame is erased. Same for the VAD bit;
    • In case of QR frames, if the preamble bits do not correspond to CNG QR then the frame is erased. Further, the VMR-WB encoder sets the SID_UPDATE bit to 1 and the mode request bits to 0010. If this is not the case then the frame is erased;
    • In case of ER frames, if all-one ER frame is received then the frame is erased. Further, the VMR-WB encoder uses the all zero ISF bit pattern (first 14 bits) to signal blank frames. If this pattern is received then the frame is erased.


If the received frame is a valid Interoperable mode frame the following operations are performed:

    • I-FR frames are sent to AMR-WB decoder as 12.65, 8.8, or 6.6,kbit/s frames depending on the I-FR type;
    • QR CNG frames are sent to the AMR-WB decoder as SID_UPDATE frames;
    • ER CNG frames are sent to AMR-WB decoder as NO_DATA frames; and
    • I-HR frames are translated to 12.65, 8.85, or 6.6 kbit/s frames (depending on the frame type) by generating the missing algebraic codebook indices in step 1010. The indices can be generated randomly, or by repeating part of the existing coding bits or in some predetermined manner. It also discards bits indicating the I-HR type (bits used to distinguish different half rate types in the VMR-WB codec).


      AMR-WB Encoding—VMR-WB Decoding


In this direction, the methods 1000 is limited by the AMR-WB DTX operation. However, during the active speech encoding, there is one bit in the bitstream (the 1st data bit) indicating VAD_flag (0 for DTX hangover period, 1 for active speech). So the operation at the gateway can be summarized as follows:

    • SID_UPDATE frames are forwarded as QR CNG frames;
    • SID_FIRST frames and NO_DATA frames are forwarded as ER blank frames;
    • Erased frames (speech lost) are forwarded as ER erasure frames;


The first frame after active speech with VAD_flag=0 (verified in step 1012) is kept as FR frame but the following frames with VAD_flag=0 are forwarded as ER blank frames;

    • If the gateway receives in step 1014 a request for half-rate-max operation (frame-level signaling) while receiving FR frames, then the frame is translated into a I-HR frame. This consists of dropping the bits corresponding to algebraic codebook indices and adding the mode bits indicating the I-HR frame type.


In this illustrative embodiment, in ER blank frames, the first two bytes are set to 0×00 and in ER erasure frames the first two bytes are set to 0×04. Basically, the first 14 bits correspond to the ISF indices and two patterns are reserved to indicate blank frames (all-zero) or erasure frames (all-zero except 14th bit set to 1, which is 0×04 in hexadecimal). At the VMR-WB decoder 1004, when blank ER frames are detected, they are processed by the CNG decoder by using the last received good CNG parameters. An exception is the case of the first received blank ER frame (CNG decoder initialization; no old CNG parameters are known yet). Since the first frame with VAD_flag=0 is transmitted as FR, the parameters from this frame as well as last CNG parameters are used to initialize CNG operation. In -case of ER erasure frames, the decoder uses the concealment procedure used for erased frames.


Note that in the illustrated embodiment shown in FIG. 12, 12.65 kbit/s is used for FR frames. However, 8.85 and 6.6 kbit/s can equally be used in accordance with a link adaptation algorithm that requires the use of lower rates in case of bad channel conditions. For example, for interoperation between CDMA2000 and GSM systems, the link adaptation module in GSM system may decide to lower the bit rate to 8.85 or 6.6 kbit/s in case of bad channel conditions. In this case, these lower bit rates need to be included in the CDMA VMR-WB solution.


CDMA VMR-WB Codec Operating in Rate Set I


In Rate Set I, the bit rates used are 8.55 kbit/s for FR, 4.0 kbit/s for HR, 2.0 kbit/s for QR, and 800 bit/s for ER. In this case only AMR-WB codec at 6.6 kbit/s can be used at FR and CNG frames can be sent at either QR (SID_UPDATE) or ER for other background noise frames (similar to the Rate Set II operation described above). To overcome the limitation of the low quality of the 6.6 kbit/s rate, an 8.55 kbit/s rate is provided which is interoperable with the 8.85 kbit/s bit rate of AMR-WB codec. It will be referred to as Rate Set I lnteroperable FR (I-FR-I). The bit allocation of the 8.85 kbit/s rate and two possible configurations of I-FR-I are shown in Table 6.

TABLE 6Bit allocation of the I-FR-I coding types in Rate Set Iconfiguration.I-FR-II-FR-IAMR-WBat 8.55 kbit/sat 8.55 kbit/sAt 8.85 kbit/s(configuration(configurationParameterBits/Frame1) Bits/Frame2) Bits/frameHalf-ratemode bitsVAD flag 100LP 464146ParametersPitch Delay 26 = 8 + 5 + 8 + 52626Gains 24 = 6 + 6 + 6 + 62424Algebraic 80 = 20 + 20 + 20 + 208075CodebookTotal177171171


In the I-FR-I, the VAD_flag bit and additional 5 bits are dropped to obtain a 8.55 kbit/s rate. The dropped bits can be easily introduced at the decoder or system interface so that the 8.85 kbit/s decoder can be used. Several methods can be used to drop the 5 bits in a way that cause little impact on the speech quality. In Configuration 1 shown in Table 6, the 5 bits are dropped from the linear prediction (LP) parameter quantization. In AMR-WB, 46 bits are used to quantize the LP parameters in the ISP (immitance spectrum pair) domain (using mean removal and moving average prediction). The 16 dimensional ISP residual vector (after prediction) is quantized using split-multistage vector quantization. The vector is split into 2 subvectors of dimensions 9 and 7, respectively. The 2 subvectors are quantized in two stages. In the first stage each subvector is quantized with 8 bits. The quantization error vectors are split in the second stage into 3 and 2 subvectors, respectively. The second stage subvectors are of dimension 3, 3, 3, 3, and 4, and are quantized with 6, 7, 7, 5, and 5 bits, respectively. In the proposed I-FR-I mode, the 5 bits of the last second stage subvectors are dropped. These have the least impact since they correspond to the high frequency portion of the spectrum. Dropping these 5 bits is done in practice by fixing the index of the last second stage subvector to a certain value that doesn't need to be transmitted. The fact that this 5-bit index is fixed is easily taken into account during the quantization at the VMR-WB encoder. The fixed index is added either at the system interface (i.e. during VMR-WB encoder/AMR-WB decoder operation) or at the decoder (i.e. during AMR-WB encoder/VMR-WB decoder operation). In this way the AMR-WB decoder at 8.85 kbit/s is used to decode the Rate Set I I-FR frame.


In a second configuration of the illustrated embodiment, the 5 bits are dropped from the algebraic codebook indices. In the AMR-WB at 8.85 kbit/s, a frame is divided into four 64-sample subframes. The algebraic excitation codebook consists on dividing the subframe into 4 tracks of 16 positions and placing a signed pulse in each track. Each pulse is encoded with 5 bits: 4 bits for the position and 1 bit for the sign. Thus, for each subframe, a 20-bit algebraic codebook is used. One way of dropping the five bits is to drop one pulse from a certain subframe. For example, the 4th pulse in the 4th position-track in the 4th subframe. At the VMR-WB encoder, this pulse can be fixed to a predetermined value (position and sign) during the codebook search. This known pulse index can then be added at the system interface and sent to the AMR-WB decoder. In the other direction, the index of this pulse is dropped at the system interface, and at the CDMA VMR-WB decoder, the pulse index can be randomly generated. Other methods can be also used to drop these bits.


To cope with a dim-and-burst or half-rate max request by the CDMA2000 system, an Interoperable HR mode is provided also for the Rate Set I codec (I-HR-I). Similarly to the Rate Set II case, some bits must be dropped at the system interface during AMR-WB encoding NMR-WB decoding operation, or generated at the system interface during VMR-WB encoding/AMR-WB decoding. A bit allocation of the 8.85 kbit/s rate and an example configuration of I-HR-I is shown in Table 7.

TABLE 7Example bit allocation of the I-HR-I coding type in RateSet I configuration.I_HR-I atAMR-WB at 8.85 kbit/s4.0 Bits/ParameterBits/FrameFrameHalf-rate modebitsVAD flag 10LP Parameters 4636Pitch Delay 26 = 8 + 5 + 8 + 520Gains 24 = 6 + 6 + 6 + 624Algebraic 80 = 20 + 20 + 20 + 200CodebookTotal17780


In the proposed I-HR-I mode, the 10 bits of the last 2 second stage subvectors in the quantization of the LP filter parameters are dropped or generated at the system interface in a manner similar to Rate Set II described above. The pitch delay is encoded only with integer resolution and with bit allocation of 7, 3, 7, 3 bits in four subframes. This translates in the AMR-WB encoder/NMR-WB decoder operation to dropping the fractional part of the pitch at the system interface and to clip the differential delay to 3 bits for the 2nd and 4th subframes. Algebraic codebook indices are dropped altogether similarly as in the I-HR solution of Rate Set II. The signal energy information is kept intact.


The rest of operation of the Rate Set I Interoperable mode is similar to the operation of the Rate Set II mode explained above in FIG. 12 (in terms of VAD/DTX/CNG operation) and will not be described herein in more detail.


Although the present invention has been described hereinabove by way of illustrative embodiments thereof, it can be modified without departing from the spirit and nature of the subject invention, as defined in the appended claims. For example, although the illustrative embodiments of the present invention are described in relation to encoding of a speech signal, it should be kept in mind that these embodiments also apply to sound signals other than speech.

Claims
  • 1. A source-controlled Variable bit-rate Multi-mode WideBand (VMR-WB) codec comprising a unit operable with an Adaptive Multi-Rate wideband (AMR-WB) codec, where in a VMR-WB encoding/AMR-WB decoding case, speech frames are encoded in an AMR-WB interoperable mode of a VMR-WB encoder using one of bit rates corresponding to Interoperable-Full Rate (I-FR) for active speech frames, Interoperable-Half Rate (I-HR) at least for dim-and-burst signaling, Quarter Rate-Comfort Noise Generator (CNG-QR) to encode at least relevant background noise frames and Eighth Rate-Comfort Noise Generator (CNG-ER) frames for background noise frames not encoded as CNG-QR frames, said unit responsive to a case that voice activity is not detected for using CNG-ER encoding, further responsive to a case that voice activity is detected, and responsive to a voiced versus unvoiced classification such that if a frame is classified as unvoiced, the frame is encoded with one of Unvoiced HR or Unvoiced QR encoding, further responsive to a frame not being classified as unvoiced for using a stable voiced classification, and if the frame is classified as stable voiced, encoded the frame using Voiced HR encoding, else assuming the frame to likely contain a non-stationary speech segment for using an appropriate FR encoding, whereas a frame with low energy, and not detected as at least a background or an unvoiced frame, is encoded using generic HR coding to reduce the average data rate; an unvoiced classification decision being based on at least some of a voicing measure {overscore (r)}x, a spectral tilt et, an energy variation within a frame dE, and a relative frame energy Erel, where decision thresholds are set based at least in part on an operating mode comprising a required average data rate.
  • 2. A method for encoding a sampled speech signal comprising speech frames, the method comprising: determining whether a current frame of the sampled speech signal is an active speech frame or an inactive speech frame, if said current frame is an active speech frame, performing a classification procedure to determine whether the current frame is an unvoiced frame, said classification procedure comprising examining at least three of the following parameters in order to determine whether the current frame is an unvoiced frame: a) a voicing measure (rx,{overscore (r)}x); b) a spectral tilt measure (etilt , et); c) an energy variation within the current frame (dE); d) a relative energy of the current frame (Erel); and when the current frame is classified as an unvoiced frame by said classification procedure, encoding the current frame using an unvoiced signal coding algorithm.
  • 3. A method according to claim 2, wherein the voicing measure ({overscore (r)}x) is defined as
  • 4. A method according to claim 3, further comprising adding a noise correction factor (re) to said voicing measure ({overscore (r)}x).
  • 5. A method according to claim 2, comprising defining a number of perceptual critical bands representative of frequency ranges within an energy spectrum of the current frame, ordered according to increasing frequency from a first perceptual critical band representative of a lowest frequency range to a last perceptual critical band representative of a highest frequency range, and performing a spectral analysis of the current frame to determine a distribution of energy amongst the perceptual critical bands.
  • 6. A method according to claim 2, wherein the spectral tilt is proportional to a ratio between the energy of the current frame at low frequencies and the energy of the current frame at high frequencies.
  • 7. A method according to claim 5, comprising computing a measure ({overscore (E)}h) representative of the energy of the current frame at high frequencies by calculating an average of the energies of the last two perceptual critical bands.
  • 8. A method according to claim 5, comprising computing a measure ({overscore (E)}1) representative of the energy of the current frame at low frequencies by calculating an average of the energies in the first i perceptual critical bands.
  • 9. A method according to claim 5, comprising computing a measure ({overscore (E)}1) representative of the energy of the current frame at low frequencies by calculating an average of the energies in the first i perceptual critical bands excluding the first perceptual critical band.
  • 10. A method according to claim 8, further comprising determining a speech pitch period and for speech pitch periods shorter than a predetermined value, computing the low frequency energy measure ({overscore (E)}l) by summing the energy within frequency bins resulting from spectral analysis of the current frame and only frequency bins sufficiently close to the speech harmonics are taken into account in the summation according to the formula:
  • 11. A method according to claim 8, further comprising determining a speech pitch period and for pitch values larger than a predetermined value, computing the low frequency energy measure ({overscore (E)}1) according to the formula:
  • 12. A method according to claim 8, further comprising identifying an a priori unvoiced sound when
  • 13. A method according to claim 7, further comprising: computing a measure (Nh) representative of a noise energy of the current frame at high frequencies by calculating an average of the noise energies of the last two perceptual critical bands; computing a measure (Nl) representative of a noise energy of the current frame at low frequencies by calculating an average of the noise energies in the first i perceptual critical bands; subtracting the high frequency noise measure (Nh) from the high frequency energy measure ({overscore (E)}h) to obtain a high frequency energy (Eh); subtracting the low frequency noise measure (Nl) from the low frequency energy measure ({overscore (E)}l) to obtain a low frequency energy (El); and computing the spectral tilt measure (etilt) as a ratio of the low frequency energy (Et) divided by the high frequency energy (Eh).
  • 14. A method according to claim 13, comprising performing the spectral analysis of claim 4 twice for the current frame, once for a first half of the current frame and once for a second half of the current frame and further computing the spectral tilt measure (etilt) twice for the current frame, once for each spectral analysis, to obtain a first spectral tilt measure (etilt(0)) for the first half of the current frame and a second spectral tilt measure (etilt(1)) for the second half of the current frame.
  • 15. A method according to claim 14, further comprising computing an average spectral tilt (et) according to the formula:
  • 16. A method according to claim 2, comprising calculating the relative energy (Erel) of the current frame as a difference between a frame energy (Et) in dB and a long-term average energy value ({overscore (E)}f).
  • 17. A method according to claim 16, comprising computing the frame energy (Et) as according to the formula:
  • 18. A method according to claim 16, comprising computing the long-term average energy value according to the formula:
  • 19. A method according to claim 2, comprising selecting an encoding bit-rate from a set of available encoding bit-rates, and encoding the current frame in accordance with the selected encoding bit-rate.
  • 20. A method according to claim 19, wherein the set of available encoding bit-rates includes a full-rate encoding bit-rate, a half-rate encoding bit-rate, a quarter-rate encoding bit-rate and an eighth-rate encoding bit-rate.
  • 21. A method according to claim 20, wherein when the current frame is classified as an unvoiced frame, encoding the current frame at said half-rate encoding bit-rate using an unvoiced half-rate encoding algorithm.
  • 22. A method according to claim 20, wherein said classification procedure to determine whether the current frame is an unvoiced frame further includes determining whether the current frame is located at a transition between voiced and unvoiced speech and, when the current frame is classified as an unvoiced frame and is located at a transition between voiced and unvoiced speech, encoding the current frame at said half-rate encoding bit-rate using an unvoiced half-rate encoding algorithm and, when the current frame is classified as unvoiced speech and is not located at a transition between voiced and unvoiced speech, encoding the current frame at said quarter-rate encoding bit-rate using an unvoiced quarter-rate encoding algorithm.
  • 23. A method according to claim 2, comprising using a comfort noise generation algorithm when it is determined that the current frame is an inactive speech frame.
  • 24. A method according to claim 2, comprising using a discontinuous transmission mode when it is determined that the current frame is an inactive speech frame.
  • 25. A method according to claim 20, comprising defining a set of operating modes, each operating mode providing a predetermined average bit-rate, selecting an operating mode and encoding the sampled speech signal according to the selected operating mode.
  • 26. A method according to claim 25, wherein the set of operating modes comprises a Premium mode having a highest average bit-rate, a Standard mode having an intermediate average bit-rate and an Economy mode having a lowest average bit-rate.
  • 27. A method according to claim 26, wherein when the sampled speech signal is encoded in Premium mode and the current frame is classified as an unvoiced frame, the current frame is encoded at said half-rate encoding bit-rate when the following conditions are fulfilled: said voicing measure is smaller than a predetermined first threshold value; and said spectral tilt measure is smaller than a predetermined second threshold value; and said energy variation is smaller than a predetermined third threshold value.
  • 28. A method according to claim 26, wherein when the sampled speech signal is encoded in Standard mode; and the current frame is classified as an unvoiced frame, the current frame is encoded at said half-rate encoding bit-rate when the following conditions are fulfilled: said voicing measure is smaller than a predetermined fourth threshold value; and said spectral tilt measure is smaller than a predetermined fifth threshold value; and said energy variation is smaller than a predetermined sixth threshold value or said relative energy is smaller than a predetermined seventh threshold value.
  • 29. A method according to claim 28, wherein said fourth threshold value is 0.695, said fifth threshold value is 4, said sixth threshold value is 40, and said seventh threshold value is −14.
  • 30. A method according to claim 26, wherein when the sampled speech signal is encoded in Economy mode and the current frame is classified as an unvoiced frame, the current frame is encoded at said half-rate encoding bit-rate when the following conditions are fulfilled: said voicing measure is smaller than a predetermined eighth threshold value; and said spectral tilt measure is smaller than a predetermined ninth threshold value; and said energy variation is smaller than a predetermined tenth threshold value or said relative energy is smaller than a predetermined eleventh threshold value.
  • 31. A method according to claim 30, wherein said eighth threshold value is 0.695, said ninth threshold value is 4, said tenth threshold value is 60, and said eleventh threshold value is −14
  • 32. A method according to claim 26, wherein when the sampled speech signal is encoded in Economy mode and the current frame is classified as an unvoiced frame the current frame is encoded at said quarter-rate encoding bit-rate when the following further conditions are fulfilled: the normalized correlation in a lookahead frame (rx(2)) is smaller than a predetermined twelfth threshold value; and the second spectral tilt measure (etilt(1)) for the second half of the current frame is smaller than a predetermined thirteenth threshold value.
  • 33. A method according to claim 32, wherein said twelfth threshold value is 0.73 and said thirteenth threshold value is 3.
  • 34. A device for encoding a sampled speech signal comprising speech frames, the device comprising: a voice activity detector for determining whether frames of the sampled speech signal are active speech frames or inactive speech frames; a classification unit arranged to perform a classification procedure on active speech frames to determine whether said active speech frames are unvoiced frames, said classification procedure comprising examining at least three of the following parameters in order to determine whether a current frame is an unvoiced frame: a) a voicing measure (rx,{overscore (r)}x); b) a spectral tilt measure (etilt,et); c) an energy variation within the current frame (dE); d) a relative energy of the current frame (Erel); said device being arranged to encode the current frame using an unvoiced signal coding algorithm when the classification unit classifies the current frame as an unvoiced frame.
  • 35. A device according to claim 34, wherein the voicing measure ({overscore (r)}x) is defined as
  • 36. A device according to claim 35, further arranged to add a noise correction factor (re) to said voicing measure ({overscore (r)}x).
  • 37. A device according to claim 34, arranged to define a number of perceptual critical bands representative of frequency ranges within an energy spectrum of the current frame, ordered according to increasing frequency from a first perceptual critical band representative of a lowest frequency range to a last perceptual critical band representative of a highest frequency range, and to perform a spectral analysis of the current frame to determine a distribution of energy amongst the perceptual critical bands.
  • 38. A device according to claim 34, wherein the spectral tilt is proportional to a ratio between the energy of the current frame at low frequencies and the energy of the current frame at high frequencies.
  • 39. A device according to claim 37, arranged to compute a measure ({overscore (E)}h) representative of the energy of the current frame at high frequencies by calculating an average of the energies of the last two perceptual critical bands.
  • 40. A device according to claim 37, arranged to compute a measure ({overscore (E)}t) representative of the energy of the current frame at low frequencies by calculating an average of the energies in the first i perceptual critical bands.
  • 41. A device according to claim 37, arranged to compute a measure ({overscore (E)}l) representative of the energy of the current frame at low frequencies by calculating an average of the energies in the first i perceptual critical bands excluding the first perceptual critical band.
  • 42. A device according to claim 40, further arranged to determine a speech pitch period and, for speech pitch periods shorter than a predetermined value, to compute the low frequency energy measure ({overscore (E)}t) by summing the energy within frequency bins resulting from spectral analysis of the current frame and to take only frequency bins sufficiently close to the speech harmonics into account in the summation according to the formula:
  • 43. A device according to claim 40, further arranged to determine a speech pitch period and for pitch values larger than a predetermined value, and to compute the low frequency energy measure ({overscore (E)}l) according to the formula:
  • 44. A device according to claim 40, further arranged to identify an a priori unvoiced sound when
  • 45. A device according to claim 39, further arranged: to compute a measure (Nh) representative of a noise energy of the current frame at high frequencies by calculating an average of the noise energies of the last two perceptual critical bands; to compute a measure (Nl) representative of a noise energy of the current frame at low frequencies by calculating an average of the noise energies in the first i perceptual critical bands; to subtract the high frequency noise measure (Nh) from the high frequency energy measure ({overscore (E)}h) to obtain a high frequency energy (Eh); to subtract the low frequency noise measure (N1) from the low frequency energy measure ({overscore (E)}l) to obtain a low frequency energy (El); and to compute the spectral tilt measure (etilt) as a ratio of the low frequency energy (El) divided by the high frequency energy (Eh).
  • 46. A device according to claim 45, arranged to perform the spectral analysis of claim 36 twice for the current frame, once for a first half of the current frame and once for a second half of the current frame and further to compute the spectral tilt measure (etilt) twice for the current frame, once for each spectral analysis, to obtain a first spectral tilt measure (etilt(0)) for the first half of the current frame and a second spectral tilt measure (etilt(1)) for the second half of the current frame.
  • 47. A device according to claim 46, further arranged to compute an average spectral tilt (et) according to the formula:
  • 48. A device according to claim 34, arranged to calculate the relative energy (Erel) of the current frame as a difference between a frame energy (Et) in dB and a long-term average energy value ({overscore (E)}f).
  • 49. A device according to claim 48, arranged to compute the frame energy (Et) as according to the formula:
  • 50. A device according to claim 48, arranged to compute the long-term average energy value according to the formula:
  • 51. A device according to claim 34, arranged to select an encoding bit-rate from a set of available encoding bit-rates, and to encode the current frame in accordance with the selected encoding bit-rate.
  • 52. A device according to claim 51, wherein the set of available encoding bit-rates includes a full-rate encoding bit-rate, a half-rate encoding bit-rate, a quarter-rate encoding bit-rate and an eighth-rate encoding bit-rate.
  • 53. A device according to claim 52, arranged to encode the current frame at said half-rate encoding bit-rate using an unvoiced half-rate encoding algorithm when the current frame is classified as an unvoiced frame.
  • 54. A device according to claim 52, further arranged to determine whether the current unvoiced frame is located at a transition between voiced and unvoiced speech and, when the current frame is classified as an unvoiced frame and is located at a transition between voiced and unvoiced speech, to encode the current frame at said half-rate encoding bit-rate using an unvoiced half-rate encoding algorithm and, when the current frame is classified as unvoiced speech and is not located at a transition between voiced and unvoiced speech, to encode the current frame at said quarter-rate encoding bit-rate using an unvoiced quarter-rate encoding algorithm.
  • 55. A device according to claim 34, arranged to use a comfort noise generation algorithm when it is determined that the current frame is an inactive speech frame.
  • 56. A device according to claim 34, arranged to use a discontinuous transmission mode when it is determined that the current frame is an inactive speech frame.
  • 57. A device according to claim 52, arranged to define a set of operating modes, each operating mode providing a predetermined average bit-rate, to select an operating mode and to encode the sampled speech signal according to the selected operating mode.
  • 58. A device according to claim 57, wherein the set of operating modes comprises a Premium mode having a highest average bit-rate, a Standard mode having an intermediate average bit-rate and an Economy mode having a lowest average bit-rate.
  • 59. A device according to claim 58, arranged to encode the current frame at said half-rate encoding bit-rate when the sampled speech signal is encoded in Premium mode and the current frame is classified as an unvoiced frame, and the following conditions are fulfilled: said voicing measure is smaller than a predetermined first threshold value; and said spectral tilt measure is smaller than a predetermined second threshold value; and said energy variation is smaller than a predetermined third threshold value.
  • 60. A device according to claim 58, arranged to encode the current frame at said half-rate encoding bit-rate when the sampled speech signal is encoded in Standard mode and the current frame is classified as an unvoiced frame, and the following conditions are fulfilled: said voicing measure is smaller than a predetermined fourth threshold value; and said spectral tilt measure is smaller than a predetermined fifth threshold value; and said energy variation is smaller than a predetermined sixth threshold value or said relative energy is smaller than a predetermined seventh threshold value.
  • 61. A device according to claim 60, wherein said fourth threshold value is 0.695, said fifth threshold value is 4, said sixth threshold value is 40, and said seventh threshold value is −14.
  • 62. A device according to claim 58, arranged to encode the current frame at said half-rate encoding bit-rate when the sampled speech signal is encoded in Economy mode and the current frame is classified as an unvoiced frame, and the following conditions are fulfilled: said voicing measure is smaller than a predetermined eighth threshold value; and said spectral tilt measure is smaller than a predetermined ninth threshold value; and said energy variation is smaller than a predetermined tenth threshold value or said relative energy is smaller than a predetermined eleventh threshold value.
  • 63. A device according to claim 62, wherein said eighth threshold value is 0.695, said ninth threshold value is 4, said tenth threshold value is 60, and said eleventh threshold value is −14
  • 64. A device according to claim 58, arranged to encode the current frame at said quarter-rate encoding bit-rate when the sampled speech signal is encoded in Economy mode and the current frame is classified as an unvoiced frame, and the following further conditions are fulfilled: the normalized correlation in a lookahead frame (rx(2)) is smaller than a predetermined twelfth threshold value; and the second spectral tilt measure (etilt(1)) for the second half of the current frame is smaller than a predetermined thirteenth threshold value.
  • 65. A device according to claim 64, wherein said twelfth threshold value is 0.73 and said thirteenth threshold value is 3.
  • 66. A device for encoding a sampled speech signal comprising speech frames, the device comprising: means for determining whether a current frame of the sampled speech signal is an active speech frame or an inactive speech frame, means, responsive to said current frame being an active speech frame, for performing a classification procedure to determine whether the current frame is an unvoiced frame, said classification procedure comprising examining at least three of the following parameters in order to determine whether the current frame is an unvoiced frame: a) a voicing measure (rx,{overscore (r)}x); b) a spectral tilt measure (etilt, et); c) an energy variation within the current frame (dE); d) a relative energy of the current frame (Erel); and means for encoding the current frame using an unvoiced signal coding algorithm when the current frame is classified as an unvoiced frame by said classification procedure.
  • 67. A speech encoder, responsive to a current frame being classified as an active speech frame, for encoding said current frame using an unvoiced signal coding algorithm, wherein an active speech frame is further classified as an active unvoiced speech frame by examining at least three parameters selected from the set: a voicing measure (rx,{overscore (r)}x), a spectral tilt measure (etilt,et), an energy variation within the current frame (dE), and a relative energy of the current frame (Erel).
  • 68. A program of machine-readable instructions, tangibly embodied on an information bearing medium and executable by a digital data processor, to perform actions directed toward encoding a sampled speech signal comprising speech frames, the actions comprising: determining whether a current frame of the sampled speech signal is an active speech frame or an inactive speech frame, performing a classification procedure on an active speech frame to determine whether the current frame is an unvoiced frame, said classification procedure comprising examining at least three of the following parameters in order to determine whether the current frame is an unvoiced frame: a) a voicing measure (rx,{overscore (r)}x); b) a spectral tilt measure (etilt,et); c) an energy variation within the current frame (dE); d) a relative energy of the current frame (Erel); and encoding the current frame using an unvoiced signal coding algorithm when the current frame is classified as an unvoiced frame by said classification procedure.
  • 69. A program according to claim 68, wherein the voicing measure ({overscore (r)}x) is defined as
  • 70. A program according to claim 69, wherein the actions further comprise adding a noise correction factor (re) to said voicing measure ({overscore (r)}x).
  • 71. A program according to claim 68, wherein the actions further comprise defining a number of perceptual critical bands representative of frequency ranges within an energy spectrum of the current frame, ordered according to increasing frequency from a first perceptual critical band representative of a lowest frequency range to a last perceptual critical band representative of a highest frequency range, and performing a spectral analysis of the current frame to determine a distribution of energy amongst the perceptual critical bands.
  • 72. A program according to claim 68, wherein the spectral tilt is proportional to a ratio between the energy of the current frame at low frequencies and the energy of the current frame at high frequencies.
  • 73. A program according to claim 71, wherein the actions further comprise computing a measure ({overscore (E)}h) representative of the energy of the current frame at high frequencies by calculating an average of the energies of the last two perceptual critical bands.
  • 74. A program according to claim 71, wherein the actions further comprise computing a measure ({overscore (E)}l) representative of the energy of the current frame at low frequencies by calculating an average of the energies in the first i perceptual critical bands.
  • 75. A program according to claim 71, wherein the actions further comprise computing a measure ({overscore (E)}l) representative of the energy of the current frame at low frequencies by calculating an average of the energies in the first i perceptual critical bands excluding the first perceptual critical band.
  • 76. A program according to claim 74, wherein the actions further comprise determining a speech pitch period and for speech pitch periods shorter than a predetermined value, and computing the low frequency energy measure ({overscore (E)}l) by summing the energy within frequency bins resulting from spectral analysis of the current frame and only frequency bins sufficiently close to the speech harmonics are taken into account in the summation according to the formula:
  • 77. A program according to claim 74, wherein the actions further comprise determining a speech pitch period and for pitch values larger than a predetermined value, and computing the low frequency energy measure ({overscore (E)}l) according to the formula:
  • 78. A program according to claim 74, wherein the actions further comprise identifying an a priori unvoiced sound when
  • 79. A program according to claim 73, wherein the actions further comprise: computing a measure (Nh) representative of a noise energy of the current frame at high frequencies by calculating an average of the noise energies of the last two perceptual critical bands; computing a measure (Nl) representative of a noise energy of the current frame at low frequencies by calculating an average of the noise energies in the first i perceptual critical bands; subtracting the high frequency noise measure (Nh) from the high frequency energy measure ({overscore (E)}h) to obtain a high frequency energy (Eh); subtracting the low frequency noise measure (Nl) from the low frequency energy measure ({overscore (E)}l) to obtain a low frequency energy (El); and computing the spectral tilt measure (etilt) as a ratio of the low frequency energy (El) divided by the high frequency energy (Eh).
  • 80. A program according to claim 79, wherein the actions further comprise performing the spectral analysis of claim 36 twice for the current frame, once for a first half of the current frame and once for a second half of the current frame and further computing the spectral tilt measure (etilt) twice for the current frame, once for each spectral analysis, to obtain a first spectral tilt measure (etilt(0)) for the first half of the current frame and a second spectral tilt measure (etilt(1)) for the second half of the current frame.
  • 81. A program according to claim 80, wherein the actions further comprise computing an average spectral tilt (et) according to the formula:
  • 82. A program according to claim 68, wherein the actions further comprise computing the relative energy (Erel) of the current frame as a difference between a frame energy (Et) in dB and a long-term average energy value ({overscore (E)}f).
  • 83. A program according to claim 82, wherein the actions further comprise computing the frame energy (Et) as according to the formula:
  • 84. A program according to claim 82, wherein the actions further comprise computing the long-term average energy value according to the formula:
  • 85. The program of claim 68, wherein the information bearing medium and the digital data processor are disposed within a mobile station.
Provisional Applications (1)
Number Date Country
60417667 Oct 2002 US
Continuations (1)
Number Date Country
Parent PCT/CA03/01571 Oct 2003 US
Child 11039539 Jan 2005 US