The invention relates to the field of coding/decoding of digital audio signals, more specifically to the so-called field of “transform audio coding/decoding with overlap”.
“Transform coding” consists in coding time-domain signals in the transform (frequency) domain. This transform notably makes it possible to use the frequency characteristics of the audio signals (music, speech, other) in order to optimize and enhance the coding efficiency. Use is, for example, made of the fact that a harmonic sound is represented in the frequency domain by a finite and reduced number of spectral rays which can thus be coded concisely. Use is also, for example, made advantageously of the frequency masking effects to format the coding noise in such a way that it is as inaudible as possible.
A standard transform coding technique is summarized as follows.
The digital audio stream (at a given sampling frequency Fs), to be coded, is cut up into frames (or, more generally “blocks”) of finite numbers of samples 2M. Each frame conventionally overlaps the preceding frame to 50%. A weighting window ha (called “analysis window”) is applied to each frame.
A transform is then applied to the signal. In the case of a transform called “MDCT” (“Modified Discrete Cosine Transform”), and in a particular embodiment, the weighted frame is “folded” according to a 2M samples to M samples transform. A DCT transform of IV type is then applied to the folded frame in order to obtain a frame of size M in the transformed domain.
The frame in the transformed domain is then quantized using a suitable quantizer. The quantization makes it possible to reduce the size of the data, but introduces a noise (audible or not) into the original frame. The higher the bit rate of the coder, the more this noise is reduced and the closer the quantized frame comes to the original frame.
Upon decoding, an inverse MDCT transform is then applied to the quantized frame. The quantized frame of size M is converted into a frame of size M in the time domain by using a DCT of inverse IV type. A second, M to 2M “unfolding” transform is then applied to the temporal frame of size M.
So-called “synthesis” weighting windows hs are then applied to the frames of sizes 2M.
The decoded audio stream is then synthesized by aggregating the overlapping parts.
For a synthesis window and a given overlap, an analysis window is determined which makes it possible to obtain a perfect reconstruction of the signal to be coded (in the absence of quantization).
A window conventionally used in transform coding is a window of sinusoidal type that is identical both in analysis and in synthesis. In this configuration, the minimum algorithmic delay introduced by the coding system is 2M/Fs seconds.
To reduce this delay, it is possible to impose zeros at the start of the synthesis window and at the end of the analysis window. Since the result of a multiplication of the signal by “0” is known in advance, it is possible to offset the frame rate relative to the position of the windows. These symmetrical windows, for example consist of:
These windows have an algorithmic delay of (2M−2Mz)/Fs seconds and thus make it possible to reduce the delay by 2Mz/Fs seconds.
However, such a technique, while it makes it possible to reduce the delay, does tend, when the reduction of the delay increases to resemble a rectangular window. Such a window form is not very frequency selective and ultimately drastically lowers the audio quality of the encoded signal. In addition, it greatly constrains the window because 4Mz samples are imposed in its construction. Not many degrees of freedom are available for proposing effective windows for the coding, notably to offer a significant frequency selectivity.
The document WO-2009/081003 has proposed using asymmetrical windows to mitigate this problem. These windows, from analysis, are made up of 0s only over the end of the analysis window. In order to limit the required storage space, the synthesis window is chosen to be the temporal reversal of the analysis window. This technique notably makes it possible to reduce the encoding delay, as well as the decoding delay. For a total number of zeros Mz two times lower than that of the symmetrical windows previously described, the delay gain is the same. Given the reduced number of zeros, the frequency selectivity of such asymmetrical windows is greater than that of the symmetrical windows. The audio quality of the decoded signal is thereby enhanced.
More particularly, document WO-2009/081003 presents an analysis window ha(n) made up of two parts ha1 and ha2 from an initial window h(n) given by:
and h(n)=0 otherwise (that is to say, for 2M−Mz≦n<2M)
and a correction factor Δ(n) making it possible to have the perfect reconstruction condition, given by:
Δ(n)=√{square root over (h(n)h(2M−1−n)+h(n+M)h(M−1−n))}{square root over (h(n)h(2M−1−n)+h(n+M)h(M−1−n))}{square root over (h(n)h(2M−1−n)+h(n+M)h(M−1−n))}{square root over (h(n)h(2M−1−n)+h(n+M)h(M−1−n))}
The analysis window ha is given by:
h
a1(n+M)=h(n+M)/Δ(n) and ha2(n)=h(n)/Δ(n)
for 0≦n<M
The synthesis window hs(n) is the temporal reversal of the analysis window:
h
s(2M−1−n)=ha(n), for 0≦n<2M
Such windows are, for one and the same delay gain, of better quality than symmetrical windows because of their better frequency selectivity.
However, even if the prior art is advantageous and proposes an enhancement of the quality compared to the preceding techniques, when a solution is sought with a more significant delay gain, with, for example, a number of zeros Mz greater than M/4 (where M is a frame duration), an audible degradation is observed, by applying such windows, which can notably be explained by the fact that a portion of the window takes high values, much greater than 1, as illustrated in
The present invention improves the situation.
To this end, it proposes a method for coding a digital signal made up of successive blocks of samples, the coding being of the transform with overlap type and comprising, upon analysis, the application of a weighting window over two successive blocks of M samples. In particular, the abovementioned weighting window is asymmetrical and comprises four distinct portions extending in succession over the two blocks, with:
As will be seen later, according to one of the advantages obtained through the invention, the constancy of the window at 1 during the second interval makes it possible to reduce the complexity of the use of the windows of the prior art as described in document WO-2009/081003, while retaining its low delay advantages and also enhancing the quality of the audio rendition, as will be seen later with reference to
Moreover, it is advantageous for the first, second and third intervals to be calculated at least as a function of the duration of the fourth interval (number of 0s at the end of the window), which sets the abovementioned delay, which can advantageously be rounded to an algorithmic delay as will be seen in the exemplary embodiments hereinbelow. Similarly, the rising and falling edges of the respectively increasing and decreasing portions can be optimized as a function notably of the duration of the fourth interval. The fourth interval (hereinafter denoted Mz) is self-expressed as a function of the number of samples M per block, and, of course, as a function of the desired maximum delay.
The succession of the analysis windows exhibits characteristics similar to that described in the abovementioned document WO-2009/081003. In particular, two blocks of samples of the same size 2M, being weighted respectively by a first and a second analysis window, the rising edge of the second window can be different from the falling edge of the temporally reversed first window. These edges are not therefore a priori symmetrical.
Moreover, in the implementation of the invention, upon coding, a number of identical analysis windows having the abovementioned characteristics (rise, constancy at 1, descent and constancy at 0) can be applied successively to a plurality of successive blocks of 2M samples, overlapping by M samples, as illustrated in
In a particular embodiment, the window varies over the first interval, denoted R1, as a function w1 of type:
and:
Δn(n)=√{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}, nε[0; M−1] with C1 and R1, constants greater than 0.
By optimization for example, it is found that the term C1 can be between 3 and 5, for a range of delays of the order of 15 to 30 ms. In a particular exemplary embodiment, C1=4.8425.
The first interval, denoted R1, is, in this exemplary embodiment, of a duration given by:
in which M corresponds to the duration of a block,
the notation └x┘ designating the integer less than or equal to x and closest to x.
With respect to the second portion of the window, the latter can vary, in an exemplary embodiment, over the third interval, denoted R2, as a function w3 of type:
and:
Δn(n)=√{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}, nε[0; M−1] with C2 and R2, constants greater than 0.
According to optimization tests carried out, the term C2 is preferentially between 0.85 and 1.05 and in the particular exemplary embodiment, C2=0.9659.
The third interval, denoted R2, is, in this exemplary embodiment, of a preferential duration given by:
in which M corresponds to the duration of a block,
the notation └x┘ designating the integer less than or equal to x and closest to x.
In this exemplary embodiment, the fourth interval, denoted Mz, is chosen initially such that it is of a duration given by
in which the notation └x┘ designates the integer greater than or equal to x and closest to x, M corresponding to the duration of a block.
Of course, other delays can be implemented and thus other durations of the fourth interval Mz can be provided. Table 1 given in the exemplary embodiments detailed hereinbelow indicates values of the parameters C1, C2, and of the intervals R1, R2, for different delay values and therefore for different fourth interval durations Mz.
Thus, the method can advantageously include a preliminary step of optimization of the form of the window, this optimization being based on at least one cost function estimation, to arrive at the optimum parameters C1, C2, and/or even R1, R2 described above.
Overall, it is advantageous for the total number of “1” in the window to be approximately two times greater than the number of 0, according to the optimizations made, notably for a good quality audio rendition.
Thus, in another particular exemplary embodiment, the first interval, denoted R1, is, for example, of a duration given by:
R1=└M−Mz+1+0.5┘, in which M corresponds to the duration of a block, and Mz corresponds to the duration of the fourth interval.
In this example, the third interval R2 can be of a duration given by:
R2=└M−2Mz+1+0.5┘, in which M corresponds to the duration of a block, and Mz corresponds to the duration of the fourth interval.
Table 2 given in the exemplary embodiments detailed hereinbelow indicates values of the parameters C1 and C2, when the intervals R1 and R2 have been thus set, for different delay values and therefore for different fourth interval durations Mz.
Thus, the invention proposes, on a principle of asymmetrical window with perfect reconstruction with a chosen number of zeros of the type presented in the document WO-2009/081003, the use of optimized analysis and synthesis windows, which make it possible to have good sound rendition, while ensuring an effective implementation.
The present invention targets a method for decoding a digital signal, coded by the implementation of the above method, the decoding being of the transform with overlap type and comprising, upon synthesis, the application of a weighting window over two successive blocks of coded samples. In particular, the weighting window, upon synthesis, is identical to the analysis window used in the coding, temporally reversed, for example to ensure a perfect reconstruction property, as will be seen later.
The present invention also targets a computer program intended to be stored in memory of a coding or decoding device and comprising in particular instructions for the implementation of the above coding method or of the abovementioned decoding method, when the instructions are executed by a processor of the device. In particular, it can be a computer program, comprising a first part specific to the coding and a second part specific to the decoding.
As represented schematically in
Other advantages and features of the invention will become apparent on reading the detailed description, given below by way of examples of nonlimiting embodiments, and the appended drawings in which:
Reference is first made to
The next step 73 consists in applying a transform, for example of MDCT type, to the block of two frames thus weighted by the window ha, then in quantizing (step 74) the values in the transform domain.
Upon decoding, an inverse transform makes it possible, in the step 75, to reconvert the values into the time domain. If the transform upon coding is, for example, of MDCT type, an inverse transform iMDCT can be applied upon decoding.
In the step 76, to ensure a condition of perfect reconstruction, a synthesis window hs is applied to the two decoded frames. As described in document WO-2009/081003, this condition imposes a correction factor 1/Δn (described in detail hereinbelow) applied to an initialization window hi to obtain the analysis window ha. The synthesis window hs appears as the temporal reversal of the analysis window ha, with:
h
s(n)=ha(2M−n−1)
In the step 77, the blocks which overlap are aggregated, to finally deliver the decoded signal, assuring a perfect reconstruction thereof.
Reference is now made again to
Over a first interval hereinbelow denoted R1, the analysis window varies as a function w1 of type:
and:
Δn(n)=√{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))},nε[0;M−1]
Then, the analysis window is constant and has the value w2=1 over a second interval.
Over a third interval hereinbelow denoted R2, the window varies as a function w3 of type:
and:
Δn(n)=√{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}, with:
nε[0;M−1]
Finally, over a fourth interval Mz, the analysis window is constant and has the value w4=0.
It is shown hereinbelow that, compared to the prior art WO-2009/081003, the form of such windows makes it possible to ensure an optimum audio quality for a significant delay gain (possibly ranging for example up to 40%). The use of such windows (of general variations: increasing, constant at 1, decreasing and constant at 0) is not limited to one type of transform MDCT. They can also be used for example in the case where the coding only relates solely to only a part of the signal to be coded (for example a part of the audio band only, for example to process a coding error compared to another coding technique, or other).
There now follows a description with reference to
Following an initialization step 80, initialization parameters R1, R2, C1 and C2 are defined in step 81. In the next step 82, an initialization window hi is calculated from these initialization parameters. As illustrated in
The first segment W1 of length R1 is defined by the equation:
The second segment W2 of length L=2M−R1−R2−Mz is made up of values at 1.
The third segment W3 of length R2 is defined by the equation:
The fourth segment W4 of length Mz is made up of values all at 0.
The initialization window hi(n) is therefore given by:
In the step 83, a factor 1/Δn is applied to the initialization window hi, which makes it possible to ensure a condition of perfect reconstruction, and do so on the assumption that the synthesis window is the temporal reversal of the analysis window and that the transform upon decoding will be dual (for example an iMDCT transform, if an MDCT transform was applied on coding).
The term Δn is given by:
Δn(n)=Δn(n+M)=√{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}{square root over (hi(n)·hi(2M−n−1)+hi(n+M)·hi(M−n−1))}
nε[0;M−1]
The analysis window ha with perfect reconstruction is then given by
It will be noted that the values strictly at “1” do not require any weighting multiplication. Thus, the expected gain in complexity is significant compared to the prior art, as the table below shows, according to another advantage that is obtained through the invention.
Thus, for a given delay gain (a given number Mz of zeros), there is an optimum combination of the four parameters R1, R2, C1, C2 defining the precise form of the analysis and synthesis windows that makes it possible to have the best possible audio quality. These parameters can be obtained by optimization with successive iterations, as described later with reference once again to
For example, a delay gain of 35% (corresponding to 14 ms for 40 ms frames in the example described here), corresponds simply to an algorithmic delay of the coder. This delay, of 26 ms in the example described, imposes a number of zeros Mz given by:
in which ┌x┐ denotes the integer greater than or equal to x that is closest to x. It is then found that Mz=14 ms, for M=40 ms.
With this choice, the values of the parameters of the analysis and synthesis windows can, for example, be given by:
in which └x┐ denotes the integer less than or equal to x that is closest to x.
Such an embodiment corresponds to the initialization window represented in
Another exemplary approach makes it possible to reduce the number of parameters of the initialization window to be sought. This approach consists in considering that the number of “1” in the window hi should be twice the number of “0” and that the axis of symmetry of the window hi corresponds to the middle of the segment W2, as illustrated in
In these conditions:
in which Gdelay is the desired gain on the delay, in ms, FL is the length of the frame 2M in ms (the sampling frequency being given by Fs=2M/FL×1000, if counting in milliseconds or “ms”).
Then, in the step 84 of
Starting, for example, at the step 81 with a choice of initial parameters for the values of R1; R2; C1 and C2, respectively of 2Mz; Mz; 1 and 1, a cost function is calculated in step 84 that is applied to:
The cost function can be made up of a set of criteria to be verified in the test 85. Examples that can be cited in a nonlimiting manner include:
the maximization of the signal-to-noise ratio “SNR”, expressed as a logarithm between a non-coded signal and the error introduced by the coding, for a given audio sample by applying both the analysis window and the synthesis window according to the invention.
In the test 85, it is possible to check whether the end of optimization criteria are reached (cost function value, variation of the value of the parameters, or other). If appropriate (OK arrow), the optimized parameter values are found in the end step 87. Otherwise, in the contrary case (KO arrow), the values of R1, R2, C1 and C2 are modified in such a way as to reduce the cost function.
Thus, by starting from a choice of initial parameters R1; R2; C1 and C2 respectively at 2Mz; Mz; 1 and 1, it is found that, after optimization:
if the option is taken to optimize all these four parameters,
or, alternatively:
It is therefore possible, in this second option, to limit the search for optimum values to C1 and C2 in the case where it is assumed that the number of 1 is twice the number of 0 and that the axis of symmetry of the window corresponds to the middle of the segment W2 as illustrated in
It should be noted that, with the abovementioned first option (optimizing all four parameters), for a delay of 28 ms (instead of 26 ms as previously), it is found that C1=4.1582 and C2=0.9181 with this optimization technique.
More generally, table 1 below presents a set of optimized parameters R1, R2, C1 and C2, according to different delay options and therefore number of “0” samples (Mz). The number of samples per frame M is given for a 48 000 Hz sampling frequency and 20 ms frames:
The data of this table are expressed in particular as a function of the number of “0” samples in the fourth interval Mz, as follows:
Table 2 below presents a set of parameters C1 and C2 optimized, according to the abovementioned second option, by setting the intervals R1 and R2 as a function of the number of zeros Mz. The number of samples per frame M is given for a 48 000 Hz sampling frequency and 20 ms frames:
Of course, the present invention is not limited to the embodiment described above as an example; it extends to other variants.
For example, the method of optimization by iteration can, as described above, be a method of the so-called “gradients” type but other variants are, of course, possible. It is also possible, for example, within the optimization process, to set the maximum of the window ha to 1, so as to process the sound samples with a relatively constant weight.
More generally, the values of the analysis and synthesis windows can be determined beforehand (by optimization as described above), then hard-stored in a memory of a coding or decoding device, to be used in a coding or decoding method. In a variant, it is possible to define initialization windows, store them in memory of the abovementioned devices and then optimize them, for example, according to the communication conditions.
Number | Date | Country | Kind |
---|---|---|---|
1155769 | Jun 2011 | FR | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/FR2012/051463 | 6/26/2012 | WO | 00 | 12/23/2013 |