# Coding device, decoding device, and method and program thereof

A coding method and a decoding method are provided which can use in combination a predictive coding and decoding method which is a coding and decoding method that can accurately express coefficients which are convertible into linear prediction coefficients with a small code amount and a coding and decoding method that can obtain correctly, by decoding, coefficients which are convertible into linear prediction coefficients of the present frame if a linear prediction coefficient code of the present frame is correctly input to a decoding device. A coding device includes: a predictive coding unit that obtains a first code by coding a differential vector formed of differentials between a vector of coefficients which are convertible into linear prediction coefficients of more than one order of the present frame and a prediction vector containing at least a predicted vector from a past frame, and obtains a quantization differential vector corresponding to the first code; and a non-predictive coding unit that generates a second code by coding a correction vector which is formed of differentials between the vector of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame and the quantization differential vector or formed of some of elements of the differentials.

## Latest Nippon Telegraph and Telephone Corporation Patents:

- DIAGNOSTIC APPARATUS
- VIDEO TRANSMISSION DEVICE AND VIDEO TRANSMISSION METHOD
- ANOMALY DETECTION APPARATUS, PROBABILITY DISTRIBUTION LEARNING APPARATUS, AUTOENCODER LEARNING APPARATUS, DATA TRANSFORMATION APPARATUS, AND PROGRAM
- IMAGE PROCESSING APPARATUS, IMAGE PROCESSING METHOD AND IMAGE PROCESSING PROGRAM
- LEARNING DEVICE, LEARNING METHOD, AND LEARNING PROGRAM

**Description**

**CROSS-REFERENCE TO RELATED APPLICATIONS**

This application is a continuation of and claims the benefit of priority under 35 U.S.C. § 120 from U.S. application Ser. No. 15/307,059 filed Oct. 27, 2016, the entire contents of which are incorporated herein by reference. U.S. application Ser. No. 15/307,059 is a National Stage of PCT/JP2015/057727 filed Mar. 16, 2015, which claims the benefit of priority under 35 U.S.C. § 119 from Japanese Application No. 2014-094758 filed May 1, 2014.

**TECHNICAL FIELD**

The present invention relates to a coding technology and a decoding technology of coding and decoding linear prediction coefficients and coefficients which are convertible thereinto.

**BACKGROUND ART**

In coding of sound signals such as speech and music, a method of performing the coding by using linear prediction coefficients obtained by performing linear prediction analysis on an input sound signal is widely used.

In order to make it possible to obtain, on the part of a decoding device, the information on the linear prediction coefficients used in coding processing by decoding, a coding device codes the linear prediction coefficients and sends a code corresponding to the linear prediction coefficients to the decoding device. In Non-patent Literature 1, a coding device converts linear prediction coefficients into a sequence of LSP (Line Spectrum Pair) parameters which are parameters in a frequency domain and equivalent to the linear prediction coefficients and sends an LSP code obtained by coding the sequence of LSP parameters to a decoding device.

In Non-patent Literature 1, in order to reduce the code amount of the LSP code, a vector coding and decoding technology using moving average prediction (MA prediction) is used.

First, the flow of coding processing will be described.

<Linear Prediction Coefficient Coding Device **80**>

**80**.

To the linear prediction coefficient coding device **80**, LSP (Line Spectrum Pairs) parameters θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p] of each frame are input, and the linear prediction coefficient coding device **80** performs the following processing of a predictive subtraction unit **83**, a vector coding unit **84**, and a delay input unit **87** on a frame-by-frame basis, obtains an LSP code C_{f}, and outputs the LSP code C_{f}. Incidentally, f represents a frame number and p represents a prediction order.

When an input sound signal X_{f }is input to the linear prediction coefficient coding device **80**, the linear prediction coefficient coding device **80** is also provided with a linear prediction analysis unit **81** and an LSP calculation unit **82**, and the frame-by-frame input sound signals X_{f }are consecutively input thereto and the following processing is performed on a frame-by-frame basis.

Hereinafter, specific processing of each unit will be described.

<Linear Prediction Analysis Unit **81**>

The linear prediction analysis unit **81** receives the input sound signal X_{f}, performs linear prediction analysis on the input sound signal X_{f}, obtains linear prediction coefficients a_{f}[1], a_{f}[2], . . . , a_{f}[p], and outputs the linear prediction coefficients a_{f}[1], a_{f}[2], . . . , a_{f}[p]. Here, a_{f}[i] represents an ith-order linear prediction coefficient that is obtained by performing linear prediction analysis on an input sound signal X_{f }of an fth frame.

<LSP Calculation Unit **82**>

The LSP calculation unit **82** receives the linear prediction coefficients a_{f}[1], a_{f}[2], . . . , a_{f}[p], obtains LSP parameters θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p] from the linear prediction coefficients a_{f}[1], a_{f}[2], . . . , a_{f}[p], and outputs an LSP parameter vector Θ_{f}=(θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p])^{T }that is a vector using the obtained LSP parameters as elements thereof. Here, θ_{f}[i] is an ith-order LSP parameter corresponding to the input sound signal X_{f }of the fth frame.

<Predictive Subtraction Unit **83**>

The predictive subtraction unit **83** is formed of, for example, a storage **83***c *storing a predetermined coefficient α, a storage **83***d *storing a predictive mean vector V, a multiplication unit **88**, and subtraction units **83***a *and **83***b. *

The predictive subtraction unit **83** receives the LSP parameter vector Θ_{f }and a preceding-frame quantization differential vector {circumflex over ( )}S_{f-1}.

The predictive subtraction unit **83** generates a differential vector S_{f}=Θ_{f}−V−α×{circumflex over ( )}S_{f-1}=(s_{f}[1], s_{f}[2], . . . , s_{f}[p])^{T }that is a vector obtained by subtracting the predictive mean vector V and a vector α{circumflex over ( )}S_{f-1 }from the LSP parameter vector Θ_{f }and outputs the differential vector S_{f}.

Incidentally, the predictive mean vector V=(v[1], v[2], . . . , v[p])^{T }is a predetermined vector stored in the storage **83***d *and simply has to be obtained in advance from, for example, a sound signal for learning. For example, in the linear prediction coefficient coding device **80**, by using a sound signal picked up in the same environment (for instance, the same speaker, sound pick-up device, and place) as the sound signal to be coded as an input sound signal for learning, LSP parameter vectors of many frames are obtained, and the average thereof is used as the predictive mean vector.

The multiplication unit **88** obtains a vector α×{circumflex over ( )}S_{f-1 }by multiplying a decoded differential vector {circumflex over ( )}S_{f-1 }of a preceding frame by the predetermined coefficient α stored in the storage **83***c. *

Incidentally, in **83***a *and **83***b*, first, after the predictive mean vector V stored in the storage **83***d *is subtracted from the LSP parameter vector Θ_{f }in the subtraction unit **83***a*, the vector α×{circumflex over ( )}S_{f-1 }is subtracted in the subtraction unit **83***b*, but the above may be performed the other way around. Alternatively, the differential vector S_{f }may be generated by subtracting, from the LSP parameter vector Θ_{f}, a vector V+α×{circumflex over ( )}S_{f-1 }obtained by adding the predictive mean vector V and the vector α×{circumflex over ( )}S_{f-1}.

The differential vector S_{f }of the present frame may also be called a vector that is obtained by subtracting a vector containing at least a prediction based on a past frame from a vector (an LSP parameter vector Θ_{f}) based on coefficients which are convertible into linear prediction coefficients of more than one order of the present frame.

<Vector Coding Unit **84**>

The vector coding unit **84** receives the differential vector S_{f}, codes the differential vector S_{f}, and obtains an LSP code C_{f }and a quantization differential vector {circumflex over ( )}S_{f}=({circumflex over ( )}s_{f}[1], {circumflex over ( )}s_{f}[2], . . . , {circumflex over ( )}s_{f}[p])^{T }corresponding to the LSP code C_{f }and outputs the LSP code C_{f }and the quantization differential vector {circumflex over ( )}S_{f}. For coding of the differential vector S_{f}, any one of the well-known coding methods may be used, such as a method of vector quantizing the differential vector S_{f}, a method of dividing the differential vector S_{f }into a plurality of subvectors and vector quantizing each of the subvectors, a method of multistage vector quantizing the differential vector S_{f }or the subvectors, a method of scalar quantizing the elements of a vector, and a method obtained by combining these methods.

Here, an example of a case in which the method of vector quantizing the differential vector S_{f }is used will be described.

The vector coding unit **84** searches for a candidate differential vector closest to the differential vector S_{f }from a plurality of candidate differential vectors stored in a vector codebook **86** and outputs the candidate differential vector as the quantization differential vector {circumflex over ( )}S_{f}, and outputs a differential vector code corresponding to the quantization differential vector {circumflex over ( )}S_{f }as the LSP code C_{f}. Incidentally, the quantization differential vector {circumflex over ( )}S_{f }corresponds to a decoded differential vector which will be described later.

<Vector Codebook **86**>

In the vector codebook **86**, candidate differential vectors and differential vector codes corresponding to the candidate differential vectors are stored in advance.

<Delay Input Unit **87**>

The delay input unit **87** receives the quantization differential vector {circumflex over ( )}S_{f}, holds the quantization differential vector {circumflex over ( )}S_{f}, delays the quantization differential vector {circumflex over ( )}S_{f }by one frame, and outputs the resultant vector as a preceding-frame quantization differential vector {circumflex over ( )}S_{f-1}. That is, if the predictive subtraction unit **83** has performed processing on a quantization differential vector {circumflex over ( )}S_{f }of an fth frame, the delay input unit **87** outputs a quantization differential vector {circumflex over ( )}S_{f-1 }on an f−1th frame.

<Linear Prediction Coefficient Decoding Device **90**>

**90**. To the linear prediction coefficient decoding device **90**, frame-by-frame LSP codes C_{f }are consecutively input, and the linear prediction coefficient decoding device **90** obtains a decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f}=({circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p]) by decoding the LSP code C_{f }on a frame-by-frame basis.

Hereinafter, specific processing of each unit will be described.

<Vector Decoding Unit **91**>

A vector decoding unit **91** receives the LSP code C_{f}, decodes the LSP code C_{f}, obtains a decoded differential vector {circumflex over ( )}S_{f }corresponding to the LSP code C_{f}, and outputs the decoded differential vector {circumflex over ( )}S_{f}. For decoding of the LSP code C_{f}, a decoding method corresponding to the coding method adopted by the vector coding unit **84** of the coding device is used.

Here, an example of a case in which a decoding method corresponding to the method adopted by the vector coding unit **84**, the method of vector quantizing the differential vector S_{f}, is used will be described.

The vector decoding unit **91** searches for a plurality of differential vector codes corresponding to the LSP code C_{f }from differential vector codes stored in a vector codebook **92** and outputs a candidate differential vector corresponding to the differential vector codes as the decoded differential vector {circumflex over ( )}S_{f}. Incidentally, the decoded differential vector {circumflex over ( )}S_{f }corresponds to the above-described quantization differential vector {circumflex over ( )}S_{f }and corresponding elements take the same values if there are no transmission errors and no errors and the like in the course of coding and decoding.

<Vector Codebook **92**>

In the vector codebook **92**, the candidate differential vectors and the differential vector codes corresponding to the candidate differential vectors are stored in advance. Incidentally, the vector codebook **92** shares information in common with the vector codebook **86** of the above-described linear prediction coefficient coding device **80**.

<Delay Input Unit **93**>

A delay input unit **93** receives the decoded differential vector {circumflex over ( )}S_{f}, holds the decoded differential vector {circumflex over ( )}S_{f}, delays the decoded differential vector {circumflex over ( )}S_{f }by one frame, and outputs the resultant vector as a preceding-frame decoded differential vector {circumflex over ( )}S_{f-1}. That is, if a predictive addition unit **95** performs processing on a decoded differential vector {circumflex over ( )}S_{f }of an fth frame, the delay input unit **93** outputs a decoded differential vector {circumflex over ( )}S_{f-1 }of an f−1th frame.

<Predictive Addition Unit **95**>

A predictive addition unit **95** is formed of, for example, a storage **95***c *storing a predetermined coefficient α, a storage **95***d *storing a predictive mean vector V, a multiplication unit **94**, and addition units **95***a *and **95***b. *

The predictive addition unit **95** receives the decoded differential vector {circumflex over ( )}S_{f }of the present frame and the preceding-frame decoded differential vector {circumflex over ( )}S_{f-1}.

The predictive addition unit **95** generates a decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f}(={circumflex over ( )}S_{f}+V+α{circumflex over ( )}S_{f-1}) that is a vector obtained by adding the decoded differential vector {circumflex over ( )}S_{f}, the predictive mean vector V=(v[1], v[2], . . . , v[N])^{T}, and a vector α×{circumflex over ( )}S_{f-1 }and outputs the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f}.

The multiplication unit **94** obtains the vector α×{circumflex over ( )}S_{f-1 }by multiplying the preceding-frame decoded differential vector {circumflex over ( )}S_{f-1 }by the predetermined coefficient α stored in the storage **95***c. *

In **95***a *and **95***b*, first, after the vector α×{circumflex over ( )}S_{f-1 }is added to the decoded differential vector {circumflex over ( )}S_{f }of the present frame in the addition unit **95***a*, the predictive mean vector V is added in the addition unit **95***b*, but the above may be performed the other way around. Alternatively, the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f }may be generated by adding a vector obtained by adding the vector α×{circumflex over ( )}S_{f-1 }and the predictive mean vector V to the decoded differential vector {circumflex over ( )}S_{f}.

Incidentally, it is assumed that the predictive mean vector V used here is the same as the predictive mean vector V used in the predictive subtraction unit **83** of the above-described linear prediction coefficient coding device **80**.

