1. Field of the Invention
The present invention relates to the predictive coding of information signals, such as, for example, audio signals, and in particular to adaptive predictive coding.
2. Description of the Related Art
predictive coder—or transmitter—codes signals by predicting a current value of the signal to be coded by the previous or preceding values of the signal. In the case of linear prediction, this prediction or presumption is accomplished via the current value of the signal by a weighted sum of the previous values of the signal. The prediction weights or prediction coefficients are continuously adjusted or adapted to the signal so that the difference between the predicted signal and the actual signal is minimized in a predetermined manner. The prediction coefficients, for example, are optimized with regard to the square of the prediction error. The error criterion when optimizing the predictive coder or predictor, however, may also be selected to be something else. Instead of using the least square error criterion, the spectral flatness of the error signal, i.e. of the differences or residuals, may be minimized.
Only the differences between the predicted values and the actual values of the signal are transmitted to the decoder or receiver. These values are referred to as residuals or prediction errors. The actual signal value can be reconstructed in the receiver by using the same predictor and by adding the predicted value obtained in the same manner as in the coder to the prediction error having been transmitted by the coder.
The prediction weights for the prediction may be adapted to the signal with a predetermined speed. In the so-called least mean squares (LMS) algorithm, one parameter is used for this. The parameter must be adjusted in a manner acting as a trade-off between adaption speed and precision of the prediction coefficients. This parameter, which is sometimes also referred to as step-size parameter, thus determines how fast the prediction coefficients adapt to an optimum set of prediction coefficients, wherein a set of prediction coefficients not adjusted optimally results in the prediction to be less precise and thus the prediction errors to be greater, which in turn results in an increased bit rate for transmitting the signal since small values or small prediction errors or differences can be transmitted by fewer bits than greater ones.
A problem in predictive coding is that in the case of transmitting errors, i.e. if incorrectly transmitted prediction differences or errors occur, prediction will no longer be the same on the transmitter and receiver sides. Incorrect values will be reconstructed since, when a prediction error first occurs, it is added on the receiver side to the currently predicted value to obtain the decoded value of the signal. Subsequent values, too, are affected since the prediction on the receiver side is performed based on the signal values already decoded.
In order to obtain resynchronization or adjustment between transmitter and receiver, the predictors, i.e. the prediction algorithms, are reset to a certain state on the transmitter and receiver sides at predetermined times equal for both sides, a process also referred to as reset.
However, it is problematic that directly after such a reset the prediction coefficients are not adjusted to the signal at all. The adaption of these prediction coefficients, however, will always require some time starting from the reset times. This increases the mean prediction error resulting in an increased bit rate or reduced signal quality, such as, for example, due to distortions.
Consequently, it is an object of the present invention to provide a scheme for predictive coding of an information signal which, on the one hand, allows more sufficient robustness to errors in the difference value or residuals of the coded information signal and, on the other hand, allows a lower accompanying increase in the bit rate or decrease in signal quality.
In accordance with a first aspect, the present invention provides a method for predictively coding an information signal including a sequence of information values by means of an adaptive prediction algorithm the prediction coefficients of which may be initialized and which is controllable by a speed parameter to operate with a first adaption speed and a first adaption precision in the case that the speed parameter has a first value and to operate with a second, compared to the first one, lower adaption speed and a second, compared to the first one, higher adaption precision in the case that the speed parameter has a second value, having the steps of: A) initializing the prediction coefficients; B) controlling the adaptive prediction algorithm to set the speed parameter to the first value; C) coding successive information values of the information signal by means of the adaptive prediction algorithm with the speed parameter set to the first value as long as a predetermined duration after step B) has not expired to code a first part of the information signal; D) after expiry of the predetermined duration after step B), controlling the adaptive prediction algorithm to set the speed parameter to the second value; and E) coding information values of the information signal following the information values coded in step C) by means of the adaptive prediction algorithm with the speed parameter set to the second value to code a second part of the information signal following the first part.
In accordance with a second aspect, the present invention provides a device for predictively coding an information signal including a sequence of information values, having: means for performing an adaptive prediction algorithm the prediction coefficients of which may be initialized and which is controllable by a speed parameter to operate with a first adaption speed and a first adaption precision in the case that the speed parameter has a first value and to operate with a second, compared to the first one, lower adaption speed and a second, compared to the first one, higher adaption precision in the case that the speed parameter has a second value; and control means coupled to the means for performing the adaptive prediction algorithm and effective to cause: A) initialization of the prediction coefficients; B) control of the adaptive prediction algorithm to set the speed parameter to the first value; C) coding of successive information values of the information signal by means of the adaptive prediction algorithm with the speed parameter set to the first value as long as a predetermined duration after the control B) has not expired to code a first part of the information signal; D) after expiry of the predetermined duration after the control B), control of the adaptive prediction algorithm to set the speed parameter to the second value; and E) coding of information values of the information signal following the information values coded in the coding C) by means of the adaptive prediction algorithm with the speed parameter set to the second value to code a second part of the information signal following the first part.
In accordance with a third aspect, the present invention provides a method for decoding a predictively coded information signal including a sequence of difference values by means of an adaptive prediction algorithm the prediction coefficients of which may be initialized and which is controllable by a speed parameter to operate with a first adaption speed and a first adaption precision in the case that the speed parameter has a first value and to operate with a second, compared to the first one, lower adaption speed and a second, compared to the first one, higher adaption precision in the case that the speed parameter has a second value, having the steps of: F) initializing the prediction coefficients; G) controlling the adaptive prediction algorithm to set the speed parameter to the first value; H) decoding successive difference values of the predictively coded information signal by means of the adaptive prediction algorithm with the speed parameter set to the first value as long as a predetermined duration after step G) has not expired to decode a first part of the predictively coded information signal; I) after expiry of the predetermined duration after step G), controlling the adaptive prediction algorithm to set the speed parameter to the second value; and J) decoding difference values of the predictively coded information signal following the difference values decoded in step H) by means of the adaptive prediction algorithm with the speed parameter set to the second value to decode a second part of the predictively coded information signal.
In accordance with a fourth aspect, the present invention provides a device for decoding a predictively coded information signal including a sequence of difference values, having: means for performing an adaptive prediction algorithm the prediction coefficients of which may be initialized and which is controllable by a speed parameter to operate with a first adaption speed and a first adaption precision in the case that the speed parameter has a first value and to operate with a second, compared to the first one, lower adaption speed and a second, compared to the first one, higher adaption precision in the case that the speed parameter has a second value; and control means coupled to the means for performing the adaptive prediction algorithm and effective to cause: F) initialization of the prediction coefficients; G) control of the adaptive prediction algorithm to set the speed parameter to the first value; H) decoding of successive difference values of the predictively coded information signal by means of the adaptive prediction algorithm with the speed parameter set to the first value as long as a predetermined duration after the control G) has not expired to decode a first part of the predictively coded information signal; I) after expiry of the predetermined duration after the control G), control of the adaptive prediction algorithm to set the speed parameter to the second value; and J) decoding of difference values of the predictively coded information signal following the difference values decoded in the decoding H) by means of the adaptive prediction algorithm with the speed parameter set to the second value to decode a second part of the predictively coded information signal.
In accordance with a fifth aspect, the present invention provides a computer program having a program code for performing one of the above mentioned methods when the computer program runs on a computer.
The present invention is based on the finding that the, up to now, fixed setting of the speed parameter of the adaptive prediction algorithm acting as the basis of predictive coding has to be given up in favor of a variable setting of this parameter. If an adaptive prediction algorithm controllable by a speed coefficient is started from to operate with a first adaption speed and a first adaption precision and an accompanying first prediction precision in the case that the speed coefficient has a first value and to operate with a second, but compared to the first one, lower adaption speed and a second, compared to the first one, higher precision in the case that the speed parameter has a second value, the adaption durations occurring after the reset times where the prediction errors are at first increased due to the prediction coefficients having not yet been adapted can be decreased by at first setting the speed parameter to the first value and, after a while, to the second value. After setting the speed parameter again to the second value after a predetermined duration after the reset times, the prediction errors and thus the residuals to be transmitted are more optimized or smaller than would be possible with the first speed parameter value.
Put differently, the present invention is based on the finding that prediction errors can be minimized after reset times by altering the speed parameters, such as, for example, the step-size parameter of an LMS algorithm, for a certain duration after the reset times such that the speed of the adaption of the weights is increased for this duration—of course entailing reduced precision.
Preferred embodiments of the present invention will be detailed subsequently referring to the appended drawings, in which:
Before discussing embodiments of the present invention in greater detail referring to the figures, it is pointed out that elements occurring in different figures are provided with same reference numerals and that a repeated description of these elements is omitted.
The information signal may be any signal, such as, for example, an audio signal, a video signal, a measuring signal or the like. The information signal s consists of a sequence of information values s(i), iε|N, i.e. audio values, pixel values, measuring values or the like. The coded information signal δ includes, as will be discussed in greater detail below, a sequence of difference values or residuals δ(i), iε|N, corresponding to the signal values s(i) in the manner described below.
Internally, the coder 10 includes prediction means 16, a subtracter 18 and control means 20. The prediction means 16 is connected to the input 12 in order to calculate, as will be discussed in greater detail below, a predicted value s′(n) from previous signal values s(m), m<n and mεIN, for a current signal value s(n) and to output same to an output which in turn is connected to an inverting input of the subtracter 18. A non-inverting input of the subtracter 18 is also connected to the input 12 to subtract the predicted value s′(m) from the actual signal value s(n)—or simply to calculate the difference of the two values—and to output the result at the output 14 as the difference value δ(n).
The prediction means 16 implements an adaptive prediction algorithm. In order to be able to perform the adaption, it receives the difference value δ(n)—also referred to as prediction error—at another input via a feedback path 22. In addition, the prediction means 16 includes two control inputs connected to the control means 20. By means of these control inputs, the control means 20 is able to initialize prediction coefficients or filter coefficients ωi of the prediction means 16 at certain times, as will be discussed in greater detail below, and to change a speed parameter of the prediction algorithm on which the prediction means 16 is based, which subsequently will be referred to by λ.
After the setup of the coder 10 of
In step 40, the control means 20 at first initializes the prediction or filter coefficients ωi of the prediction means 16. The initialization according to step 40 takes place at predetermined reset times. The reset times or, more precisely, the signal value numbers n where a reset according to step 40 has been performed may, for example, occur in fixed time intervals. The reset times may be reconstructed on the decoder side, for example by integrating information about same in the coded information signal δ or by standardizing the fixed time interval or the fixed number of signal values between same.
The coefficients ωi are set to any values which may, for example, be the same at any reset time, i.e. every time step 40 is executed. Preferably, the prediction coefficients are initialized in step 40 to values having been derived heuristically from typical representative information signals and having resulted, on average, i.e. over the representative set of information signals, such as, for example, a mixture of jazz, classical, rock etc. pieces of music, in an optimum set of prediction coefficients.
In step 42, the control means 20 sets the speed parameter λ to a first value, wherein steps 40 and 42 are preferably executed essentially simultaneously to the reset times. As will become obvious subsequently, the setting of the speed parameter to the first value has the result that the prediction means 16 performs a quick adaption of the prediction coefficients ωi initialized in step 40—of course entailing reduced adaption precision.
In step 44, the prediction means 16 and the subtracter 18 cooperate as prediction means to code the information signal s and, in particular, the current signal value s(n) by predicting same using adaption of the prediction coefficients ωi. More precisely, step 44 includes several substeps, namely calculating a predicted value s′(n) for the current signal value s(n) by the prediction means 16 using previous signal values s(m), m<n, using the current prediction coefficients ωi, subtracting the value s′(n) predicted in this way from the actual signal value s(n) by the subtracter 18, outputting the resulting difference value δ(n) at the output 14 as part of the coded information signal δ and adapting or adjusting the coefficients ωi by the prediction means 16 using the prediction error or difference value δ(n) it obtains via the feedback path 22.
The prediction means 16 uses, for the adaption or adjustment of the prediction coefficients ωi, the speed parameter λ predetermined or set by the control means 20 which, as will be discussed in greater detail below referring to the embodiment of an LMS algorithm, determines how strongly the feedback prediction error δ(n) per adjustment iteration, here n, influences the adaption or update of the prediction coefficients ωi or how strongly the prediction coefficients ωi can change depending on the prediction error δ(n) per adaption iteration, i.e. per δ(n) fed back.
In step 46, the control means 20 checks whether the speed parameter λ is to be altered or not. The determination of step 46 can be performed in different manners. Exemplarily, the control means 20 determines that a speed parameter change is to be performed when a predetermined duration has passed since the initialization or setting in step 40 and 42, respectively. Alternatively, the control means 20 for determining evaluates, in step 46, an adaption degree of the prediction means 16, such as, for example, the approximation to an optimum set of coefficients ωi with correspondingly low means prediction errors, as will be discussed in greater detail below.
It is assumed that at first no speed parameter change is recognized in step 46. In this case, the control means 20 checks in step 48 whether there is again a reset time, i.e. a time when for reasons of resynchronization the prediction coefficients are to be initialized again. At first, it is again assumed that there is no reset time. If there is no reset time, the prediction means 16 will continue coding the next signal value, as is indicated in
After having passed the loop 44-48 several times, the control means 20 will at some time recognize a reset time in step 48, whereupon the functional flow starts over again at step 40.
It is also to be pointed out that the manner in which the sequence of difference values δ(n) is integrated in the coded information signal δ has not been described in detail above. Although it would be possible to integrate the difference values δ(n) in the coded signal in a binary representation having a fixed bit length, it is, however, of more advantage to code the difference values δ(n) with a variable bit length, such as, for example, Huffman coding or arithmetic coding or another entropy coding. A bit rate advantage or an advantage of a smaller amount of bits required for coding the information signal s results in the coder 10 of
Now that the predictive coding according to an embodiment of the present invention has been described above, a decoder corresponding to the coder of
An input of the prediction means 66 is connected to the output 64 to obtain signal values s(n) already decoded. From these signal values s(m), m<n, already decoded the prediction means 66 calculates a predicted value s′(n) for a current signal value s(n) to be decoded and outputs this predicted value to a first input of the adder 68. A second input of the adder 68 is connected to the input 62 to add the predicted value s′(n) and the difference value δ(n) and to output the result or the sum to the output 64 as a part of the decoded signal ŝ and to the input of the prediction means 66 for predicting the next signal value.
Another input of the prediction means 66 is connected to the input 62 to obtain the difference value δ(n), wherein it then uses this value to adapt the current prediction coefficients ωi. Like in the prediction means 16 of
The mode of functioning of the decoder 60 will be described subsequently referring at the same time to
In step 94, the prediction means 66 decodes the coded information signal δ or the current difference value δ(n) by predicting the information signal using adaption of the prediction coefficients ωi. More precisely, step 94 includes several substeps. At first, the prediction means 66 knowing the signal values s(m) already decoded, m<n, predicts the current signal value to be determined therefrom to obtain the predicted value s′(n). Thus, the prediction means 66 uses the current prediction coefficients ωi. The current difference value δ(n) to be decoded is added by the adder 68 to the predicted value s′(n) to output the sum obtained in this way as a part of the decoded signal ŝ at the output 64. However, the sum is also input in the prediction means 66 which will use this value s(n) in the next predictions. Additionally, the prediction means 66 uses the difference value δ(n) from the coded signal stream to adapt the current prediction coefficients ωi, the adaption speed and the adaption precision being predetermined by the currently set speed parameter λ. The prediction coefficients ωi are updated or adapted in this manner.
In step 96 corresponding to step 46 of
If, however, there is a speed parameter alteration time in step 96, in step 100 the control means 70 will set the speed parameter λ to a second value corresponding to a lower adaption speed but higher adaption precision, as has already been discussed with regard to coding.
As has been mentioned, it is ensured either by information in the coded information signal 62 or by standardization that the speed parameter changes and reset times occur at the same positions or between the same signal values or decoded signal values, namely on the transmitter side and the receiver side.
After a predictive coding scheme according to an embodiment of the present invention has been described in general referring to
The LMS algorithm implemented by the prediction means 16—maybe in cooperation with the subtracter 18 (
Details of the transversal filter 130 are illustrated in
In a broader sense, the estimation value s′(n) comes close to a value predicted according to the Wiener solution in a, in a broader sense, stationary surrounding when the number of iterations n reaches infinity.
The adaption controller 132 is shown in greater detail in
The scaling factor λ used in the adaption controller 132 and, as has already been mentioned, referred to as step-size parameter may be considered to be a positive quantity and should meet certain conditions relative to the spectral content of the information signal in order for the LMS algorithm realized by the means 16 of
An alteration of the speed parameter λ causes an alteration in the adaption precision, i.e. in precision, since the coefficients ωi may be adjusted to an optimum set of coefficients. Maladjustment of the filter coefficients results in an increase in the mean square error or the energy in the difference values δ in the steady state n→∞. In particular, the feedback loop acting on the weights ωi acts like a low-pass filter, the determination duration constant of which is inversely proportional to the parameter λ. Consequently, the adaptive process is slowed down by setting the parameter λ to a small value, wherein the effects of this gradient noise on the weights ωi are largely filtered out. This has the reverse effect of reducing maladjustment.
If, however, as has been described referring to
With regard to the above description of the figures, it is pointed out that the present invention is not limited to LMS algorithm implementations. Although, referring to
Additionally, it is pointed out that, instead of the fixed duration described above after the reset times for triggering the speed parameter change, triggering may also be performed depending on the adaption degree, such as, for example, triggering a speed parameter change when the coefficient corrections δω, such as, for example, a sum of the absolute values thereof, fall below a certain value, indicating an approximation to the quasi-stationary state, as is shown in
In particular, it is pointed out that depending on the circumstances the inventive scheme may also be implemented in software. The implementation may be on a digital storage medium, in particular on a disc or a CD having control signals which may be read out electronically which can cooperate with a programmable computer system such that the corresponding method will be executed. In general, the invention thus also is in a computer program product having a program code stored on a machine-readable carrier for performing the inventive method when the computer program product runs on a computer. Put differently, the invention may thus also be realized as a computer program having a program code for performing the method when the computer program runs on a computer.
While this invention has been described in terms of several preferred embodiments, there are alterations, permutations, and equivalents which fall within the scope of this invention. It should also be noted that there are many alternative ways of implementing the methods and compositions of the present invention. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
102004007185.3 | Feb 2004 | DE | national |
This application is a continuation of copending International Application No. PCT/EP2004/014496, filed Dec. 20, 2004, which designated the United States and was not published in English, and is incorporated herein by reference in its entirety, and which claimed priority to German Patent Application No. 10 2004 007 185.3, filed Feb. 13, 2004.
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP04/14496 | Dec 2004 | US |
Child | 11462140 | Aug 2006 | US |