An audio encoder device includes an audio encoder configured for producing an encoded audio bitstream from an audio signal having consecutive audio frames; a dynamic range control encoder configured for producing an encoded dynamic range control bitstream from an a dynamic range control sequence corresponding to the audio signal and having consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames has one or more nodes, wherein each node of the one or more nodes has gain information for the audio signal and time information indicating to which point in time the gain information corresponds.

Patent
   RE49107
Priority
Mar 25 2014
Filed
May 06 2019
Issued
Jun 14 2022
Expiry
Mar 20 2035
Assg.orig
Entity
Large
0
28
currently ok
0. 51. A method for operating an audio encoder, the method comprising:
producing an encoded audio bitstream from an audio signal comprising consecutive audio frames;
producing an encoded dynamic range control bitstream from a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames comprises one or more nodes, wherein each node of the one or more nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
executing a shift procedure, wherein one or more nodes of the nodes of one reference dynamic range control frame of the dynamic range control frames are selected as shifted nodes, wherein a bit representation of each of the one or more shifted nodes of the one reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame.
0. 53. A non-transitory digital storage medium having a computer program stored thereon to perform the method for operating an audio encoder, the method comprising:
producing an encoded audio bitstream from an audio signal comprising consecutive audio frames;
producing an encoded dynamic range control bitstream from a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames comprises one or more nodes, wherein each node of the one or more nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
executing a shift procedure, wherein one or more nodes of the nodes of one reference dynamic range control frame of the dynamic range control frames are selected as shifted nodes, wherein a bit representation of each of the one or more shifted nodes of the one reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame,
when said computer program is run by a computer.
0. 27. An audio encoder device comprising:
an audio encoder configured for producing an encoded audio bitstream from an audio signal comprising consecutive audio frames;
a dynamic range control encoder configured for producing an encoded dynamic range control bitstream from a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames comprises one or more nodes, wherein each node of the one or more nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the dynamic range control encoder is configured in such way that the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the dynamic range control encoder is configured for executing a shift procedure, wherein one or more nodes of the nodes of one reference dynamic range control frame of the dynamic range control frames are selected as shifted nodes, wherein a bit representation of each of the one or more shifted nodes of the one reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame.
0. 50. A system comprising an audio encoder device comprising:
an audio encoder configured for producing an encoded audio bitstream from an audio signal comprising consecutive audio frames;
a dynamic range control encoder configured for producing an encoded dynamic range control bitstream from a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames comprises one or more nodes, wherein each node of the one or more nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the dynamic range control encoder is configured in such way that the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the dynamic range control encoder is configured for executing a shift procedure, wherein one or more nodes of the nodes of one reference dynamic range control frame of the dynamic range control frames are selected as shifted nodes, wherein a bit representation of each of the one or more shifted nodes of the one reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame,
and an audio decoder device according to claim 40.
23. A method for operating an audio encoder, the method comprising:
producing an encoded audio bitstream from an audio signal comprising consecutive audio frames;
producing an encoded dynamic range control bitstream from an a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames comprises one or more nodes, wherein each node of the one or more nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
executing a shift procedure, wherein one or more nodes of the nodes of one reference dynamic range control frame of the dynamic range control frames are selected as shifted nodes, wherein a bit representation of each of the one or more shifted nodes of the one reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame, wherein a bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame.
0. 52. A method for operating an audio decoder, the method comprising:
decoding an encoded audio bitstream in order to reproduce an audio signal comprising consecutive audio frames;
decoding an encoded dynamic range control bitstream in order to reproduce a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the encoded dynamic range control bitstream comprises bit representations of nodes, wherein each bit representation of one node of the nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bit stream comprises bit representations of shifted nodes selected from the nodes of one reference dynamic range control frame of the dynamic range control frames, which are embedded in a bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame,
wherein the bit representation of each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames is decoded in order to reproduce each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames.
25. A non-transitory digital storage medium having a computer program stored thereon to perform the method for operating an audio encoder, the method comprising:
producing an encoded audio bitstream from an audio signal comprising consecutive audio frames;
producing an encoded dynamic range control bitstream from an a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames comprises one or more nodes, wherein each node of the one or more nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
executing a shift procedure, wherein one or more nodes of the nodes of one reference dynamic range control frame of the dynamic range control frames are selected as shifted nodes, wherein a bit representation of each of the one or more shifted nodes of the one reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame, wherein a bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame,
when said computer program is run by a computer.
0. 40. An audio decoder device comprising:
an audio decoder configured for decoding an encoded audio bitstream in order to reproduce an audio signal comprising consecutive audio frames;
a dynamic range control decoder configured for decoding an encoded dynamic range control bitstream in order to reproduce a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the encoded dynamic range control bitstream comprises bit representations of nodes, wherein each bit representation of one node of the nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bit stream comprises bit representations of shifted nodes selected from the nodes of one reference dynamic range control frame of the dynamic range control frames, which are embedded in a bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame; and
wherein the dynamic range control decoder is configured for decoding the bit representation of each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames in order to reproduce each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames.
1. An audio encoder device comprising:
an audio encoder configured for producing an encoded audio bitstream from an audio signal comprising consecutive audio frames;
a dynamic range control encoder configured for producing an encoded dynamic range control bitstream from an a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames comprises one or more nodes, wherein each node of the one or more nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the dynamic range control encoder is configured in such way that the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the dynamic range control encoder is configured for executing a shift procedure, wherein one or more nodes of the nodes of one reference dynamic range control frame of the dynamic range control frames are selected as shifted nodes, wherein a bit representation of each of the one or more shifted nodes of the one reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame, wherein a bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame.
0. 54. A non-transitory digital storage medium having a computer program stored thereon to perform the method for operating an audio decoder, the method comprising:
decoding an encoded audio bitstream in order to reproduce an audio signal comprising consecutive audio frames;
decoding an encoded dynamic range control bitstream in order to reproduce a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the encoded dynamic range control bitstream comprises bit representations of nodes, wherein each bit representation of one node of the nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bit stream comprises bit representations of shifted nodes selected from the nodes of one reference dynamic range control frame of the dynamic range control frames, which are embedded in a bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame,
wherein the bit representation of each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames is decoded in order to reproduce each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames;
when said computer program is run by a computer.
24. A method for operating an audio decoder, the method comprising:
decoding an encoded audio bitstream in order to reproduce an audio signal comprising consecutive audio frames;
decoding an encoded dynamic range control bitstream in order to reproduce an a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the encoded dynamic range control bitstream comprises bit representations of nodes, wherein each bit representation of one node of the nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bit stream comprises bit representations of shifted nodes selected from the nodes of one reference dynamic range control frame of the dynamic range control frames, which are embedded in a bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame, wherein the bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame; and
wherein the bit representation of each remaining node of the remaining nodes of the one reference dynamic range control frame of the dynamic range control frames is decoded in order to reproduce each remaining node of the one reference dynamic range control frame of the dynamic range control frames;
wherein the bit representation of each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames is decoded in order to reproduce each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames; and
wherein the reproduced remaining nodes and the reproduced shifted nodes are combined in order to reconstruct the reference dynamic range control frame.
13. An audio decoder device comprising:
an audio decoder configured for decoding an encoded audio bitstream in order to reproduce an audio signal comprising consecutive audio frames;
a dynamic range control decoder configured for decoding an encoded dynamic range control bitstream in order to reproduce an a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the encoded dynamic range control bitstream comprises bit representations of nodes, wherein each bit representation of one node of the nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bit stream comprises bit representations of shifted nodes selected from the nodes of one reference dynamic range control frame of the dynamic range control frames, which are embedded in a bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame, wherein the bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame; and
wherein the dynamic range control decoder is configured for decoding the bit representation of each remaining node of the remaining nodes of the one reference dynamic range control frame of the dynamic range control frames in order to reproduce each remaining node of the one reference dynamic range control frame of the dynamic range control frames, for decoding the bit representation of each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames in order to reproduce each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames and for combining the reproduced remaining nodes and the reproduced shifted nodes in order to reconstruct the reference dynamic range control frame.
26. A non-transitory digital storage medium having a computer program stored thereon to perform the method for operating an audio decoder, the method comprising:
decoding an encoded audio bitstream in order to reproduce an audio signal comprising consecutive audio frames;
decoding an encoded dynamic range control bitstream in order to reproduce an a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames;
wherein the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the encoded dynamic range control bitstream comprises bit representations of nodes, wherein each bit representation of one node of the nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the encoded dynamic range control bit stream comprises bit representations of shifted nodes selected from the nodes of one reference dynamic range control frame of the dynamic range control frames, which are embedded in a bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame, wherein the bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame; and
wherein the bit representation of each remaining node of the remaining nodes of the one reference dynamic range control frame of the dynamic range control frames is decoded in order to reproduce each remaining node of the one reference dynamic range control frame of the dynamic range control frames;
wherein the bit representation of each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames is decoded in order to reproduce each shifted node of the shifted nodes selected from the nodes of the one reference dynamic range control frame of the dynamic range control frames; and
wherein the reproduced remaining nodes and the reproduced shifted nodes are combined in order to reconstruct the reference dynamic range control frame,
when said computer program is run by a computer.
2. The audio encoder device according to claim 1, wherein the shift procedure is initiated in case that a number of the nodes of the reference dynamic range control frame is greater than a predefined threshold value.
3. The audio encoder device according to claim 1, wherein the shift procedure is initiated in case that a sum of a number of the nodes of the reference dynamic range control frame and a number of shifted nodes from the dynamic range control frame preceding the reference dynamic range control frame to be embedded in the bitstream portion corresponding to the reference dynamic range control frame is greater than a predefined threshold value.
4. The audio encoder device according to claim 1, wherein the shift procedure is initiated in case that a sum of a number of the nodes of the reference dynamic range control frame and a number of shifted nodes from the dynamic range control frame preceding the reference dynamic range control frame to be embedded in the bitstream portion corresponding to the reference dynamic range control frame is greater than a number of the nodes of the dynamic range control frame subsequent to the reference dynamic range control frame.
5. The audio encoder device according to claim 1, wherein the time information of the one or more nodes is represented in such way that the one or more shifted nodes may be identified by using the time information.
6. The audio encoder device according to claim 5, wherein the time information of the one or more shifted nodes is represented by a sum of a time difference from a beginning of the dynamic range control frame to which the respective node belongs to the temporal position of the respective node within the dynamic range control frame to which the respective node belongs and an offset value being greater than or equal to a temporal size of the dynamic range control frame subsequent to the respective dynamic range control frame.
7. The audio encoder device according to claim 1, wherein the gain information of the bit representation of the shifted node, which is at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by an absolute gain value and wherein the gain information of each bit representation of the shifted nodes at a position after the bit representation of the node, which is at the first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by a relative gain value which is equal to a difference of a gain value of the bit representation of the respective shifted node and a gain value of the bit representation of the node, which precedes the bit representation of the respective node.
8. The audio encoder device according to claim 1, wherein, in case that the bit representations of one or more shifted nodes of the reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, the gain information of the bit representation of the node of the subsequent dynamic range control frame at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame after the one or more positions of the bit representations of the one or more shifted nodes is represented by a relative gain value which is equal to a difference of a gain value of the bit representation of the respective node and a gain value of the bit representation of the shifted node, which precedes the bit representation of the respective node.
9. The audio encoder device according to claim 1, wherein a temporal size of the audio frames is equal to a temporal size of the dynamic range control frames.
10. The audio encoder device according to claim 1, wherein the one or more nodes of one of the dynamic range control frame are selected from a uniform time grid.
11. The audio encoder device according to claim 1, wherein each node of the one or more nodes comprises slope information.
12. The audio encoder device according to claim 1, wherein the dynamic range control encoder is configured for encoding the nodes using an entropy encoding technique.
14. The audio decoder device according to claim 13, wherein the dynamic range control decoder is configured for identifying the one or more shifted nodes by using the time information.
15. The audio decoder device according to claim 13, wherein the dynamic range control decoder is configured for decoding the time information of the one or more shifted nodes, which is represented by a sum of a time difference from a beginning of the dynamic range control frame to which the respective node belongs to the temporal position of the respective node within the dynamic range control frame to which the respective node belongs and an offset value being greater than or equal to a temporal size of the dynamic range control frame subsequent to the respective dynamic range control frame.
16. The audio decoder device according to claim 13, wherein the dynamic range control decoder is configured for decoding the gain information of the bit representation of the shifted node, which is at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by an absolute gain value and wherein the gain information of each bit representation of the shifted nodes at a position after the bit representation of the node, which is at the first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by a relative gain value which is equal to a difference of a gain value of the bit representation B′2 of the respective shifted node B2 and a gain value of the bit representation of the node, which precedes the bit representation of the respective node.
17. The audio decoder device according to claim 13, wherein the dynamic range control decoder is configured for decoding the gain information of the bit representation of the node of the subsequent dynamic range control frame at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame after the one or more positions of the bit representations of the one or more shifted nodes is represented by a relative gain value which is equal to a difference of a gain value of the bit representation of the respective node and a gain value of the bit representation of the shifted node, which precedes the bit representation of the respective node.
18. The audio decoder device according to claim 13, wherein a temporal size of the audio frames is equal to a temporal size of the dynamic range control frames.
19. The audio decoder device according to claim 13, wherein the one or more nodes of one of the dynamic range control frames are selected from a uniform time grid.
20. The audio decoder device according to claim 13, wherein each node of the one or more nodes comprises slope information.
21. The audio decoder device according to claim 13, wherein the dynamic range control decoder is configured for decoding the bit representations of the nodes using an entropy decoding technique.
22. A system comprising an audio encoder device comprising:
an audio encoder configured for producing an encoded audio bitstream from an audio signal comprising consecutive audio frames;
a dynamic range control encoder configured for producing an encoded dynamic range control bitstream from an a dynamic range control sequence corresponding to the audio signal and comprising consecutive dynamic range control frames, wherein each dynamic range control frame of the dynamic range control frames comprises one or more nodes, wherein each node of the one or more nodes comprises gain information for the audio signal and time information indicating to which point in time the gain information corresponds;
wherein the dynamic range control encoder is configured in such way that the encoded dynamic range control bitstream comprises for each dynamic range control frame of the dynamic range control frames a corresponding bitstream portion;
wherein the dynamic range control encoder is configured for executing a shift procedure, wherein one or more nodes of the nodes of one reference dynamic range control frame of the dynamic range control frames are selected as shifted nodes, wherein a bit representation of each of the one or more shifted nodes of the one reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the one reference dynamic range control frame, wherein a bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame,
and an audio decoder device according to claim 13.
0. 28. The audio encoder device according to claim 27, wherein a bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame.
0. 29. The audio encoder device according to claim 27, wherein the shift procedure is initiated in case that a number of the nodes of the reference dynamic range control frame is greater than a predefined threshold value.
0. 30. The audio encoder device according to claim 27, wherein the shift procedure is initiated in case that a sum of a number of the nodes of the reference dynamic range control frame and a number of shifted nodes from the dynamic range control frame preceding the reference dynamic range control frame to be embedded in the bitstream portion corresponding to the reference dynamic range control frame is greater than a predefined threshold value.
0. 31. The audio encoder device according to claim 27, wherein the shift procedure is initiated in case that a sum of a number of the nodes of the reference dynamic range control frame and a number of shifted nodes from the dynamic range control frame preceding the reference dynamic range control frame to be embedded in the bitstream portion corresponding to the reference dynamic range control frame is greater than a number of the nodes of the dynamic range control frame subsequent to the reference dynamic range control frame.
0. 32. The audio encoder device according to claim 27, wherein the time information of the one or more nodes is represented in such way that the one or more shifted nodes may be identified by using the time information.
0. 33. The audio encoder device according to claim 32, wherein the time information of the one or more shifted nodes is represented by a sum of a time difference from a beginning of the dynamic range control frame to which the respective node belongs to the temporal position of the respective node within the dynamic range control frame to which the respective node belongs and an offset value being greater than or equal to a temporal size of the dynamic range control frame subsequent to the respective dynamic range control frame.
0. 34. The audio encoder device according to claim 27, wherein the gain information of the bit representation of the shifted node, which is at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by an absolute gain value and wherein the gain information of each bit representation of the shifted nodes at a position after the bit representation of the node, which is at the first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by a relative gain value which is equal to a difference of a gain value of the bit representation of the respective shifted node and a gain value of the bit representation of the node, which precedes the bit representation of the respective node.
0. 35. The audio encoder device according to claim 27, wherein, in case that the bit representations of one or more shifted nodes of the reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, the gain information of the bit representation of the node of the subsequent dynamic range control frame at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame after the one or more positions of the bit representations of the one or more shifted nodes is represented by a relative gain value which is equal to a difference of a gain value of the bit representation of the respective node and a gain value of the bit representation of the shifted node, which precedes the bit representation of the respective node.
0. 36. The audio encoder device according to claim 27, wherein a temporal size of the audio frames is equal to a temporal size of the dynamic range control frames.
0. 37. The audio encoder device according to claim 27, wherein the one or more nodes of one of the dynamic range control frame are selected from a uniform time grid.
0. 38. The audio encoder device according to claim 27, wherein each node of the one or more nodes comprises slope information.
0. 39. The audio encoder device according to claim 27, wherein the dynamic range control encoder is configured for encoding the nodes using an entropy encoding technique.
0. 41. The audio decoder device according to claim 40, wherein the bit representation of each remaining node of the nodes of the one reference dynamic range control frame of the dynamic range control frames is embedded into the bitstream portion corresponding to the one reference dynamic range control frame,
wherein the dynamic range control decoder is configured for decoding the bit representation of each remaining node of the remaining nodes of the one reference dynamic range control frame of the dynamic range control frames in order to reproduce each remaining node of the one reference dynamic range control frame of the dynamic range control frames and for combining the reproduced remaining nodes and the reproduced shifted nodes in order to reconstruct the reference dynamic range control frame.
0. 42. The audio decoder device according to claim 40, wherein the dynamic range control decoder is configured for identifying the one or more shifted nodes by using the time information.
0. 43. The audio decoder device according to claim 40, wherein the dynamic range control decoder is configured for decoding the time information of the one or more shifted nodes, which is represented by a sum of a time difference from a beginning of the dynamic range control frame to which the respective node belongs to the temporal position of the respective node within the dynamic range control frame to which the respective node belongs and an offset value being greater than or equal to a temporal size of the dynamic range control frame subsequent to the respective dynamic range control frame.
0. 44. The audio decoder device according to claim 40, wherein the dynamic range control decoder is configured for decoding the gain information of the bit representation of the shifted node, which is at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by an absolute gain value and wherein the gain information of each bit representation of the shifted nodes at a position after the bit representation of the node, which is at the first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by a relative gain value which is equal to a difference of a gain value of the bit representation B′2 of the respective shifted node B2 and a gain value of the bit representation of the node, which precedes the bit representation of the respective node.
0. 45. The audio decoder device according to claim 40, wherein the dynamic range control decoder is configured for decoding the gain information of the bit representation of the node of the subsequent dynamic range control frame at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame after the one or more positions of the bit representations of the one or more shifted nodes is represented by a relative gain value which is equal to a difference of a gain value of the bit representation of the respective node and a gain value of the bit representation of the shifted node, which precedes the bit representation of the respective node.
0. 46. The audio decoder device according to claim 40, wherein a temporal size of the audio frames is equal to a temporal size of the dynamic range control frames.
0. 47. The audio decoder device according to claim 40, wherein the one or more nodes of one of the dynamic range control frames are selected from a uniform time grid.
0. 48. The audio decoder device according to claim 40, wherein each node of the one or more nodes comprises slope information.
0. 49. The audio decoder device according to claim 40, wherein the dynamic range control decoder is configured for decoding the bit representations of the nodes using an entropy decoding technique.