<Decoded Predictive Linear Prediction Coefficient Calculation Unit **96**>

If linear prediction coefficients are necessary, the linear prediction coefficient decoding device **90** may be provided with a decoded predictive linear prediction coefficient calculation unit **96**. In this case, the decoded predictive linear prediction coefficient calculation unit **96** receives the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f}, converts the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f }into decoded predictive linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p], and outputs the decoded predictive linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p].

**PRIOR ART LITERATURE**

**Non-Patent Literature**

Non-patent Literature 1: “ITU-T Recommendation G.729”, ITU, 1996

**SUMMARY OF THE INVENTION**

**Problems to be Solved by the Invention**

In the linear prediction coefficient decoding device of Non-patent Literature 1, since decoding processing of an fth frame is performed by using the decoded differential vector {circumflex over ( )}S_{f-1 }which is the decoding result of an f−1th frame, not only when a transmission error occurs in an LSP code of the present frame, but also when a transmission error occurs in an LSP code of the immediately preceding frame, LSP parameters of the present frame also cannot be decoded correctly.

In the linear prediction coefficient decoding device of Non-patent Literature 1, since the LSP parameters obtained by decoding are used only for linear prediction synthesis, even when the LSP parameters cannot be decoded correctly, this merely causes a reduction in the sound quality of the decoded sound signal in a plurality of consecutive frames. That is, it can be said that the linear prediction coefficient coding device and the linear prediction coefficient decoding device of Non-patent Literature 1 have a configuration which gives a higher priority to expressing the LSP parameters with a small code amount than to a problem which will arise when the LSP parameters cannot be decoded correctly.

However, the linear prediction coefficient coding device and the linear prediction coefficient decoding device are also used in a coding device and a decoding device which use the LSP parameters not only for linear prediction analysis and synthesis, but also for variable-length coding and decoding depending on the amplitude values forming a spectral envelope which is determined from the LSP parameters. In this case, the following problem arises: if the LSP parameters cannot be decoded correctly in one frame, variable-length decoding cannot be performed correctly in a plurality of consecutive frames including that frame, which makes it impossible to obtain a decoded sound signal.

In view of such a problem, an object of the present invention is to provide a coding method and a decoding method of coding and decoding coefficients which are convertible into linear prediction coefficients, the coding method and the decoding method that can use in combination predictive coding method and decoding method which are a coding method and a decoding method that can accurately express coefficients which are convertible into linear prediction coefficients with a small code amount, the coefficients such as those used in linear prediction analysis and synthesis, for example, and a coding method and a decoding method which can obtain correctly, by decoding, coefficients which are convertible into linear prediction coefficients of the present frame, even when a linear prediction coefficient code (for example, an LSP code) that is a code corresponding to coefficients which are convertible into linear prediction coefficients of a preceding frame, the coefficients such as those used in variable-length coding/decoding depending on the amplitude values forming a spectral envelope which is determined from LSP parameters, for example, is not correctly input to a linear prediction coefficient decoding device, if a linear prediction coefficient code of the present frame is correctly input to the linear prediction coefficient decoding device.

**Means to Solve the Problems**

In order to solve the above-described problem, according to one aspect of the present invention, a coding device includes: a predictive coding unit that obtains a first code by coding a differential vector formed of differentials between a vector of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame and a prediction vector containing at least a predicted vector from a past frame, and obtains a quantization differential vector corresponding to the first code; and a non-predictive coding unit that generates a second code by coding a correction vector which is formed of differentials between the vector of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame and the quantization differential vector or formed of some of elements of the differentials.

In order to solve the above-described problem, according to another aspect of the present invention, a coding device includes: a predictive coding unit that obtains a first code by coding a differential vector formed of differentials between a vector of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame and a prediction vector formed of at least a prediction based on a past frame and a predetermined vector, and obtains a quantization differential vector corresponding to the first code; and a non-predictive coding unit that generates a second code by coding a correction vector which is formed of differentials obtained by subtracting the quantization differential vector and the predetermined vector from the vector of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame or formed of some of elements of the differentials.

In order to solve the above-described problem, according to another aspect of the present invention, a decoding device includes: a predictive decoding unit that obtains a decoded differential vector by decoding a first code and generates a first decoded vector formed of decoded values of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame by adding the decoded differential vector and a prediction vector containing at least a prediction based on a past frame; and a non-predictive decoding unit that obtains a decoded correction vector by decoding a second code and generates a second decoded vector formed of decoded values of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame by adding elements of the decoded correction vector and at least elements of corresponding orders of the decoded differential vector.

In order to solve the above-described problem, according to another aspect of the present invention, a decoding device includes: a predictive decoding unit that obtains a decoded differential vector by decoding a first code and generates a first decoded vector formed of decoded values of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame by adding the decoded differential vector and a prediction vector formed of at least a prediction based on a past frame and a predetermined vector; and a non-predictive decoding unit that obtains a decoded correction vector by decoding a second code and generates a second decoded vector formed of decoded values of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame by adding, to the decoded correction vector, at least the decoded differential vector and the predetermined vector for each of elements of corresponding orders.

In order to solve the above-described problem, according to another aspect of the present invention, a coding method includes: a predictive coding step of obtaining a first code by coding a differential vector formed of differentials between a vector of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame and a prediction vector containing at least a predicted vector from a past frame, and obtaining a quantization differential vector corresponding to the first code; and a non-predictive coding step of generating a second code by coding a correction vector which is formed of differentials between the vector of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame and the quantization differential vector or formed of some of elements of the differentials.

In order to solve the above-described problem, according to another aspect of the present invention, a coding method includes: a predictive coding step of obtaining a first code by coding a differential vector formed of differentials between a vector of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame and a prediction vector formed of at least a prediction based on a past frame and a predetermined vector, and obtaining a quantization differential vector corresponding to the first code; and a non-predictive coding step of generating a second code by coding a correction vector which is formed of differentials obtained by subtracting the quantization differential vector and the predetermined vector from the vector of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame or formed of some of elements of the differentials.

In order to solve the above-described problem, according to another aspect of the present invention, a decoding method includes: a predictive decoding step of obtaining a decoded differential vector by decoding a first code and generating a first decoded vector formed of decoded values of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame by adding the decoded differential vector and a prediction vector containing at least a prediction based on a past frame; and a non-predictive decoding step of obtaining a decoded correction vector by decoding a second code and generating a second decoded vector formed of decoded values of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame by adding elements of the decoded correction vector and at least elements of corresponding orders of the decoded differential vector.

In order to solve the above-described problem, according to another aspect of the present invention, a decoding method includes: a predictive decoding step of obtaining a decoded differential vector by decoding a first code and generating a first decoded vector formed of decoded values of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame by adding the decoded differential vector and a prediction vector formed of at least a prediction based on a past frame and a predetermined vector; and a non-predictive decoding step of obtaining a decoded correction vector by decoding a second code and generating a second decoded vector formed of decoded values of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame by adding, to the decoded correction vector, at least the decoded differential vector and the predetermined vector for each of elements of corresponding orders.

**Effects of the Invention**

The present invention produces the effect of being able to use in combination predictive coding method and decoding method which are a coding method and a decoding method that can accurately express coefficients which are convertible into linear prediction coefficients with a small code amount and a coding method and a decoding method which can obtain correctly, by decoding, coefficients which are convertible into linear prediction coefficients of the present frame, even when a linear prediction coefficient code of a preceding frame is not correctly input to a linear prediction coefficient decoding device, if a linear prediction coefficient code of the present frame is correctly input to the linear prediction coefficient decoding device.

**BRIEF DESCRIPTION OF THE DRAWINGS**

**DETAILED DESCRIPTION OF THE EMBODIMENTS**

Hereinafter, embodiments of the present invention will be described. Incidentally, in the drawings which are used in the following description, component elements having the same function and steps in which the same processing is performed are identified with the same characters and overlapping explanations will be omitted. In the following description, symbols such as “{circumflex over ( )}”, “{tilde over ( )}”, and “

**First Embodiment**

Hereinafter, differences from the existing linear prediction coefficient coding device and linear prediction coefficient decoding device will be mainly described.

<Linear Prediction Coefficient Coding Device **100** According to the First Embodiment>

**100** according to the first embodiment, and

The linear prediction coefficient coding device **100** includes a linear prediction analysis unit **81**, an LSP calculation unit **82**, a predictive coding unit **120**, and a non-predictive coding unit **110**. The processing which is performed in the linear prediction analysis unit **81** and the LSP calculation unit **82** is the same as that described in the existing technology and corresponds to s**81** and s**82** of

The linear prediction coefficient coding device **100** receives a sound signal X_{f}, obtains an LSP code C_{f }and a correction LSP code D_{f}, and outputs the LSP code C_{f }and the correction LSP code D_{f}. The codes output from the linear prediction coefficient coding device **100** are input to a linear prediction coefficient decoding device **200**. Incidentally, if an LSP parameter vector Θ_{f}=(θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p])^{T }derived from the sound signal X_{f }is generated by another device and the input of the linear prediction coefficient coding device **100** is the LSP parameter vector Θ_{f}, the linear prediction coefficient coding device **100** does not have to include the linear prediction analysis unit **81** and the LSP calculation unit **82**.

<Predictive Coding Unit **120**>

The predictive coding unit **120** includes a predictive subtraction unit **83**, a vector coding unit **84**, a vector codebook **86**, and a delay input unit **87**, and the processing which is performed in each unit is the same as that described in the existing technology. The processing which is performed in the predictive subtraction unit **83**, the vector coding unit **84**, and the delay input unit **87** corresponds to s**83** to s**87**, respectively, of **84** outputs the quantization differential vector {circumflex over ( )}S_{f }not only to the delay input unit **87**, but also to the non-predictive coding unit **110**.

The predictive coding unit **120** receives the LSP parameter vector Θ_{f}, codes a differential vector S_{f }formed of differentials between the LSP parameter vector Θ_{f }and a prediction vector containing at least a prediction based on a past frame, obtains an LSP code C_{f }and a quantization differential vector {circumflex over ( )}S_{f }corresponding to the LSP code C_{f }(s**120**), and outputs the LSP code C_{f }and the quantization differential vector {circumflex over ( )}S_{f}. Incidentally, the quantization differential vector {circumflex over ( )}S_{f }corresponding to the LSP code C_{f }is a vector formed of quantization values corresponding to the element values of the differential vector S_{f}.

Here, the prediction vector containing at least a prediction based on a past frame is, for example, a vector V+α×{circumflex over ( )}S_{f-1 }obtained by adding a predetermined predictive mean vector V and a vector obtained by multiplying each element of a quantization differential vector (a preceding-frame quantization differential vector) {circumflex over ( )}S_{f-1 }of the immediately preceding frame by predetermined α. In this example, the vector representing a prediction based on a past frame, the prediction contained in the prediction vector, is α×{circumflex over ( )}S_{f-1 }which is α times as long as the preceding-frame quantization differential vector {circumflex over ( )}S_{f-1}.

Incidentally, since the predictive coding unit **120** does not need any input from the outside other than the LSP parameter vector Θ_{f}, it can be said that the predictive coding unit **120** obtains the LSP code C_{f }by coding the LSP parameter vector Θ_{f}.

Moreover, though a predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f }is not generated in the predictive coding unit **120**, it can be said that the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f }obtained by quantizing the elements of the LSP parameter vector Θ_{f }in the predictive coding unit **120** is what is obtained by adding the prediction vector V+α×{circumflex over ( )}S_{f-1 }to the quantization differential vector {circumflex over ( )}S_{f}. That is, the predictive quantization LSP parameter vector is {circumflex over ( )}Θ_{f}={circumflex over ( )}S_{f}+V+α×{circumflex over ( )}S_{f-1}. Furthermore, a quantization error vector in the predictive coding unit **120** is Θ_{f}−{circumflex over ( )}Θ_{f}=Θ_{f}−({circumflex over ( )}S_{f}+V+α×{circumflex over ( )}S_{f-1}).

<Non-Predictive Coding Unit **110**>

The non-predictive coding unit **110** includes a non-predictive subtraction unit **111**, a correction vector coding unit **112**, and a correction vector codebook **113**.

The non-predictive coding unit **110** receives the LSP parameter vector Θ_{f }and the quantization differential vector {circumflex over ( )}S_{f}, and obtains a correction LSP code D_{f }by coding a correction vector which is a differential between the LSP parameter vector Θ_{f }and the quantization differential vector {circumflex over ( )}S_{f }and outputs the correction LSP code D_{f }(s**110**).

Here, since the correction vector is Θ_{f}−{circumflex over ( )}S_{f }and the quantization error vector of the predictive coding unit **120** is Θ_{f}−{circumflex over ( )}Θ_{f}=Θ_{f}−({circumflex over ( )}S_{f}+V+α×S_{f-1}), the correction vector is what is obtained by adding the quantization error vector Θ_{f}−{circumflex over ( )}Θ_{f }of the predictive coding unit **120**, the predictive mean vector V, and α×{circumflex over ( )}S_{f-1 }which is the preceding-frame quantization differential vector multiplied by α. That is, it can be said that the non-predictive coding unit **110** obtains the correction LSP code D_{f }by coding what is obtained by adding the quantization error vector Θ_{f}−{circumflex over ( )}Θ_{f }and the prediction vector V+α×{circumflex over ( )}S_{f-1}.

Any one of the well-known coding methods may be used for coding the correction vector Θ_{f}−{circumflex over ( )}S_{f}; in the following description, a method of vector quantizing what is obtained by subtracting a non-predictive mean vector Y from the correction vector Θ_{f}−{circumflex over ( )}S_{f }will be described. Incidentally, in the following description, U_{f}=Θ_{f}−Y−{circumflex over ( )}S_{f }that is a vector obtained by subtracting the non-predictive mean vector Y from the correction vector Θ_{f}−{circumflex over ( )}S_{f }is referred to as a correction vector for descriptive purposes.

