The present document relates to coding. In particular, the present document relates to lossless coding using linear prediction, possibly in combination with entropy encoding.
Audio encoders and in particular lossless audio encoders typically employ a FIR (Finite Impulse Response) prediction filter to reduce the entropy of an audio signal. Employing an IIR (Infinite Impulse Response) prediction filter may lead to improved prediction results and to reduced entropy of the prediction error signal. IIR prediction filters may e.g. be used in the so-called Dolby TrueHD lossless encoder. However, unlike FIR predictors it is typically difficult to derive optimal IIR prediction coefficients on a frame-by-frame basis that guarantees the stability of the predictor system (for the encoder) and its inverse system (for the decoder).
The present document addresses the above-mentioned technical problem. In particular, the present document describes methods for determining the coefficients of IIR-based prediction filters which lead to improved prediction results (i.e. which lead to a reduction of the entropy of the prediction error signal). The IIR prediction filters may be determined such that stability may be guaranteed. As such, the methods described in the present document enable the use of IIR-based prediction, thereby providing audio encoders (in particular lossless audio encoders) with improved coding gains.
According to an aspect a method for determining a general prediction filter for a frame of an input signal is described. The general prediction filter may be determined such that it is ensured that the determined general prediction filter is stable. Typically the frame of the input signal (e.g. an audio signal such as a speech signal or a music signal, or an image signal, e.g. a line or a column of an image) comprises a plurality of samples (e.g. 50 or more, or 100 or more samples). The general prediction filter may comprise an infinite impulse response (IIR) prediction filter. In general terms, the general prediction filter may comprise an IIR prediction filter component and/or an FIR prediction filter component. The z-transform of the general prediction filter may be represented as a ratio of an FIR filter in the numerator and an FIR filter in the denominator. In particular, the z-transform of the general prediction filter (also referred to as the transfer function of the general prediction filter or the z-transform of the impulse response of the general prediction filter) may be presented in a form which comprises an approximation to the z-transform of a finite impulse response (FIR) filter with the z variable of the FIR prediction filter being replaced by the z-transform of an allpass filter. By way of example, the general prediction filter may be presented in a form which comprises the z-transform of a FIR filter with the z variable of the FIR prediction filter being replaced by the z-transform of an allpass filter. In other words, it is proposed to make use of a general prediction filter (which may comprise an IIR prediction filter) which may be derived by replacing the delays of an FIR prediction filter with allpass filters. The FIR filter typically comprises a plurality (K with K>1, e.g. K=4 or 8 or more) of FIR coefficients. The allpass filter may exhibit a pole defined by an adjustable pole parameter λ. As such, the general prediction filter may be defined by the plurality of FIR coefficients and by the pole parameter λ. In an embodiment, the allpass filter exhibits a single pole defined by a single adjustable pole parameter.
As indicated above, the z-transform of the general prediction filter may be derived from (an approximation of) the z-transform of an FIR filter with the z variable of the FIR prediction filter being replaced by the z-transform of an allpass filter. In particular, the general prediction filter may be determined by first determining an intermediate general prediction filter having a z-transform which (exactly) comprises the z-transform of an FIR filter with the z variable of the FIR prediction filter being replaced by the z-transform of an allpass filter. The coefficients of the intermediate general prediction filter may then be approximated (e.g. the coefficients may be quantized), thereby yielding the coefficients of the general prediction filter. As a consequence of the approximation of the coefficients of the intermediate general prediction filter, the z-transform of the general prediction filter comprises an approximation of the z-transform of an FIR filter with the z variable of the FIR prediction filter being replaced by the z-transform of an allpass filter. The approximation may be due to the quantization of filter coefficients and/or due to the transformation of the FIR filter coefficients and the pole parameter to an IIR filter representation (as described below in the context of the “mapping” feature).
The pole parameter λ may be used to adapt the general prediction filter between an FIR prediction filter and an IIR prediction filter. In other words, the method may yield an adaptive general prediction filter which may adapt its filter structure (i.e. IIR structure or FIR structure) to the frame of the input signal using one or more pole parameters λ. It should be noted that a general prediction filter having an IIR structure typically also comprises an FIR filter component. On the other hand, a general prediction filter having an FIR structure typically only comprises an FIR filter component.
By way of example, the z-transform of the allpass filter may comprise the z-transform of the following allpass filter
with λ being the pole parameter adjustable between values ±1. In particular, the pole parameter may be unequal to zero, thereby providing a general prediction filter which exhibits an infinite impulse response. On the other hand, if the pole parameter is determined to be zero, the general prediction filter typically corresponds to an FIR prediction filter. This means that for the particular frame of the input signal, entropy minimization may be achieved using an FIR prediction filter without the need of providing an IIR prediction filter. Furthermore, the z-transform of the general prediction filter may comprise a pre-filter configured to whiten a spectrum of the prediction error signal. By whitening the spectrum of the prediction error signal, the entropy encoding of the prediction error signal may be performed with increased efficiency. In addition, the z-transform of the general prediction filter may comprise an overall delay. By inserting an overall delay, it may be ensured that the general prediction may be performed in a causal manner.
In a particular example, the z-transform of the general prediction filter may be representable as Σk=1Kz−1βkHk(z), with k=1, . . . , K, with K>1, with
and with βk, k=1, . . . , K being the plurality of FIR coefficients (412). It can be seen that the general prediction filter comprise an overall delay z−1 and that each filter component Hk(z) comprises a pre-filter
for whitening purposes.
The method may comprise determining the pole parameter and the plurality of FIR coefficients, such that an entropy of a frame of a prediction error signal which is derived from the frame of the input signal using the general prediction filter defined by the pole parameter and the plurality of FIR coefficients is reduced (e.g. is minimized). The general prediction filter may be used to determine a frame of an estimated signal (e.g. an estimated audio signal or an estimated image signal) from the frame of the input signal. The difference between the frame of the estimated signal and the frame of the input signal may provide the frame of the prediction error signal. The pole parameter and the plurality of FIR coefficients may specify the general prediction filter, and the general prediction filter may be adjusted such that the entropy of the frame of the prediction error signal is reduced (e.g. minimized).
The entropy of the frame of the prediction error signal may be estimated by determining a probability distribution of the values of samples of the frame of the prediction error signal. The entropy may be estimated based on a weighted sum of the probability distribution. The weighted sum of the probability distribution may be given by
with Pi being the probability of the value i of a sample of the prediction error signal and with b being the base of the log function (e.g. b=2 or 10 or e, i.e. Euler's number).
Determining the pole parameter and the plurality of FIR coefficients may comprise setting the adjustable pole parameter to a fixed first value and determining the plurality of FIR coefficients using the set pole parameter. For a fixed or set pole parameter, determining the plurality of FIR coefficients may comprise determining the plurality of FIR coefficients such that a mean squared power of the frame of the prediction error signal is reduced. In view of the fact that the general prediction filter is derived from an FIR filter, this target may be achieved by solving a set of normal equations (e.g. using a Levinson-Durbin algorithm). By way of example, for a fixed or a set pole parameter, determining the plurality of FIR coefficients may comprise determining a frame of a regressor signal based on the frame of the input signal for each tap of the general prediction filter (i.e. for each filter component Hk(z)), thereby yielding a plurality of regressor signal frames. The plurality of regressor signal frames may be used to determine an autocorrelation matrix Q for the plurality of regressor signal frames. The size of the autocorrelation matrix Q typically depends on the number K of FIR coefficients which are to be determined. Furthermore, a cross-correlation vector P may be determined based on the plurality of regressor signal frames and the frame of the input signal. An FIR coefficient vector β comprising the plurality of FIR coefficients may be determined by solving the normal equations Qβ=P.
Determining the pole parameter and the plurality of FIR coefficients may comprise estimating the entropy of the frame of the prediction error signal obtained using the general prediction filter defined by the set pole parameter and the plurality of FIR coefficients. The plurality of FIR coefficients have been determined based on the set pole parameter (e.g. using the above mentioned set of normal equations). The steps of determining the plurality of FIR coefficients (for a set pole parameter) and of estimating the entropy may be repeated for a plurality of differently set pole parameters, thereby yielding a corresponding plurality of entropy values. The pole parameter may be selected from the plurality of differently set pole parameters, which reduces the estimated entropy of the frame of the prediction error signal. In other words, the pole parameter which yields the lowest entropy from the plurality of entropies may be selected. Furthermore, the plurality of FIR coefficients which has been determined using the selected pole parameters may be selected. The selected pole parameter and the selected plurality of FIR coefficients may be the pole parameter and the plurality of FIR coefficients, which reduce (e.g. minimize) the entropy of the frame of the prediction error signal.
Alternatively or in addition, setting the pole parameter to a fixed first value may comprise estimating a frequency based on the frame of the input signal. In particular, a dominant frequency of the frame of the input signal may be estimated. Estimating a frequency based on the frame of the input signal may comprise determining a spectral envelope of a spectrum of the frame of the input signal, and estimating the frequency of the frame of the input signal based on the spectral envelope (e.g. based on a maximum of the spectral envelope). The first value for the pole parameter may be determined based on the estimated frequency, e.g. using a pre-determined look-up table or a pre-determined function. The pre-determined look-up table or function may provide a mapping between a plurality of frequency values and a corresponding plurality of pole parameter values. The pre-determined look-up table or function may be determined experimentally, e.g. using a training set of input signals.
The z-transform of the general prediction filter may be representable as a ratio of a first and a second FIR filter (e.g. the filters A and B as described in the present document) comprising first and second sets of coefficients, respectively. The first and second FIR filters may be filters in accordance to the True HD coder. The method may further comprise mapping the determined pole parameter and the determined plurality of FIR coefficients to the first and second sets of coefficients. By way of example, the mapping may make use of formulas (e.g. the formulas described in the present document) for determining the first and second sets of coefficients from the determined pole parameter and from the determined plurality of FIR coefficients. The formulas may provide for an exact bi-directional transformation of the first and second sets of coefficients and of the determined pole parameter and the determined plurality of FIR coefficients. Alternatively the formulas may yield an approximation of the general prediction filter described by the determined pole parameter and the determined plurality of FIR coefficients. Alternatively or in addition, the mapping may comprise quantizing of the first and second sets of coefficients. As such, the general prediction filter may be used in conjunction with incumbent IIR-based encoders such as the True HD coder, thereby allowing the reuse of an already existing installed base of decoders.
According to a further aspect, a method for encoding a frame of an input signal using a general prediction filter is described. The method comprises determining the general prediction filter using the methods described in the present document. Furthermore, the method comprises determining an estimate of the frame of the input signal using the determined general prediction filter. A frame of a prediction error signal may be determined based on the estimated frame and the frame of the input signal (e.g. based on the difference). The method may comprise encoding information indicative of the determined general prediction filter; and encoding the frame of the prediction error signal (e.g. using an entropy encoder). The information indicative of the determined general prediction filter may comprise the pole parameter.
According to a further aspect, an encoded signal (e.g. an encoded audio signal or an encoded image signal) is described. The encoded signal comprises information indicative of a general prediction filter to be used by a decoder for decoding the encoded signal. The z-transform of the general prediction filter may be representable by a filter comprising (or having) the z-transform of a FIR filter with the z variable of the FIR filter being replaced by the z-transform of an allpass filter or an approximation of the z-transform of a FIR filter with the z variable of the FIR filter being replaced by the z-transform of an allpass filter. The FIR filter may comprise a plurality of FIR coefficients and the allpass filter may exhibit a pole defined by a pole parameter. The information indicative of the general prediction filter may comprise information indicative of the pole parameter.
According to another aspect, a method for determining a look-up table providing a mapping between an estimated frequency of a frame of an input signal and a pole parameter defining a pole of an allpass filter is described. The allpass filter may be used to provide a general prediction filter based on an FIR filter. The method may comprise providing a training set of different frames of input signals. The training set of frames may be used to estimate a corresponding set of frequencies for the training set of frames. Furthermore, a set of pole parameters may be determined which provide general prediction filters that reduce an entropy of frames of prediction error signals. The set of pole parameters may be determined using the methods described in the present document. The method may comprise determining the look-up table based on the set of frequencies and based on the corresponding set of pole parameters. In particular, clustering techniques may be used to determine the look-up table from the set of frequencies and the corresponding set of pole parameters.
According to a further aspect, a method for decoding an encoded signal is described. The encoded signal may have been encoded as described in the present document. The method may comprise receiving information indicative of a pole parameter of an allpass filter. The allpass filter may be used to provide a general prediction filter based on an FIR filter comprising a plurality of FIR coefficients. The method may comprise receiving information indicative of the plurality of FIR coefficients. The general prediction filter may be determined based on the received information indicative of the pole parameter and based on the received information indicative of the plurality of FIR coefficients. The general prediction filter may be used to decode the encoded signal. In particular, the method may comprise decoding a frame of a prediction error signal (comprised within the encoded signal). A frame of an estimated input signal (also referred to as the estimated decoded signal) may be determined based on the decoded frame of the prediction error signal and based the FIR prediction filter. A decoded frame of the encoded signal may be determined based on the frame of the estimated input signal and based the decoded frame of the prediction error signal.
According to another aspect, an encoder (e.g. an audio encoder or an image encoder) configured to determine a general prediction filter for a frame of an input signal is described. The z-transform of the general prediction filter may be indicative of (or may correspond to) the z-transform of a FIR filter with the z variable of the FIR filter being replaced by the z-transform of an allpass filter or of an approximation to the z-transform of a FIR filter with the z variable of the FIR filter being replaced by the z-transform of an allpass filter. The FIR filter may comprise a plurality of FIR coefficients. The allpass filter may exhibit a pole defined by an adjustable pole parameter. The encoder may be configured to determine the pole parameter and the plurality of FIR coefficients, such that an entropy of a frame of a prediction error signal is reduced (e.g. minimized). The frame of the prediction error signal is derived from the frame of the input signal using the general prediction filter, wherein the general prediction filter is defined by the pole parameter and the plurality of FIR coefficients.
According to another aspect, a decoder (e.g. an audio decoder or an image decoder) for decoding an encoded signal (e.g. an encoded audio signal or an encoded image signal) is described. The decoder may be configured to extract information indicative of a pole parameter of an allpass filter from the encoded signal. The allpass filter may be used to provide a general prediction filter based on an FIR filter comprising a plurality of FIR coefficients. The decoder may be further configured to extract information indicative of the plurality of FIR coefficients from the encoded signal. In addition, the decoder may be configured to determine the general prediction filter based on the extracted information indicative of the pole parameter and based on the extracted information indicative of the plurality of FIR coefficients. The general prediction filter may be used by the decoder to decode the encoded signal.
According to a further aspect, a method for decoding a frame of an encoded signal using a general prediction filter is described. The frame of the encoded signal may be indicative of coefficients of the general prediction filter. As outlined above, the general prediction filter may comprise an IIR prediction filter. Furthermore, the frame of the encoded signal may be indicative of a frame of a prediction error signal. The method may comprise extracting (indications of) coefficients of the general prediction filter from the encoded signal. The coefficients of the general prediction filter may have been determined using the methods described in the present document. Furthermore, the method may comprise decoding the frame of the prediction error signal (e.g. using a de-quantizer). The method may proceed in determining a frame of an estimated decoded signal based on the decoded frame of the prediction error signal and based on the general prediction filter. Furthermore, the method may comprise determining a decoded frame of the encoded signal based on the frame of the estimated decoded signal and based on the decoded frame of the prediction error signal. In particular, the decoded frame of the encoded signal may be determined by adding corresponding samples of the frame of the estimated decoded signal and of the decoded frame of the prediction error signal.
According to another aspect, a decoder for decoding an encoded signal is described. The encoded signal may be indicative of coefficients of a general prediction filter and of samples of a prediction error signal. The decoder may comprise means for extracting coefficients of the general prediction filter from the encoded signal. The coefficients of the general prediction filter may have been determined using the methods described in the present document. The coefficients may be associated with a frame of the encoded signal. Furthermore, the decoder may comprise means for decoding a frame of the prediction error signal, e.g. using a de-quantizer. In addition, the decoder may comprise means for determining a frame of an estimated decoded signal based on the decoded frame of the prediction error signal and based on the general prediction filter. Furthermore, the decoder may comprise means for determining a decoded frame of the encoded signal based on the frame of the estimated decoded signal and based the decoded frame of the prediction error signal.
According to a further aspect, a software program is described. The software program may be adapted for execution on a processor and for performing the method steps outlined in the present document when carried out on the processor.
According to another aspect, a storage medium is described. The storage medium may comprise a software program adapted for execution on a processor and for performing the method steps outlined in the present document when carried out on the processor.
According to a further aspect, a computer program product is described. The computer program may comprise executable instructions for performing the method steps outlined in the present document when executed on a computer.
It should be noted that the methods and systems including their preferred embodiments as outlined in the present patent application may be used stand-alone or in combination with the other methods and systems disclosed in this document. Furthermore, all aspects of the methods and systems outlined in the present patent application may be arbitrarily combined. In particular, the features of the claims may be combined with one another in an arbitrary manner.
The invention is explained below in an exemplary manner with reference to the accompanying drawings, wherein
a shows an example short-term spectrum of an audio signal comprising an excerpt of music;
b shows a block diagram of an example encoder and decoder using linear prediction;
a illustrates example spectra of an audio signal and of prediction error signals determined using FIR prediction and IIR prediction, respectively;
b and 2c show block diagrams of example encoders and decoders using linear prediction;
d and 2e show block diagrams of an example encoder and decoder using IIR based linear prediction, respectively;
a illustrates the concept of frequency warping;
b illustrates block diagrams of an example encoder and decoder using warped linear prediction (WLP);
c shows example prediction results obtained using linear prediction and warped linear prediction;
a illustrates an experimental relationship between example adjustable pole parameters and signal frequency such that entropy of the signal is minimized;
b and 5c illustrate example entropy reductions which are achievable when using IIR based linear prediction; and
The following aspects are described in the context of an audio signal. It should be noted that the aspects described in the present document are also applicable to prediction-based encoding of other types of signals, e.g. of image signals such as lines or columns of an image frame. In particular, the aspects described in the present document are applicable to lossless audio coding, as well as to lossless image coding.
As outlined in the background section, linear prediction is frequently used to reduce the entropy of an input audio signal, thereby yielding a prediction error signal having reduced entropy. In other words, linear prediction is directed at removing redundancies from the input audio signal, thereby yielding a decorrelated prediction error signal. If the values of future audio samples of the input audio signal can be estimated, then only the rules of prediction need to be transmitted along with the difference between the estimated signal and the actual signal, i.e. along with the prediction error signal. The prediction is typically performed by a so called decorrelator (so called because when optimally adapted there is no correlation between the currently transmitted sample of the prediction error signal and its previous samples).
a shows the short-term spectrum 100 of an example input audio signal (e.g. an excerpt of a music track). It can be seen that the spectrum 100 is not flat and it is an objective of the decorrelator to flatten the spectrum 100 using prediction techniques, thereby yielding coding gains. Ideally the decorrelator yields a prediction error signal having a flat spectrum 101, i.e. a prediction error signal which essentially corresponds to white noise. The Gerzon-Craven theorems show that the level of the optimally decorrelated prediction error signal is given by the average of the original signal spectrum when plotted as decibels versus linear frequency. As illustrated in
b illustrates the block diagram of an example FIR based decorrelator 110 (or encoder) and a corresponding example FIR based re-correlator 120 (or decoder). The decorrelator 110 makes use of an FIR prediction filter comprising a plurality of delay units z−1 115 and a plurality of filter coefficients ak 112, with k=1, . . . , K, typically K>1. A sample of the input audio signal x 111 is predicted based on a plurality of previous samples of the input audio signal x 111 using the plurality of filter coefficients ak 112, thereby yielding a sample of the predicted or estimated audio signal {circumflex over (x)} 113. The difference between the sample of the input audio signal 111 and the estimated audio signal 113 yields a corresponding sample of the prediction error signal r 114 (also referred to as the residual signal). The residual signal 114 typically exhibits reduced entropy compared to the input audio signal 111. The residual signal 114 may be encoded using an appropriate entropy-coding scheme (e.g. using a Rice code, or Huffman coding, or Arithmetic coding), thereby providing a lossless audio coding scheme.
The plurality of filter coefficients ak 112 may be determined by the decorrelator 110 on a frame-by-frame basis using the samples of a frame of the input audio signal 111. In particular, the plurality of filter coefficients ak 112 may be determined such that the mean squared energy of the prediction error signal 114 is reduced (minimized). This may be achieved in an efficient manner using the Levinson-Durbin algorithm.
As such, a lossless audio coder may be provided by first removing the redundancy from the input audio signal 111 (e.g. using linear prediction techniques) and by then coding the resulting prediction error signal 114 with an efficient entropy-coding scheme. The encoded signal comprises for each frame of the input audio signal 111 a representation of the plurality of filter coefficients ak 112 and the entropy-encoded samples of the frame of the prediction error signal 114.
The re-correlator 120 (also referred to as the decoder) performs corresponding steps to the decorrelator 110. In particular, the re-correlator 120 uses the same FIR filter comprising the same plurality of filter coefficients ak 112 to reconstruct the input audio signal 111 from the residual audio signal r 114.
The degree to which an input audio signal can be “whitened” depends on the content of the input audio signal 111 and on the complexity (e.g. the number K of coefficients and/or the structure) of the prediction filter. Infinite complexity (e.g. an infinite number K of filter coefficients) could theoretically achieve a prediction at the entropy level 101 shown in
Typically, lossless audio coders (including the MPEG-4 ALS, Audio Lossless Coding, coder) make use of an FIR-based predictor or decorrelator 110. IIR-based predictors or decorrelators 110 may be beneficial, in situations where the control of peak data rates is important. A further situation where IIR-based decorrelators 110 may be beneficial is where the spectrum 100 of the input audio signal 111 exhibits a relatively wide dynamic range. In such a situation, compression gains may be expected, in particular for relatively high sampling rates. By way of example, IIR-based predictors show an improvement over FIR-based predictors of approx. 0.2 bits/sample (for audio signals at a 44.1 kHz sampling rate) and an improvement of more than 1 bit/sample (for audio signals at a 96 kHz sampling rate, which are band-limited to 32 kHz). As such, it can be seen that IIR-based predictors are increasingly beneficial for encoding input audio signals 111 having an increasingly high ratio of sampling rate over signal bandwidth.
a illustrates the spectral level 201 of an example input audio signal 111, the spectral level 203 of an example prediction error signal 114 obtained using an FIR decorrelator comprising K=8 coefficients (FIR8) and the spectral level 202 of an example prediction error signal 114 obtained using an IIR decorrelator comprising a length of four (IIR4). From
b shows an example block diagram of a conventional prediction architecture, where in an encoder 210 a prediction filter is used to determine an estimated signal which is subtracted from the input signal, thereby yielding the prediction error signal. At the decoder 220, the same prediction filter may be used to reconstruct the input signal. The prediction architecture of
This problem may be overcome by quantizing the output of the prediction filter at the encoder 210, i.e. by quantizing the estimated signal using a quanitzer 216. This is illustrated in
A possible architecture for overcoming this technical problem is illustrated in
The encoder 210 of
For FIR-based predictors, optimal prediction coefficients can be obtained using the Levinson-Durbin algorithm. For IIR-based predictors, there is no such efficient algorithm for obtaining the optimal IIR prediction coefficients. The present document addresses the technical problem of determining the coefficients of an IIR-based decorrelator in an efficient manner such that the entropy of the prediction error signal is reduced (e.g. minimized).
It is proposed in the present document to make use of so called Warped Linear Prediction (WLP) and/or Laguerre Linear Prediction (LLP) as a preprocessor to determine the coefficients of IIR-based decorrelators. It is shown that prediction filters which have been determined using a WLP and/or LLP scheme can be transformed into filters A 212 and B 213 of an IIR-based decorrelator (as shown in
Frequency warped processing may be used to process audio signals according to the frequency resolution of the human auditory system. For this purpose, the frequency range of an input signal may be mapped to a warped frequency range, thereby modeling the frequency resolution of the human auditory system. This is illustrated in
wherein the parameter λ defines the pole of the allpass filter. In case of a pole parameter λ=0 conventional FIR-based linear prediction is implemented. For an input signal at a sampling rate of 44.1 hHz, a Bark scale mapping is obtained with a pole parameter λ=0.756.
b illustrates a modified encoder 310 and a modified decoder 320, where the delay units 115 have been replaced by allpass filters A(z) 315. The optimal coefficients of the allpass filters A(z) 315 for a fixed pole parameter λ may be determined using the Levinson-Durbin algorithm.
A problem of WLP is that WLP provides prediction error signals which are not whitened in the original frequency domain. This problem may be overcome by whitening the prediction error signal using a residual post-filter
or alternatively, optional WLP coefficients can be obtained using a pre-filter
wherein the pre-filter is typically not applied in the prediction filtering operation. This means that the pre-filter W(z) may be used when determining the optimal prediction coefficients ak and the pole parameter λ. However, when performing linear prediction filtering as shown in
While the use of a post-filter or a pre-filter whitens the prediction error signal, it is typically not possible to implement a synthesis filter at the decoder 320 because of delay-free loops. This technical problem may be solved by adding an explicit delay unit 115 to the encoder and the decoder, thereby yielding a so called Laguerre Linear Prediction (LLP) scheme which is illustrated in
with k=1, 2, . . . , K, wherein for a pole parameter λ=0, the encoder and decoder structure of
The encoder 410 receives an input signal 111 and determines an estimated signal 413 using the decorrelator comprising the delay unit 115, the Laguerre filters 411 and respective filter coefficients 412 (referred to as LLP coefficients). The estimated signal 413 is subtracted from the input signal 111, thereby yielding the prediction error signal 414. The corresponding decoder 420 performs the corresponding operations to reconstruct the input signal 111. In particular, the decoder 420 receives the LLP coefficients 412 and uses a delay unit 115, the Laguerre filters 411 and the received LLP coefficients 412 to reconstruct the input audio signal 111 from the prediction error signal 414.
One method for determining optimal LLP coefficients βk; with k=1, 2, . . . , K is as follows:
where βk are the LLP coefficients 412.
Hence, the predictor coefficients βk 412 may be determined in an efficient manner under the assumption of a fixed pole parameter λ using e.g. a Levinson-Durbin algorithm. This is particularly true for a pole parameter λ=0, for which the Laguerre filters 411 become delays, i.e. Hk(z)=z−k, and for which the optimal LLP coefficients βk; with k=1, 2, . . . , K correspond to the coefficients of an FIR prediction filter.
As will be shown below, the encoder 410 and decoder 420 may be transformed in accordance to the encoder 210, 220 of
The use of Laguerre filters 411 for implementing a decorrelator has several advantages. The encoder/decoder of
Furthermore, the prediction error signal 414 exhibits spectral flatness on the original frequency scale 301. In this context, the pole parameter λ (which defines the pole of the allpass filter) provides an extra degree of freedom. It is proposed in the present document to use this extra degree of freedom to provide for an additional reduction (e.g. a minimization) of the entropy of the prediction error signal 414. By doing this, an optimal combination of FIR/IIR filters may be determined for each block or frame of the input audio signal 111.
As a further advantage it should be noted that the encoder 410 of
When using a pole parameter λ=0, the methods described in the present document provide an FIR prediction filter. As the pole parameter provides a further degree of freedom, it can be stipulated that, for an equal number of prediction coefficients, the IIR predictors which are determined using the methods described in the present document should provide an entropy reduction which is at least as good as the corresponding FIR predictor (with a pole parameter λ=0).
As indicated above, the pole parameter λ may be used to reduce the entropy of the prediction error signal 414. This may be achieved e.g. by using a brute force approach. By way of example, the pole parameter λ (and the corresponding pole of the allpass filter A(z)) may be varied from −0.9 to +0.9 and the pole parameter λ may be selected, which produces a prediction error signal 414 with the least entropy. In an embodiment, for every analysis frame of the input audio signal 111, the pole parameter λ may be varied from −0.9 to 0.9 in steps of 0.1. For each pole parameter λ, the optimal LLP coefficients 412 are determined and the residual signal 414 and its entropy are determined. Then, the pole parameter λ for which the entropy of the residual signal 414 is reduced (e.g. is minimal) may be selected, and the (entropy encoded) residual signal 414 and the LLP coefficients 412 for the selected pole parameter λ may be transmitted to the decoder 420.
It should be noted that more efficient schemes than the above mentioned brute force approach for selecting a pole parameter λ which reduces (e.g. minimizes) the entropy of the prediction error signal 414 may be provided and are discussed below.
The determined LLP coefficients βk 412 may be transformed into filter coefficients for the filters A 212 and B 213 which are used by the encoder 210 and decoder 220 of
It should be noted that in case of a pole parameter λ=0, only the FIR filter A 212 is active. The transformation formulas for other values of K may be determined in an analogous manner.
The benefits of using an IIR-based decorrelator have been tested using a sine sweep ranging from 0 to 24 kHz, sampled with 16 bits/sample and with a sampling rate of 48 kHz. The performance of FIR-based decorrelators using an FIR predictor of order 4 (FIR4) and an FIR predictor of order 8 (FIR8) were compared to the performance of an IIR-based decorrelator using an IIR predictor of order 4 (IIR4). The tests were performed for different frame sizes of the input audio signal 111, i.e. for different predictor analysis frame sizes. The example results are shown in Table 1.
It can be seen that in most of the cases, a reduction of the entropy of the prediction error signal can be achieved when using an IIR predictor.
Furthermore, it has been observed using a sine sweep test that the optimal pole parameter λ has an almost linear relationship to the frequency of the input audio signal 111. This is illustrated in
b illustrates the entropy reduction (measured in bits/sample) which is possible when using an IIR4 predictor compared to the situation when using a FIR4 predictor. The input audio signal 111 comprises a sine sweep such that the x-axis 502 may be viewed as the frequency of the input audio signal 111. It can be seen that the entropy reduction 503 which may be achieved when using an IIR predictor varies with the frequency of the input signal. A similar observation can be made in
As indicated above, the observation of
The encoder 410 may be configured to use the pre-determined look-up table to determine the pole parameter λ which is to be used to calculate the LLP coefficients 412 for a particular frame of an input audio signal 111. The encoder 410 may employ a frequency estimation method, and estimate the (dominant) frequency content of the particular frame of the input signal 111. By way of example, the encoder may employ a low-order linear predictor and estimate the spectral envelope of the particular frame of the input audio signal 111. The estimated (dominant) frequency may correspond to the peak of the spectral envelope. Once the dominant frequency is estimated, the encoder 410 may look-up the corresponding optimal entropy minimizing pole parameter λ from the look-up table. This entropy minimizing pole parameter λ may be used to determine optimal LLP coefficients 412 which minimize the power of the corresponding frame of the prediction error signal 414 (using a Levinson-Durbin type algorithm). The determined LLP coefficients 412 may optionally be mapped to the prediction structure of
It should be noted that various other methods may be used to determine the pole parameter λ. In particular, a hybrid method for determining the optimal entropy minimizing pole parameter λ may make use of a combination of a look-up table and a brute force search. For instance, a look-up table may be used to determine a first estimate of the optimal pole parameter λ. Furthermore, the looked-up value of λ may be refined by evaluating additional surrounding values of the looked-up value of λ (and possibly λ=0). Finally, the value for λ may be chosen which minimizes entropy. For example, if the looked-up value of λ is 0.7, one could evaluate other value of λ in the range of 0.6 and 0.8 in addition to 0.7 (and possibly the value 0, in order to verify whether the FIR predictor provides a better solution than the IIR predictor).
In the present document, a method for determining an IIR-based decorrelator has been described. The method may be implemented in an efficient manner and allows for the determination of IIR filter prediction filter coefficients which minimize the entropy of the prediction error signal. As such, the method enables the implementation of audio coding schemes having increased coding gains. The IIR-based decorrelator may be used in conjunction with an entropy encoder of the prediction error signal to provide a lossless audio coder. Furthermore, the method may be used to adaptively switch between FIR and IIR based linear prediction on a frame-by-frame basis, in order to minimize the entropy of the prediction error signal. In addition, the IIR-based decorrelator is compliant with existing Dolby True HD coders, thereby enabling the reuse of already deployed Dolby True HD decoders.
The methods and systems described in the present document may be implemented as software, firmware and/or hardware. Certain components may e.g. be implemented as software running on a digital signal processor or microprocessor. Other components may e.g. be implemented as hardware and or as application specific integrated circuits. The signals encountered in the described methods and systems may be stored on media such as random access memory or optical storage media. They may be transferred via networks, such as radio networks, satellite networks, wireless networks or wireline networks, e.g. the Internet. Typical devices making use of the methods and systems described in the present document are portable electronic devices or other consumer equipment which are used to store and/or render audio signals.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2013/077461 | 12/19/2013 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
61739379 | Dec 2012 | US |