where k denotes a sample time index. The value of the gain g(k) may be computed, e.g. based on a short-term estimate of the root-mean square of the audio signal x(k). More details about strategies to determine suitable gains values are discussed in [1]. In the following we refer to the time-variant gains g(k) as a gain sequence.

In the following, the coding of dynamic range control gain sequences is explained. First, the dynamic range control gain sequence is divided into so-called dynamic range control frames of gain samples, containing a fixed number of gain samples. Usually, a temporal frame size for the dynamic range control frames is chosen to be equal to the temporal size of an audio frame of the corresponding audio encoder. Within each dynamic range control frame, so-called nodes are selected, advantageously on a uniform time grid.

The spacing of this grid defines the highest available time resolution, i.e., the minimum distance in samples between two nodes equals to samples having the highest available time resolution. Each node is represented by the sample position within the dynamic range control frame, the gain information, which may be expressed as a gain value, for that position and optionally information about the slope of the gain values at the node positions. For the following discussion it will be useful to define the maximum number of nodes that can be selected within one frame.

The dynamic range control encoder encodes the gain information from the nodes, e.g., by using quantized differential values of pairs of consecutive gain nodes. At the decoder, the original gain sequence is reconstructed as good as possible by using spline interpolation or linear interpolation based on the transmitted information of the nodes (gain value, sample position within the dynamic range control frame, and slope information if applicable).

