The present invention is related to audio encoding/decoding, in particular, to spatial audio coding and spatial audio object coding, and, more particularly, to an apparatus and method for efficient object metadata coding.
Spatial audio coding tools are well-known in the art and are, for example, standardized in the MPEG-surround standard. Spatial audio coding starts from original input channels such as five or seven channels which are identified by their placement in a reproduction setup, i.e., a left channel, a center channel, a right channel, a left surround channel, a right surround channel and a low frequency enhancement channel. A spatial audio encoder typically derives one or more downmix channels from the original channels and, additionally, derives parametric data relating to spatial cues such as interchannel level differences in the channel coherence values, interchannel phase differences, interchannel time differences, etc. The one or more downmix channels are transmitted together with the parametric side information indicating the spatial cues to a spatial audio decoder which decodes the downmix channel and the associated parametric data in order to finally obtain output channels which are an approximated version of the original input channels. The placement of the channels in the output setup is typically fixed and is, for example, a 5.1 format, a 7.1 format, etc.
Such channel-based audio formats are widely used for storing or transmitting multi-channel audio content where each channel relates to a specific loudspeaker at a given position. A faithful reproduction of these kind of formats necessitates a loudspeaker setup where the speakers are placed at the same positions as the speakers that were used during the production of the audio signals. While increasing the number of loudspeakers improves the reproduction of truly immersive 3D audio scenes, it becomes more and more difficult to fulfill this requirement—especially in a domestic environment like a living room.
The necessity of having a specific loudspeaker setup can be overcome by an object-based approach where the loudspeaker signals are rendered specifically for the playback setup.
For example, spatial audio object coding tools are well-known in the art and are standardized in the MPEG SAOC standard (SAOC=spatial audio object coding). In contrast to spatial audio coding starting from original channels, spatial audio object coding starts from audio objects which are not automatically dedicated for a certain rendering reproduction setup. Instead, the placement of the audio objects in the reproduction scene is flexible and can be determined by the user by inputting certain rendering information into a spatial audio object coding decoder. Alternatively or additionally, rendering information, i.e., information at which position in the reproduction setup a certain audio object is to be placed typically over time can be transmitted as additional side information or metadata. In order to obtain a certain data compression, a number of audio objects are encoded by an SAOC encoder which calculates, from the input objects, one or more transport channels by downmixing the objects in accordance with certain downmixing information. Furthermore, the SAOC encoder calculates parametric side information representing inter-object cues such as object level differences (OLD), object coherence values, etc. As in SAC (SAC=Spatial Audio Coding), the inter object parametric data is calculated for individual time/frequency tiles, i.e., for a certain frame of the audio signal comprising, for example, 1024 or 2048 samples, 24, 32, or 64, etc., frequency bands are considered so that, in the end, parametric data exists for each frame and each frequency band. As an example, when an audio piece has 20 frames and when each frame is subdivided into 32 frequency bands, then the number of time/frequency tiles is 640.
In an object-based approach, the sound field is described by discrete audio objects. This necessitates object metadata that describes among others the time-variant position of each sound source in 3D space.
A first metadata coding concept in conventional technology is the spatial sound description interchange format (SpatDIF), an audio scene description format which is still under development [1]. It is designed as an interchange format for object-based sound scenes and does not provide any compression method for object trajectories. SpatDIF uses the text-based Open Sound Control (OSC) format to structure the object metadata [2]. A simple text-based representation, however, is not an option for the compressed transmission of object trajectories.
Another metadata concept in conventional technology is the Audio Scene Description Format (ASDF) [3], a text-based solution that has the same disadvantage. The data is structured by an extension of the Synchronized Multimedia Integration Language (SMIL) which is a sub set of the Extensible Markup Language (XML) [4,5].
A further metadata concept in conventional technology is the audio binary format for scenes (AudioBIFS), a binary format that is part of the MPEG-4 specification [6,7]. It is closely related to the XML-based Virtual Reality Modeling Language (VRML) which was developed for the description of audio-visual 3D scenes and interactive virtual reality applications [8]. The complex AudioBIFS specification uses scene graphs to specify routes of object movements. A major disadvantage of AudioBIFS is that is not designed for real-time operation where a limited system delay and random access to the data stream are a requirement. Furthermore, the encoding of the object positions does not exploit the limited localization performance of human listeners. For a fixed listener position within the audio-visual scene, the object data can be quantized with a much lower number of bits [9]. Hence, the encoding of the object metadata that is applied in AudioBIFS is not efficient with regard to data compression.
It would therefore be highly appreciated, if improved, efficient object metadata coding concepts would be provided.
According to an embodiment, an apparatus for generating one or more audio channels may have: a metadata decoder for generating one or more reconstructed metadata signals from one or more processed metadata signals depending on a control signal, wherein each of the one or more reconstructed metadata signals indicates information associated with an audio object signal of one or more audio object signals, wherein the metadata decoder is configured to generate the one or more reconstructed metadata signals by determining a plurality of reconstructed metadata samples for each of the one or more reconstructed metadata signals, and an audio channel generator for generating the one or more audio channels depending on the one or more audio object signals and depending on the one or more reconstructed metadata signals, wherein the metadata decoder is configured to receive a plurality of processed metadata samples of each of the one or more processed metadata signals, wherein the metadata decoder is configured to receive the control signal, wherein the metadata decoder is configured to determine each reconstructed metadata sample of the plurality of reconstructed metadata samples of each reconstructed metadata signal of the one or more reconstructed metadata signals, so that, when the control signal indicates a first state, said reconstructed metadata sample is a sum of one of the processed metadata samples of one of the one or more processed metadata signals and of another already generated reconstructed metadata sample of said reconstructed metadata signal, and so that, when the control signal indicates a second state being different from the first state, said reconstructed metadata sample is said one of the processed metadata samples of said one of the one or more processed metadata signals.
According to another embodiment, an apparatus for decoding encoded audio data may have: an input interface for receiving the encoded audio data, the encoded audio data including a plurality of encoded channels or a plurality of encoded objects or compress metadata related to the plurality of objects, and an inventive apparatus, wherein the metadata decoder of the inventive apparatus is a metadata decompressor for decompressing the compressed metadata, wherein the audio channel generator of the inventive apparatus includes a core decoder for decoding the plurality of encoded channels and the plurality of encoded objects, wherein the audio channel generator further includes an object processor for processing the plurality of decoded objects using the decompressed metadata to obtain a number of output channels including audio data from the objects and the decoded channels, and wherein the audio channel generator further includes a post processor for converting the number of output channels into an output format.
According to another embodiment, an apparatus for generating encoded audio information including one or more encoded audio signals and one or more processed metadata signals may have: a metadata encoder for receiving one or more original metadata signals and for determining the one or more processed metadata signals, wherein each of the one or more original metadata signals includes a plurality of original metadata samples, wherein the original metadata samples of each of the one or more original metadata signals indicate information associated with an audio object signal of one or more audio object signals, and an audio encoder for encoding the one or more audio object signals to obtain the one or more encoded audio signals, wherein the metadata encoder is configured to determine each processed metadata sample of a plurality of processed metadata samples of each processed metadata signal of the one or more processed metadata signals, so that, when the control signal indicates a first state, said reconstructed metadata sample indicates a difference or a quantized difference between one of a plurality of original metadata samples of one of the one or more original metadata signals and of another already generated processed metadata sample of said processed metadata signal, and so that, when the control signal indicates a second state being different from the first state, said processed metadata sample is said one of the original metadata samples of said one of the one or more processed metadata signals, or is a quantized representation said one of the original metadata samples.
According to another embodiment, an apparatus for encoding audio input data to obtain audio output data may have: an input interface for receiving a plurality of audio channels, a plurality of audio objects and metadata related to one or more of the plurality of audio objects, a mixer for mixing the plurality of objects and the plurality of channels to obtain a plurality of pre-mixed channels, each pre-mixed channel including audio data of a channel and audio data of at least one object, and an inventive apparatus, wherein the audio encoder of the inventive apparatus is a core encoder for core encoding core encoder input data, and wherein the metadata encoder of the inventive apparatus is a metadata compressor for compressing the metadata related to the one or more of the plurality of audio objects.
According to another embodiment, a system may have: an inventive apparatus for generating encoded audio information including one or more encoded audio signals and one or more processed metadata signals, and an inventive apparatus for receiving the one or more encoded audio signals and the one or more processed metadata signals, and for generating one or more audio channels depending on the one or more encoded audio signals and depending on the one or more processed metadata signals.
According to another embodiment, a method for generating one or more audio channels may have the steps of: generating one or more reconstructed metadata signals from one or more processed metadata signals depending on a control signal, wherein each of the one or more reconstructed metadata signals indicates information associated with an audio object signal of one or more audio object signals, wherein generating the one or more reconstructed metadata signals is conducted by determining a plurality of reconstructed metadata samples for each of the one or more reconstructed metadata signals, and generating the one or more audio channels depending on the one or more audio object signals and depending on the one or more reconstructed metadata signals, wherein generating the one or more reconstructed metadata signals is conducted by receiving a plurality of processed metadata samples of each of the one or more processed metadata signals, by receiving the control signal, and by determining each reconstructed metadata sample of the plurality of reconstructed metadata samples of each reconstructed metadata signal of the one or more reconstructed metadata signals, so that, when the control signal indicates a first state, said reconstructed metadata sample is a sum of one of the processed metadata samples of one of the one or more processed metadata signals and of another already generated reconstructed metadata sample of said reconstructed metadata signal, and so that, when the control signal indicates a second state being different from the first state, said reconstructed metadata sample is said one of the processed metadata samples of said one of the one or more processed metadata signals.
According to another embodiment, a method for generating encoded audio information including one or more encoded audio signals and one or more processed metadata signals, may have the steps of: receiving one or more original metadata signals, determining the one or more processed metadata signals, and encoding the one or more audio object signals to obtain the one or more encoded audio signals, wherein each of the one or more original metadata signals includes a plurality of original metadata samples, wherein the original metadata samples of each of the one or more original metadata signals indicate information associated with an audio object signal of one or more audio object signals, and wherein determining the one or more processed metadata signals includes determining each processed metadata sample of a plurality of processed metadata samples of each processed metadata signal of the one or more processed metadata signals, so that, when the control signal indicates a first state, said reconstructed metadata sample indicates a difference or a quantized difference between one of a plurality of original metadata samples of one of the one or more original metadata signals and of another already generated processed metadata sample of said processed metadata signal, and so that, when the control signal indicates a second state being different from the first state, said processed metadata sample is said one of the original metadata samples of said one of the one or more processed metadata signals, or is a quantized representation said one of the original metadata samples.
Another embodiment may have a non-transitory digital storage medium having computer-readable code stored thereon to perform the inventive methods when being executed on a computer or signal processor.
An apparatus for generating one or more audio channels is provided. The apparatus comprises a metadata decoder for generating one or more reconstructed metadata signals (x1′, . . . , xN′) from one or more processed metadata signals (z1, . . . , zN) depending on a control signal (b), wherein each of the one or more reconstructed metadata signals (x1′, . . . , xN′) indicates information associated with an audio object signal of one or more audio object signals, wherein the metadata decoder is configured to generate the one or more reconstructed metadata signals (x1′, . . . , xN′) by determining a plurality of reconstructed metadata samples (x1′(n), . . . , xN′(n)) for each of the one or more reconstructed metadata signals (x1′, . . . , xN′). Moreover, the apparatus comprises an audio channel generator for generating the one or more audio channels depending on the one or more audio object signals and depending on the one or more reconstructed metadata signals (x1′, . . . , xN′). The metadata decoder is configured to receive a plurality of processed metadata samples (z1(n), . . . , zN(n)) of each of the one or more processed metadata signals (z1, . . . , zN). Moreover, the metadata decoder is configured to receive the control signal (b). Furthermore, the metadata decoder is configured to determine each reconstructed metadata sample (xi′(n)) of the plurality of reconstructed metadata samples (xi′(1), . . . xi′(n−1), xi′(n)) of each reconstructed metadata signal (xi′) of the one or more reconstructed metadata signals (x1′, . . . , xN′), so that, when the control signal (b) indicates a first state (b(n)=0), said reconstructed metadata sample (xi′(n)) is a sum of one of the processed metadata samples (zi(n)) of one of the one or more processed metadata signals (zi) and of another already generated reconstructed metadata sample (xi′(n−1)) of said reconstructed metadata signal (xi′), and so that, when the control signal indicates a second state (b(n)=1) being different from the first state, said reconstructed metadata sample (xi′(n)) is said one (zi(n)) of the processed metadata samples (zi(1), . . . , zi(n)) of said one (zi) of the one or more processed metadata signals (z1, . . . , zN).
Moreover, an apparatus for generating encoded audio information comprising one or more encoded audio signals and one or more processed metadata signals is provided. The apparatus comprises a metadata encoder for receiving one or more original metadata signals and for determining the one or more processed metadata signals, wherein each of the one or more original metadata signals comprises a plurality of original metadata samples, wherein the original metadata samples of each of the one or more original metadata signals indicate information associated with an audio object signal of one or more audio object signals.
Moreover, the apparatus comprises an audio encoder for encoding the one or more audio object signals to obtain the one or more encoded audio signals.
The metadata encoder is configured to determine each processed metadata sample (zi(n)) of a plurality of processed metadata samples (zi(1), . . . zi(n−1), zi(n)) of each processed metadata signal (zi) of the one or more processed metadata signals (z1, . . . , zN), so that, when the control signal (b) indicates a first state (b(n)=0), said reconstructed metadata sample (zi(n)) indicates a difference or a quantized difference between one of a plurality of original metadata samples (xi(n)) of one of the one or more original metadata signals (xi) and of another already generated processed metadata sample of said processed metadata signal (zi), and so that, when the control signal indicates a second state (b(n)=1) being different from the first state, said processed metadata sample (zi(n)) is said one (xi(n)) of the original metadata samples (xi(1), . . . , xi(n)) of said one of the one or more processed metadata signals (xi), or is a quantized representation (qi(n)) said one (xi(n)) of the original metadata samples (xi(1), . . . , xi(n)).
According to embodiments, data compression concepts for object metadata are provided, which achieve efficient compression mechanism for transmission channels with limited data rate. No additional delay is introduced by the encoder and decoder, respectively. Moreover, a good compression rate for pure azimuth changes, for example, camera rotations, is achieved. Furthermore, the provided concepts support discontinuous trajectories, e.g., positional jumps. Moreover, low decoding complexity is realized. Furthermore, random access with limited reinitialization time is achieved.
Moreover, a method for generating one or more audio channels is provided. The method comprises:
Generating the one or more reconstructed metadata signals (x1′, . . . , xN′) is conducted by receiving a plurality of processed metadata samples (z1(n), . . . , zN(n)) of each of the one or more processed metadata signals (z1, . . . , zN), by receiving the control signal (b), and by determining each reconstructed metadata sample (xi′(n)) of the plurality of reconstructed metadata samples (xi′(1), . . . xi′(n−1), xi′(n)) of each reconstructed metadata signal (xi′) of the one or more reconstructed metadata signals (x1′, . . . xN′), so that, when the control signal (b) indicates a first state (b(n)=0), said reconstructed metadata sample (xi′(n)) is a sum of one of the processed metadata samples (zi(n)) of one of the one or more processed metadata signals (zi) and of another already generated reconstructed metadata sample (xi′(n−1)) of said reconstructed metadata signal (xi′), and so that, when the control signal indicates a second state (b(n)=1) being different from the first state, said reconstructed metadata sample (xi′(n)) is said one (zi(n)) of the processed metadata samples (zi(1), . . . , zi(n)) of said one (zi) of the one or more processed metadata signals (z1, . . . , zN).
Furthermore, a method for generating encoded audio information comprising one or more encoded audio signals and one or more processed metadata signals is provided. The method comprises:
Each of the one or more original metadata signals comprises a plurality of original metadata samples, wherein the original metadata samples of each of the one or more original metadata signals indicate information associated with an audio object signal of one or more audio object signals. Determining the one or more processed metadata signals comprises determining each processed metadata sample (zi(n)) of a plurality of processed metadata samples (zi(1), . . . zi(n−1), zi(n)) of each processed metadata signal (zi) of the one or more processed metadata signals (z1, . . . , zN), so that, when the control signal (b) indicates a first state (b(n)=0), said reconstructed metadata sample (zi(n)) indicates a difference or a quantized difference between one of a plurality of original metadata samples (xi(n)) of one of the one or more original metadata signals (xi) and of another already generated processed metadata sample of said processed metadata signal (zi), and so that, when the control signal indicates a second state (b(n)=1) being different from the first state, said processed metadata sample (zi(n)) is said one (xi(n)) of the original metadata samples (xi(1), . . . , xi(n)) of said one of the one or more processed metadata signals (xi), or is a quantized representation (qi(n)) said one (xi(n)) of the original metadata samples (xi(1), . . . , xi(n)).
Moreover, a computer program for implementing the above-described method when being executed on a computer or signal processor is provided.
Embodiments of the present invention will be detailed subsequently referring to the appended drawings, in which:
The apparatus 250 comprises a metadata encoder 210 for receiving one or more original metadata signals and for determining the one or more processed metadata signals, wherein each of the one or more original metadata signals comprises a plurality of original metadata samples, wherein the original metadata samples of each of the one or more original metadata signals indicate information associated with an audio object signal of one or more audio object signals.
Moreover, the apparatus 250 comprises an audio encoder 220 for encoding the one or more audio object signals to obtain the one or more encoded audio signals.
The metadata encoder 210 is configured to determine each processed metadata sample (zi(n)) of a plurality of processed metadata samples (zi(1), . . . zi(n−1), zi(n)) of each processed metadata signal (zi) of the one or more processed metadata signals (z1, . . . , zN), so that, when the control signal (b) indicates a first state (b(n)=0), said reconstructed metadata sample (zi(n)) indicates a difference or a quantized difference between one of a plurality of original metadata samples (xi(n)) of one of the one or more original metadata signals (xi) and of another already generated processed metadata sample of said processed metadata signal (zi), and so that, when the control signal indicates a second state (b(n)=1) being different from the first state, said processed metadata sample (zi(n)) is said one (xi(n)) of the original metadata samples (xi(1), . . . , xi(n)) of said one of the one or more processed metadata signals (xi), or is a quantized representation (qi(n)) said one (xi(n)) of the original metadata samples (xi(1), . . . , xi(n)).
The apparatus 100 comprises a metadata decoder 110 for generating one or more reconstructed metadata signals (x1′, . . . , xN′) from one or more processed metadata signals (z1, . . . , zN) depending on a control signal (b), wherein each of the one or more reconstructed metadata signals (x1′, . . . , xN′) indicates information associated with an audio object signal of one or more audio object signals, wherein the metadata decoder 110 is configured to generate the one or more reconstructed metadata signals (x1′, . . . , xN′) by determining a plurality of reconstructed metadata samples (x1′(n), . . . , xN′(n)) for each of the one or more reconstructed metadata signals (x1′, . . . , xN′).
Moreover, the apparatus 100 comprises an audio channel generator 120 for generating the one or more audio channels depending on the one or more audio object signals and depending on the one or more reconstructed metadata signals (x1′, . . . , xN′).
The metadata decoder 110 is configured to receive a plurality of processed metadata samples (z1(n), . . . , zN(n)) of each of the one or more processed metadata signals (z1, . . . , zN). Moreover, the metadata decoder 110 is configured to receive the control signal (b).
Furthermore, the metadata decoder 110 is configured to determine each reconstructed metadata sample (xi′(n)) of the plurality of reconstructed metadata samples (xi′(1), . . . xi′(n−1), xi′(n)) of each reconstructed metadata signal (xi′) of the one or more reconstructed metadata signals (x1′, . . . , xN′), so that, when the control signal (b) indicates a first state (b(n)=0), said reconstructed metadata sample (xi′(n)) is a sum of one of the processed metadata samples (zi(n)) of one of the one or more processed metadata signals (zi) and of another already generated reconstructed metadata sample (xi′(n−1)) of said reconstructed metadata signal (xi′), and so that, when the control signal indicates a second state (b(n)=1) being different from the first state, said reconstructed metadata sample (xi′(n)) is said one (zi(n)) of the processed metadata samples (zi(1), . . . , zi(n)) of said one (zi) of the one or more processed metadata signals (z1, . . . , zN).
When referring to metadata samples, it should be noted, that a metadata sample is characterised by its metadata sample value, but also by the instant of time, to which it relates. For example, such an instant of time may be relative to the start of an audio sequence or similar. For example, an index n or k might identify a position of the metadata sample in a metadata signal and by this, a (relative) instant of time (being relative to a start time) is indicated. It should be noted that when two metadata samples relate to different instants of time, these two metadata samples are different metadata samples, even when their metadata sample values are equal, what sometimes may be the case.
The above embodiments are based on the finding that metadata information (comprised by a metadata signal) that is associated with an audio object signal often changes slowly.
For example, a metadata signal may indicate position information on an audio object (e.g., an azimuth angle, an elevation angle or a radius defining the position of an audio object). It may be assumed that, at most times, the position of the audio object either does not change or only changes slowly.
Or, a metadata signal may, for example, indicate a volume (e.g., a gain) of an audio object, and it may also be assumed, that at most times, the volume of an audio object changes slowly.
For this reason, it is not necessitated to transmit the (complete) metadata information at every instant of time.
Instead, the (complete) metadata information, may, for example, according to some embodiments, only be transmitted at certain instants of time, for example, periodically, e.g., at every N-th instant of time, e.g., at point in time 0, N, 2N, 3N, etc.
For example, in embodiments, three metadata signals specify the position of an audio object in a 3D space. A first one of the metadata signals may, e.g., specify the azimuth angle of the position of the audio object. A second one of the metadata signals may, e.g., specify the elevation angle of the position of the audio object. A third one of the metadata signals may, e.g., specify the radius relating to the distance of the audio object.
Azimuth angle, elevation angle and radius unambiguously define the position of an audio object in a 3D space from an origin. This is illustrated with reference to
The elevation angle specifies, for example, the angle between the straight line from the origin to the object position and the normal projection of this straight line onto the xy-plane (the plane defined by the x-axis and the y-axis). The azimuth angle defines, for example, the angle between the x-axis and the said normal projection. By specifying the azimuth angle and the elevation angle, the straight line 415 through the origin 400 and the position 410 of the audio object can be defined. By furthermore specifying the radius, the exact position 410 of the audio object can be defined.
In an embodiment, the azimuth angle is defined for the range: −180°<azimuth≤180°, the elevation angle is defined for the range: −90°≤elevation≤90° and the radius may, for example, be defined in meters [m] (greater than or equal to 0 m).
In another embodiment, where it, may, for example, be assumed that all x-values of the audio object positions in an xyz-coordinate system are greater than or equal to zero, the azimuth angle may be defined for the range: −90°≤azimuth≤90°, the elevation angle may be defined for the range:−90°≤elevation≤90°, and the radius may, for example, be defined in meters [m].
In a further embodiment, the metadata signals may be scaled such that the azimuth angle is defined for the range: −128°<azimuth≤128°, the elevation angle is defined for the range: −32°≤elevation≤32° and the radius may, for example, be defined on a logarithmic scale. In some embodiments, the original metadata signals, the processed metadata signals and the reconstructed metadata signals, respectively, may comprise a scaled representation of a position information and/or a scaled representation of a volume of one of the one or more audio object signals.
The audio channel generator 120 may, for example, be configured to generate the one or more audio channels depending on the one or more audio object signals and depending on the reconstructed metadata signals, wherein the reconstructed metadata signals may, for example, indicate the position of the audio objects.
In
In other embodiments, audio channel generator 120 may generate the four audio channels such that the first audio object 510 is reproduced with a high volume by loudspeakers 511 and 512 and with a low volume by loudspeakers 513 and 514.
Moreover, the second audio object is located at a position 520 close to the assumed positions of loudspeakers 513 and 514, and is located far away from loudspeakers 511 and 512. Therefore, the audio channel generator 120 may generate the four audio channels such that the second audio object 520 is reproduced by loudspeakers 513 and 514 but not by loudspeakers 511 and 512.
In other embodiments, audio channel generator 120 may generate the four audio channels such that the second audio object 520 is reproduced with a high volume by loudspeakers 513 and 514 and with a low volume by loudspeakers 511 and 512.
In alternative embodiments, only two metadata signals are used to specify the position of an audio object. For example, only the azimuth and the radius may be specified, for example, when it is assumed that all audio objects are located within a single plane.
In further other embodiments, for each audio object, only a single metadata signal is encoded and transmitted as position information. For example, only an azimuth angle may be specified as position information for an audio object (e.g., it may be assumed that all audio objects are located in the same plane having the same distance from a center point, and are thus assumed to have the same radius). The azimuth information may, for example, be sufficient to determine that an audio object is located close to a left loudspeaker and far away from a right loudspeaker. In such a situation, the audio channel generator 120 may, for example, generate the one or more audio channels such that the audio object is reproduced by the left loudspeaker, but not by the right loudspeaker.
For example, Vector Base Amplitude Panning (VBAP) may be employed (see, e.g., [11]) to determine the weight of an audio object signal within each of the audio channels of the loudspeakers. E.g., with respect to VBAP, it is assumed that an audio object relates to a virtual source.
In embodiments, a further metadata signal may specify a volume, e.g., a gain (for example, expressed in decibel [dB]) for each audio object.
For example, in
Embodiments also assume that such gain values of audio objects often change slowly. Therefore, it is not necessitated to transmit such metadata information at every point in time. Instead, metadata information is only transmitted at certain points in time. At intermediate points in time, the metadata information may, e.g., be approximated using the preceding metadata sample and the succeeding metadata sample, that were transmitted. For example, linear interpolation may be employed for approximation of intermediate values. E.g., the gain, the azimuth, the elevation and/or the radius of each of the audio objects may be approximated for points in time, where such metadata was not transmitted.
By such an approach, considerable savings in the transmission rate of metadata can be achieved.
The system comprises an apparatus 250 for generating encoded audio information comprising one or more encoded audio signals and one or more processed metadata signals as described above.
Moreover, the system comprises an apparatus 100 for receiving the one or more encoded audio signals and the one or more processed metadata signals, and for generating one or more audio channels depending on the one or more encoded audio signals and depending on the one or more processed metadata signals as described above.
For example, the one or more encoded audio signals may be decoded by the apparatus 100 for generating one or more audio channels by employing a SAOC decoder according to the state of the art to obtain one or more audio object signals, when the apparatus 250 for encoding did use a SAOC encoder for encoding the one or more audio objects.
Embodiments are based on the finding, that concepts of the Differential Pulse Code Modulation may be extended, and, such extended concepts are then suitable to encode metadata signals for audio objects.
The Differential Pulse Code Modulation (DPCM) method is an established method for slowly varying time signals that reduces irrelevance via quantization and redundancy via a differential transmission [10]. A DPCM encoder is shown in
In the DPCM encoder of
d(n) is then quantized in quantizer 620 to obtain another output sample y(n) of the output signal y. In general, y(n) is either equal to d(n) or a value close to d(n).
Moreover, y(n) is fed into adder 630. Furthermore, x* (n−1) is fed into the adder 630. As d(n) results from the subtraction d(n)=x(n)-x*(n−1), and as y(n) is a value equal to or at least close to d(n), the output x*(n) of the adder 630 is equal to x(n) or at least close to x(n).
x* (n) is held for a sampling period in unit 640, and then, processing is continued with the next sample x(n+1).
In
x′(n) is hold for a sampling period in unit 740, and then, processing is continued with the next sample y(n+1).
While a DPCM compression method fulfills most of the previously stated necessitated features, it does not allow for random access.
The encoding method employed by the metadata encoder 801 of
The metadata encoder 801 of
In an embodiment, each of the N DPCM encoders is configured to receive the metadata samples xi(n) of one of the N original metadata signals x1, . . . , xN, and generates a difference value as difference sample yi(n) of a metadata difference signal yi for each of the metadata samples xi(n) of said original metadata signal xi, which is fed into said DPCM encoder. In an embodiment, generating the difference sample yi(n) may, for example, be conducted as described with reference to
The metadata encoder 801 of
The selector 830 is moreover, configured to receive the N metadata difference signals y1 . . . yN.
Furthermore, in the embodiment of
The selector 830 may be configured to generate processed metadata signals zi from the quantized metadata signals qi and from the DPCM encoded difference metadata signals yi depending on the control signal b(n).
For example, when the control signal b is in a first state (e.g., b(n)=0), the selector 830 may be configured to output the difference samples yi(n) of the metadata difference signals yi as metadata samples zi(n) of the processed metadata signals zi.
When the control signal b is in a second state, being different from the first state (e.g., b(n)=1), the selector 830 may be configured to output the metadata samples qi(n) of the quantized metadata signals qi as metadata samples zi(n) of the processed metadata signals zi.
In the embodiment of
In such an embodiment, when, for example, the control signal b is in a first state (e.g., b(n)=0), the selector 830 may be configured to output the difference samples yi(n) of the metadata difference signals yi as metadata samples zi(n) of the processed metadata signals zi.
When the control signal b is in a second state, being different from the first state (e.g., b(n)=1), the selector 830 may be configured to output the metadata samples xi(n) of the original metadata signals xi as metadata samples zi(n) of the processed metadata signals zi.
The metadata decoder 901 of
In an embodiment, each of the N processed metadata signals z1, . . . , zN is fed into a different one of the metadata decoder subunits 911, . . . , 91N. Moreover, according to an embodiment, the control signal b is fed into each of the metadata decoder subunits 911, . . . , 91N. According to an embodiment, the number of metadata decoder subunits 911, . . . , 91N is identical to the number of processed metadata signals z1, . . . , zN that are received be the metadata decoder 901.
The metadata decoder subunit 91i is configured to generate the reconstructed metadata signal xi′ from the received processed metadata signal zi depending on the control signal b(n).
This may, for example, be realized as follows:
The last reconstructed metadata sample xi′(n−1) of the reconstructed metadata signal xi′ is fed into the adder 910. Moreover, the actual metadata sample zi(n) of the processed metadata signal zi is also fed into the adder 910. The adder is configured to add the last reconstructed metadata sample xi′(n−1) and the actual metadata sample zi(n). to obtain a sum value si(n) which is fed into the selector 930.
Moreover, the actual metadata sample zi(n) is also fed into the adder 930.
The selector is configured to select either the sum value si(n) from the adder 910 or the actual metadata sample zi(n) as the actual metadata sample xi′(n) of the reconstructed metadata signal xi′(n) depending on the contral signal b.
When, for example, the control signal b is in a first state (e.g., b(n)=0), the control signal b indicates that the actual metadata sample zi(n) is a difference value, and so, the sum value si(n) is the correct actual metadata sample xi′(n) of the reconstructed metadata signal xi′. The selector 830 is configured to select the sum value si(n) as the actual metadata sample xi′(n) of the reconstructed metadata signal xi′, when the control signal is in the first state (when b(n)=0).
When the control signal b is in a second state, being different from the first state (e.g., b(n)=1), the control signal b indicates that the actual metadata sample zi(n) is not a difference value, and so, the actual metadata sample zi(n) is the correct actual metadata sample xi′(n) of the reconstructed metadata signal xi′. The selector 830 is configured to select the actual metadata sample zi(n) as the actual metadata sample xi′(n) of the reconstructed metadata signal xi′, when the control signal is in the second state (when b(n)=1).
According to embodiments, the metadata decoder subunit 91i′ further comprises a unit 920. Unit 920 is configured to hold the actual metadata sample xi′(n) of the reconstructed metadata signal for the duration of a sampling period. In an embodiment, this ensures, that when xi′(n) is being generated, the generated x′(n) is not fed back too early, so that when zi(n) is a difference value, xi′(n) is really generated based on xi′(n−1).
In an embodiment of
In the following, the DPCM encoded signals are denoted as yi(n) and the second input signal (the sum signal) of B as si(n). For output components that only depend on the corresponding input components, the encoder and decoder output is given as follows:
z
i(n)=A(xi(n),vi(n),b(n))
x
i′(n)=B(zi(n),si(n),b(n))
A solution according to an embodiment for the general approach sketched above is to use b(n) to switch between the DPCM encoded signal and the quantized input signal. Omitting the time index n for simplicity reasons, the function blocks A and B are then given as follows:
In the metadata encoders 801, 802, the selector 830 (A) selects:
In the metadata decoder subunits 91i, 91i′, the selector 930 (B) selects:
This allows to transmit the quantized input signal whenever b(n) is equal to 1 and to transmit a DPCM signal whenever b(n) is 0. In the latter case, the decoder becomes a DPCM decoder.
When applied for the transmission of object metadata, this mechanism is used to regularly transmit uncompressed object positions which can be used by the decoder for random access.
In embodiments, fewer bits are used for encoding the difference values than the number of bits used for encoding the metadata samples. These embodiments are based on the finding that (e.g., N) subsequent metadata samples in most times only vary slightly. For example, if one kind of metadata samples is encoded, e.g., by 8 bits, these metadata samples can take on one out of 256 different values. Because of the, in general, slight changes of (e.g., N) subsequent metadata values, it may be considered sufficient, to encode the difference values only, e.g., by 5 bits. Thus, even if difference values are transmitted, the number of transmitted bits can be reduced.
In an embodiment, the metadata encoder 210 is configured to encode each of the processed metadata samples (zi(1), . . . , zi(n)) of one zi ( ) of the one or more processed metadata signals (z1, . . . , zN) with a first number of bits when the control signal indicates the first state (b(n)=0), and with a second number of bits when the control signal indicates the second state (b(n)=1), wherein the first number of bits is smaller than the second number of bits.
In an embodiment, one or more difference values are transmitted, each of the one or more difference values is encoded with fewer bits than each of the metadata samples, and each of the difference value is an integer value.
According to an embodiment, the metadata encoder 110 is configured to encode one or more of the metadata samples of one of the one or more processed metadata signals with a first number of bits, wherein each of said one or more of the metadata samples of said one of the one or more processed metadata signals indicates an integer. Moreover metadata encoder (110) is configured to encode one or more of the difference values with a second number of bits, wherein each of said one or more of the difference values indicates an integer, wherein the second number of bits is smaller than the first number of bits.
Consider, for example, that in an embodiment, metadata samples may represent an azimuth being encoded by 8 bits. E.g., the azimuth may be an integer between −90≤azimuth≤90. Thus, the azimuth can take on 181 different values. If however, one can assume that (e.g. N) subsequent azimuth samples only differ by no more than, e.g., ±15, then, 5 bits (25=32) may be enough to encode the difference values. If difference values are represented as integers, then determining the difference values automatically transforms the additional values, to be transmitted, to a suitable value range.
For example, consider a case where a first azimuth value of a first audio object is 60° and its subsequent values vary from 45° to 75°. Moreover, consider that a second azimuth value of a second audio object is −30° and its subsequent values vary from −45° to −15°. By determining difference values for both the subsequent values of the first audio object and for both the subsequent values of the second audio object, the difference values of the first azimuth value and of the second azimuth value are both in the value range from −15° to +15°, so that 5 bits are sufficient to encode each of the difference values and so that the bit sequence, which encodes the difference values, has the same meaning for difference values of the first azimuth angle and difference values of the second azimuth value.
In the following, object metadata frames according to embodiments and symbol representation according to embodiments are described.
The encoded object metadata is transmitted in frames. These object metadata frames may contain either intracoded object data or dynamic object data where the latter contains the changes since the last transmitted frame.
Some or all portions of the following syntax for object metadata frames may, for example, be employed:
In the following, intracoded object data according to an embodiment is described.
Random access of the encoded object metadata is realized via intracoded object data (“I-Frames”) which contain the quantized values sampled on a regular grid (e.g. every 32 frames of length 1024). These I-Frames may, for example, have the following syntax, where position_azimuth, position_elevation, position_radius, and gain_factor specify the current quantized values:
In the following, dynamic object data according to an embodiment is described.
DPCM data is transmitted in dynamic object frames which may, for example, have the following syntax:
In particular, in an embodiment, the above macros may, e.g., have the following meaning:
Definition of object_data( ) payloads according to an embodiment:
Definition of intracoded_object_metadata( ) payloads according to an embodiment:
Definition of dynamic_object_metadata( ) payloads according to an embodiment:
Definition of single_dynamic_object_metadata( ) payloads according to an embodiment:
In conventional technology, no flexible technology exists combining channel coding on the one hand and object coding on the other hand so that acceptable audio qualities at low bit rates are obtained.
This limitation is overcome by the 3D Audio Codec System. Now, the 3D Audio Codec System is described.
Furthermore, the 3D audio encoder comprises a core encoder 300 for core encoding core encoder input data, a metadata compressor 400 for compressing the metadata related to the one or more of the plurality of audio objects.
Furthermore, the 3D audio encoder can comprise a mode controller 600 for controlling the mixer, the core encoder and/or an output interface 500 in one of several operation modes, wherein in the first mode, the core encoder is configured to encode the plurality of audio channels and the plurality of audio objects received by the input interface 1100 without any interaction by the mixer, i.e., without any mixing by the mixer 200. In a second mode, however, in which the mixer 200 was active, the core encoder encodes the plurality of mixed channels, i.e., the output generated by block 200. In this latter case, it is advantageous to not encode any object data anymore. Instead, the metadata indicating positions of the audio objects are already used by the mixer 200 to render the objects onto the channels as indicated by the metadata. In other words, the mixer 200 uses the metadata related to the plurality of audio objects to pre-render the audio objects and then the pre-rendered audio objects are mixed with the channels to obtain mixed channels at the output of the mixer. In this embodiment, any objects may not necessarily be transmitted and this also applies for compressed metadata as output by block 400. However, if not all objects input into the interface 1100 are mixed but only a certain amount of objects is mixed, then only the remaining non-mixed objects and the associated metadata nevertheless are transmitted to the core encoder 300 or the metadata compressor 400, respectively.
In
Furthermore, as illustrated in
In
The
In addition to the first and the second modes as discussed in the context of
Finally, the SAOC encoder 800 can encode, when the 3D audio encoder is configured in the fourth mode, the channels plus pre-rendered objects as generated by the pre-renderer/mixer. Thus, in the fourth mode the lowest bit rate applications will provide good quality due to the fact that the channels and objects have completely been transformed into individual SAOC transport channels and associated side information as indicated in
In
According to an embodiment, an apparatus for encoding audio input data 101 to obtain audio output data 501 is provided. The apparatus for encoding audio input data 101 comprises:
The audio encoder 220 of the apparatus 250 for generating encoded audio information is a core encoder (300) for core encoding core encoder input data.
The metadata encoder 210 of the apparatus 250 for generating encoded audio information is a metadata compressor 400 for compressing the metadata related to the one or more of the plurality of audio objects.
The 3D audio decoder comprises a metadata decompressor 1400, a core decoder 1300, an object processor 1200, a mode controller 1600 and a postprocessor 1700.
Specifically, the 3D audio decoder is configured for decoding encoded audio data and the input interface is configured for receiving the encoded audio data, the encoded audio data comprising a plurality of encoded channels and the plurality of encoded objects and compressed metadata related to the plurality of objects in a certain mode.
Furthermore, the core decoder 1300 is configured for decoding the plurality of encoded channels and the plurality of encoded objects and, additionally, the metadata decompressor is configured for decompressing the compressed metadata.
Furthermore, the object processor 1200 is configured for processing the plurality of decoded objects as generated by the core decoder 1300 using the decompressed metadata to obtain a predetermined number of output channels comprising object data and the decoded channels. These output channels as indicated at 1205 are then input into a postprocessor 1700. The postprocessor 1700 is configured for converting the number of output channels 1205 into a certain output format which can be a binaural output format or a loudspeaker output format such as a 5.1, 7.1, etc., output format.
The 3D audio decoder comprises a mode controller 1600 which is configured for analyzing the encoded data to detect a mode indication. Therefore, the mode controller 1600 is connected to the input interface 1100 in
The indication whether mode 1 or mode 2 is to be applied is included in the encoded audio data and then the mode controller 1600 analyses the encoded data to detect a mode indication. Mode 1 is used when the mode indication indicates that the encoded audio data comprises encoded channels and encoded objects and mode 2 is applied when the mode indication indicates that the encoded audio data does not contain any audio objects, i.e., only contain pre-rendered channels obtained by mode 2 of the
In
Furthermore, the postprocessor 1700 can be implemented as a binaural renderer 1710 or a format converter 1720. Alternatively, a direct output of data 1205 of
In an embodiment of the present invention, the object processor 1200 comprises the SAOC decoder 1800 and the SAOC decoder is configured for decoding one or more transport channels output by the core decoder and associated parametric data and using decompressed metadata to obtain the plurality of rendered audio objects. To this end, the OAM output is connected to box 1800.
Furthermore, the object processor 1200 is configured to render decoded objects output by the core decoder which are not encoded in SAOC transport channels but which are individually encoded in typically single channeled elements as indicated by the object renderer 1210. Furthermore, the decoder comprises an output interface corresponding to the output 1730 for outputting an output of the mixer to the loudspeakers.
In a further embodiment, the object processor 1200 comprises a spatial audio object coding decoder 1800 for decoding one or more transport channels and associated parametric side information representing encoded audio signals or encoded audio channels, wherein the spatial audio object coding decoder is configured to transcode the associated parametric information and the decompressed metadata into transcoded parametric side information usable for directly rendering the output format, as for example defined in an earlier version of SAOC. The postprocessor 1700 is configured for calculating audio channels of the output format using the decoded transport channels and the transcoded parametric side information. The processing performed by the post processor can be similar to the MPEG Surround processing or can be any other processing such as BCC processing or so.
In a further embodiment, the object processor 1200 comprises a spatial audio object coding decoder 1800 configured to directly upmix and render channel signals for the output format using the decoded (by the core decoder) transport channels and the parametric side information
Furthermore, and importantly, the object processor 1200 of
The mixer 1220 is connected to the output interface 1730, the binaural renderer 1710 and the format converter 1720. The binaural renderer 1710 is configured for rendering the output channels into two binaural channels using head related transfer functions or binaural room impulse responses (BRIR). The format converter 1720 is configured for converting the output channels into an output format having a lower number of channels than the output channels 1205 of the mixer and the format converter 1720 necessitates information on the reproduction layout such as 5.1 speakers or so.
In
The
Furthermore, a vector base amplitude panning (VBAP) stage 1810 is configured which receives, from the SAOC decoder, information on the reproduction layout and which outputs a rendering matrix to the SAOC decoder so that the SAOC decoder can, in the end, provide rendered channels without any further operation of the mixer in the high channel format of 1205, i.e., 32 loudspeakers.
the VBAP block receives the decoded OAM data to derive the rendering matrices. More general, it necessitates geometric information not only of the reproduction layout but also of the positions where the input signals should be rendered to on the reproduction layout. This geometric input data can be OAM data for objects or channel position information for channels that have been transmitted using SAOC.
However, if only a specific output interface is necessitated then the VBAP state 1810 can already provide the necessitated rendering matrix for the e.g., 5.1 output. The SAOC decoder 1800 then performs a direct rendering from the SAOC transport channels, the associated parametric data and decompressed metadata, a direct rendering into the necessitated output format without any interaction of the mixer 1220. However, when a certain mix between modes is applied, i.e., where several channels are SAOC encoded but not all channels are SAOC encoded or where several objects are SAOC encoded but not all objects are SAOC encoded or when only a certain amount of pre-rendered objects with channels are SAOC decoded and remaining channels are not SAOC processed then the mixer will put together the data from the individual input portions, i.e., directly from the core decoder 1300, from the object renderer 1210 and from the SAOC decoder 1800.
In
An apparatus for decoding encoded audio data is provided. The apparatus for decoding encoded audio data comprises:
The metadata decoder 110 of the apparatus 100 for generating one or more audio channels is a metadata decompressor 400 for decompressing the compressed metadata.
The audio channel generator 120 of the apparatus 100 for generating one or more audio channels comprises a core decoder 1300 for decoding the plurality of encoded channels and the plurality of encoded objects.
Moreover, the audio channel generator 120 further comprises an object processor 1200 for processing the plurality of decoded objects using the decompressed metadata to obtain a number of output channels 1205 comprising audio data from the objects and the decoded channels.
Furthermore, the audio channel generator 120 further comprises a post processor 1700 for converting the number of output channels 1205 into an output format.
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.
The inventive decomposed signal can be stored on a digital storage medium or can be transmitted on a transmission medium such as a wireless transmission medium or a wired transmission medium such as the Internet.
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 non-transitory 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, stored on a machine readable carrier.
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 for example be configured 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 to 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 performed by any hardware apparatus.
While this invention has been described in terms of several advantageous embodiments, there are alterations, permutations, and equivalents which fall within the scope of this invention. It should also be noted that there are many alternative ways of implementing the methods and compositions of the present invention. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations, and equivalents as fall within the true spirit and scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
13177365 | Jul 2013 | EP | regional |
13177367 | Jul 2013 | EP | regional |
13177378 | Jul 2013 | EP | regional |
13189279 | Oct 2013 | EP | regional |
This application is a continuation of copending U.S. application Ser. No. 16/360,776, filed Mar. 21, 2019, which is a continuation of copending U.S. application Ser. No. 15/695,791, filed Sep. 5, 2017, which is a continuation of copending U.S. application Ser. No. 15/002,127, filed Jan. 20, 2016, which in turn is a continuation of copending International Application No. PCT/EP2014/065283, filed Jul. 16, 2014, which are all incorporated herein by reference in their entirety, and additionally claims priority from European Applications Nos. EP13177365, filed Jul. 22, 2013, EP13177367, filed Jul. 22, 2013, EP13177378, filed Jul. 22, 2013 and EP13189279, filed Oct. 18, 2013, which are all incorporated herein by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 16360776 | Mar 2019 | US |
Child | 16810538 | US | |
Parent | 15695791 | Sep 2017 | US |
Child | 16360776 | US | |
Parent | 15002127 | Jan 2016 | US |
Child | 15695791 | US | |
Parent | PCT/EP2014/065283 | Jul 2014 | US |
Child | 15002127 | US |