Hereinafter, processing of each unit will be described.

<Non-Predictive Subtraction Unit **111**>

The non-predictive subtraction unit **111** is formed of, for example, a storage **111***c *storing the non-predictive mean vector Y and subtraction units **111***a *and **111***b. *

The non-predictive subtraction unit **111** receives the LSP parameter vector Θ_{f}=(θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p])^{T }output from the LSP calculation unit **82** and the quantization differential vector {circumflex over ( )}S_{f}.

The non-predictive subtraction unit **111** generates a correction vector U_{f}=Θ_{f}−Y−{circumflex over ( )}S_{f }that is a vector obtained by subtracting the quantization differential vector {circumflex over ( )}S_{f}=({circumflex over ( )}s_{f}[1], {circumflex over ( )}s_{f}[2], . . . , {circumflex over ( )}s_{f}[p])^{T }and the non-predictive mean vector Y=(y[1], y[2], . . . , y[p])^{T }from the LSP parameter vector Θ_{f}=(θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p])^{T }(s**111**), and outputs the correction vector U_{f}.

Incidentally, in **111***a *and **111***b*, first, after the non-predictive mean vector Y stored in the storage **111***c *is subtracted from the LSP parameter vector Θ_{f }in the subtraction unit **111***a*, the quantization differential vector {circumflex over ( )}S_{f }is subtracted in the subtraction unit **111***b*, but these subtractions may be performed the other way around. Alternatively, the correction vector U_{f }may be generated by subtracting a vector obtained by adding the non-predictive mean vector Y and the quantization differential vector {circumflex over ( )}S_{f }from the LSP parameter vector Θ_{f}.

Incidentally, the non-predictive mean vector Y is a predetermined vector and simply has to be obtained in advance from, for example, a sound signal for learning. For example, in the corresponding linear prediction coefficient coding device **100**, by using a sound signal picked up in the same environment (for instance, the same speaker, sound pick-up device, and place) as the sound signal to be coded as an input sound signal for learning, differentials between the LSP parameter vectors and the quantization differential vectors for the LSP parameter vectors of many frames are obtained, and the average of the differentials is used as the non-predictive mean vector.

<Correction Vector Codebook **113**>

In the correction vector codebook **113**, candidate correction vectors and correction vector codes corresponding to the candidate correction vectors are stored.

<Correction Vector Coding Unit **112**>

The correction vector coding unit **112** receives the correction vector U_{f}, codes the correction vector U_{f}, obtains the correction LSP code D_{f }(s**112**), and outputs the correction LSP code D_{f}. For example, the correction vector coding unit **112** searches for a candidate correction vector closest to the correction vector U_{f }from the plurality of candidate correction vectors stored in the correction vector codebook **113** and outputs the correction vector code corresponding to that candidate correction vector as the correction LSP code D_{f}. Incidentally, although actual generation thereof does not have to be performed in the correction vector coding unit **112**, the following description will be given on the assumption that a candidate correction vector closest to the correction vector U_{f }is a quantized correction vector {circumflex over ( )}U_{f}.

Incidentally, as described earlier, since the correction vector contains at least the preceding-frame quantization differential vector {circumflex over ( )}S_{f-1 }which is the prediction of the predictive coding unit **120** based on the preceding frame, it can be said that the correction vector coding unit **112** codes at least the prediction of the predictive coding unit **120** based on the preceding frame.

Moreover, although generation thereof does not have to be performed in the non-predictive coding unit **110**, a non-predictive quantization LSP parameter vector {circumflex over ( )}Φ_{f }obtained by quantizing the elements of the LSP parameter vector Θ_{f }in the non-predictive coding unit **110** is what is obtained by adding the non-predictive mean vector Y, the quantization differential vector {circumflex over ( )}S_{f}, and the quantized correction vector {circumflex over ( )}U_{f}. That is, {circumflex over ( )}Φ_{f}={circumflex over ( )}U_{f}+Y+{circumflex over ( )}S_{f }holds.

<Linear Prediction Coefficient Decoding Device **200** According to the First Embodiment>

Hereinafter, differences from the existing example will be mainly described.

**200** according to the first embodiment, and

The linear prediction coefficient decoding device **200** includes a predictive decoding unit **220** and a non-predictive decoding unit **210**.

The linear prediction coefficient decoding device **200** receives the LSP code C_{f }and the correction LSP code D_{f}, generates a decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f}=({circumflex over ( )}0_{f}[1], {circumflex over ( )}0_{f}[2], . . . , {circumflex over ( )}0_{f}[p]) and a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}=({circumflex over ( )}ϕ_{f}[1], {circumflex over ( )}ϕ_{f}[2], . . . , {circumflex over ( )}ϕ_{f}[p]), and outputs the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f }and the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}. Moreover, when necessary, the linear prediction coefficient decoding device **200** generates decoded predictive linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p] and decoded non-predictive linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p] which are obtained by converting the decoded predictive LSP parameters {circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p] and the decoded non-predictive LSP parameters {circumflex over ( )}ϕ_{f}[1], {circumflex over ( )}ϕ_{f}[2], . . . , {circumflex over ( )}ϕ_{f}[p] respectively into linear prediction coefficients, and outputs the decoded predictive linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p] and the decoded non-predictive linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p].

<Predictive Decoding Unit **220**>

The predictive decoding unit **220** has a configuration similar to that of the linear prediction coefficient decoding device **90** of the existing technology, and the predictive decoding unit **220** includes a vector codebook **92**, a vector decoding unit **91**, a delay input unit **93**, and a predictive addition unit **95** and, when necessary, also includes a decoded predictive linear prediction coefficient calculation unit **96**. The processing which is performed in the vector decoding unit **91**, the delay input unit **93**, the predictive addition unit **95**, and the decoded predictive linear prediction coefficient calculation unit **96** corresponds to s**91** to s**96**, respectively, of

The predictive decoding unit **220** receives the LSP code C_{f}, obtains a decoded differential vector {circumflex over ( )}S_{f }by decoding the LSP code C_{f}, generates a decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f}=({circumflex over ( )}Θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p]) formed of decoded values {circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p] of the elements of the LSP parameter vector by adding the decoded differential vector {circumflex over ( )}S_{f }and a prediction vector containing at least a prediction based on a past frame (s**220**), and outputs the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f}. When necessary, the predictive decoding unit **220** further converts the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f }into decoded predictive linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p] (s**220**) and outputs the decoded predictive linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p].

In the present embodiment, the prediction vector is a vector (V+α×{circumflex over ( )}S_{f-1}) obtained by adding the predetermined predictive mean vector V and what is obtained by multiplying the decoded differential vector {circumflex over ( )}S_{f-1 }of a past frame by a factor of α.

Incidentally, the vector decoding unit **91** outputs the decoded differential vector {circumflex over ( )}S_{f }also to a non-predictive addition unit **213** of the non-predictive decoding unit **210** in addition to the delay input unit **93** and the predictive addition unit **95**.

<Non-Predictive Decoding Unit **210**>

The non-predictive decoding unit **210** includes a correction vector codebook **212**, a correction vector decoding unit **211**, and the non-predictive addition unit **213** and, when necessary, also includes a decoded non-predictive linear prediction coefficient calculation unit **214**.

To the non-predictive decoding unit **210**, the correction LSP code D_{f }and the decoded differential vector {circumflex over ( )}S_{f }are input. The non-predictive decoding unit **210** obtains a decoded correction vector {circumflex over ( )}U_{f}=({circumflex over ( )}u_{f}[1], {circumflex over ( )}u_{f}[2], . . . , {circumflex over ( )}u_{f}[p])^{T }by decoding the correction LSP code D_{f}. The non-predictive decoding unit **210** further generates a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}=({circumflex over ( )}ϕ_{f}[1], {circumflex over ( )}ϕ_{f}[2], . . . , {circumflex over ( )}ϕ_{f}[p]) formed of decoded values {circumflex over ( )}ϕ_{f}[1], {circumflex over ( )}ϕ_{f}[2], . . . , {circumflex over ( )}ϕ_{f}[p] of the elements of the LSP parameter vector of the present frame by adding at least the decoded differential vector {circumflex over ( )}S_{f }to the decoded correction vector {circumflex over ( )}U_{f }(s**210**) and outputs the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}. When necessary, the non-predictive decoding unit **210** further converts the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }into decoded non-predictive linear prediction coefficients {circumflex over ( )}b_{f[}1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p] (s**210**) and outputs the decoded non-predictive linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p].

In the present embodiment, the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }is a vector obtained by adding the decoded differential vector {circumflex over ( )}S_{f }obtained by decoding the LSP code C_{f }and the predetermined non-predictive mean vector Y to the decoded correction vector {circumflex over ( )}U_{f }obtained by decoding the correction LSP code D_{f}. That is, in the non-predictive decoding unit **210**, the decoded vector {circumflex over ( )}Φ_{f }of the LSP parameter vector of the present frame is obtained only from the codes input in the present frame.

Hereinafter, the details of processing of each unit will be described.

<Correction Vector Codebook **212**>

The correction vector codebook **212** stores the information with the same contents as those of the correction vector codebook **113** in the linear prediction coefficient coding device **100**. That is, in the correction vector codebook **212**, candidate correction vectors and correction vector codes corresponding to the candidate correction vectors are stored.

<Correction Vector Decoding Unit **211**>

The correction vector decoding unit **211** receives the correction LSP code D_{f}, obtains the decoded correction vector {circumflex over ( )}U_{f }by decoding the correction LSP code D_{f }(s**211**), and outputs the decoded correction vector {circumflex over ( )}U_{f}. For example, the correction vector decoding unit **211** searches for a correction vector code corresponding to the correction LSP code D_{f }input to the linear prediction coefficient decoding device **200** from the plurality of correction vector codes stored in the correction vector codebook **212** and outputs a candidate correction vector corresponding to the correction vector code obtained by the search as the decoded correction vector {circumflex over ( )}U_{f}.

<Non-Predictive Addition Unit **213**>

The non-predictive addition unit **213** is formed of, for example, a storage **213***c *storing a non-predictive mean vector Y and addition units **213***a *and **213***b. *

The non-predictive addition unit **213** receives the decoded correction vector {circumflex over ( )}U_{f }and the decoded differential vector {circumflex over ( )}S_{f}. The non-predictive addition unit **213** generates a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}={circumflex over ( )}U_{f}+Y+{circumflex over ( )}S_{f}=({circumflex over ( )}ϕ_{f}[1], {circumflex over ( )}ϕ_{f}[2], . . . , {circumflex over ( )}ϕ_{f}[p]) obtained by adding the decoded correction vector {circumflex over ( )}U_{f}, the decoded differential vector {circumflex over ( )}S_{f}, and the non-predictive mean vector Y stored in the storage **213***c *(s**213**) and outputs the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}. Incidentally, in **213***a *and **213***b*, first, after the decoded differential vector {circumflex over ( )}S_{f }is added to the decoded correction vector {circumflex over ( )}U_{f }in the addition unit **213***a*, the non-predictive mean vector Y stored in the storage **213***c *is added in the addition unit **213***b*, but these additions may be performed the other way around. Alternatively, the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }may be generated by adding a vector obtained by adding the non-predictive mean vector Y and the decoded differential vector {circumflex over ( )}S_{f }to the decoded correction vector {circumflex over ( )}U_{f}.

Incidentally, it is assumed that the non-predictive mean vector Y used here is the same as the non-predictive mean vector Y used in the non-predictive subtraction unit **111** of the above-described linear prediction coefficient coding device **100**.

<Decoded Non-Predictive Linear Prediction Coefficient Calculation Unit **214**>

The decoded non-predictive linear prediction coefficient calculation unit **214** receives the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}. The decoded non-predictive linear prediction coefficient calculation unit **214** converts the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }into decoded non-predictive linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p] (s**214**) and outputs the decoded non-predictive linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p].

<Effect of the First Embodiment>

With the linear prediction coefficient decoding device of the first embodiment, even when the decoded differential vector {circumflex over ( )}S_{f-1 }cannot be decoded correctly due to a transmission error occurred in an LSP code C_{f-1 }of an f−1th frame, since the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }which is a decoded value of the LSP parameter vector which does not depend on the decoded differential vector {circumflex over ( )}S_{f-1 }is obtained in the non-predictive decoding unit **210**, it is possible to prevent the transmission error in the LSP code C_{f-1 }of the f−1th frame from affecting the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }of an fth frame. For example, when the non-predictive quantization LSP parameter vector/decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }is used as an LSP parameter vector which is used in variable-length coding/decoding depending on the amplitude values forming a spectral envelope which is determined from an LSP parameter vector, even when a correct decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }cannot be obtained in the f−1th frame and variable-length decoding cannot be performed correctly, a correct decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }is obtained in the fth frame and variable-length decoding can be performed correctly.

Incidentally, since the correction vector does not have to be quantized accurately to such an extent that the LSP parameter vector is quantized (in such a way that a quantization error becomes smaller), the number of types of candidate correction vectors prepared in the correction vector codebook **113** may be small. For example, the bit length of the correction vector code is 2-bit, and, in the correction vector codebook **113**, four types of candidate correction vectors corresponding to four types of correction vector codes (“00” “01” “10” “11”) are stored.

This makes it possible to reduce the number of types of candidate correction vectors prepared in the correction vector codebook and thereby assign a code with a small code amount. As a result, with an increase in a small code amount, it is possible to implement coding and decoding in which less distortion occurs than in the existing example.

<Modification>