An efficient approach for encoding the dynamic range control gain sequence is to use a quantized value of the gain difference (typically in dB) of pairs of consecutive nodes, as well as the time difference of the sample positions of these nodes within the considered dynamic range control frame. The slope information is usually not represented as a difference between two nodes. Since there is no preceding node for the first node within a frame, its gain value is not encoded in a differential way, but the values are encoded explicitly. The time difference of the first node is usually determined as the offset to the beginning of the dynamic range control frame.

The encoder may then assign a fixed code word e.g. of a pre-defined Huffman table (code book) to each of the gain and time differences of pairs of nodes.

At the dynamic range control decoder, the dynamic range control bitstream is decoded and the relevant information (gain value, sample position within the dynamic range control frame, and slope information if applicable) at the positions of the transmitted nodes is reconstructed. The gain values for the remaining gain samples within a frame are obtained by interpolation between pairs of transmitted and decoded nodes. The interpolation can be based on splines if the slope information of the gain nodes has been transmitted or, alternatively, using linear interpolation if only the gain differences between pairs of nodes are available and the slope information is discarded.

In principle, dynamic range control encoder/decoder chains can be operated in two modes. The so-called full-frame mode refers to the case where after decoding of a received dynamic range control bitstream, corresponding to a reference dynamic range control frame, the gains at each sample position of the reference dynamic range control frame can be immediately determined after interpolation based on the decoded nodes. This implies that a node has to be transmitted at each frame border, i.e., at the sample position corresponding to the last sample of the reference dynamic range control frame. If the dynamic range control frame length is N this means the last transmitted node has to be located at the sample position N within the reference dynamic range control frame.

The invention avoids this disadvantage as it is based on the second mode, which is referred to as “delay mode”. In this case, there is no need for transmitting a node for the last sample position within the reference dynamic range control frame. Therefore, the dynamic range control decoder has to wait for decoding the dynamic range control frame subsequent to the reference dynamic range control frame in order to perform the interpolation that may be used of all gain values following the last node within reference dynamic range control frame. This is because the information of the first node of the subsequent dynamic range control frame has to be known to perform the interpolation between the last node of the reference dynamic range control frame and the first node of the subsequent dynamic range control frame in order to determine the gain value in between via interpolation.

In practice the delay caused by using the delay mode for coding of the dynamic range control information is not an issue. This is because audio codecs that commonly accompany the dynamic range control coding scheme also introduce an inherent delay of one audio frame when subsequently applying the encoding and decoding steps. Important examples of such audio codecs are the ISO/IEC 13818-7, Advanced Audio Coding (MPEG-2 AAC), ISO/IEC 14496-3, subpart 4 (MPEG-4 AAC), or ISO/IEC 23003-3, part 3, Unified Speech and Audio Coding (USAC). Such audio coding schemes use the reference audio frame and the audio frame subsequent to the reference audio frame in order to compute (using an overlap-add structure) the correct audio samples corresponding to the reference dynamic range control audio frame.

It is important to note that the number of nodes that may be used for sufficiently approximating the original dynamic range control gain sequence significantly varies from dynamic range control frame to dynamic range control frame. That results from the fact that more nodes may be used for representing highly time-variant gains compared to the case where only slowly changing gain values have to be encoded. This observation implies that the bitrate that may be used to transmit gain sequences can vary significantly from frame to frame. Some frames may involve a large number of nodes being encoded, resulting in high bitrate peaks. This is not desirable, especially, when the audio signal and the dynamic range control gain sequence are transmitted in a joint bitstream having the encoded dynamic range control bitstream and the encoded audio bitstream, which should have almost constant bitrate. Then, a peak in the dynamic range control related bitrate reduces the available bitrate for the audio encoder, which often result in a degradation of the audio quality after decoding. However, with the current state-of-the-art methods for the coding of dynamic range control gain sequences, a reduction of the dynamic range control related bitrate in a certain frame is only achieved by reducing the number of nodes that are selected to represent the gain sequence within that frame. This again may lead to large errors between the original gain sequence and the one that is reconstructed after the dynamic range control decoding process. The invention overcomes these disadvantages by reducing the peak bitrates of encoded dynamic range control bitstream without increasing the error between the original and the reconstructed dynamic range control sequence.

In this section, the coding of dynamic range control gain sequences according to the invention is presented. The invention allows controlling the peak bitrate that may be used for a reference dynamic range control frame without changing the resulting bitstream sequence compared to the case where the proposed method is not used. The proposed approach exploits the inherent delay of one frame introduced by state-of-the-art audio coders to reduce peaks of number of nodes within one frame by distributing the transmission of some of the nodes to the next subsequent dynamic range control frame. The details of the proposed method are presented in the following.

As explained above, when combined with an audio coding scheme that introduces a frame delay relative to the dynamic range control gains, the decoded dynamic range control gains are delayed by one frame before being applied to the audio signal. This means that the nodes of the reference dynamic range control frame are applied to the valid audio decoder output at dynamic range control frame subsequent to the reference dynamic range control frame. This implies that in the default delay mode it is sufficient to transmit the nodes of the reference dynamic range control frame together with the nodes of the dynamic range control frame subsequent to the reference dynamic range control frame and apply the corresponding dynamic range control gains without a delay directly to the corresponding audio output signal at the decoder.

This fact is exploited in the invention in order to reduce the maximum number of nodes transmitted within one dynamic range control frame. According to the invention some of the nodes of the reference dynamic range control frame are shifted to the subsequent dynamic range control frame, which may be done before encoding. As it will be discussed in the following, the shifted nodes may be “preceding” the first node in the subsequent dynamic range control frame only for the encoding of the gain differences and the slope information. For the coding of the time difference information, a different method may be applied.

According to an advantageous embodiment of the invention the shift procedure is initiated in case that a number of the nodes of the reference dynamic range control frame is greater than a predefined threshold value.

According to an advantageous embodiment of the invention the shift procedure is initiated in case that a sum of a number of the nodes of the reference dynamic range control frame and a number of shifted nodes from the dynamic range control frame preceding the reference dynamic range control frame to be embedded in the bitstream portion corresponding to the reference dynamic range control frame is greater than a predefined threshold value.

According to an advantageous embodiment of the invention the shift procedure is initiated in case that a sum of a number of the nodes of the reference dynamic range control frame and a number of shifted nodes from the dynamic range control frame preceding the reference dynamic range control frame to be embedded in the bitstream portion corresponding to the reference dynamic range control frame is greater than a number of the nodes of the dynamic range control frame subsequent to the reference dynamic range control frame.

Independent from the conditions defined under which the shift procedure is initiated, the first node of the reference dynamic range control frame should not be shifted to the subsequent dynamic range control frame as its value is needed for interpolation of the gain control values at the beginning of the reference dynamic range control frame. Furthermore, a node should be shifted only one time in order to avoid a delay when decoding the bitstream.

According to an advantageous embodiment of the invention the time information of the one or more nodes is represented in such way that the one or more shifted nodes may be identified by using the time information.

According to an advantageous embodiment of the invention the time information of the one or more shifted nodes is represented by a sum of a time difference from a beginning of the dynamic range control frame to which the respective node belongs to the temporal position of the respective node within the dynamic range control frame to which the respective node belongs and an offset value being greater than or equal to a temporal size of the dynamic range control frame subsequent to the respective dynamic range control frame.

According to an advantageous embodiment of the invention the gain information of the bit representation of the shifted node, which is at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by an absolute gain value and wherein the gain information of each bit representation of the shifted nodes at a position after the bit representation of the node, which is at the first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, is represented by a relative gain value which is equal to a difference of a gain value of the bit representation of the respective shifted node and the gain value of the bit representation of the node, which precedes the bit representation of the respective node.

According to an advantageous embodiment of the invention, in case that the bit representations of one or more shifted nodes of the reference dynamic range control frame is embedded in the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame, the gain information of the bit representation of the node of the subsequent dynamic range control frame at a first position of the bitstream portion corresponding to the dynamic range control frame subsequent to the reference dynamic range control frame after the one or more positions of the bit representations of the one or more shifted nodes is represented by a relative gain value which is equal to a difference of a gain value of the bit representation of the respective node and a gain value of the bit representation of the shifted node, which precedes the bit representation of the respective node.

According to an advantageous embodiment of the invention a temporal size of the audio frames is equal to a temporal size of the dynamic range control frames.