In the present embodiment, LSP parameters are described, but other coefficients may be used as long as the coefficients are coefficients which are convertible into linear prediction coefficients of more than one order. The above may be applied to PARCOR coefficients, coefficients obtained by transforming the LSP parameters or PARCOR coefficients, and linear prediction coefficients themselves. All of these coefficients can be converted into one another in the technical field of speech coding, and the effect of the first embodiment can be obtained by using any one of these coefficients. Incidentally, the LSP code C_{f }or a code corresponding to the LSP code C_{f }is also referred to as a first code and the predictive coding unit is also referred to as a first coding unit. Likewise, the correction LSP code or a code corresponding to the correction LSP code is also referred to as a second code and the non-predictive coding unit is also referred to as a second coding unit. Moreover, the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f }or a vector corresponding to the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f }is also referred to as a first decoded vector and the predictive decoding unit is also referred to as a first decoding unit. Furthermore, the decoded non-predictive LSP parameter vector {circumflex over ( )}Θ_{f }or a vector corresponding to the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }is also referred to as a second decoded vector and the non-predictive decoding unit is also referred to as a second decoding unit.

In the present embodiment, only one frame is used as a “past frame”, but, if necessary, two frames or more may be used as appropriate.

**Second Embodiment**

Differences from the first embodiment will be mainly described.

In the present embodiment, it is determined whether or not to code a correction vector and decode a correction LSP code by using the magnitude of a change in the height difference in the waves of the amplitude of a spectral envelope, in other words, the peak-to-valley height of the spectral envelope.

If LSP parameters are coded by the same code amount irrespective of the magnitude of a change in the height difference in the waves of the amplitude of a spectral envelope, a quantization error observed when a change in the height difference in the waves of the amplitude of a spectral envelope is great is larger than a quantization error observed when a change in the height difference of the waves of the amplitude of a spectral envelope is small. Thus, a linear prediction coefficient coding device executes the correction vector coding unit only when a quantization error in LSP is deemed to be large and outputs a correction LSP code D_{f }and a linear prediction coefficient decoding device decodes the correction LSP code D_{f}, whereby it is possible to perform coding and decoding processing which suffers less reduction in the sound quality caused by a transmission error in a code than in the existing technology while reducing the code amount as a whole compared to the first embodiment.

<Linear Prediction Coefficient Coding Device **300** According to the Second Embodiment>

**300** according to the second embodiment, and

The linear prediction coefficient coding device **300** of the second embodiment includes a non-predictive coding unit **310** in place of the non-predictive coding unit **110**. As is the case with the linear prediction coefficient coding device **100** of the first embodiment, if LSP parameters θ derived from a sound signal X_{f }are generated by another device and the input of the linear prediction coefficient coding device **300** is the LSP parameters θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p], the linear prediction coefficient coding device **300** does not have to include the linear prediction analysis unit **81** and the LSP calculation unit **82**.

The non-predictive coding unit **310** includes a non-predictive subtraction unit **311**, a correction vector coding unit **312**, the correction vector codebook **113**, a predictive addition unit **314**, and an index calculation unit **315**. The difference lies in that it is determined whether or not to perform subtraction processing in the non-predictive subtraction unit **311** and perform coding processing in the correction vector coding unit **312** depending on the calculation result of the index calculation unit **315**.

Incidentally, the predictive coding unit **120** outputs a vector α×{circumflex over ( )}S_{f-1}, which is an output value of the multiplication unit **88**, in addition to a quantization differential vector {circumflex over ( )}S_{f}.

<Predictive Addition Unit **314**>

The predictive addition unit **314** is formed of, for example, a storage **314***c *storing a predictive mean vector V and addition units **314***a *and **314***b. *

The predictive addition unit **314** receives the quantization differential vector {circumflex over ( )}S_{f }of the present frame and the vector α×{circumflex over ( )}S_{f-1 }obtained by multiplying the preceding-frame quantization differential vector {circumflex over ( )}S_{f-1 }by a predetermined coefficient α.

The predictive addition unit **314** generates a predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}(={circumflex over ( )}S_{f}+V+α{circumflex over ( )}S_{f-1})=({circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p])^{T }that is a vector obtained by adding the quantization differential vector {circumflex over ( )}S_{f}, the predictive mean vector V, and the vector α×{circumflex over ( )}S_{f-1 }(s**314**) and outputs the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}.

In **314***a *and **314***b*, first, after the vector α×{circumflex over ( )}S_{f-1 }is added to the quantization differential vector {circumflex over ( )}S_{f }of the present frame in the addition unit **314***b*, the predictive mean vector V is added in the addition unit **314***a*, but the above may be performed the other way around. Alternatively, the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f }may be generated by adding a vector obtained by adding the vector α×{circumflex over ( )}S_{f-1 }and the predictive mean vector V to the quantization differential vector {circumflex over ( )}S_{f}.

Incidentally, since both the quantization differential vector {circumflex over ( )}S_{f }of the present frame and the vector α×{circumflex over ( )}S_{f-1 }obtained by multiplying the preceding-frame quantization differential vector {circumflex over ( )}S_{f-1 }by the predetermined coefficient α, the quantization differential vector {circumflex over ( )}S_{f }and the vector α×{circumflex over ( )}S_{f-1 }being input to the predictive addition unit **314**, are generated also in the predictive coding unit **120** and the predictive mean vector V stored in the storage **314***c *in the predictive addition unit **314** is the same as the predictive mean vector V stored in the storage **83***d *in the predictive coding unit **120**, a configuration may be adopted in which the predictive coding unit **120** generates the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f }by performing the processing which is performed by the predictive addition unit **314** and outputs the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f }to the non-predictive coding unit **310** and the predictive addition unit **314** is not provided in the non-predictive coding unit **310**.

<Index Calculation Unit **315**>

The index calculation unit **315** receives the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}. By using the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}, the index calculation unit **315** calculates an index Q commensurate with how high the peak-to-valley height of a spectral envelope is, the spectral envelope corresponding to the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}, that is, the index Q which increases with an increase in the peak-to-valley of the spectral envelope and/or an index Q′ commensurate with how short the peak-to-valley height of the spectral envelope is, that is, the index Q′ which decreases with an increase in the peak-to-valley of the spectral envelope (s**315**). In accordance with the magnitude of the index Q and/or Q′, the index calculation unit **315** outputs a control signal C to the correction vector coding unit **312** such that the correction vector coding unit **312** performs coding processing or performs coding processing using a predetermined bit number. Moreover, in accordance with the magnitude of the index Q and/or Q′, the index calculation unit **315** outputs the control signal C to the non-predictive subtraction unit **311** such that the non-predictive subtraction unit **311** performs subtraction processing. Hereinafter, a method of generating the control signal C will be described.

In general, LSP parameters are a parameter sequence in a frequency domain having a correlation to a power spectral envelope of an input sound signal, and each value of the LSP parameters correlates with the frequency position of the extreme value of the power spectral envelope of the input sound signal. If the LSP parameters are assumed to be θ[1], θ[2], . . . , θ[p], the extreme value of the power spectral envelope is present in the frequency position between θ[i] and θ[i+1], and, the steeper the slope of a tangent around this extreme value is, the narrower the interval (that is, the value of (θ[i+1]−θ[i])) between ON and θ[i+1] becomes. That is, the larger the height difference in the waves of the amplitude of the power spectral envelope is, the more unequal the interval between θ[i] and θ[i+1] becomes for each i, that is, the higher the variance of the intervals between the LSP parameters becomes; conversely, if there is almost no height difference in the waves of the power spectral envelope, the more equal the interval between θ[i] and θ[i+1] becomes for each i, that is, the lower the variance of the intervals between the LSP parameters becomes.

Thus, a large index corresponding to the variance of the intervals between the LSP parameters means a large change in the height difference of the waves of the amplitude of a power spectral envelope. Moreover, a small index corresponding to the minimum value of the intervals between the LSP parameters means a large change in the height difference of the waves of the amplitude of a power spectral envelope.

Since predictive quantization LSP parameters {circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}_{f}[p] are what are obtained by quantizing the LSP parameters θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p] and, if the LSP code C_{f }is input to the linear predictive decoding device from the linear predictive coding device without error, the decoded predictive LSP parameters {circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p] are the same as the predictive quantization LSP parameters {circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p], the predictive quantization LSP parameters {circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p] and the decoded predictive LSP parameters {circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p] also have the properties similar to those of the LSP parameters θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p].

Thus, a value corresponding to the variance of the intervals between the predictive quantization LSP parameters {circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p] can be used as the index Q which increases with an increase in the peak-to-valley of a spectral envelope, and the minimum value of the differentials ({circumflex over ( )}θ_{f}[i+1]−{circumflex over ( )}θ_{f}[i]) between the predictive quantization LSP parameters with adjacent orders, the predictive quantization LSP parameters of the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}=({circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p]), can be used as the index Q′ which decreases with an increase in the peak-to-valley of a spectral envelope.

The index Q which increases with an increase in the peak-to-valley of a spectral envelope is calculated by, for example, an index Q indicating the variance of the intervals between the predictive quantization LSP parameters which are the elements of the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}, each having an order lower than or equal to a predetermined order T (T≤p), that is,

Moreover, the index Q′ which decreases with an increase in the peak-to-valley of a spectral envelope is calculated by, for example, an index Q′ indicating the minimum value of the interval between the predictive quantization LSP parameters with adjacent orders, the predictive quantization LSP parameters of the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f }whose order is lower than or equal to a predetermined order T (T≤p), that is,

Alternatively, the index Q′ is calculated by an index Q′ indicating the minimum value of the interval between the prediction quantized LSP parameters with adjacent orders, the prediction quantized LSP parameters of the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}, and the value of the lowest-order predictive quantization LSP parameter:

Since the LSP parameters are parameters present between 0 and π in sequence of order, the lowest-order predictive quantization LSP parameter {circumflex over ( )}θ_{f}[1] in this formula means the interval ({circumflex over ( )}θ_{f}[1]−0) between {circumflex over ( )}θ_{f}[1] and 0.

The index calculation unit **315** outputs, to the non-predictive subtraction unit **311** and the correction vector coding unit **312**, the control signal C indicating that correction coding processing is performed if the peak-to-valley of the spectral envelope is above a predetermined standard, that is, in the above-described example, if (A-1) the index Q is larger than or equal to a predetermined threshold value Th**1** and/or (B-1) the index Q′ is smaller than or equal to a predetermined threshold value Th**1**′; otherwise, the index calculation unit **315** outputs, to the non-predictive subtraction unit **311** and the correction vector coding unit **312**, the control signal C indicating that correction coding processing is not performed. Here, “in the case of (A-1) and/or (B-1)” is an expression including the following three cases: a case in which only the index Q is obtained and the condition (A-1) is satisfied, a case in which only the index Q′ is obtained and the condition (B-1) is satisfied, and a case in which both the index Q and the index Q′ are obtained and the conditions (A-1) and (B-1) are satisfied. It goes without saying that, even when a determination as to whether or not the condition (A-1) is satisfied is made, the index Q′ may be obtained, and, even when a determination as to whether or not the condition (B-1) is satisfied is made, the index Q may be obtained. The same goes for “and/or” in the following description.

Moreover, the index calculation unit **315** may be configured such that the index calculation unit **315** outputs a positive integer (or a code representing a positive integer) representing a predetermined bit number as the control signal C in the case of (A-1) and/or (B-1); otherwise, the index calculation unit **315** outputs 0 as the control signal C.

Incidentally, when the non-predictive subtraction unit **311** is configured so as to perform subtraction processing if the non-predictive subtraction unit **311** receives the control signal C and the correction vector coding unit **312** is configured so as to perform coding processing if the correction vector coding unit **312** receives the control signal C, the index calculation unit **315** may be configured so as not to output the control signal C in cases other than the case (A-1) and/or (B-1).

<Non-Predictive Subtraction Unit **311**>

The non-predictive subtraction unit **311** receives the control signal C, the LSP parameter vector Θ_{f}=(θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p])^{T}, and the quantization differential vector {circumflex over ( )}S_{f}.

If the non-predictive subtraction unit **311** receives the control signal C indicating that correction coding processing is performed or a positive integer (or a code representing a positive integer) as the control signal C, in a word, if the peak-to-valley of the spectral envelope is above the predetermined standard, that is, in the above-described example, in the case of (A-1) and/or (B-1), the non-predictive subtraction unit **311** generates a correction vector U_{f}=Θ_{f}−Y−{circumflex over ( )}S_{f }that is a vector obtained by subtracting the quantization differential vector {circumflex over ( )}S_{f-1 }and the non-predictive mean vector Y=(y[1], y[2], . . . , y[p])^{T }from the LSP parameter vector Θ_{f}=(θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p])^{T }(s**311**) and outputs the correction vector U_{f}.

<Correction Vector Coding Unit **312**>

The correction vector coding unit **312** receives the control signal C and the correction vector U_{f}. If the correction vector coding unit **312** receives the control signal C indicating that correction coding processing is performed or a positive integer (or a code representing a positive integer) as the control signal C, in a word, if the peak-to-valley of the spectral envelope is above the predetermined standard, that is, in the above-described example, in the case of (A-1) and/or (B-1), the correction vector coding unit **312** obtains a correction LSP code D_{f }by coding the correction vector U_{f }(s**312**) and outputs the correction LSP code D_{f}. The coding processing itself of coding the correction vector U_{f }is similar to that performed in the correction vector coding unit **112**.

If the correction vector coding unit **312** receives the control signal C indicating that correction coding processing is not performed or 0 as the control signal C, in a word, if the peak-to-valley of the spectral envelope is not above the predetermined standard, that is, in the above-described example, in cases other than the case (A-1) and/or (B-1), the correction vector coding unit **312** does not perform coding of the correction vector U_{f }and does not obtain and output a correction LSP code D_{f}.

<Linear Prediction Coefficient Decoding Device **400** According to the Second Embodiment>

**400** according to the second embodiment, and

The linear prediction coefficient decoding device **400** of the second embodiment includes a non-predictive decoding unit **410** in place of the non-predictive decoding unit **210**.

The non-predictive decoding unit **410** includes the correction vector codebook **212**, a correction vector decoding unit **411**, a non-predictive addition unit **413**, and an index calculation unit **415** and, when necessary, also includes the decoded non-predictive linear prediction coefficient calculation unit **214**.

The difference lies in that it is determined whether or not to perform addition processing in the non-predictive addition unit **413** and perform decoding processing in the correction vector decoding unit **411** depending on the calculation result of the index calculation unit **415**.

<Index Calculation Unit **415**>

The index calculation unit **415** receives the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f }and calculates an index Q commensurate with how high the peak-to-valley height of a spectral envelope is, the spectral envelope corresponding to the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f}=({circumflex over ( )}θ_{f}[1], {circumflex over ( )}θ_{f}[2], . . . , {circumflex over ( )}θ_{f}[p])^{T}, that is, the index Q which increases with an increase in the peak-to-valley of the spectral envelope and/or an index Q′ commensurate with how short the peak-to-valley height of the spectral envelope is, that is, the index Q′ which decreases with an increase in the peak-to-valley of the spectral envelope (s**415**). In accordance with the magnitude of the index Q and/or Q′, the index calculation unit **415** outputs, to the correction vector decoding unit **411** and the non-predictive addition unit **413**, a control signal C indicating that correction decoding processing is performed/not performed or a control signal C indicating that correction decoding processing is performed using a predetermined bit number. The indices Q and Q′ are similar to those in the description of the index calculation unit **315** and simply have to be calculated in a manner similar to that used in the index calculation unit **315** by using the decoded predictive LSP parameter vector {circumflex over ( )}Θ_{f }in place of the predictive quantization LSP parameter vector {circumflex over ( )}Θ_{f}.

The index calculation unit **415** outputs, to the non-predictive addition unit **413** and the correction vector decoding unit **411**, the control signal C indicating that correction decoding processing is performed if the peak-to-valley of the spectral envelope is above the predetermined standard, that is, in the above-described example, if (A-1) the index Q is larger than or equal to the predetermined threshold value Th**1** and/or (B-1) the index Q′ is smaller than or equal to the predetermined threshold value Th**1**′; otherwise, the index calculation unit **415** outputs, to the non-predictive addition unit **413** and the correction vector decoding unit **411**, the control signal C indicating that correction decoding processing is not performed.

Moreover, the index calculation unit **415** may be configured such that the index calculation unit **415** outputs a positive integer (or a code representing a positive integer) representing a predetermined bit number as the control signal C in the case of (A-1) and/or (B-1); otherwise, the index calculation unit **415** outputs 0 as the control signal C.

Incidentally, when the correction vector decoding unit **411** and the non-predictive addition unit **413** are configured so as to determine to perform correction decoding processing if the correction vector decoding unit **411** and the non-predictive addition unit **413** receive the control signal C, the index calculation unit **415** may be configured so as not to output the control signal C in cases other than the case (A-1) and/or (B-1).

<Correction Vector Decoding Unit **411**>

The correction vector decoding unit **411** receives the correction LSP code D_{f }and the control signal C. If the correction vector decoding unit **411** receives the control signal C indicating that correction decoding processing is performed or a positive integer (or a code representing a positive integer) as the control signal C, in a word, if the peak-to-valley of the spectral envelope is above the predetermined standard, that is, in the above-described example, in the case of (A-1) and/or (B-1), the correction vector decoding unit **411** obtains a decoded correction vector {circumflex over ( )}U_{f }by decoding the correction LSP code D_{f }by referring to the correction vector codebook **212** (s**411**) and outputs the decoded correction vector {circumflex over ( )}U_{f}. The decoding processing itself of decoding the correction LSP code D_{f }is similar to that performed in the correction vector decoding unit **211**.

If the correction vector decoding unit **411** receives the control signal C indicating that correction decoding processing is not performed or 0 as the control signal C, in a word, if the peak-to-valley of the spectral envelope is not above the predetermined standard, that is, in the above-described example, in cases other than the case (A-1) and/or (B-1), the correction vector decoding unit **411** does not perform decoding of the correction LSP code D_{f }and does not obtain and output a decoded correction vector {circumflex over ( )}U_{f}.

<Non-Predictive Addition Unit **413**>

The non-predictive addition unit **413** is formed of, for example, a storage **413***c *storing a non-predictive mean vector Y and addition units **413***a *and **413***b. *

The non-predictive addition unit **413** receives the control signal C and the decoded differential vector {circumflex over ( )}S_{f}. If the non-predictive addition unit **413** receives the control signal C indicating that correction decoding processing is performed or a positive integer (or a code representing a positive integer) as the control signal C, in a word, if the peak-to-valley of the spectral envelope is above the predetermined standard, in the case of (A-1) and/or (B-1), the non-predictive addition unit **413** further receives the decoded correction vector {circumflex over ( )}U_{f}. Then, the non-predictive addition unit **413** generates a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}={circumflex over ( )}U_{f}+Y+{circumflex over ( )}S_{f }obtained by adding the decoded differential vector {circumflex over ( )}S_{f }and the non-predictive mean vector Y stored in the storage **413***c *to the decoded correction vector {circumflex over ( )}U_{f }(s**413**) and outputs the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}. Incidentally, in **413***a *and **413***b*, first, after the decoded differential vector {circumflex over ( )}S_{f }is added to the decoded correction vector {circumflex over ( )}U_{f }in the addition unit **413***a*, the non-predictive mean vector Y stored in the storage **413***c *is added in the addition unit **413***b*, but these additions may be performed the other way around. Alternatively, the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }may be generated by adding a vector obtained by adding the non-predictive mean vector Y and the decoded differential vector {circumflex over ( )}S_{f }to the decoded correction vector {circumflex over ( )}U_{f}.

If the non-predictive addition unit **413** receives the control signal C indicating that correction decoding processing is not performed or 0 as the control signal C, in a word, if the peak-to-valley of the spectral envelope is not above the predetermined standard, that is, in the above-described example, in cases other than the case (A-1) and/or (B-1), that is, if the non-predictive addition unit **413** does not receive the decoded correction vector {circumflex over ( )}U_{f}, the non-predictive addition unit **413** generates a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}=Y+{circumflex over ( )}S_{f }(s**413**) and outputs the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}.

Incidentally, it is assumed that the non-predictive mean vector Y used here is the same as the non-predictive mean vector Y used in the non-predictive subtraction unit **311** of the above-described linear prediction coefficient coding device **300**.

<Effect of the Second Embodiment>

With such a configuration, in addition to preventing a transmission error in an LSP code C_{f-1 }of an f−1th frame from affecting the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }of an fth frame, it is possible to obtain a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }containing reduced quantization errors by adding, to the non-predictive mean vector Y and the decoded differential vector {circumflex over ( )}S_{f}, the decoded correction vector {circumflex over ( )}U_{f }obtained by decoding the correction LSP code D_{f }if the peak-to-valley height of a spectral envelope is high and reduce the code amount by an amount corresponding to the correction LSP code D_{f }by using, as the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}, what is obtained by adding the non-predictive mean vector Y and the decoded differential vector {circumflex over ( )}S_{f}, which does not need the correction LSP code D_{f}, if the peak-to-valley height of a spectral envelope is not high. That is, it is possible to perform coding and decoding processing which suffers less reduction in the sound quality caused by a transmission error in a code of the preceding frame than in the existing technology while reducing the code amount as a whole compared to the coding and decoding of the first embodiment.

<Modification>

As already explained in the modification of the first embodiment, in place of the LSP parameters, other coefficients may be used as long as the coefficients are coefficients which are convertible into linear prediction coefficients. The above may be applied to PARCOR coefficients, coefficients obtained by transforming any one of the LSP parameters and the PARCOR coefficients, and linear prediction coefficients themselves. Hereinafter, a case in which PARCOR coefficients k_{f}[1], k_{f}[2], . . . , k_{f}[p] are used will be described.

It is known that the higher the peak-to-valley height of a spectral envelope corresponding to an LSP parameter vector Θ_{f }is, the smaller a value of

determined by a PARCOR coefficient becomes. Thus, when the PARCOR coefficients are used, the index calculation unit **315** receives quantized PARCOR coefficients {circumflex over ( )}k_{f}[1], {circumflex over ( )}k_{f}[2], . . . , {circumflex over ( )}k_{f}[p] and calculates an index Q′ commensurate with how short the peak-to-valley height of a spectral envelope is by

(s**315**). In accordance with the magnitude of the index Q′, the index calculation unit **315** outputs, to the correction vector coding unit **312** and the non-predictive subtraction unit **311**, a control signal C indicating that correction coding processing is performed/not performed or a control signal C which is a positive integer representing a predetermined bit number or is 0. Likewise, in accordance with the magnitude of the index Q′, the index calculation unit **415** outputs, to the correction vector decoding unit **411** and the non-predictive addition unit **413**, a control signal C indicating that correction decoding processing is performed/not performed or a control signal C which is a positive integer representing a predetermined bit number or is 0.

The index calculation unit **315** and the index calculation unit **415** may be configured so as to output the index Q and/or the index Q′ in place of the control signal C. In that case, in accordance with the magnitude of the index Q and/or the index Q, the correction vector coding unit **312** and the correction vector decoding unit **411** simply have to determine whether or not to perform coding processing and the decoding processing, respectively. Moreover, likewise, in accordance with the magnitude of the index Q and/or the index Q′, the non-predictive subtraction unit **311** simply has to determine whether or not to perform subtraction processing and the non-predictive addition unit **413** simply has to determine what kind of addition processing the non-predictive addition unit **413** performs. The determinations made in the correction vector coding unit **312**, the correction vector decoding unit **411**, the non-predictive subtraction unit **311**, and the non-predictive addition unit **413** are the same as those explained in the above-described index calculation unit **315** and index calculation unit **415**.

**Third Embodiment**

Differences from the second embodiment will be mainly described.

A large number of candidate correction vectors stored in a correction vector codebook means that coding can be performed with an accordingly high accuracy of approximation. Thus, in the present embodiment, the correction vector coding unit and the correction vector decoding unit are executed by using a correction vector codebook whose accuracy is increased with an increase in the influence of a reduction in the accuracy of decoding caused by a transmission error in an LSP code.

<Linear Prediction Coefficient Coding Device **500** According to the Third Embodiment>

**500** of the third embodiment, and

The linear prediction coefficient coding device **500** of the third embodiment includes a non-predictive coding unit **510** in place of the non-predictive coding unit **310**.

The non-predictive coding unit **510** includes the non-predictive subtraction unit **311**, a correction vector coding unit **512**, correction vector codebooks **513**A and **513**B, the predictive addition unit **314**, and the index calculation unit **315**. As is the case with the linear prediction coefficient coding devices **100** and **300** of the first and second embodiments, if LSP parameters θ derived from a sound signal X_{f }are generated by another device and the input of the linear prediction coefficient coding device **500** is the LSP parameters θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p], the linear prediction coefficient coding device **500** does not have to include the linear prediction analysis unit **81** and the LSP calculation unit **82**.

The differences from the second embodiment lie in that the linear prediction coefficient coding device **500** of the third embodiment includes a plurality of correction vector codebooks and the correction vector coding unit **512** performs coding by selecting any one of the correction vector codebooks in accordance with the index Q and/or Q′ calculated in the index calculation unit **315**.

Hereinafter, a description will be given by taking up as an example a case in which the two types of correction vector codebooks **513**A and **513**B are provided.

The correction vector codebooks **513**A and **513**B differ from each other in the total number of candidate correction vectors stored therein. A large total number of candidate correction vectors means a large bit number of a corresponding correction vector code. To put it the other way around, the larger the bit number of a correction vector code is made, the more candidate correction vectors can be prepared. For example, if the bit number of a correction vector code is assumed to be A, up to 2^{A }candidate correction vectors can be prepared.

Hereinafter, a description will be given on the assumption that the total number of candidate correction vectors stored in the correction vector codebook **513**A is larger than the total number of candidate correction vectors stored in the correction vector codebook **513**B. In other words, the code length (average code length) of the codes stored in the correction vector codebook **513**A is larger than the code length (average code length) of the codes stored in the correction vector codebook **513**B. For example, 2^{A }pairs of a correction vector code having a code length of A-bit and a candidate correction vector are stored in the correction vector codebook **513**A, and 2^{B }(2^{B}<2^{A}) pairs of a correction vector code having a code length of B-bit (B<A) and a candidate correction vector are stored in the correction vector codebook **513**B.

Incidentally, in the present embodiment, as already explained in the modification part of the second embodiment, the index calculation unit outputs the index Q and/or the index Q′ in place of the control signal C, and, in accordance with the magnitude of the index Q and/or the index Q′, the correction vector coding unit and the correction vector decoding unit determine what kind of coding and decoding the correction vector coding unit and the correction vector decoding unit perform, respectively. However, as in the second embodiment, a configuration may be adopted in which the index calculation unit determines what kind of coding and decoding is performed and outputs the control signal C. Incidentally, as already explained in the modification part of the second embodiment, in accordance with the magnitude of the index Q and/or the index Q′, the non-predictive subtraction unit **311** determines whether or not to perform subtraction processing and the non-predictive addition unit **413** determines what kind of addition processing the non-predictive addition unit **413** performs.

<Correction Vector Coding Unit **512**>