According to an advantageous embodiment of the invention the one or more nodes of one of the dynamic range control frame are selected from a uniform time grid.

According to an advantageous embodiment of the invention each node of the one or more nodes comprises slope information.

According to an advantageous embodiment of the invention the dynamic range control encoder is configured for encoding the nodes using an entropy encoding technique, such as Huffman coding or arithmetic coding.

The encoder may assign a fixed code word e.g. of a pre-defined Huffman table (code book) to each of the gain and time differences of pairs of nodes. Examples of suitable Huffman tables for encoding the time differences of pairs of consecutive nodes are given in Table 1 and Table 2, respectively.

TABLE 1
Example of a Huffman table for the coding of time
differences of DRC gain nodes.
Codeword
size Time difference Time difference tDrcDelta
[bits] binary encoding in multiples of deltaTmin
 1 0 × 000 nNodesMax
 3 0 × 004 1
 5 0 × 014 + (a − 2) a = [2 . . . 5]
 6 0 × 030 + (a − 6) a = [6 . . . 13]
12 0 × E00 + (a − 14) a = [14 . . . 2*nNodesMax − 1]

TABLE 2
Example of a Huffman table for the coding of time differences of
DRC gain nodes, where Z = ceil (log2(2*nNodesMax))
Time difference in
multiples of
Encoding Size deltaTmin Range
00 2 bits tDrcDelta = 1  1
{01, μ} {2 bits, tDrcDelta = μ + 2  2 . . . 5
2 bits}
{10, μ} {2 bits, tDrcDelta = μ + 6  6 . . . 13
3 bits}
{11, μ} {2 bits, tDrcDelta = μ + 14 14 . . . 2*nNodesMax
Z bits}

In a further aspect of the invention the objective is achieved by an audio decoder device comprising:

an audio decoder configured for decoding an encoded audio bitstream in order to reproduce an audio signal comprising consecutive audio frames;

a dynamic range control decoder configured for decoding an encoded dynamic range control bitstream in order to reproduce

where k denotes a sample time index. The value of the gain g(k) is computed, e.g. based on a short-term estimate of the root-mean square of the input signal x(k). More details about strategies to determine suitable gains values are discussed in [1]. In the following we refer to the time-variant gains g(k) as a gain sequence.

The invention refers to an application scenario, where both, the audio signal AS and the dynamic range control sequence DS are coded and transmitted. In this case, the dynamic range control gains are not directly applied to the audio signal AS, but encoded and transmitted together with the encoded audio signal ABS. At the decoder 4, both, the audio signal AS and the dynamic range control sequence DS are decoded and the dynamic range control information is applied to the corresponding audio signal AS.

In one aspect the invention provides a system comprising an audio encoder device 1 according to the invention and an audio decoder device 4 according to the invention.

FIG. 3 illustrates the different modes for the coding of dynamic range control gain sequences in a schematic view, namely the full-frame mode (A) and delay mode (B). Gain nodes received in frame n are shown as circles and gain nodes received frame n+1 are shown as squares. The solid line illustrates the interpolated DRC gain up to DRC frame n+1.

In principle, the dynamic range control encoder/decoder chain can be operated in two modes. The so-called full-frame mode refers to the case where after decoding of a received dynamic range control bitstream, corresponding to a specific dynamic range control frame, the gains at each sample position of the dynamic range control frame can be immediately determined after interpolation based on the decoded nodes. This implies that a node has to be transmitted at each frame border, i.e., at the sample position corresponding to the last sample of the dynamic range control frame. If the dynamic range control frame length is N this means the last transmitted node has to be located at the sample position N within that frame. This is illustrated at the top in FIG. 3 denoted by “A”. As shown, the dynamic range control gains of the nth frame can immediately be applied to the corresponding audio frame.

The second mode is referred to as “delay mode” and it is illustrated in the lower part “B” of FIG. 3. In this case, there is no node transmitted for the last sample position within frame n. Therefore, the DRC decoder has to wait for decoding the DRC frame n+1 in order to perform the interpolation that may be used of all gain values following the last node within frame n. This is because the information of the first node of frame n+1 has to be known to perform the interpolation between the last node of frame n and the first node in frame n+1 in order to determine the gain value in between via interpolation.

FIG. 4 illustrates the application of dynamic range control in the context of audio coding in a schematic view where the audio coder introduces one frame delay relative to the dynamic range coding scheme.

FIG. 5 illustrates a shift procedure for nodes according to the invention in a schematic view. The left-hand side shows the situation when using a state-of-the-art approach, whereas the right-hand side shows the proposed method, where each square corresponds to a node A0 . . . A5; B0 . . . B2; C0.

According to an advantageous embodiment of the invention the shift procedure is initiated in case that a number of the nodes B0 . . . B2 of the reference dynamic range control frame DFR is greater than a predefined threshold value.

According to an advantageous embodiment of the invention the shift procedure is initiated in case that a sum of a number of the nodes B0 . . . B2 of the reference dynamic range control frame DFR and a number of shifted nodes A4, A5 from the dynamic range control frame DFP preceding the reference dynamic range control frame DFR to be embedded in the bitstream portion DFR′ corresponding to the reference dynamic range control frame DFR is greater than a predefined threshold value.

According to an advantageous embodiment of the invention the shift procedure is initiated in case that a sum of a number of the nodes B0 . . . B2 of the reference dynamic range control frame DFR and a number of shifted nodes A4, A5 from the dynamic range control frame DFP preceding the reference dynamic range control frame DFR to be embedded in the bitstream portion DFR′ corresponding to the reference dynamic range control frame DFR is greater than a number of the nodes C0 of the dynamic range control frame DFS subsequent to the reference dynamic range control frame DFR.

As explained above, when combined with an audio coding scheme that introduces a frame delay relative to the dynamic range control frames, the decoded dynamic range control gains are delayed by one frame before being applied to the audio signal. Considering the left-hand side in FIG. 5, this means that the nodes Ai of the nth frame are applied to the valid audio decoder output at frame n+1. This implies that in the default delay mode it would be sufficient to transmit the nodes Ai together with the node B0 in frame n+1 and apply the corresponding DRC gains without a delay directly to the corresponding audio output signal at the decoder.

This fact is exploited in the proposed method to reduce the maximum number of nodes transmitted within one frame. This is illustrated on the right-hand side in FIG. 4. The nodes A4 and A5 are shifted to frame n+1 before encoding, i.e., the maximum number of nodes in frame n is reduced from 6 to 4 in the given example. As it will be discussed in the following, the nodes A4 and A5 are “preceding” the first node in frame n+1, i.e., B0 only for the encoding of the gain differences and the slope information. For the coding of the time difference information, a different method has to be applied.

FIG. 6 illustrates the coding of time information according to the invention in a schematic view.

According to an advantageous embodiment of the invention the time information TA0 . . . TA5; TB0 . . . TB2; TC0 of the one or more nodes A0 . . . A5; B0 . . . B2; C0 is represented in such way that the one or more shifted nodes A4, A5; B1, B2 may be identified by using the time information TA4, TA5; TB1, TB2.

According to an advantageous embodiment of the invention the time information TA4, TA5; TB1, TB2 of the one or more shifted nodes A4, A5; B1, B2 is represented by a sum of a time difference t_A4, t_A5; t_B2 from a beginning of the dynamic range control frame DFP; DFR to which the respective node A4, A5; B1, B2 belongs to the temporal position of the respective node A4, A5; B1, B2 within the dynamic range control frame DFP; DFR to which the respective node A4, A5; B1, B2 belongs and an offset value drcFrameSize being greater than or equal to a temporal size of the dynamic range control frame DFR; DFS subsequent to the respective dynamic range control frame DFP; DFR.