The correction vector coding unit **512** receives the index Q and/or the index Q′ and the correction vector U_{f}. The correction vector coding unit **512** obtains a correction LSP code D_{f }whose bit number becomes greater (code length becomes larger) as (A-2) the index Q increases and/or (B-2) the index Q′ decreases (s**512**) and outputs the correction LSP code D_{f}. For example, the correction vector coding unit **512** performs coding in the following manner by using a predetermined threshold value Th**2** and/or a predetermined threshold value Th**2**′. Incidentally, since the correction vector coding unit **512** performs coding processing if the index Q is larger than or equal to the predetermined threshold value Th**1** and/or the index Q′ is smaller than or equal to the predetermined threshold value Th**1**′, Th**2** is a value greater than Th**1** and Th**2**′ is a value smaller than Th**1**′.

If (A-5) the index Q is larger than or equal to the predetermined threshold value Th**2** and/or (B-5) the index Q′ is smaller than or equal to the predetermined threshold value Th**2**′, A which is a positive integer is assumed to be set as the bit number of the correction LSP code D_{f}, and the correction vector coding unit **512** obtains a correction LSP code D_{f }by coding the correction vector U_{f }by referring to the correction vector codebook **513**A storing the 2^{A }pairs of a correction vector code having the bit number (code length) A and a candidate correction vector (s**512**) and outputs the correction LSP code D_{f}.

If (A-6) the index Q is smaller than the predetermined threshold value Th**2** and the index Q is larger than or equal to the predetermined threshold value Th**1** and/or (B-6) the index Q′ is larger than the predetermined threshold value Th**2**′ and the index Q′ is smaller than or equal to the predetermined threshold value Th**1**′, B which is a positive integer less than the bit number A is assumed to be set as the bit number of the correction LSP code D_{f}, and the correction vector coding unit **512** obtains a correction LSP code D_{f }by coding the correction vector U_{f }by referring to the correction vector codebook **513**B storing the 2^{B }pairs of a correction vector code having the bit number (code length) B and a candidate correction vector (s**512**) and outputs the correction LSP code D_{f}.

In other cases (C-6), 0 is assumed to be set as the bit number of the correction LSP code D_{f}, and the correction vector coding unit **512** does not code the correction vector U_{f }and does not obtain and output a correction LSP code D_{f}.

Thus, the correction vector coding unit **512** of the third embodiment is executed when the index Q calculated in the index calculation unit **315** is larger than the predetermined threshold value Th**1** and/or the index Q′ calculated in the index calculation unit **315** is smaller than the predetermined threshold value Th**1**′.

<Linear Prediction Coefficient Decoding Device **600** According to the Third Embodiment>

**600** according to the third embodiment, and

The linear prediction coefficient decoding device **600** of the third embodiment includes a non-predictive decoding unit **610** in place of the non-predictive decoding unit **410**.

The non-predictive decoding unit **610** includes the non-predictive addition unit **413**, a correction vector decoding unit **611**, correction vector codebooks **612**A and **612**B, and the index calculation unit **415** and, when necessary, also includes the decoded non-predictive linear prediction coefficient calculation unit **214**.

Differences from the linear prediction coefficient decoding device **400** of the second embodiment lie in that the linear prediction coefficient decoding device **600** of the third embodiment includes a plurality of correction vector codebooks and the correction vector decoding unit **611** performs decoding by selecting any one of the correction vector codebooks in accordance with the index Q and/or Q′ calculated in the index calculation unit **415**.

Hereinafter, a description will be given by taking up as an example a case in which the two types of correction vector codebooks **612**A and **612**B are provided.

The correction vector codebooks **612**A and **612**B store the contents shared by the correction vector codebooks **513**A and **513**B, respectively, of the linear prediction coefficient coding device **500**. That is, in the correction vector codebooks **612**A and **612**B, candidate correction vectors and correction vector codes corresponding to the candidate correction vectors are stored, and the code length (average code length) of the codes stored in the correction vector codebook **612**A is larger than the code length (average code length) of the codes stored in the correction vector codebook **612**B. For example, 2^{A }pairs of a correction vector code having a code length of A-bit and a candidate correction vector are stored in the correction vector codebook **612**A, and 2^{B }(2^{B}<2^{A}) pairs of a correction vector code having a code length of B-bit (B<A) and a candidate correction vector are stored in the correction vector codebook **612**B.

<Correction Vector Decoding Unit **611**>

The correction vector decoding unit **611** receives the index Q and/or the index Q′ and the correction LSP code D_{f}. The correction vector decoding unit **611** obtains a decoded correction vector {circumflex over ( )}U_{f }from a large number of candidate correction vectors by decoding a correction LSP code D_{f }with a bit number depending on the magnitude of the index Q and the index Q′, such that (A-2) the larger the index Q and/or (B-2) the smaller the index Q′, the greater the bit number (s**611**). For example, the correction vector decoding unit **611** performs decoding in the following manner by using a predetermined threshold value Th**2** and/or Th**2**′. Incidentally, since the correction vector decoding unit **611** performs the decoding processing if the index Q is larger than or equal to the predetermined threshold value Th**1** and/or the index Q′ is smaller than or equal to the predetermined threshold value Th**1**′, Th**2** is a value greater than Th**1** and Th**2**′ is a value smaller than Th**1**′.

If (A-5) the index Q is larger than or equal to the predetermined threshold value Th**2** and/or (B-5) the index Q′ is smaller than or equal to the predetermined threshold value Th**2**′, A which is a positive integer is assumed to be set as the bit number of the correction LSP code D_{f}, and the correction vector decoding unit **611** obtains, as a decoded correction vector {circumflex over ( )}U_{f}, a candidate correction vector corresponding to a correction vector code that coincides with the correction LSP code D_{f }by referring to the correction vector codebook **612**A storing the 2^{A }pairs of a correction vector code having the bit number (code length) A and a candidate correction vector (s**611**) and outputs the decoded correction vector {circumflex over ( )}U_{f}.

If (A-6) the index Q is smaller than the predetermined threshold value Th**2** and the index Q is larger than or equal to the predetermined threshold value Th**1** and/or (B-6) the index Q′ is larger than the predetermined threshold value Th**2**′ and the index Q′ is smaller than or equal to the predetermined threshold value Th**1**′, B which is a positive integer less than the bit number A is assumed to be set as the bit number of the correction LSP code D_{f }and the correction vector decoding unit **611** obtains, as a decoded correction vector {circumflex over ( )}U_{f}, a candidate correction vector corresponding to a correction vector code that coincides with the correction LSP code D_{f }by referring to the correction vector codebook **612**B storing the 2^{B }pairs of a correction vector code having the bit number (code length) B and a candidate correction vector (s**611**) and outputs the decoded correction vector {circumflex over ( )}U_{f}.

In other cases (C-6), 0 is assumed to be set as the bit number of the correction LSP code D_{f}, and the correction vector decoding unit **611** does not decode the correction LSP code D_{f }and does not generate a decoded correction vector {circumflex over ( )}U_{f}.

Thus, the correction vector decoding unit **611** of the third embodiment is executed if the index Q calculated in the index calculation unit **415** is larger than the predetermined threshold value Th**1** and/or the index Q′ calculated in the index calculation unit **415** is smaller than the predetermined threshold value Th**1**′.

<Effect of the Third Embodiment>

With such a configuration, it is possible to obtain the effect similar to that of the second embodiment. In addition, by changing the accuracy of approximation depending on the magnitude of the influence of a reduction in the accuracy of decoding caused by a transmission error in an LSP code, it is possible to perform coding and decoding processing of higher sound quality than the coding and decoding of the second embodiment while reducing the code amount as a whole compared to the coding and decoding of the first embodiment.

<Modification>

The number of correction vector codebooks does not necessarily have to be two and may be three or more. The bit number (bit length) of stored correction vector codes differs from correction vector codebook to correction vector codebook, and correction vectors corresponding to the correction vector codes are stored. It is necessary simply to set a threshold value depending on the number of correction vector codebooks. A threshold value for the index Q simply has to be set in such a way that the greater the value of the threshold value becomes, the greater the bit number of a correction vector code becomes, the correction vector code which is stored in the correction vector codebook that is used if the index Q is larger than or equal to that threshold value. Likewise, a threshold value for the index Q′ simply has to be set in such a way that the smaller the value of the threshold value becomes, the greater the bit number of a correction vector code becomes, the correction vector code which is stored in the correction vector codebook that is used if the index Q′ is smaller than or equal to that threshold value. With such a configuration, it is possible to perform coding and decoding of higher accuracy while reducing the code amount as a whole.

<Coding Device **700** According to a Fourth Embodiment>

A coding device **700** according to a fourth embodiment is what is obtained by applying the linear prediction coefficient coding device **100** and the linear prediction coefficient decoding device **200** of the first embodiment to TCX (transform coded excitation) coding method which is a coding method in a frequency domain.

**700** of the fourth embodiment, and

The coding device **700** of the fourth embodiment includes the linear prediction coefficient coding device **100**, the linear prediction coefficient decoding device **200**, a power spectral envelope series calculation unit **710**, a first smoothing power spectral envelope series calculation unit **720**A, a second smoothing power spectral envelope series calculation unit **720**B, a frequency domain conversion unit **730**, an envelope normalization unit **740**, a variable-length coding parameter calculation unit **750**, and a variable-length coding unit **760**. Incidentally, in place of the linear prediction coefficient coding device **100** and the linear prediction coefficient decoding device **200**, the linear prediction coefficient coding devices **300** and **500** and the linear prediction coefficient decoding devices **400** and **600** of the second and third embodiments may be used.

The coding device **700** of the fourth embodiment receives an input sound signal X_{f }and outputs a frequency domain signal code.

<Linear Prediction Coefficient Coding Device **100**>

The linear prediction coefficient coding device **100** receives the sound signal X_{f}, obtains an LSP code C_{f }and a correction LSP code D_{f }(s**100**), and outputs the LSP code C_{f }and the correction LSP code D_{f}.

<Linear Prediction Coefficient Decoding Device **200**>

The linear prediction coefficient decoding device **200** receives the LSP code C_{f }and the correction LSP code D_{f}, obtains predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p] and non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p] (s**200**), and outputs the predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p] and the non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p].

Incidentally, the linear prediction coefficient coding device **100** of the coding device **700** may be configured so as to obtain, when obtaining the LSP code C_{f }and the correction LSP code D_{f }predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p] corresponding to the LSP code C_{f }and non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p] corresponding to the LSP code C_{f }and the correction LSP code D_{f}. In this case, the coding device **700** does not have to include the linear prediction coefficient decoding device **200**.

<Power Spectral Envelope Series Calculation Unit **710**>

The power spectral envelope series calculation unit **710** receives the non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p]. The power spectral envelope series calculation unit **710** calculates a power spectral envelope series Z[1], . . . , Z[N] of the input sound signal at point N by using the non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p] (s**710**) and outputs the power spectral envelope series Z[1], . . . , Z[N]. For example, each value Z[n] of the power spectral envelope series can be determined by the following formula.

where n is an integer 1≤n≤N, exp(·) is an exponential function using Napier's constant as a base, j is an imaginary unit, and σ^{2 }is prediction residual energy.

<First Smoothing Power Spectral Envelope Series Calculation Unit **720**A>

The first smoothing power spectral envelope series calculation unit **720**A receives the predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p]. By using the predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p] and a correction factor γ^{i }which is given in advance and is a positive constant smaller than or equal to 1, the first smoothing power spectral envelope series calculation unit **720**A calculates a first smoothed power spectral envelope series {tilde over ( )}W[1], {tilde over ( )}W[2], . . . , {tilde over ( )}W[N] by

(s**720**A), and outputs the first smoothed power spectral envelope series {tilde over ( )}W[1], {tilde over ( )}W[2], . . . , {tilde over ( )}W[N].

The first smoothed power spectral envelope series {tilde over ( )}W[1], {tilde over ( )}W[2], . . . , {tilde over ( )}W[N] corresponds to a series obtained by flattening (smoothing) the waves of the amplitude of a power spectral envelope series W[1], W[2], . . . , W[N] determined by the predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p]. γ^{i }is a positive constant that determines the degree of smoothing.

<Second Smoothing Power Spectral Envelope Series Calculation Unit **720**B>

The second smoothing power spectral envelope series calculation unit **720**B receives the non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p]. By using the non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p] and a correction factor γ^{i }which is given in advance and is a positive constant smaller than or equal to 1, the second smoothing power spectral envelope series calculation unit **720**B calculates a second smoothed power spectral envelope series {tilde over ( )}Z[1], {tilde over ( )}Z[2], . . . , {tilde over ( )}Z[N] by

(s**720**B) and outputs the second smoothed power spectral envelope series {tilde over ( )}Z[1], {tilde over ( )}Z[2], . . . , {tilde over ( )}Z[N].

The second smoothed power spectral envelope series {tilde over ( )}Z[1], {tilde over ( )}Z[2], . . . , {tilde over ( )}Z[N] corresponds to a series obtained by flattening (smoothing) the waves of the amplitude of a power spectral envelope series Z[1], Z[2], . . . , Z[N] determined by the non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p]. γ^{i }is a positive constant that determines the degree of smoothing.

<Frequency Domain Conversion Unit **730**>

The frequency domain conversion unit **730** converts the input sound signal X_{f}, which is input to the frequency domain conversion unit **730**, in the time domain into MDCT coefficient sequence X[1], . . . , X[N] at point N in the frequency domain frame by frame which is a predetermined time segment (s**730**) and outputs the NIDCT coefficient sequence X[1], . . . , X[N]. Here, N is a positive integer.

<Envelope Normalization Unit **740**>

The envelope normalization unit **740** receives the MDCT coefficient sequence X[1], . . . , X[N] and the first smoothed power spectral envelope series {tilde over ( )}W[1], {tilde over ( )}W[2], . . . , {tilde over ( )}W[N], obtains a normalized MDCT coefficient sequence X_{N}[1], . . . , X_{N}[N] which is a series obtained by normalizing each coefficient X[i] of the MDCT coefficient sequence X[1], . . . , X[N] by the square root of each value {tilde over ( )}W[i] of the first smoothed power spectral envelope series {tilde over ( )}W[1], {tilde over ( )}W[2], . . . , {tilde over ( )}W[N] (s**740**), and outputs the normalized MDCT coefficient sequence X_{N}[1], . . . , X_{N}[N]. That is, X_{N}[i]=X[i]/sqrt({tilde over ( )}W[i]) holds. Here, sqrt(·) is a symbol representing the one-half power.

<Variable-Length Coding Parameter Calculation Unit **750**>

The variable-length coding parameter calculation unit **750** receives the power spectral envelope series Z[1], . . . , Z[N], the second smoothed power spectral envelope series {tilde over ( )}Z[1], . . . , {tilde over ( )}Z[N], the MDCT coefficient sequence X[1], . . . , X[N], and the normalized MDCT coefficient sequence X_{N}[1], . . . , X_{N}[N]. By using these values, the variable-length coding parameter calculation unit **750** calculates a variable-length coding parameter r_{i }which is a parameter for performing variable-length coding of the normalized MDCT coefficient sequence X_{N}[1], . . . , X_{N}[N] (s**750**) and outputs the variable-length coding parameter r_{i}. The variable-length coding parameter r_{i }is a parameter that specifies a possible range of the amplitude of the normalized MDCT coefficient sequence X_{N}[1], . . . , X_{N}[N] to be coded. In the case of Rice coding, a Rice parameter corresponds to the variable-length coding parameter; in the case of arithmetic coding, a possible range of the amplitude of an object to be coded corresponds to the variable-length coding parameter.

When variable-length coding is performed per sample, a variable-length coding parameter is calculated for each coefficient X_{N}[i] of the normalized MDCT coefficient sequence. When variable-length coding is performed collectively for a sample group formed of a plurality of samples (for example, two samples at a time), a variable-length coding parameter is calculated for each sample group. That is, the variable-length coding parameter calculation unit **750** calculates a variable-length coding parameter for a normalized partial coefficient sequence which is part of the normalized MDCT coefficient sequence. Here, it is assumed that there are a plurality of normalized partial coefficient sequences and, in the plurality of normalized partial coefficient sequences, coefficients of the normalized MDCT coefficient sequence are included without overlaps.

Hereinafter, a method of calculating a variable-length coding parameter will be described by taking up as an example a case in which Rice coding is performed per sample.

(Step 1) For example, by the following formula, the logarithm of the average of the amplitudes of the coefficients of the normalized MDCT coefficient sequence X_{N}[1], X_{N}[2], . . . , X_{N}[N] is calculated as a Rice parameter sb.

sb is coded only once in each frame and is transmitted to the decoding device as a code corresponding to a reference Rice parameter. Alternatively, when the amplitude of X[i] can be estimated by another information which is transmitted to the decoding device, a method of approximately determining sb from the estimated value of the amplitude of X[i], the method shared by the coding device **700** and the decoding device, may be set. In this case, there is no need to code sb and output a code corresponding to a reference Rice parameter to the decoding device.

(Step 2) A threshold value θ is calculated by the following formula.

(Step 3) The greater the extent to which |sqrt(Z[i])/sqrt({tilde over ( )}Z[i])| is greater than θ, the greater a value than sb, the value to which the Rice parameter r_{i }is set. The lesser the extent to which |sqrt(Z[i])/sqrt({tilde over ( )}Z[i])| is smaller than θ, the smaller a value than sb, the value to which the Rice parameter r_{i }is set.

(Step 4) By repeatedly performing the processing in step 3 on all of i=1, 2, . . . , N, a Rice parameter r_{i }for each normalized MDCT coefficient X_{N}[i] is obtained.

<Variable-Length Coding Unit **760**>

The variable-length coding unit **760** receives the variable-length coding parameter r performs variable-length coding on the normalized coefficient sequence X_{N}(1), . . . , X_{N}(N) by using this value, and outputs a variable-length code C_{X }(s**760**).

<Effect of the Fourth Embodiment>

The fourth embodiment has a configuration in which the normalized MDCT coefficient sequence X_{N}[1], . . . , X_{N}[N] obtained by normalizing the MDCT coefficient sequence X[1], X[2], . . . , X[N] by the smoothed power spectral envelope series is coded by using a variable-length coding parameter.

Since it is necessary to obtain, by using the most accurate possible power spectral envelope series, a normalized MDCT coefficient sequence on which variable-length coding is to be performed, the envelope normalization unit **740** generates a normalized MDCT coefficient sequence by using the first smoothed power spectral envelope series {tilde over ( )}W[1], {tilde over ( )}W[2], . . . , {tilde over ( )}W[N] determined by the predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p], the first smoothed power spectral envelope series {tilde over ( )}W[1], {tilde over ( )}W[2], . . . , {tilde over ( )}W[N] whose difference from a power spectral envelope series determined by smoothing linear prediction coefficients is small.

The variable-length coding parameter calculation unit **750** uses a power spectral envelope series and a smoothed power spectral envelope series to obtain a variable-length coding parameter. Thus, it is also desirable that, for the power spectral envelope series and the smoothed power spectral envelope series which are used in the variable-length coding parameter calculation unit **750**, a difference from a power spectral envelope series which is determined by linear prediction coefficients and a power spectral envelope series which is determined by smoothing linear prediction coefficients is small. However, not only when a transmission error occurs in an LSP code of the present frame, but also when a transmission error occurs in an LSP code of the preceding frame, the correct values of the predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p] cannot be obtained on the decoding side. That is, if a variable-length coding parameter is determined from a power spectral envelope series and a smoothed power spectral envelope series which are determined from the predictive quantization linear prediction coefficients {circumflex over ( )}a_{f}[1], {circumflex over ( )}a_{f}[2], . . . , {circumflex over ( )}a_{f}[p], it becomes impossible to perform variable-length decoding correctly not only when a transmission error occurs in an LSP code of the present frame, but also when a transmission error occurs in an LSP code of the preceding frame.

Thus, in the fourth embodiment, a variable-length coding parameter is determined by using a power spectral envelope series and a smoothed power spectral envelope series which are determined from the non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2] . . . , {circumflex over ( )}b_{f}[p]. As a result, even when a transmission error occurs in an LSP code of the preceding frame, since it is possible to obtain the same non-predictive quantization linear prediction coefficients {circumflex over ( )}b_{f}[1], {circumflex over ( )}b_{f}[2], . . . , {circumflex over ( )}b_{f}[p], power spectral envelope series Z[1], Z[2], . . . , Z[N], and second smoothed power spectral envelope series {tilde over ( )}Z[1], {tilde over ( )} Z[2], . . . , {tilde over ( )}Z[N] as those on the coding side in the present frame if no transmission error occurs in an LSP code of the present frame, it is possible to obtain the same variable-length coding parameter as that on the coding side in the present frame and thereby increase the resistance to a transmission error in an LSP code.

Incidentally, in the fourth embodiment, a normalized MDCT coefficient sequence X_{N}[1], . . . , X_{N}[N] obtained by using the first smoothed power spectral envelope series {tilde over ( )}W[1], {tilde over ( )}W[2], . . . , {tilde over ( )}W[N] is set as an object on which variable-length coding is to be performed. Therefore, not only when a transmission error occurs in an LSP code of the present frame, but also when a transmission error occurs in an LSP code of the preceding frame, an error occurs in the square root of each value of a smoothed power spectral envelope series by which the normalized MDCT coefficient sequence X_{N}[1], . . . , X_{N}[N] is multiplied on the decoding side and distortion undesirably occurs in an MDCT coefficient sequence which is obtained by decoding. However, this is less problematic than an error in a variable-length coding parameter that makes variable-length decoding itself incorrect.

<First Modification>

In the above first to fourth embodiments, only an LSP parameter (a low-order LSP parameter) whose order is lower than or equal to a predetermined order T_{L }lower than a prediction order p may be set as an object on which processing (non-predictive coding processing) is to be performed, the processing being performed in the non-predictive coding unit **110** of the linear prediction coefficient coding device **100** of **310** of the linear prediction coefficient coding device **300** of **510** of the linear prediction coefficient coding device **500** of

First, each of the non-predictive coding units **110**, **310**, and **510** will be described.

<Non-Predictive Subtraction Units **111** and **311**>

The non-predictive subtraction units **111** and **311** generate a low-order correction vector U′_{f}=Θ′_{f}−Y′−{circumflex over ( )}S′_{f }that is a vector obtained by subtracting, from a low-order LSP parameter vector Θ′_{f}=(θ_{f}[1], θ_{f}[2], . . . , θ_{f}[T_{L}])^{T }formed of LSP parameters, whose orders are lower than or equal to the order T_{L}, of the input LSP parameter vector Θ_{f}=(θ_{f}[1], θ_{f}[2], . . . , θ_{f}[p])^{T}, a non-predictive low-order mean vector Y′=(y[1], y[2], . . . , y[T_{L}])^{T }stored in the storage **111***c *and a low-order quantization differential vector {circumflex over ( )}S′_{f}=({circumflex over ( )}s_{f}[1], {circumflex over ( )}s_{f}[2], . . . , {circumflex over ( )}s_{f}[T_{L}])^{T }formed of elements, whose orders are lower than or equal to the order T_{L}, of the input quantization differential vector {circumflex over ( )}S_{f}=({circumflex over ( )}s_{f}[1], {circumflex over ( )}s_{f}[2], . . . , {circumflex over ( )}s_{f}[p])^{T}, and output the low-order correction vector U′_{f}. That is, the non-predictive subtraction units **111** and **311** generate a low-order correction vector U′_{f }that is a vector formed of some of the elements of the correction vector U_{f }and output the low-order correction vector U′_{f}.

Here, the non-predictive low-order mean vector Y′=(y[1], y[2], . . . , y[T_{L}])^{T }is a predetermined vector and is a vector formed of elements, whose orders are lower than or equal to the order T_{L}, of the non-predictive mean vector Y=(y[1], y[2], . . . , y[p])^{T }which is used in the decoding device of the first modification.

Incidentally, a low-order LSP parameter vector Θ′_{f }formed of LSP parameters, whose orders are lower than or equal to the order T_{L}, of the LSP parameter vector Θ_{f }may be output from the LSP calculation unit **82** and input to the non-predictive subtraction units **111** and **311**. Moreover, a low-order quantization differential vector {circumflex over ( )}S′_{f }formed of elements, whose orders are lower than or equal to the order T_{L}, of the quantization differential vector {circumflex over ( )}S_{f }may be output from the vector coding unit **84** and input to the non-predictive subtraction units **111** and **311**.

<Correction Vector Coding Units **112**, **312**, and **512**>

The correction vector coding units **112**, **312**, and **512** code the low-order correction vector U′_{f }that is a vector formed of some of the elements of the correction vector U_{f }by referring to the correction vector codebooks **113**, **513**A, and **513**B. The candidate correction vectors that are stored in the correction vector codebooks **113**, **513**A, and **513**B simply have to be vectors of the order T_{L}.

Next, the linear prediction coefficient decoding devices **200**, **400**, and **600** of the first modification will be described.

Processing (non-predictive decoding processing) which is performed in the non-predictive decoding unit **210** of the linear prediction coefficient decoding device **200** of the first modification, the non-predictive decoding unit **410** of the linear prediction coefficient decoding device **400** of the first modification, and the non-predictive decoding unit **610** of the linear prediction coefficient decoding device **600** of the first modification will be described.

<Correction Vector Decoding Units **211**, **411**, and **611**>

The correction vector decoding units **211**, **411**, and **611** receive a correction LSP code D_{f}, obtain a decoded low-order correction vector U′_{f }by decoding the correction LSP code D_{f }by referring to the correction vector codebooks **212**, **612**A, and **612**B, and output the decoded low-order correction vector {circumflex over ( )}U′_{f}. The decoded low-order correction vector {circumflex over ( )}U′_{f}=(u_{f}[1], u_{f}[2], . . . , u_{f}[T_{L}])^{T }is a vector of the order T_{L}. The candidate correction vectors that are stored in the correction vector codebooks **212**, **612**A, and **612**B simply have to be vectors of the order T_{L }as in the case of the correction vector codebooks **113**, **513**A, and **513**B.

<Non-Predictive Addition Unit **213**>

The non-predictive addition unit **213** receives the decoded low-order correction vector {circumflex over ( )}U′_{f}=(u_{f}[1], u_{f}[2], . . . , u_{f}[T_{L}])^{T}, the non-predictive mean vector Y=(y[1], y[2], . . . , y[p])^{T}, and the decoded differential vector {circumflex over ( )}S_{f}=({circumflex over ( )}s_{f}[1], {circumflex over ( )}s_{f}[2], . . . , {circumflex over ( )}s_{f}[p])^{T}.

The non-predictive addition unit **213** generates a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }which is obtained by adding the elements of the decoded low-order correction vector U′_{f}, the decoded differential vector {circumflex over ( )}S_{f}, and the non-predictive mean vector Y for each order which is lower than or equal to the order T_{L }and by adding the elements of the decoded differential vector {circumflex over ( )}S_{f }and the non-predictive mean vector Y for each order which is lower than or equal to the order p and is higher than the order T_{L}, and outputs the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}. That is, the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }is {circumflex over ( )}Φ_{f}=(u_{f}[1]+y[1]+{circumflex over ( )}s_{f}[1], u_{f}[2]+y[2]+{circumflex over ( )}s_{f}[2], . . . , u_{f}[T_{L}]+y[T_{L}]+{circumflex over ( )}s_{f}[T_{L}], y[T_{L}+1]+{circumflex over ( )}s_{f}[T_{L}+1], . . . , y[p]+{circumflex over ( )}s_{f}[p]).