First we consider the encoding of the time differences between pairs of nodes. In FIG. 6 the situation for determining the time differences for pairs of nodes is depicted for the example according to FIG. 4, where t_Ai denotes the sample position of node A on the grid of possible node positions within a frame. As discussed earlier nodes can be selected on a uniform time grid, where the spacing of this grid defines the highest available time resolution deltaTmin. Thus, the time information t_Ai is given in samples, where the time differences between two nodes are integer multiples of deltaTmin.

The temporal position information of a node is encoded in a differential way, i.e., relative to the position of the previous node. If a node is the first node within a frame, the time difference is determined relative to the beginning of a frame. The left-hand side of FIG. 6 depicts the situation if no node shifting is applied. In this case, the differential time information of node A4 tDrcDelta_A4 is computed as tDrcDelta_A4=t_A4−t_A3. This differential time value is then encoded using the corresponding entry in an appropriate Huffman table, e.g. according to Table 1 or 2. As another example we look at the encoded time difference of node B0. Since it is the first node of frame n+1, the corresponding time difference is determined relative to the beginning of the frame, i.e. tDrcDelta_B0=t_B0.

Let us now consider the encoding of the node position for the proposed node reservoir technique using node shifting. For the example shown on the right-hand side of FIG. 6, the nodes A4 and A5 have been shifted to the next frame for encoding. The representation of nodes A0 to A3 has not changed and the encoded time differences are therefore also not changed. The same is true for the encoded position information of node B0. However, the time information of node A4 and node A5 is now processed differently. As shown in FIG. 6, the original value t_A4 indicating the sample position of node A4 is modified at the encoder by adding an offset of drcFrameSize. Since the resulting position information exceeds the maximum value that would be possible in case of regular encoding, the offset indicates the decoder that the corresponding node has to be further processed within the context of the previous frame. Furthermore, the decoder knows that the original sample position t_A4 is obtained by subtracting the offset drcFrameSize from the decoded value.

Next, we consider the computation of the time difference information that is actually encoded for the situation shown on the right-hand side of FIG. 6. For coding efficiency reasons, the differential position information for node A4 is computed relative to node B0. In contrast to the situation previously discussed for the left-hand side of FIG. 6, the differential time information is now computed according to tDrcDelta_A4=t_A4+drcFrameSize−t_B0, i.e., by including the offset. Analogously, for node A5 we obtain tDrcDelta_A5=t_A5+drcFrameSize−t_A4−drcFrameSize, which obviously is the same as tDrcDelta_A5=t_A5−t_A4. These differential time values are encoded using the corresponding code word entry of the correct Huffman table, e.g. according to Table 1 or 2.

The method for decoding the temporal position information can be summarized as follows. The decoder extracts the time difference information of a node based on the corresponding code word from the bitstream. The time information is obtained by adding the time difference information to the time information of the previous node. If the resulting sample position is larger than drcFrameSize the decoder knows that the present node has to be processed as if it were the last node in the previous frame, i.e., it has to be appended to the nodes decoded in the previous frame. The correct sample position is determined by subtracting the offset value drcFrameSize from the decoded time value. The same processing steps are applied in an analog way if more shifted nodes occur in a decoded frame.

After decoding and correcting the time information of an entire frame, the decoder knows how many nodes have been shifted back to the previous frame (without explicitly providing this information at the encoder) and on which sample position they are located within the previous frame. The information about the number of shifted nodes will be further exploited in the context of decoding gain and slope information described below.

FIG. 7 illustrates the coding of gain information according to the invention in a schematic view.

According to an advantageous embodiment of the invention the gain information GB1 of the bit representation B′1 of the shifted node B1, which is at a first position of the bitstream portion DFS′ corresponding to the dynamic range control frame DFS subsequent to the reference dynamic range control frame DFR, is represented by an absolute gain value g_B1 and wherein the gain information GB2 of each bit representation B′2 of the shifted nodes B2 at a position after the bit representation B′1 of the node B1, which is at the first position of the bitstream portion DFS′ corresponding to the dynamic range control frame DFS subsequent to the reference dynamic range control frame DFR, is represented by a relative gain value which is equal to a difference of a gain value g_B2 of the bit representation B′2 of the respective shifted node B2 and the gain value g_B1 of the bit representation B′1 of the nodeB1 node B1, which precedes the bit representation B′2 of the respective nodeB2 node B2.

According to an advantageous embodiment of the invention, in case that the bit representations B′1, B′2 of one or more shifted nodes B1, B2 of the reference dynamic range control frame DFR is embedded in the bitstream portion DFS′ corresponding to the dynamic range control frame DFS subsequent to the reference dynamic range control frame DFR, the gain information GC0 of the bit representation C′0 of the node C0 of the subsequent dynamic range control frame DFS at a first position of the bitstream portion DFS′ corresponding to the dynamic range control frame DFS subsequent to the reference dynamic range control frame DFR after the one or more positions of the bit representations B′1, B′2 of the one or more shifted nodes B1, B2 is represented by a relative gain value which is equal to a difference of a gain value g_C0 of the bit representation C′0 of the respective node C0 and a gain value g_B2 of the bit representation B′2 of the shifted nodeB2 node B2, which precedes the bit representation C′0 of the respective node C0.

In FIG. 7 the situation for determining the gain differences for pairs of nodes is depicted for the example according to FIG. 5, where g_Ai denotes the gain value of node Ai.

First, the differential gain values for the node A4 is considered. For the approach without node reservoir, depicted on the left-hand side of FIG. 7, the differential gain value gain Delta_A4 is computed from the difference of the gain value (in dB) of the preceding node A3 and the node A4, i.e., gainDelta_A4=g_A4−g_A3. This differential gain value is then encoded using the corresponding entry in an appropriate Huffman table. Furthermore, we consider the first node of frame n+1 on the left-hand side of FIG. 7. Since B0 is the first node of that frame, it gain value is not encoded in a differential way, but according to a specific coding of initial gain values gainInitial, i.e., the gain value is encoded as its actual value: gainDelta_B0=g_B0.

For the situation shown on the right-hand side, where the node A4 has been shifted to the next frame n+1, the values of the encoded gain information is different. As can be seen, after being shifted, the node A4 becomes the first node in frame n+1 with respect to encoding the gain differences. Thus, its gain value is not encoded in a differential way, but the specific coding of initial gain values is applied as described above. The differential gain value of A5 will remain the same for both situations shown on the left- and the right-hand side. Since node B0 now follows node A5 if the node reservoir is used, its gain information will be determined from the difference of the gains of node B0 and A5, i.e., gainDelta_B0=g_B0−g_A5. Note that only the way how the gain differences are determined changes when applying the node reservoir technique, whereas the reconstructed values of the gains remain the same for each node. Obviously, after decoding the entire gain related information of the frames n and n+1, the obtained gain values for the nodes A0 to B0 are identical to that obtained in the left-hand side, and the nodes can be computed “in time” for application of the DRC gains to the corresponding audio frame.