<Non-Predictive Addition Unit **413**>

The non-predictive addition unit **413** receives the decoded low-order correction vector {circumflex over ( )}U′_{f}=(u_{f}[1], u_{f}[2], . . . , u_{f}[T_{L}])^{T}, the non-predictive mean vector Y=(y[1], y[2], . . . , y[p])^{T}, and the decoded differential vector {circumflex over ( )}S_{f}=({circumflex over ( )}s_{f}[1], {circumflex over ( )}s_{f}[2], . . . , {circumflex over ( )}s_{f}[p])^{T}.

If the non-predictive addition unit **413** receives the control signal C indicating that correction decoding processing is performed or a positive integer (or a code representing a positive integer) as the control signal C, in a word, if the peak-to-valley of the spectral envelope is above the predetermined standard, in the case of (A-1) and/or (B-1), the non-predictive addition unit **413** generates a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }which is obtained by adding the elements of the decoded low-order correction vector {circumflex over ( )}U′_{f}, the decoded differential vector {circumflex over ( )}S_{f}, and the non-predictive mean vector Y for each order lower than or equal to the order T_{L }and by adding the elements of the decoded differential vector {circumflex over ( )}S_{f }and the non-predictive mean vector Y for each order which is lower than or equal to the order p and is higher than the order T_{L}, and outputs the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}. That is, the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f }is {circumflex over ( )}Φ_{f}=(u_{f}[1]+y[1]+{circumflex over ( )}s_{f}[1], u_{f}[2]+y[2]+{circumflex over ( )}s_{f}[2], . . . , u_{f}[T_{L}]+y[T_{L}]+{circumflex over ( )}s_{f}[T_{L}], y[T_{L}+1]+{circumflex over ( )}s_{f}[T_{L}+1], . . . , y[p]+{circumflex over ( )}s_{f}[p]).

If the non-predictive addition unit **413** receives the control signal C indicating that correction decoding processing is not performed or 0 as the control signal C, in a word, if the peak-to-valley of the spectral envelope is not above the predetermined standard, that is, in the above-described example, in cases other than the case (A-1) and/or (B-1), the non-predictive addition unit **413** generates a decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}=Y+{circumflex over ( )}S_{f }that is obtained by adding the decoded differential vector {circumflex over ( )}S_{f }and the non-predictive mean vector Y and outputs the decoded non-predictive LSP parameter vector {circumflex over ( )}Φ_{f}.

As a result, by preferentially reducing coding distortion of a low-order LSP parameter whose degree of accuracy of approximation may have a greater influence on the efficiency of signal processing which will be described later, it is possible to reduce the code amount as compared to the methods of the first to third embodiments while suppressing an increase in distortion.

<Second Modification>

In the first to fourth embodiments, the linear prediction coefficients a_{f}[1], a_{f}[2], . . . , a_{f}[p] are used as the input of the LSP calculation unit; for example, a series of coefficients a_{f}[1]×γ, a_{f}[2]×γ^{2}, . . . , a_{f}[p]×γ^{P }obtained by multiplying each coefficient a_{f}[i] of the linear prediction coefficients by γ raised to the ith power may be used as the input of the LSP calculation unit.

Moreover, in the first to fourth embodiments, an object to be coded by the linear prediction coefficient coding device and decoded by the linear prediction coefficient decoding device is assumed to be an LSP parameter, but a linear prediction coefficient itself or any coefficient such as an ISP parameter may be used as an object to be coded and decoded as long as the coefficient is a coefficient which is convertible into a linear prediction coefficient.

<Other Modifications>

The present invention is not limited to the above-described embodiments and modifications. For example, the above-described various kinds of processing may be performed, in addition to being performed in chronological order in accordance with the description, concurrently or individually depending on the processing power of a device that performs the processing or when needed. Other changes may be made as appropriate without departing from the spirit of the present invention.

<Program and Recording Medium>

Moreover, various kinds of processing functions of the devices described in the above-described embodiments and modifications may be implemented by a computer. In that case, the processing details of the functions supposed to be provided in the devices are described by a program. As a result of this program being executed by the computer, the various kinds of processing functions of the above-described devices are implemented on the computer.

The program describing the processing details can be recorded on a computer-readable recording medium. As the computer-readable recording medium, for example, any one of a magnetic recording device, an optical disk, a magneto-optical recording medium, semiconductor memory, and so forth may be used.

Moreover, the distribution of this program is performed by, for example, selling, transferring, or lending a portable recording medium such as a DVD or a CD-ROM on which the program is recorded. Furthermore, the program may be distributed by storing the program in a storage device of a server computer and transferring the program to other computers from the server computer via a network.

The computer that executes such a program first, for example, temporarily stores the program recorded on the portable recording medium or the program transferred from the server computer in a storage thereof. Then, at the time of execution of processing, the computer reads the program stored in the storage thereof and executes the processing in accordance with the read program. Moreover, as another embodiment of this program, the computer may read the program directly from the portable recording medium and execute the processing in accordance with the program. Furthermore, every time the program is transferred to the computer from the server computer, the computer may sequentially execute the processing in accordance with the received program. In addition, a configuration may be adopted in which the transfer of a program to the computer from the server computer is not performed and the above-described processing is executed by so-called application service provider (ASP)-type service by which the processing functions are implemented only by an instruction for execution thereof and result acquisition. Incidentally, it is assumed that the program includes information (data or the like which is not a direct command to the computer but has the property of defining the processing of the computer) which is used for processing by an electronic calculator and is equivalent to a program.

Moreover, the devices are assumed to be configured as a result of a predetermined program being executed on the computer, but at least part of these processing details may be implemented on the hardware.

## Claims

1. A decoding device comprising:

- processing circuitry configured to: execute a predictive decoding processing in which the processing circuitry obtains a decoded differential vector by decoding a first code and generates a first decoded vector formed of decoded values of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame by adding the decoded differential vector and a prediction vector containing at least a prediction based on a past frame; and execute a non-predictive decoding processing in which the processing circuitry obtains a decoded correction vector by decoding a second code and generates a second decoded vector formed of decoded values of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame by adding elements of the decoded correction vector and at least elements of corresponding orders of the decoded differential vector.

2. A decoding device comprising:

- processing circuitry configured to: execute a predictive decoding processing in which the processing circuitry obtains a decoded differential vector by decoding a first code and generates a first decoded vector formed of decoded values of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame by adding the decoded differential vector and a prediction vector formed of at least a prediction based on a past frame and a predetermined vector; and execute a non-predictive decoding processing in which the processing circuitry obtains a decoded correction vector by decoding a second code and generates a second decoded vector formed of decoded values of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame by adding, to the decoded correction vector, at least the decoded differential vector and a predetermined vector for each of elements of corresponding orders.

3. The decoding device according to claim 2, wherein

- with an assumption that a is a positive constant, the prediction vector is a vector obtained by adding a predetermined predictive mean vector and what is obtained by multiplying a decoded differential vector of the past frame by a factor of α, and,

- the second decoded vector is a vector obtained by adding elements of the decoded correction vector, elements of corresponding orders of the decoded differential vector and elements of corresponding orders of a predetermined non-predictive mean vector.

4. The decoding device according to any one of claims 1 to 3, wherein

- a number of elements TL of the decoded correction vector obtained by decoding the second code is less than a number of elements p of each of the vectors of the predictive decoding processing, and

- a number of elements of the second decoded vector generated by the non-predictive decoding processing is p.

5. A decoding method, implemented by a decoding device that includes processing circuitry, comprising:

- a predictive decoding step in which the processing circuitry obtains a decoded differential vector by decoding a first code and generates a first decoded vector formed of decoded values of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame by adding the decoded differential vector and a prediction vector containing at least a prediction based on a past frame; and

- a non-predictive decoding step in which the processing circuitry obtains a decoded correction vector by decoding a second code and generates a second decoded vector formed of decoded values of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame by adding elements of the decoded correction vector and at least elements of corresponding orders of the decoded differential vector.

6. A decoding method, implemented by a decoding device that includes processing circuitry, comprising:

- a predictive decoding step in which the processing circuitry obtains a decoded differential vector by decoding a first code and generates a first decoded vector formed of decoded values of coefficients which are convertible into linear prediction coefficients of more than one order of a present frame by adding the decoded differential vector and a prediction vector formed of at least a prediction based on a past frame and a predetermined vector; and

- a non-predictive decoding step in which the processing circuitry obtains a decoded correction vector by decoding a second code and generates a second decoded vector formed of decoded values of the coefficients which are convertible into the linear prediction coefficients of more than one order of the present frame by adding, to the decoded correction vector, at least the decoded differential vector and a predetermined vector for each of elements of corresponding orders.

7. The decoding method according to claim 6, wherein

- with an assumption that a is a positive constant, the prediction vector is a vector obtained by adding a predetermined predictive mean vector and what is obtained by multiplying a decoded differential vector of the past frame by a factor of α, and,

- the second decoded vector is a vector obtained by adding elements of the decoded correction vector, elements of corresponding orders of the decoded differential vector and elements of corresponding orders of a predetermined non-predictive mean vector.

8. The decoding method according to any one of claims 5 to 7, wherein

- a number of elements TL of the decoded correction vector obtained by decoding the second code is less than a number of elements p of each of the vectors in the predictive decoding step, and

- a number of elements of the second decoded vector generated in the non-predictive decoding step is p.

9. A non-transitory recording medium comprising instructions which, when executed by a computer, cause the computer to perform the steps of the decoding method according to any one of claims 5 to 7.

**Referenced Cited**

**U.S. Patent Documents**

5778334 | July 7, 1998 | Ozawa |

6122608 | September 19, 2000 | McCree |

6757654 | June 29, 2004 | Westerlund |

8068042 | November 29, 2011 | Harada |

8463602 | June 11, 2013 | Oshikiri |

8892428 | November 18, 2014 | Oshikiri |

9424830 | August 23, 2016 | Togawa |

9852741 | December 26, 2017 | Salami |

20020173951 | November 21, 2002 | Ehara |

20040176951 | September 9, 2004 | Sung |

20090248404 | October 1, 2009 | Ehara |

20100145712 | June 10, 2010 | Kovesi |

20100153121 | June 17, 2010 | Toguri |

20130028426 | January 31, 2013 | Purnhagen |

20140236588 | August 21, 2014 | Subasingha |

20150302861 | October 22, 2015 | Salam i |

20160093311 | March 31, 2016 | Kim |

20160293173 | October 6, 2016 | Faure |

20180075856 | March 15, 2018 | Salam i |

**Foreign Patent Documents**

3139382 | November 2017 | EP |

**Other references**

- M. Jelinek, T. Vaillancourt and J. Gibbs, “G.718: A new embedded speech and audio coding standard with high resilience to error-prone transmission channels,” in IEEE Communications Magazine, vol. 47, No. 10, pp. 117-123, Oct. 2009, doi: 10.1109/MCOM.2009.5273818. (Year: 2009).
- H. Zarrinkoub and P. Mermelstein, “Switched prediction and quantization of LSP frequencies,” 1996 IEEE International Conference on Acoustics, Speech, and Signal Processing Conference Proceedings, Atlanta, GA, USA, 1996, pp. 757-760 vol. 2, doi: 10.1109/ICASSP.1996.543231. (Year: 1996).
- International Search Report dated Apr. 14, 2015 in PCT/JP2015/057727 filed Mar. 16, 2015.
- ITU-T, G.729, Telecommunication Standardization Sector of ITU, General Aspects of Digital Transmission Systems: Coding of Speech At 8 kbit/s Using Conjugate-Structure Algebraic-Code-Excited Linear-Prediction (CS-ACELP), (Mar. 1996), 38 pages.
- Office Action dated Sep. 19, 2017 in Korean Patent Application No. 10-2016-7030130 (with English language translation).
- ITU-T Recommendation G.718. “Frame error robust narrow-band and wideband embedded variable bit-rate coding of speech and audio from 8-32 kbit/s” ITU-T, 2008, 255 Pages.
- Frank K. Soong, et al., “Line Spectrum Pair (LSP) and Speech Data Compression”, IEEE International Conference on Acoustics, Speech, and Signal Processing (ICASSP'84), 1984, 4 pages.
- Extended Search Report dated Oct. 24, 2017 in European Patent Application No. 15786812.6.
- ITU-T, G.729, Telecommunication Standardization Sector of ITU, Series G: Transmission Systems and Media,Digital Systems and Networks, Digital terminal equipments-Coding of voice and audio signals, Coding of speech at 8 kbit/s using conjugate-structure algebraic-code-excited linear-prediction (CS-ACELP), (Jun. 2012), XP055234042, 152 pages.

**Patent History**

**Patent number**: 11120809

**Type:**Grant

**Filed**: Jul 31, 2019

**Date of Patent**: Sep 14, 2021

**Patent Publication Number**: 20190355369

**Assignee**: Nippon Telegraph and Telephone Corporation (Chiyoda-ku)

**Inventors**: Takehiro Moriya (Atsugi), Yutaka Kamamoto (Atsugi), Noboru Harada (Atsugi)

**Primary Examiner**: Michael Ortiz-Sanchez

**Application Number**: 16/527,160

**Classifications**

**Current U.S. Class**:

**Linear Prediction (704/219)**

**International Classification**: G10L 19/00 (20130101); G10L 21/00 (20130101); G10L 19/07 (20130101); G10L 19/038 (20130101); G10L 19/005 (20130101);