As discussed in the previous paragraph, the number of shifted nodes and their sample position within the previous frame are known after decoding the time difference information. As illustrated on the right-hand side of FIG. 6, the gain values of shifted nodes from frame n start immediately from the beginning of the received gain information of frame n+1. Therefore, the information on the number of shifted nodes is sufficient for the decoder to assign each gain value to the correct sample position within the correct frame. Considering the example shown on the right-hand side in FIG. 6, the decoder knows that the first two decoded gain values of frame n+1 have to be appended to the last gain values of the previous frame, whereas the third gain value corresponds to the correct gain value of the first node in the current frame.

FIG. 8 illustrates the coding of slope information according to the invention in a schematic view.

According to an advantageous embodiment of the invention each node A0 . . . A5; B0 . . . B2; C0 of the one or more nodes comprises A0 . . . A5; B0 . . . B2; C0 slope information SA0 . . . SA5; SB0 . . . SB2, SC0.

Next, the coding of slope information is considered, which is illustrated in FIG. 8. The slope information of the nodes isn't encoded in a differential way between pairs of nodes, but for each node independently. Therefore, the slope related information remains unchanged in both cases with and without usage of the node reservoir. As in case of coding of gain values, the Huffman tables for generating the code words for slope information remain the same for both cases, with and without using the proposed node shifting. The assignment of the slope information to the correct sample position within the correct frame is performed analogously to the case of decoding the gain values.

After all nodes information received for frame n+1 have been decoded and if applicable shifted back to the preceding frame n, the gain interpolation for frame n using splines or linear interpolation can be performed in the common way and the gain values are applied to the corresponding audio frame.

FIG. 9 illustrates an embodiment of an audio decoder device according to the invention in a schematic view. The audio decoder device 4 comprises:

an audio decoder 5 configured for decoding an encoded audio bitstream ABS in order to reproduce an audio signal AS comprising consecutive audio frames AFP, AFR, AFS;

a dynamic range control decoder 6 configured for decoding an encoded dynamic range control bitstream DBS in order to reproduce an dynamic range control sequence DS corresponding to the audio signal AS and comprising consecutive dynamic range control frames DFP, DFR, DFS;

wherein the encoded dynamic range control bitstream DBS comprises for each dynamic range control frame DFP, DFR, DFS of the dynamic range control frames a corresponding bitstream portion DFP′, DFR′, DFS′;

wherein the encoded dynamic range control bitstream DBS comprises bit representations A′0 . . . A′5; B′0 . . . B′2; C′0 of nodes A0 . . . A5; B0 . . . B2; C0; wherein each bit representation of one node of the nodes comprises gain information GA0 . . . GA5; GB0 . . . GB2; GC0 for the audio signal AS and time information TA0 . . . TA5; TB0 . . . TB2; TC0 indicating to which point in time the gain information GA0 . . . GA5; GB0 . . . GB2; GC0 corresponds;

wherein the encoded dynamic range control bit stream DBS comprises bit representations B′1, B′2 of shifted nodes B1, B2 selected from the nodes B0 . . . B2 of one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS, which are embedded in a bitstream portion corresponding to the dynamic range control frame DFS subsequent to the one reference dynamic range control frame DFR, wherein the bit representation B′0 of each remaining node B0 of the nodes B0 . . . B2 of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS is embedded into the bitstream portion DFR′ corresponding to the one reference dynamic range control frame DFR; and

wherein the dynamic range control decoder 6 is configured for decoding the bit representation B′0 of each remaining node B0 of the remaining nodes B′0 of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS in order to reproduce each remaining node B0 of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS, for decoding the bit representation B′1, B′2 of each shifted node B1, B2 of the shifted nodes B1, B2 selected from the nodes B0 . . . B2 of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS in order to reproduce each shifted node B1, B2 of the shifted nodes B1, B2 selected from the nodes of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS and for combining the reproduced remaining nodes B0 and the reproduced shifted nodes B1, B2 in order to reconstruct the reference dynamic range control frame DFR.

According to an advantageous embodiment of the invention the dynamic range control decoder 6 is configured for identifying the one or more shifted nodes A4, A5; B1, B2 by using the time information TA4, TA5; TB1, TB2.

According to an advantageous embodiment of the invention the dynamic range control decoder 6 is configured for decoding the time information TA4, TA5; TB1, TB2 of the one or more shifted nodes A4, A5; B1, B2, which is represented by a sum of a time difference t_A4, t_A5; t_B1, t_B2 from a beginning of the dynamic range control frame DFP; DFR to which the respective node A4, A5; B1, B2 belongs to the temporal position of the respective node A4, A5; B1, B2 within the dynamic range control frame DFP; DFR to which the respective node A4, A5; B1, B2 belongs and an offset value drcFrameSize being greater than or equal to a temporal size of the dynamic range control frame DFR; DFS subsequent to the respective dynamic range control frame DFP; DFR.

According to an advantageous embodiment of the invention the dynamic range control decoder 6 is configured for decoding the gain information GB1 of the bit representation B′1 of the shifted node B1, which is at a first position of the bitstream portion DFS′ corresponding to the dynamic range control frame DFS subsequent to the reference dynamic range control frame DFR, is represented by an absolute gain value g_B1 and wherein the gain information GB2 of each bit representation B′2 of the shifted nodes B2 at a position after the bit representation B′1 of the node B1, which is at the first position of the bitstream portion DFS′ corresponding to the dynamic range control frame DFS subsequent to the reference dynamic range control frame DFR, is represented by a relative gain value which is equal to a difference of a gain value g_B2 of the bit representation B′2 of the respective shifted node B2 and the gain value g_B1 of the bit representation B′1 of the nodeB1, which precedes the bit representation B′2 of the respective nodeB2 node B2.

According to an advantageous embodiment of the invention the dynamic range control decoder 6 is configured for decoding the gain information GC0 of the bit representation C′0 of the node C0 of the subsequent dynamic range control frame DFS at a first position of the bitstream portion DFS′ corresponding to the dynamic range control frame DFS subsequent to the reference dynamic range control frame DFR after the one or more positions of the bit representations B′1, B′2 of the one or more shifted nodes B1, B2 is represented by a relative gain value which is equal to a difference of a gain value g_C0 the bit representation C′0 of the respective node C0 and the gain value g_B2 of the bit representation B′2 of the shifted nodeB2 node B2, which precedes the bit representation C′0 of the respective node C0.

According to an advantageous embodiment of the invention a temporal size of the audio frames AFP, AFR, AFS is equal to a temporal size of the dynamic range control frames AFP, AFR, AFS.

According to an advantageous embodiment of the invention the one or more nodes A0 . . . A5; B0 . . . B2; C0 of one of the dynamic range control frames DFP, DFR, DFS are selected from a uniform time grid.

According to an advantageous embodiment of the invention each node A0 . . . A5; B0 . . . B2; C0 of the one or more nodes A0 . . . A5; B0 . . . B2; C0 comprises slope information SA0 . . . SA5, SB0 . . . SB2; SC0.

According to an advantageous embodiment of the invention the dynamic range control decoder 6 is configured for decoding the bit representations of the nodes A′0 . . . A′5; B′0 . . . B′2, C0 using an entropy decoding technique.

In another aspect the invention provides a method for operating an audio decoder, the method comprises the steps:

decoding an encoded audio bitstream ABS in order to reproduce an audio signal AS comprising consecutive audio frames AFP, AFR, AFS;

decoding an encoded dynamic range control bitstream DBS in order to reproduce an dynamic range control sequence DS corresponding to the audio signal AS and comprising consecutive dynamic range control frames DFP, DFR, DFS;

wherein the encoded dynamic range control bitstream DBS comprises for each dynamic range control frame DFP, DFR, DFS of the dynamic range control frames a corresponding bitstream portion DFP′, DFR′, DFS′;

wherein the encoded dynamic range control bitstream DBS comprises bit representations A′0 . . . A′5; B′0 . . . B′2; C′0 of nodes A0 . . . A5; B0 . . . B2; C0, wherein each bit representation of one node of the nodes comprises gain information GA0 . . . GA5; GB0 . . . GB2; GC0 for the audio signal AS and time information TA0 . . . TA5; TB0 . . . TB2; TC0 indicating to which point in time the gain information GA0 . . . GA5; GB0 . . . GB2; GC0 corresponds;

wherein the encoded dynamic range control bit stream DBS comprises bit representations B′1, B′2 of shifted nodes B1, B2 selected from the nodes B0 . . . B2 of one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS, which are embedded in a bitstream portion corresponding to the dynamic range control frame DFS subsequent to the one reference dynamic range control frame DFR, wherein the bit representation B′0 of each remaining node B0 of the nodes B0 . . . B2 of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS is embedded into the bitstream portion DFR′ corresponding to the one reference dynamic range control frame DFR; and

wherein the bit representation B′0 of each remaining node B0 of the remaining nodes B′0 of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS is decoded in order to reproduce each remaining node B0 of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS;

wherein the bit representation B′1, B′2 of each shifted node B1, B2 of the shifted nodes B1, B2 selected from the nodes B0 . . . B2 of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS is decoded in order to reproduce each shifted node B1, B2 of the shifted nodes B1, B2 selected from the nodes of the one reference dynamic range control frame DFR of the dynamic range control frames DFP, DFR, DFS; and

wherein the reproduced remaining nodes B0 and the reproduced shifted nodes B1, B2 are combined in order to reconstruct the reference dynamic range control frame DFR.

With respect to the decoder, the encoder and the methods of the described embodiments the following shall be mentioned:

Although some aspects have been described in the context of an apparatus, it is clear that these aspects also represent a description of the corresponding method, where a block or device corresponds to a method step or a feature of a method step. Analogously, aspects described in the context of a method step also represent a description of a corresponding block or item or feature of a corresponding apparatus.

Depending on certain implementation requirements, embodiments of the invention can be implemented in hardware or in software. The implementation can be performed using a digital storage medium, for example a floppy disk, a DVD, a CD, a ROM, a PROM, an EPROM, an EEPROM or a FLASH memory, having electronically readable control signals stored thereon, which cooperate (or are capable of cooperating) with a programmable computer system such that the respective method is performed.

Some embodiments according to the invention comprise a data carrier having electronically readable control signals, which are capable of cooperating with a programmable computer system such that one of the methods described herein is performed.

Generally, embodiments of the present invention can be implemented as a computer program product with a program code, the program code being operative for performing one of the methods when the computer program product runs on a computer. The program code may for example be stored on a machine readable carrier.

Other embodiments comprise the computer program for performing one of the methods described herein, which is stored on a machine readable carrier or a non-transitory storage medium.

In other words, an embodiment of the inventive method is, therefore, a computer program having a program code for performing one of the methods described herein, when the computer program runs on a computer.

A further embodiment of the inventive methods is, therefore, a data carrier (or a digital storage medium, or a computer-readable medium) comprising, recorded thereon, the computer program for performing one of the methods described herein.

A further embodiment of the inventive method is, therefore, a data stream or a sequence of signals representing the computer program for performing one of the methods described herein. The data stream or the sequence of signals may be configured, for example, to be transferred via a data communication connection, for example via the Internet.

A further embodiment comprises a processing means, for example a computer, or a programmable logic device, configured or adapted to perform one of the methods described herein.

A further embodiment comprises a computer having installed thereon the computer program for performing one of the methods described herein.

In some embodiments, a programmable logic device (for example a field programmable gate array) may be used to perform some or all of the functionalities of the methods described herein. In some embodiments, a field programmable gate array may cooperate with a microprocessor in order to perform one of the methods described herein. Generally, the methods are advantageously performed by any hardware apparatus.

While this invention has been described in terms of several 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.

Meier, Michael, Kuech, Fabian, Neugebauer, Bernhard, Schreiner, Stephan, Kratschmer, Michael, Uhle, Christian

Patent Priority Assignee Title
Patent Priority Assignee Title
10074377, Mar 25 2014 Fraunhofer-Gesellschaft zur Foerderung der Angewandten Forschung E V Audio encoder device and an audio decoder device having efficient gain coding in dynamic range control
5701390, Feb 22 1995 Digital Voice Systems, Inc.; Digital Voice Systems, Inc Synthesis of MBE-based coded speech using regenerated phase information
6785655, May 15 2000 AVAGO TECHNOLOGIES INTERNATIONAL SALES PTE LIMITED Method for independent dynamic range control
8588307, Sep 17 2009 Samsung Electronics Co., Ltd. Method and apparatus for encoding and decoding mode information
9191581, Jul 02 2004 CITIBANK, N A Methods and apparatus for mixing compressed digital bit streams
9607624, Mar 29 2013 Apple Inc. Metadata driven dynamic range control
20100083344,
20110009987,
20110208528,
20110257980,
20120310654,
20130030800,
20130144631,
20130339037,
20140369527,
20150356978,
20160307580,
20170229134,
CN101587711,
EP1588498,
JP2002271207,
JP2012504260,
RU2144222,
TW293118,
WO2012026092,
WO2013173080,
WO2013181115,
WO2015144587,
///////
Executed onAssignorAssigneeConveyanceFrameReelDoc
Nov 09 2016KUECH, FABIANFraunhofer-Gesellschaft zur Foerderung der Angewandten Forschung E VASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0532710848 pdf
Nov 13 2016SCHREINER, STEPHANFraunhofer-Gesellschaft zur Foerderung der Angewandten Forschung E VASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0532710848 pdf
Nov 14 2016UHLE, CHRISTIANFraunhofer-Gesellschaft zur Foerderung der Angewandten Forschung E VASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0532710848 pdf
Nov 14 2016KRATSCHMER, MICHAELFraunhofer-Gesellschaft zur Foerderung der Angewandten Forschung E VASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0532710848 pdf
Nov 14 2016NEUGEBAUER, BERNHARDFraunhofer-Gesellschaft zur Foerderung der Angewandten Forschung E VASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0532710848 pdf
Nov 14 2016MEIER, MICHAELFraunhofer-Gesellschaft zur Foerderung der Angewandten Forschung E VASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS 0532710848 pdf
May 06 2019Fraunhofer-Gesellschaft zur Foerderung der Angewandten Forschung e. V.(assignment on the face of the patent)
Date Maintenance Fee Events
May 06 2019BIG: Entity status set to Undiscounted (note the period is included in the code).


Date Maintenance Schedule
Jun 14 20254 years fee payment window open
Dec 14 20256 months grace period start (w surcharge)
Jun 14 2026patent expiry (for year 4)
Jun 14 20282 years to revive unintentionally abandoned end. (for year 4)
Jun 14 20298 years fee payment window open
Dec 14 20296 months grace period start (w surcharge)
Jun 14 2030patent expiry (for year 8)
Jun 14 20322 years to revive unintentionally abandoned end. (for year 8)
Jun 14 203312 years fee payment window open
Dec 14 20336 months grace period start (w surcharge)
Jun 14 2034patent expiry (for year 12)
Jun 14 20362 years to revive unintentionally abandoned end. (for year 12)