Embodiments according to the invention are related to an audio signal decoder for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information.
Further embodiments according to the invention are related to a method for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information.
Further embodiments according to the invention are related to a computer program.
Some embodiments according to the invention are related to an enhanced Karaoke/Solo SAOC system.
In modern audio systems, it is desired to transfer and store audio information in a bitrate-efficient way. In addition, it is often desired to reproduce an audio content using a plurality of two or even more speakers, which are spatially distributed in a room. In such cases, it is desired to exploit the capabilities of such a multi-speaker arrangement to allow for a user to spatially identify different audio contents or different items of a single audio content. This may be achieved by individually distributing the different audio contents to the different speakers.
In other words, in the art of audio processing, audio transmission and audio storage, there is an increasing desire to handle multi-channel contents in order to improve the hearing impression. Usage of multi-channel audio content brings along significant improvements for the user. For example, a 3-dimensional hearing impression can be obtained, which brings along an improved user satisfaction in entertainment applications. However, multi-channel audio contents are also useful in professional environments, for example in telephone conferencing applications, because the speaker intelligibility can be improved by using a multi-channel audio playback.
However, it is also desirable to have a good tradeoff between audio quality and bitrate requirements in order to avoid an excessive resource load caused by multi-channel applications.
Recently, parametric techniques for the bitrate-efficient transmission and/or storage of audio scenes containing multiple audio objects has been proposed, for example, Binaural Cue Coding (Type I) (see, for example reference [BCC]), Joint Source Coding (see, for example, reference [JSC]), and MPEG Spatial Audio Object Coding (SAOC) (see, for example, references [SAOC1], [SAOC2]).
These techniques aim at perceptually reconstructing the desired output audio scene rather than by a waveform match.
The SAOC decoder 820 is configured to receive both the one or more downmix signals 812 and the side information 814. Also, the SAOC decoder 820 is typically configured to receive a user interaction information and/or a user control information 822, which describes a desired rendering setup. For example, the user interaction information/user control information 822 may describe a speaker setup and the desired spatial placement of the objects provided by the object signals x1 to xN.
The SAOC decoder 820 is configured to provide, for example, a plurality of decoded upmix channel signals ŷ1 to ŷM. The upmix channel signals may for example be associated with individual speakers of a multi-speaker rendering arrangement. The SAOC decoder 820 may, for example, comprise an object separator 820a, which is configured to reconstruct, at least approximately, the object signals x1 to xN on the basis of the one or more downmix signals 812 and the side information 814, thereby obtaining reconstructed object signals 820b. However, the reconstructed object signals 820b may deviate somewhat from the original object signals x1 to xN, for example, because the side information 814 is not quite sufficient for a perfect reconstruction due to the bitrate constraints. The SAOC decoder 820 may further comprise a mixer 820c, which may be configured to receive the reconstructed object signals 820b and the user interaction information/user control information 822, and to provide, on the basis thereof, the upmix channel signals ŷ1 to ŷM. The mixer 820c may be configured to use the user interaction information/user control information 822 to determine the contribution of the individual reconstructed object signals 820b to the upmix channel signals ŷ1 to ŷM. The user interaction information/user control information 822 may, for example, comprise rendering parameters (also designated as rendering coefficients), which determine the contribution of the individual reconstructed object signals 820b to the upmix channel signals ŷ1 to ŷM.
However, it should be noted that in many embodiments, the object separation, which is indicated by the object separator 820a in
Taking reference now to
Taking reference now to
To summarize the above, the provision of the upmix channel signals 928, 958 can be performed in a one step process or a two-step process.
Taking reference now to
The SAOC to MPEG Surround transcoder comprises a side information transcoder 982, which is configured to receive the object-related side information (for example, in the form of object meta data) and, optionally, information on the one or more downmix signals and the rendering information. The side information transcoder is also configured to provide an MPEG Surround side information 984 (for example, in the form of an MPEG Surround bitstream) on the basis of a received data. Accordingly, the side information transcoder 982 is configured to transform an object-related (parametric) side information, which is relieved from the object encoder, into a channel-related (parametric) side information 984, taking into consideration the rendering information and, optionally, the information about the content of the one or more downmix signals.
Optionally, the SAOC to MPEG Surround transcoder 980 may be configured to manipulate the one or more downmix signals, described, for example, by the downmix signal representation, to obtain a manipulated downmix signal representation 988. However, the downmix signal manipulator 986 may be omitted, such that the output downmix signal representation 988 of the SAOC to MPEG Surround transcoder 980 is identical to the input downmix signal representation of the SAOC to MPEG Surround transcoder. The downmix signal manipulator 986 may, for example, be used if the channel-related MPEG Surround side information 984 would not allow to provide a desired hearing impression on the basis of the input downmix signal representation of the SAOC to MPEG Surround transcoder 980, which may be the case in some rendering constellations.
Accordingly, the SAOC to MPEG Surround transcoder 980 provides the downmix signal representation 988 and the MPEG Surround bitstream 984 such that a plurality of upmix channel signals, which represent the audio objects in accordance with the rendering information input to the SAOC to MPEG Surround transcoder 980 can be generated using an MPEG Surround decoder which receives the MPEG Surround bitstream 984 and the downmix signal representation 988.
To summarize the above, different concepts for decoding SAOC-encoded audio signals can be used. In some cases, an SAOC decoder is used, which provides upmix channel signals (for example, upmix channel signals 928, 958) in dependence on the downmix signal representation and the object-related parametric side information. Examples for this concept can be seen in
In the MPEG SAOC system 800, a system overview of which is given in
It has been found that such a scheme is tremendously efficient, both in terms of transmission bitrate (it is only necessitated to transmit a few downmix channels plus some side information instead of N discrete object audio signals or a discrete system) and computational complexity (the processing complexity relates mainly to the number of output channels rather than the number of audio objects). Further advantages for the user on the receiving end include the freedom of choosing a rendering setup of his/her choice (mono, stereo, surround, virtualized headphone playback, and so on) and the feature of user interactivity: the rendering matrix, and thus the output scene, can be set and changed interactively by the user according to will, personal preference or other criteria. For example, it is possible to locate the talkers from one group together in one spatial area to maximize discrimination from other remaining talkers. This interactivity is achieved by providing a decoder user interface.
For each transmitted sound object, its relative level and (for non-mono rendering) spatial position of rendering can be adjusted. This may happen in real-time as the user changes the position of the associated graphical user interface (GUI) sliders (for example: object level=+5 dB, object position=−30 deg).
However, it has been found that it is difficult to handle audio objects of different audio object types in such a system. In particular, it has been found that it is difficult to process audio objects of different audio object types, for example, audio objects to which different side information is associated, if the total number of audio objects to be processed is not predetermined.
According to an embodiment, an audio signal decoder for providing an upmix signal representation in dependence on a downmix signal representation, an object-related parametric information, may have: an object separator configured to decompose the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type, and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information, wherein the second audio information is an audio information describing the audio objects of the second audio object type in a combined manner; an audio signal processor configured to receive the second audio information and to process the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information; and an audio signal combiner configured to combine the first audio information with the processed version of the second audio information, to obtain the upmix signal representation; wherein the audio signal decoder is configured to provide the upmix signal representation in dependence on a residual information associated to a subset of audio objects represented by the downmix signal representation, wherein the object separator is configured to decompose the downmix signal representation to provide the first audio information describing a first set of one or more audio objects of a first audio object type to which residual information is associated, and the second audio information describing a second set of one or more audio objects of a second audio object type, to which no residual information is associated, in dependence on the downmix signal representation and using the residual information; and wherein the audio signal processor is configured to process the second audio information, to perform an object-individual processing of the audio objects of the second audio object type, taking into consideration object-related parametric information associated with more than two audio objects of the second audio object type; and wherein the residual information describes a residual distortion, which is expected to remain if an audio object of the first audio object type is isolated merely using the object-related parametric information.
According to another embodiment, a method for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information may have the steps of: decomposing the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type, and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information, wherein the second audio information is an audio information describing the audio objects of the second audio object type in a combined manner; and processing the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information; and combining the first audio information with the processed version of the second audio information, to obtain the upmix signal representation; wherein the upmix signal representation is provided in dependence on a residual information associated to a subset of audio objects represented by the downmix signal representation, wherein the downmix signal representation is decomposed, to provide the first audio information describing a first set of one or more audio objects of a first audio object type to which residual information is associated, and the second audio information describing a second set of one or more audio objects of a second audio object type, to which no residual information is associated, in dependence on the downmix signal representation and using the residual information; wherein an object-individual processing of the audio objects of the second audio object type is performed, taking into consideration object-related parametric information associated with more than two audio objects of the second audio object type; and wherein the residual information describes a residual distortion, which is expected to remain if an audio object of the first audio object type is isolated merely using the object-related parametric information.
According to another embodiment, an audio signal decoder for providing an upmix signal representation in dependence on a downmix signal representation, an object-related parametric information, may have: an object separator configured to decompose the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type, and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information; an audio signal processor configured to receive the second audio information and to process the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information; and an audio signal combiner configured to combine the first audio information with the processed version of the second audio information, to obtain the upmix signal representation; wherein the object separator is configured to obtain the first audio information and the second audio information according to
wherein MPrediction={tilde over (D)}−1C, wherein
wherein XOBJ represent channels of the second audio information; wherein XEAO represent object signals of the first audio information; wherein {tilde over (D)}−1 represents a matrix which is an inverse of an extended downmix matrix; wherein C describes a matrix representing a plurality of channel prediction coefficients, {tilde over (c)}j,0, {tilde over (c)}j,1; wherein l0 and r0 represent channels of the downmix signal representation; wherein res0 to resN
wherein the object separator is configured to obtain the matrix C as
wherein m0 to mN
wherein the object separator is configured to derive constrained prediction coefficients cj,0 and cj,1 from the prediction coefficients {tilde over (c)}j,0 and {tilde over (c)}j,1 using a constraining algorithm, or to use the prediction coefficients {tilde over (c)}j,0 and {tilde over (c)}j,1 as the prediction coefficients cj,0 and cj,1; wherein energy quantities PLo, PRo, PLoRo, PLoCo,j and PRoCo,j are defined as
wherein parameters OLDL, OLDR and IOCL,R correspond to audio objects of the second audio object type and are defined according to
wherein d0,i and d1,i are downmix values associated with the audio objects of the second audio object type; wherein OLDi are object level difference values associated with the audio objects of the second audio object type; wherein N is a total number of audio objects; wherein NEAO is a number of audio objects of the first audio object type; wherein IOC0,1 is an inter-object-correlation value associated with a pair of audio objects of the second audio object type; wherein ei,j and eL,R are covariance values derived from object-level-difference parameters and inter-object-correlation parameters; and wherein ei,j are associated with a pair of audio objects of the 1st audio object type and eL,R is associated with a pair of audio objects of the second audio object type.
According to another embodiment, an audio signal decoder for providing an upmix signal representation in dependence on a downmix signal representation, an object-related parametric information, may have: an object separator configured to decompose the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type, and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information; an audio signal processor configured to receive the second audio information and to process the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information; and an audio signal combiner configured to combine the first audio information with the processed version of the second audio information, to obtain the upmix signal representation; wherein the object separator is configured to obtain the first audio information and the second audio information according to
wherein XOBJ represent channels of the second audio information; wherein XEAO represent object signals of the first audio information; wherein
wherein m0 to mNEAO-1 are downmix values associated with the audio objects of the first audio object type; wherein n0 to nN
According to another embodiment, an audio signal decoder for providing an upmix signal representation in dependence on a downmix signal representation, an object-related parametric information, may have: an object separator configured to decompose the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type, and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information; an audio signal processor configured to receive the second audio information and to process the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information; and an audio signal combiner configured to combine the first audio information with the processed version of the second audio information, to obtain the upmix signal representation; wherein the object separator is configured to obtain the first audio information and the second audio information according to
XOBJ=MOBJEnergy(d0)
XEAO=AEAOMEAOEnergy(d0)
wherein XOBJ represents a channel of the second audio information; wherein XEAO represent object signals of the first audio information; wherein
wherein m0 to mNEAO-1 are downmix values associated with the audio objects of the first audio object type; wherein OLDi are object level difference values associated with the audio objects of the first audio object type; wherein OLDL is a common object level difference value associated with the audio objects of the second audio object type; and
wherein AEAO is a EAO pre-rendering matrix; wherein the matrices MOBJEnergy and MEAOEnergy are applied to a representation d0 of a single SAOC downmix signal.
According to another embodiment, a method for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information, may have the steps of decomposing the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type, and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information; and processing the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information; and combining the first audio information with the processed version of the second audio information, to obtain the upmix signal representation; wherein the first audio information and the second audio information are obtained according to
wherein MPrediction={tilde over (D)}−1C, wherein
wherein XOBJ represent channels of the second audio information; wherein XEAO represent object signals of the first audio information; wherein {tilde over (D)}−1 represents a matrix which is an inverse of an extended downmix matrix; wherein C describes a matrix representing a plurality of channel prediction coefficients, {tilde over (c)}j,0, {tilde over (c)}j,1; wherein l0 and r0 represent channels of the downmix signal representation; wherein res0 to resN
wherein the matrix C is obtained as
wherein m0 to mN
wherein constrained prediction coefficients cj,0 and cj,1 are derived from the prediction coefficients {tilde over (c)}j,0 and {tilde over (c)}j,1 using a constraining algorithm, or wherein the prediction coefficients {tilde over (c)}j,0 and {tilde over (c)}j,1 are used as the prediction coefficients cj,0 and cj,1; wherein energy quantities PLo, PRo, PLoRo, PLoCo,j and PRoCo,j are defined as
wherein parameters OLDL, OLDR and IOCL,R correspond to audio objects of the second audio object type and are defined according to
wherein d0,i and d1,i are downmix values associated with the audio objects of the second audio object type; wherein OLDi are object level difference values associated with the audio objects of the second audio object type; wherein N is a total number of audio objects; wherein NEAO is a number of audio objects of the first audio object type; wherein IOC0,1 is an inter-object-correlation value associated with a pair of audio objects of the second audio object type; wherein ei,j and eL,R are covariance values derived from object-level-difference parameters and inter-object-correlation parameters; and wherein ei,j are associated with a pair of audio objects of the 1st audio object type and eL,R is associated with a pair of audio objects of the second audio object type.
According to another embodiment, a method for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information may have the steps of decomposing the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type, and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information; and processing the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information; and combining the first audio information with the processed version of the second audio information, to obtain the upmix signal representation; wherein the first audio information and the second audio information are obtained according to
wherein XOBJ represent channels of the second audio information; wherein XEAO represent object signals of the first audio information; wherein
wherein m0 to mNEAO-1 are downmix values associated with the audio objects of the first audio object type; wherein n0 to nN
According to another embodiment, a method for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information may have the steps of: decomposing the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type, and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information; and processing the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information; and combining the first audio information with the processed version of the second audio information, to obtain the upmix signal representation; wherein the first audio information and the second audio information are obtained according to
XOBJ=MOBJEnergy(d0)
XEAO=AEAOMEAOEnergy(d0)
wherein XOBJ represents a channel of the second audio information; wherein XEAO represent object signals of the first audio information; wherein
wherein m0 to mNEAO-1 are downmix values associated with the audio objects of the first audio object type; wherein OLDi are object level difference values associated with the audio objects of the first audio object type; wherein OLDL is a common object level difference value associated with the audio objects of the second audio object type; and wherein AEAO is a EAO pre-rendering matrix; wherein the matrices MOBJEnergy and MEAOEnergy are applied to a representation d0 of a single SAOC downmix signal.
Another embodiment may have a computer program for performing the inventive methods when the computer program runs on a computer.
An embodiment according to the invention creates an audio signal decoder for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information. The audio signal decoder comprises an object separator configured to decompose the downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and using at least a part of the object-related parametric information. The audio signal decoder also comprises an audio signal processor configured to receive the second audio information and to process the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information. The audio signal decoder also comprises an audio signal combiner configured to combine the first audio information with the processed version of the second audio information to obtain the upmix signal representation.
It is a key idea of the present invention that an efficient processing of different types of audio objects can be obtained in a cascaded structure, which allows for a separation of the different types of audio objects using at least a part of the object-related parametric information in a first processing step performed by the object separator, and which allows for an additional spatial processing in a second processing step performed in dependence on at least a part of the object-related parametric information by the audio signal processor. It has been found that extracting a second audio information, which comprises audio objects of the second audio object type, from a downmix signal representation can be performed with a moderate complexity even if there is a larger number of audio objects of the second audio object type. In addition, it has been found that a spatial processing of the audio objects of the second audio type can be performed efficiently once the second audio information is separated from the first audio information describing the audio objects of the first audio object type.
Additionally, it has been found that the processing algorithm performed by the object separator for separating the first audio information and the second audio information can be performed with comparatively small complexity if the object-individual processing of the audio objects of the second audio object type is postponed to the audio signal processor and not performed at the same time as the separation of the first audio information and the second audio information.
In an embodiment, the audio signal decoder is configured to provide the upmix signal representation in dependence on the downmix signal representation, the object-related parametric information and a residual information associated to a sub-set of audio objects represented by the downmix signal representation. In this case, the object separator is configured to decompose the downmix signal representation to provide the first audio information describing the first set of one or more audio objects (for example, foreground objects FGO) of the first audio object type to which residual information is associated and the second audio information describing the second set of one or more audio objects (for example, background objects BGO) of the second audio object type to which no residual information is associated in dependence on the downmix signal representation and using at least part of the object-related parametric information and the residual information.
This embodiment is based on the finding that a particularly accurate separation between the first audio information describing the first set of audio objects of the first audio object type and the second audio information describing the second set of audio objects of the second audio object type can be obtained by using a residual information in addition to the object-related parametric information. It has been found that the mere use of the object-related parametric information would result in distortions in many cases, which can be reduced significantly or even entirely eliminated by the use of residual information. The residual information describes, for example, a residual distortion, which is expected to remain if an audio object of the first audio object type is isolated merely using the object-related parametric information. The residual information is typically estimated by an audio signal encoder. By applying the residual information, the separation between the audio objects of the first audio object type and the audio objects of the second audio object type can be improved.
This allows to obtain the first audio information and the second audio information with particularly good separation between the audio objects of the first audio object type and the audio objects of the second audio object type, which, in turn, allows to achieve a high-quality spatial processing of the audio objects of the second audio object type when processing the second audio information in the audio signal processor.
In an embodiment, the object separator is therefore configured to provide the first audio information such that audio objects of the first audio object type are emphasized over audio objects of the second audio object type in the first audio information. The object separator is also configured to provide the second audio information such that audio objects of the second audio object type are emphasized over audio objects of the first audio object type in the second audio information.
In an embodiment, the audio signal decoder is configured to perform a two-step processing, such that a processing of the second audio information in the audio signal processor is performed subsequently to a separation between the first audio information describing the first set of one or more audio objects of the first audio object type and the second audio information describing the second set of one or more audio objects of the second audio object type.
In an embodiment, the audio signal processor is configured to process the second audio information in dependence on the object-related parametric information associated with the audio objects of the second audio object type and independent from the object-related parametric information associated with the audio objects of the first audio object type. Accordingly, a separate processing of the audio objects of the first audio object type and the audio objects of the second audio object type can be obtained.
In an embodiment, the object separator is configured to obtain the first audio information and the second audio information using a linear combination of one or more downmix channels and one or more residual channels. In this case, the object separator is configured to obtain combination parameters for performing the linear combination in dependence on downmix parameters associated with the audio objects of the first audio object type and in dependence on channel prediction coefficients of the audio objects of the first audio object type. The computation of the channel prediction coefficients of the audio objects of the first audio object type may, for example, take into consideration the audio objects of the second audio object type as a single, common audio object. Accordingly, a separation process can be performed with sufficiently small computational complexity, which may, for example, be almost independent from the number of audio objects of the second audio object type.
In an embodiment, the object separator is configured to apply a rendering matrix to the first audio information to map object signals of the first audio information onto audio channels of the upmix audio signal representation. This can be done, because the object separator may be capable of extracting separate audio signals individually representing the audio objects of the first audio object type. Accordingly, it is possible to map the object signals of the first audio information directly onto the audio channels of the upmix audio signal representation.
In an embodiment, the audio processor is configured to perform a stereo processing of the second audio information in dependence on a rendering information, an object-related covariance information and a downmix information, to obtain audio channels of the upmix audio signal representation.
Accordingly, the stereo processing of the audio objects of the second audio object type is separated from the separation between the audio objects of the first audio object type and the audio objects of the second audio object type. Thus, the efficient separation between audio objects of the first audio object type and audio objects of the second audio object type is not affected (or degraded) by the stereo processing, which typically leads to a distribution of audio objects over a plurality of audio channels without providing the high degree of object separation, which can be obtained in the object separator, for example, using the residual information.
In another embodiment, the audio processor is configured to perform a post-processing of the second audio information in dependence on a rendering information, an object-related covariance information and a downmix information. This form of post-processing allows for a spatial placement of the audio objects of the second audio object type within an audio scene. Nevertheless, due to the cascaded concept, the computational complexity of the audio processor can be kept sufficiently small, because the audio processor does not need to consider the object-related parametric information associated with the audio objects of the first audio object type.
In addition, different types of processing can be performed by the audio processor, like, for example, a mono-to-binaural processing, a mono-to-stereo processing, a stereo-to-binaural processing or a stereo-to-stereo processing.
In an embodiment, the object separator is configured to treat audio objects of the second audio object type, to which no residual information is associated, as a single audio object. In addition, the audio signal processor is configured to consider object-specific rendering parameters to adjust contributions of the objects of the second audio object type to the upmix signal representation. Thus, the audio objects of the second audio object type are considered as a single audio object by the object separator, which significantly reduces the complexity of the object separator and also allows to have a unique residual information, which is independent from the rendering parameters associated with the audio objects of the second audio object type.
In an embodiment, the object separator is configured to obtain a common object-level difference value for a plurality of audio objects of the second audio object type. The object separator is configured to use the common object-level difference value for a computation of channel prediction coefficients. In addition, the object separator is configured to use the channel prediction coefficients to obtain one or two audio channels representing the second audio information. For obtaining a common object-level difference value, the audio objects of the second audio object type can be handled efficiently as a single audio object by the object separator.
In an embodiment, the object separator is configured to obtain a common object level difference value for a plurality of audio objects of the second audio object type and the object separator is configured to use the common object-level difference value for a computation of entries of an energy-mode mapping matrix. The object separator is configured to use the energy-mode mapping matrix to obtain the one or more audio channels representing the second audio information. Again, the common object level difference value allows for a computationally efficient common treating of the audio objects of the second audio object type by the object separator.
In an embodiment, the object separator is configured to selectively obtain a common inter-object correlation value associated to the audio objects of the second audio object type in dependence on the object-related parametric information if it is found that there are two audio objects of the second audio object type and to set the inter-object correlation value associated to the audio objects of the second audio object type to zero if it is found that there are more or less than two audio objects of the second audio object type. The object separator is configured to use the common inter-object correlation value associated to the audio objects of the second audio object type to obtain the one or more audio channels representing the second audio information. Using this approach, the inter-object correlation value is exploited if it is obtainable with high computational efficiency, i.e. if there are two audio objects of the second audio object type. Otherwise, it would be computationally demanding to obtain inter-object correlation values. Accordingly, it has been found to be a good compromise in terms of hearing impression and computational complexity to set the inter-object correlation value associated to the audio objects of the second audio object type to zero if there are more or less than two audio objects of the second object type.
In an embodiment, the audio signal processor is configured to render the second audio information in dependence on (at least a part of) the object-related parametric information, to obtain a rendered representation of the audio objects of the second audio object type as a processed version of the second audio information. In this case, the rendering can be made independent from the audio objects of the first audio object type.
In an embodiment, the object separator is configured to provide the second audio information such that the second audio information describes more than two audio objects of the second audio object type. Embodiments according to the invention allow for a flexible adjustment of the number of audio objects of the second audio object type, which is significantly facilitated by the cascaded structure of the processing.
In an embodiment, the object separator is configured to obtain, as the second audio information, a one-channel audio signal representation or a two-channel audio signal representation representing more than two audio objects of the second audio object type. Extracting one or two audio signal channels can be performed by the object separator with low computational complexity. In particular, the complexity of the object separator can be kept significantly smaller when compared to a case in which the object separator would need to deal with more than two audio objects of the second audio object type. Nevertheless, it has been found that it is a computationally efficient representation of the audio objects of the second audio object type to use one or two channels of an audio signal.
In an embodiment, the audio signal processor is configured to receive the second audio information and to process the second audio information in dependence on (at least a part of) the object-related parametric information, taking into consideration object-related parametric information associated with more than two audio objects of the second audio object type. Accordingly, an object-individual processing is performed by the audio processor, while such an object-individual processing is not performed for audio objects of the second audio object type by the object separator.
In an embodiment, the audio decoder is configured to extract a total object number information and a foreground object number information from a configuration information related to the object-related parametric information. The audio decoder is also configured to determine a number of audio objects of the second audio object type by forming a difference between the total object number information and the foreground object number information. Accordingly, efficient signalling of the number of audio objects of the second audio object type is achieved. In addition, this concept provides for a high degree of flexibility regarding the number of audio objects of the second audio object type.
In an embodiment, the object separator is configured to use object-related parametric information associated with Neao audio objects of the first audio object type to obtain, as the first audio information, Neao, audio signals representing (advantageously, individually) the Neao audio objects of the first audio object type, and to obtain, as the second audio information, one or two audio signals representing the N-Neao audio objects of the second audio object type, treating the N-Neao audio objects of the second audio object type as a single one-channel or two-channel audio object. The audio signal processor is configured to individually render the N-Neao audio objects represented by the one or two audio signals of the second audio information using the object-related parametric information associated with the N-Neao audio objects of the second audio object type. Accordingly, the audio object separation between the audio objects of the first audio object type and the audio objects of the second audio object type is separated from the subsequent processing of the audio objects of the second audio object type.
An embodiment according to the invention creates a method for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information.
Another embodiment according to the invention creates a computer program for performing said method.
Embodiments of the present invention will be detailed subsequently referring to the appended drawings, in which:
a and 3b show a block schematic diagrams of a residual processor, which can be used as an object separator in an embodiment of the invention;
a to 4e show block schematic diagrams of audio signal processors, which can be used in an audio signal decoder according to an embodiment of the invention:
f shows a block diagram of an SAOC transcoder processing mode;
g shows a block diagram of an SAOC decoder processing mode;
a shows a block schematic diagram of an audio signal decoder, according to an embodiment of the invention;
b shows a block schematic diagram of another audio signal decoder, according to an embodiment of the invention;
a shows a Table representing a listening test design description;
b shows a Table representing systems under test;
c shows a Table representing the listening test items and rendering matrices;
d shows a graphical representation of average MUSHRA scores for a Karaoke/Solo type rendering listening test;
e shows a graphical representation of average MUSHRA scores for a classic rendering listening test;
a shows a block schematic diagram of a reference SAOC system using a separate decoder and mixer;
b shows a block schematic diagram of a reference SAOC system using an integrated decoder and mixer; and
c shows a block schematic diagram of a reference SAOC system using an SAOC-to-MPEG transcoder.
The audio signal decoder 100 is configured to receive an object-related parametric information 110 and a downmix signal representation 112. The audio signal decoder 100 is configured to provide an upmix signal representation 120 in dependence on the downmix signal representation and the object-related parametric information 110. The audio signal decoder 100 comprises an object separator 130, which is configured to decompose the downmix signal representation 112 to provide a first audio information 132 describing a first set of one or more audio objects of a first audio object type and a second audio information 134 describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation 112 and using at least a part of the object-related parametric information 110. The audio signal decoder 100 also comprises an audio signal processor 140, which is configured to receive the second audio information 134 and to process the second audio information in dependence on at least a part of the object-related parametric information 112, to obtain a processed version 142 of the second audio information 134. The audio signal decoder 100 also comprises an audio signal combiner 150 configured to combine the first audio information 132 with the processed version 142 of the second audio information 134, to obtain the upmix signal representation 120.
The audio signal decoder 100 implements a cascaded processing of the downmix signal representation, which represents audio objects of the first audio object type and audio objects of the second audio object type in a combined manner.
In a first processing step, which is performed by the object separator 130, the second audio information describing a second set of audio objects of the second audio object type is separated from the first audio information 132 describing a first set of audio objects of a first audio object type using the object-related parametric information 110. However, the second audio information 134 is typically an audio information (for example, a one-channel audio signal or a two-channel audio signal) describing the audio objects of the second audio object type in a combined manner.
In the second processing step, the audio signal processor 140 processes the second audio information 134 in dependence on the object-related parametric information. Accordingly, the audio signal processor 140 is capable of performing an object-individual processing or rendering of the audio objects of the second audio object type, which are described by the second audio information 134, and which is typically not performed by the object separator 130.
Thus, while the audio objects of the second audio object type are not processed in an object-individual manner by the object separator 130, the audio objects of the second audio object type are, indeed, processed in an object-individual manner (for example, rendered in an object-individual manner) in the second processing step, which is performed by the audio signal processor 140. Thus, the separation between the audio objects of the first audio object type and the audio objects of the second audio object type, which is performed by the object separator 130, is separated from the object-individual processing of the audio objects of the second audio object type, which is performed afterwards by the audio signal processor 140. Accordingly, the processing which is performed by the object separator 130 is substantially independent from a number of audio objects of the second audio object type. In addition, the format (for example, one-channel audio signal or the two-channel audio signal) of the second audio information 134 is typically independent from the number of audio objects of the second audio object type. Thus, the number of audio objects of the second audio object type can be varied without having the need to modify the structure of the object separator 130. In other words, the audio objects of the second audio object type are treated as a single (for example, one-channel or two-channel) audio object for which a common object-related parametric information (for example, a common object-level-difference value associated with one or two audio channels) is obtained by the object separator 140.
Accordingly, the audio signal decoder 100 according to
In the following, an audio signal decoder 200 according to an embodiment of the invention will be described. A block-schematic diagram of this audio signal decoder 200 shown in
The audio decoder 200 is configured to receive a downmix signal 210, a so-called SAOC bitstream 212, rendering matrix information 214 and, optionally, head-related-transfer-function (HRTF) parameters 216. The audio signal decoder 200 is also configured to provide an output/MPS downmix signal 220 and (optionally) a MPS bitstream 222.
2.1. Input Signals and Output Signals of the Audio Signal Decoder 200
In the following, various details regarding input signals and output signals of the audio decoder 200 will be described.
The downmix signal 200 may, for example, be a one-channel audio signal or a two-channel audio signal. The downmix signal 210 may, for example, be derived from an encoded representation of the downmix signal.
The spatial-audio-object-coding bitstream (SAOC bitstream) 212 may, for example, comprise object-related parametric information. For example, the SAOC bitstream 212 may comprise object-level-difference information, for example, in the form of object-level-difference parameters OLD, an inter-object-correlation information, for example, in the form of inter-object-correlation parameters IOC.
In addition, the SAOC bitstream 212 may comprise a downmix information describing how the downmix signals have been provided on the basis of a plurality of audio object signals using a downmix process. For example, the SAOC bitstream may comprise a downmix gain parameter DMG and (optionally) downmix-channel-level difference parameters DCLD.
The rendering matrix information 214 may, for example, describe how the different audio objects should be rendered by the audio decoder. For example, the rendering matrix information 214 may describe an allocation of an audio object to one or more channels of the output/MPS downmix signal 220.
The optional head-related-transfer-function (HRTF) parameter information 216 may further describe a transfer function for deriving a binaural headphone signal.
The output/MPEG-Surround downmix signal (also briefly designated with “output/MPS downmix signal”) 220 represents one or more audio channels, for example, in the form of a time domain audio signal representation or a frequency-domain audio signal representation. Alone or in combination with the optional MPEG-Surround bitstream (MPS bitstream) 222, which comprises MPEG-Surround parameters describing a mapping of the output/MPS downmix signal 220 onto a plurality of audio channels, an upmix signal representation is formed.
2.2. Structure and Functionality of the Audio Signal Decoder 200
In the following, the structure of the audio signal decoder 200, which may fulfill the functionality of an SAOC transcoder or the functionality of a SAOC decoder, will be described in more detail.
The audio signal decoder 200 comprises a downmix processor 230, which is configured to receive the downmix signal 210 and to provide, on the basis thereof, the output/MPS downmix signal 220. The downmix processor 230 is also configured to receive at least a part of the SAOC bitstream information 212 and at least a part of the rendering matrix information 214. In addition, the downmix processor 230 may also receive a processed SAOC parameter information 240 from a parameter processor 250.
The parameter processor 250 is configured to receive the SAOC bitstream information 212, the rendering matrix information 214 and, optionally, the head-related-transfer-function parameter information 260, and to provide, on the basis thereof, the MPEG Surround bitstream 222 carrying the MPEG surround parameters (if the MPEG surround parameters are necessitated, which is, for example, true in the transcoding mode of operation). In addition, the parameter processor 250 provides the processed SAOC information 240 (if this processed SAOC information is necessitated).
In the following, the structure and functionality of the downmix processor 230 will be described in more detail.
The downmix processor 230 comprises a residual processor 260, which is configured to receive the downmix signal 210 and to provide, on the basis thereof, a first audio object signal 262 describing so-called enhanced audio objects (EAOs), which may be considered as audio objects of a first audio object type. The first audio object signal may comprise one or more audio channels and may be considered as a first audio information. The residual processor 260 is also configured to provide a second audio object signal 264, which describes audio objects of a second audio object type and may be considered as a second audio information. The second audio object signal 264 may comprise one or more channels and may typically comprise one or two audio channels describing a plurality of audio objects. Typically, the second audio object signal may describe even more than two audio objects of the second audio object type.
The downmix processor 230 also comprises an SAOC downmix pre-processor 270, which is configured to receive the second audio object signal 264 and to provide, on the basis thereof, a processed version 272 of the second audio object signal 264, which may be considered as a processed version of the second audio information.
The downmix processor 230 also comprises an audio signal combiner 280, which is configured to receive the first audio object signal 262 and the processed version 272 of the second audio object signal 264, and to provide, on the basis thereof, the output/MPS downmix signal 220, which may be considered, alone or together with the (optional) corresponding MPEG-Surround bitstream 222, as an upmix signal representation.
In the following, the functionality of the individual units of the downmix processor 230 will be discussed in more detail.
The residual processor 260 is configured to separately provide the first audio object signal 262 and the second audio object signal 264. For this purpose, the residual processor 260 may be configured to apply at least a part of the SAOC bitstream information 212. For example, the residual processor 260 may be configured to evaluate an object-related parametric information associated with the audio objects of the first audio object type, i.e. the so-called “enhanced audio objects” EAO. In addition, the residual processor 260 may be configured to obtain an overall information describing the audio objects of the second audio object type, for example, the so-called “non-enhanced audio objects”, commonly. The residual processor 260 may also be configured to evaluate a residual information, which is provided in the SAOC bitstream information 212, for a separation between enhanced audio objects (audio objects of the first audio object type) and non-enhanced audio objects (audio objects of the second audio object type). The residual information may, for example, encode a time domain residual signal, which is applied to obtain a particularly clean separation between the enhanced audio objects and the non-enhanced audio objects. In addition, the residual processor 260 may, optionally, evaluate at least a part of the rendering matrix information 214, for example, in order to determine a distribution of the enhanced audio objects to the audio channels of the first audio object signal 262.
The SAOC downmix pre-processor 270 comprises a channel re-distributor 274, which is configured to receive the one or more audio channels of the second audio object signal 264 and to provide, on the basis thereof, one or more (typically two) audio channels of the processed second audio object signal 272. In addition, the SAOC downmix pre-processor 270 comprises a decorrelated-signal-provider 276, which is configured to receive the one or more audio channels of the second audio object signal 264 and to provide, on the basis thereof, one or more decorrelated signals 278a, 278b, which are added to the signals provided by the channel re-distributor 274 in order to obtain the processed version 272 of the second audio object signal 264.
Further details regarding the SAOC downmix processor will be discussed below.
The audio signal combiner 280 combines the first audio object signal 262 with the processed version 272 of the second audio object signal. For this purpose, a channel-wise combination may be performed. Accordingly, the output/MPS downmix signal 220 is obtained.
The parameter processor 250 is configured to obtain the (optional) MPEG-Surround parameters, which make up the MPEG-Surround bitstream 222 of the upmix signal representation, on the basis of the SAOC bitstream, taking onto consideration the rendering matrix information 214 and, optionally, the HRTF parameter information 216. In other words, the SAOC parameter processor 252 is configured to translate the object-related parameter information, which is described by the SAOC bitstream information 212, into a channel-related parametric information, which is described by the MPEG Surround bit stream 222.
In the following, a short overview of the structure of the SAOC transcoder/decoder architecture shown in
On the decoder side, the input objects are reconstructed and rendered to a certain number of playback channels. The rendering information containing reproduction level and panning position for each object is user-supplied or can be extracted from the SAOC bitstream (for example, as a preset information). The rendering information can be time-variant. Output scenarios can range from mono to multi-channel (for example, 5.1) and are independent from both, the number of input objects and the number of downmix channels. Binaural rendering of objects is possible including azimuth and elevation of virtual object positions. An optional effect interface allows for advanced manipulation of object signals, besides level and panning modification.
The objects themselves can be mono signals, stereophonic signals, as well as a multi-channel signals (for example 5.1 channels). Typical downmix configurations are mono and stereo.
In the following, the basic structure of the SAOC transcoder/decoder, which is shown in
In the following, details regarding a residual processor will be described, which may, for example, take over the functionality of the object separator 130 of the audio signal decoder 100 or of the residual processor 260 of the audio signal decoder 200. For this purpose,
The residual processor 300 is configured to receive an SAOC downmix signal 310, which may be equivalent to the downmix signal representation 112 of
The residual processor 300 comprises a 1-to-N/2-to-N unit (OTN/TTN unit) 330, which receives the SAOC downmix signal 310 and which also receives SAOC data and residuals 332. The 1-to-N/2-to-N unit 330 also provides an enhanced-audio-object signal 334, which describes the enhanced audio objects (EAO) contained in the SAOC downmix signal 310.
Also, the 1-to-N/2-to-N unit 330 provides the second audio information 322. The residual processor 300 also comprises a rendering unit 340, which receives the enhanced-audio-object signal 334 and a rendering matrix information 342 and provides, on the basis thereof, the first audio information 320.
In the following, the enhanced audio object processing (EAO processing), which is performed by the residual processor 300, will be described in more detail.
3.1. Introduction into the Operation of the Residual Processor 300
Regarding the functionality of the residual processor 300, it should be noted that the SAOC technology allows for the individual manipulation of a number of audio objects in terms of their level amplification/attenuation without significant decrease in the resulting sound quality only in a very limited way. A special “karaoke-type” application scenario necessitates a total (or almost total) suppression of the specific objects, typically the lead vocal, keeping the perceptional quality of the background sound scene unharmed.
A typical application case contains up to four enhanced audio objects (EAO) signals, which can, for example, represent two independent stereo objects (for example, two independent stereo objects which are prepared to be removed at the side of the decoder).
It should be noted that the (one or more) quality enhanced audio objects (or, more precisely, the audio signal contributions associated with the enhanced audio objects) are included in the SAOC downmix signal 310. Typically, the audio signal contributions associated with the (one or more) enhanced audio objects are mixed, by the downmix processing performed by the audio signal encoder, with audio signal contributions of other audio objects, which are not enhanced audio objects. Also, it should be noted that audio signal contributions of a plurality of enhanced audio objects are also typically overlapped or mixed by the downmix processing performed by the audio signal encoder.
3.2 SOAC Architecture Supporting Enhanced Audio Objects
In the following, details regarding the residual processor 300 will be described. Enhanced audio object processing incorporates the 1-to-N or 2-to-N units, depending on the SAOC downmix mode. The 1-to-N processing unit is dedicated to a mono downmix signal and the 2-to-N processing unit is dedicated to a stereo downmix signal 310. Both these units represent a generalized and enhanced modification of the 2-to-2 box (TTT box) known from ISO/IEC 23003-1:2007. In the encoder, regular and EAO signals are combined into the downmix. The OTN−1/TTN−1 processing units (which are inverse one-to-N processing units or inverse 2-to-N processing units) are employed to produce and encode the corresponding residual signals.
The EAO and regular signals are recovered from the downmix 310 by the OTN/TTN units 330 using the SAOC side information and incorporated residual signals. The recovered EAOs (which are described by the enhanced audio object signal 334) are fed into the rendering unit 340 which represents (or provides) the product of the corresponding rendering matrix (described by the rendering matrix information 342) and the resulting output of the OTN/TTN unit. The regular audio objects (which are described by the second audio information 322) are delivered to the SAOC downmix pre-processor, for example, the SAOC downmix preprocessor 270, for further processing.
The residual processor output signals 320,322 are computed as
XOBJ=MOBJXres,
XEAO=AEAOMEAOXres,
where XOBJ represents the downmix signal of the regular audio objects (i.e. non-EAOs) and XEAO is the rendered EAO output signal for the SAOC decoding mode or the corresponding EAO downmix signal for the SAOC transcoding mode.
The residual processor can operate in prediction (using residual information) mode or energy (without residual information) mode. The extended input signal Xres is defined accordingly:
Here, X may, for example, represent the one or more channels of the downmix signal representation 310, which may be transported in the bitstream representing the multi-channel audio content. res may designate one or more residual signals, which may be described by the bitstream representing the multi-channel audio content.
The OTN/TTN processing is represented by matrix M and EAO processor by matrix AEAO.
The OTN/TTN processing matrix M is defined according to the EAO operation mode (i.e. prediction or energy) as
The OTN/TTN processing matrix M is represented as
where the matrix MOBJ relates to the regular audio objects (i.e. non-EAOs) and MEAO to the enhanced audio objects (EAOs).
In some embodiments, one or more multichannel background objects (MBO) may be treated the same way by the residual processor 300.
A Multi-channel Background Object (MBO) is an MPS mono or stereo downmix that is part of the SAOC downmix. As opposed to using individual SAOC objects for each channel in a multi-channel signal, an MBO can be used enabling SAOC to more efficiently handle a multi-channel object. In the MBO case, the SAOC overhead gets lower as the MBO's SAOC parameters only are related to the downmix channels rather than all the upmix channels.
3.3 Further Definitions
3.3.1 Dimensionality of Signals and Parameters
In the following, the dimensionality of the signals and parameters will be briefly discussed in order to provide an understanding how often the different calculations are performed.
The audio signals are defined for every time slot n and every hybrid subband (which may be a frequency subband) k. The corresponding SAOC parameters are defined for each parameter time slot 1 and processing band m. A Subsequent mapping between the hybrid and parameter domain is specified by table A.31 ISO/IEC 23003-1:2007. Hence, all calculations are performed with respect to the certain time/band indices and the corresponding dimensionalities are implied for each introduced variable.
However, in the following, the time and frequency band indices will be omitted sometimes to keep the notation concise.
3.3.2 Calculation of the Matrix AEAO
The EAO pre-rendering matrix AEAO is defined according to the number of output channels (i.e. mono, stereo or binaural) as
The matrices A1EAO of size 1×NEAO and A2EAO of size 2×NEAO are defined as
where the rendering sub-matrix MrenEAO corresponds to the EAO rendering (and describes a desired mapping of enhanced audio objects onto channels of the upmix signal representation).
The values wiEAO are computed in dependence on rendering information associated with the enhanced audio objects using the corresponding EAO elements and using the equations of section 4.2.2.1.
In case of binaural rendering the matrix A2EAO is defined by equations given in section 4.1.2, for which the corresponding target binaural rendering matrix contains only EAO related elements.
3.4 Calculation of the OTN/TTN Elements in the Residual Mode
In the following, it will be discussed how the SAOC downmix signal 310, which typically comprises one or two audio channels, is mapped onto the enhanced audio object signal 334, which typically comprises one or more enhanced audio object channels, and the second audio information 322, which typically comprises one or two regular audio object channels.
The functionality of the 1-to-N unit or 2-to-N unit 330 may, for example, be implemented using a matrix vector multiplication, such that a vector describing both the channels of the enhanced audio object signal 334 and the channels of the second audio information 322 is obtained by multiplying a vector describing the channels of the SAOC downmix signal 310 and (optionally) one or more residual signals with a matrix MPrediction or MEnergy. Accordingly, the determination of the matrix MPrediction or MEnergy is an important step in the derivation of the first audio information 320 and the second audio information 322 from the SAOC downmix 310.
To summarize, the OTN/TTN upmix process is presented by either a matrix MPrediction for a prediction mode or MEnergy for an energy mode.
The energy based encoding/decoding procedure is designed for non-waveform preserving coding of the downmix signal. Thus the OTN/TTN upmix matrix for the corresponding energy mode does not rely on specific waveforms, but only describe the relative energy distribution of the input audio objects, as will be discussed in more detail below.
3.4.1 Prediction Mode
For the prediction mode the matrix MPrediction is defined exploiting the downmix information contained in the matrix {tilde over (D)}−1 and the CPC data from matrix C:
MPrediction={tilde over (D)}−1C.
With respect to the several SAOC modes, the extended downmix matrix {tilde over (D)} and CPC matrix C exhibit the following dimensions and structures:
3.4.1.1 Stereo Downmix Modes (TTN):
For stereo downmix modes (TTN) (for example, for the case of a stereo downmix on the basis of two regular-audio-object channels and NEAO enhanced-audio-object-channels), the (extended) downmix matrix {tilde over (D)} and the CPC matrix C can be obtained as follows:
With a stereo downmix, each EAO j holds two CPCs cj,0 and cj,1 yielding matrix C.
The residual processor output signals are computed as
Accordingly, two signals yL, yR (which are represented by XOBJ) are obtained, which represent one or two or even more than two regular audio objects (also designated as non-extended audio objects). Also, NEAO signals (represented by XEAO) representing NEAO enhanced audio objects are obtained. These signals are obtained on the basis of two SAOC downmix signals l0, r0 and NEAO residual signals res0 to resNEAO-1, which will be encoded in the SAOC side information, for example, as a part as the object-related parametric information.
It should be noted that the signals yL and yR may be equivalent to the signal 322, and that the signals y0,EAO to yNEAO-1, EAO (which are represented by XEAO) may equivalent to the signals 320.
The matrix AEAO is a rendering matrix. Entries of the matrix AEAO may describe, for example, a mapping of enhanced audio objects to the channels of the enhanced audio object signal 334 (XEAO).
Accordingly, an appropriate choice of the matrix AEAO may allow for an optional integration of the functionality of the rendering unit 340, such that the multiplication of the vector describing the channels (l0,r0) of the SAOC downmix signal 310 and one or more residual signals (res0, . . . , resNEAO-1) with the matrix AEAOMEAOPrediction may directly result in a representation XEAO of the first audio information 320.
3.4.1.2 Mono Downmix Modes (OTN):
In the following, the derivation of the enhanced audio object signals 320 (or, alternatively, of the enhanced audio object signals 334) and of the regular audio object signal 322 will be described for the case in which the SAOC downmix signal 310 comprises a signal channel only.
For mono downmix modes (OTN) (e.g., a mono downmix on the basis of one regular-audio-object channel and NEAO enhanced-audio-object channels), the (extended) downmix matrix 15 and the CPC matrix C can be obtained as follows:
With a mono downmix, one EAO j is predicted by only one coefficient cj yielding the matrix C. All matrix elements cj are obtained, for example, from the SAOC parameters (for example, from the SAOC data 322) according to the relationships provided below (section 3.4.1.4).
The residual processor output signals are computed as
The output signal XOBJ comprises, for example, one channel describing the regular audio objects (non-enhanced audio objects). The output signal XEAO comprises, for example, one, two, or even more channels describing the enhanced audio objects (advantageously NEAO channels describing the enhanced audio objects). Again, said signals are equivalent to the signals 320, 322.
3.4.1.3 Calculation of the Inverse Extended Downmix Matrix
The matrix {tilde over (D)}−1 is the inverse of the extended downmix matrix {tilde over (D)} and C implies the CPCs.
The matrix {tilde over (D)}−1 is the inverse of the extended downmix matrix {tilde over (D)} and can be calculated as
The elements {tilde over (d)}i,j (for example, of the inverse {tilde over (D)}−1 of the extended downmix matrix {tilde over (D)} of size 6×6) are derived using the following values:
The coefficients mj and nj of the extended downmix matrix {tilde over (D)} denote the downmix values for every EAO j for the right and left downmix channel as
mj=d0,EAO(j), nj=d1,EAO(j).
The elements di,j of the downmix matrix D are obtained using the downmix gain information DMG and the (optional) downmix channel level different information DCLD, which is included in the SAOC information 332, which is represented, for example, by the object-related parametric information 110 or the SAOC bitstream information 212.
For the stereo downmix case the downmix matrix D of size 2×N with elements (i=0, 1; j=0, . . . , N−1) is obtained from the DMG and DCLD parameters as
For the mono downmix case the downmix matrix D of size 1×N with elements di,j (i=0; j=0, . . . , N−1) is obtained from the DMG parameters as
d0,j=100.05DMG
Here, the dequantized downmix parameters DMGj and DCLDj are obtained, for example, from the parametric side information 110 or from the SAOC bitstream 212.
The function EAO(j) determines mapping between indices of input audio object channels and EAO signals:
EAO(j)=N−1−j, j=0, . . . ,NEAO−1.
3.4.1.4 Calculation of the Matrix C
The matrix C implies the CPCs and is derived from the transmitted SAOC parameters (i.e. the OLDs, IOCs, DMGs and DCLDs) as
cj,0=(1−λ){tilde over (c)}j,0+λγj,0, cj,1=(1−λ){tilde over (c)}j,1+λγj,1.
In other words, the constrained CPCs are obtained in accordance with the above equations, which may be considered as a constraining algorithm. However, the constrained CPCs may also be derived from the values {tilde over (c)}j,0, {tilde over (c)}j,1 using a different limitation approach (constraining algorithm), or can be set to be equal to the values {tilde over (c)}j,0, {tilde over (c)}j,1.
It should be noted, that matrix entries cj,1 (and the intermediate quantities on the basis of which the matrix entries cj,1 are computed) are typically only necessitated if the downmix signal is a stereo downmix signal.
The CPCs are constrained by the subsequent limiting functions:
with the weighting factor λ determined as
For one specific EAO channel j=0 . . . NEAO−1 the unconstrained CPCs are estimated by
The energy quantities PLo, PRo, PLoRo, PLoCo,j and PRoCo,j are computed as
The covariance matrix ei,j is defined in the following way: The covariance matrix E of size N×N with elements ei,j represents an approximation of the original signal covariance matrix E≈SS* and is obtained from the OLD and IOC parameters as
ei,j=√{square root over (OLDiOLDj)}IOCi,j.
Here, the dequantized object parameters OLDi, IOCi,j are obtained, for example, from the parametric side information 110 or from the SAOC bitstream 212.
In addition, eL,R may, for example, be obtained as
eL,R=√{square root over (OLDLOLDR)}IOCL,R.
The parameters OLDL, OLDR and IOCL,R correspond to the regular (audio) objects and can be derived using the downmix information:
As can be seen, two common object-level-different values OLDL and OLDR are computed for the regular audio objects in the case of a stereo downmix signal (which implies a two-channel regular audio object signal). In contrast, only one common object-level-different value OLDL is computed for the regular audio objects in the case of a one-channel (mono) downmix signal (which implies a one-channel regular audio object signal).
As can be seen, the first (in the case of a two-channel downmix signal) or sole (in the case of a one-channel downmix signal) common object-level-difference value OLDL is obtained by summing contributions of the regular audio objects having audio object index (or indices) i to the left channel (or sole channel) of the SAOC downmix signal 310.
The second common object-level-difference value OLDR (which is used in the case of a two-channel downmix signal) is obtained by summing the contributions of the regular audio objects having the audio object index (or indices) i to the right channel of the SAOC downmix signal 310.
The contribution OLDL of the regular audio objects (having audio objects indices i=0 to i=N−NEAO−1) onto the left channel signal (or sole channel signal) of the SAOC downmix signal 710 is computed, for example, taking into consideration the downmix gain d0,j, describing the downmix gain applied to the regular audio object having audio object index when obtaining the left channel signal of the SAOC downmix signal 310, and also the object level of the regular audio object having the audio object i, which is represented by the value OLDi.
Similarly, the common object level difference value OLDR is obtained using the downmix coefficients d1,i, describing the downmix gain which is applied to the regular audio object having the audio object index i when forming the right channel signal of the SAOC downmix signal 310, and the level information OLDi associated with the regular audio object having the audio object index i.
As can be seen, the equations for the calculation of the quantities PLo, PRo, PLoRo, PLoCo,j and PRoCo,j do not distinguish between the individual regular audio objects, but merely make use of the common object level difference values OLDL, OLDR, thereby considering the regular audio objects (having audio object indices i) as a single audio object.
Also, the inter-object-correlation value IOCL,R, which is associated with the regular audio objects, is set to 0 unless there are two regular audio objects.
The covariance matrix ei,j (and eL,R) is defined as follows:
The covariance matrix E of size N×N with elements ei,j represents an approximation of the original signal covariance matrix E≈SS* and is obtained from the OLD and IOC parameters as
ei,j=√{square root over (OLDiOLDj)}IOCi,j.
For example,
eL,R=√{square root over (OLDLOLDR)}IOCL,R,
wherein OLDL and OLDR and IOCL,R are computed as described above.
Here, the dequantized object parameters are obtained as
OLDi=DOLD(i,l,m), IOCi,j=DIOC(i,j,l,m),
wherein DOLD and DIOC are matrices comprising objects-level-difference parameters and inter-object-correlation parameters.
3.4.2. Energy Mode
In the following, another concept will be described, which can be used to separate the extended-audio-object signals 320 and the regular-audio-object (non-extended audio object) signals 322, and which can be used in combination with a non-waveform-preserving audio coding of the SAOC downmix channels 310.
In other words, the energy based encoding/decoding procedure is designed for non-waveform preserving coding of the downmix signal. Thus the OTN/TTN upmix matrix for the corresponding energy mode does not rely on specific waveforms, but only describe the relative energy distribution of the input audio objects.
Also, the concept discussed here, which is designated as an “energy mode” concept, can be used without transmitting a residual signal information. Again, the regular audio objects (non-enhanced audio objects) are treated as a single one-channel or two-channel audio object having one or two common object-level-difference values OLDL, OLDR.
For the energy mode the matrix MEnergy is defined exploiting the downmix information and the OLDs, as will be described in the following.
3.4.2.1. Energy Mode for Stereo Downmix Modes (TTN)
In case of a stereo (for example, a stereo downmix on the basis of two regular-audio-object channels and NEAO enhanced-audio-object channels), the matrices MOBJEnergy and MEAOEnergy are obtained from the corresponding OLDs according to
The residual processor output signals are computed as
The signals yL, yR, which are represented by the signal XOBJ, describe the regular audio objects (and may be equivalent to the signal 322), and the signals y0,EAO to yNEAO-1,EAO, which are described by the signal XEAO, describe the enhanced audio objects (and may be equivalent to the signal 334 or to the signal 320).
If a mono upmix signal is desired for the case of a stereo downmix signal, a 2-to-1 processing may be performed, for example, by the pre-processor 270 on the basis of the two-channel signal XOBJ.
3.4.2.2. Energy Mode for Mono Downmix Modes (OTN)
For the mono case (for example, a mono downmix on the basis of one regular-audio-object channel and NEAO enhanced-audio-object channels), the matrices MOBJEnergy and MEAOEnergy are obtained from the corresponding OLDs according to
The residual processor output signals are computed as
XOBJ=MOBJEnergy(d0),
XEAO=AEAOMEAOEnergy(d0).
A single regular-audio-object channel 322 (represented by XOBJ) and NEAO enhanced-audio-object channels 320 (represented by XEAO) can be obtained by applying the matrices MOBJEnergy and MEAOEnergy to a representation of a single channel SAOC downmix signal 310 (represented here by d0).
If a two-channel (stereo) upmix signal is desired for the case of a one-channel (mono) downmix signal, a 1-to-2 processing may be performed, for example, by the pre-processor 270 on the basis of the one-channel signal XOBJ.
In the following, the operation of the SAOC downmix pre-processor 270 will be described both for some decoding modes of operation and for some transcoding modes of operation.
4.1 Operation in the Decoding Modes
4.1.1 Introduction
In the following, a method for obtaining an output signal using SAOC parameters and panning information (or rendering information) associated with each audio object is described. The SAOC decoder 495 is depicted in
It should be noted that the SAOC decoder 494 may be used to process the regular audio objects, and may therefore receive, as the downmix signal 497a, the second audio object signal 264 or the regular-audio-object signal 322 or the second audio information 134. Accordingly, the downmix processor 497 may provide, as its output signals 497b, the processed version 272 of the second audio object signal 264 or the processed version 142 of the second audio information 134. Accordingly, the downmix processor 497 may take the role of the SAOC downmix pre-processor 270, or the role of the audio signal processor 140.
The SAOC parameter processor 496 may take the role of the SAOC parameter processor 252 and consequently provides downmix information 496a.
4.1.2 Downmix Processor
In the following, the downmix processor, which is part of the audio signal processor 140, and which is designated as a “SAOC downmix pre-processor” 270 in the embodiment of
For the decoder mode of the SAOC system, the output signal 142, 272, 497b of the downmix processor (represented in the hybrid QMF domain) is fed into the corresponding synthesis filterbank (not shown in
The output signal {circumflex over (X)} of the downmix processor 270, 497 (also designated with 142, 272, 497b) is computed from the mono downmix signal X (also designated with 134, 264, 497a) and the decorrelated mono downmix signal Xd as
{circumflex over (X)}=GX+P2Xd.
The decorrelated mono downmix signal Xd is computed as
Xd=decorrFunc(X).
The decorrelated signals Xd are created from the decorrelator described in ISO/IEC 23003-1:2007, subclause 6.6.2. Following this scheme, the bsDecorrConfig==0 configuration should be used with a decorrelator index, X=8, according to Table A.26 to Table A.29 in ISO/IEC 23003-1:2007. Hence, the decorrFunc( ) denotes the decorrelation process:
In case of binaural output the upmix parameters G and P2 derived from the SAOC data, rendering information Mrenl,m and HRTF parameters are applied to the downmix signal X (and Xd) yielding the binaural output {circumflex over (X)}, see
The target binaural rendering matrix Al,m of size 2×N consists of the elements ax,yl,m. Each element ax,yl,m is derived from HRTF parameters and rendering matrix Mrenl,m with elements my,il,m, for example, by the SAOC parameter processor. The target binaural rendering matrix Al,m represents the relation between all audio input objects y and the desired binaural output.
The HRTF parameters are given by Hi,Lm, Hi,Rm and φim for each processing band m. The spatial positions for which HRTF parameters are available are characterized by the index i. These parameters are described in ISO/IEC 23003-1:2007.
4.1.2.1 Overview
In the following, an overview over the downmix processing will be given taking reference to
Taking reference now to
Entries f of a desired covariance matrix F are obtained in dependence on the rendering matrix A and the covariance matrix E. Also, a scalar value v is obtained in dependence on the covariance matrix E and the downmix matrix D (or in dependence on the entries thereof).
Gain values PL, PR for two channels are obtained in dependence on entries of the desired covariance matrix F and the scalar value v. Also, an inter-channel phase difference value φC is obtained in dependence entries f of the desired covariance matrix F. A rotation angle α is also obtained in dependence on entries f of the desired covariance matrix F, taking into consideration, for example, a constant c. In addition, a second rotation angle β is obtained, for example, in dependence on the channel gains PL, PR and the first rotation angle α. Entries of a matrix G are obtained, for example, in dependence on the two channel gain values PL,PR and also in dependence on the inter-channel phase difference φC and, optionally, the rotation angles α, β. Similarly, entries of a matrix P2 are determined in dependence on some or all of said values PL, PR, φc, α, β.
In the following, it will be described how the matrix G and/or P2 (or the entries thereof), which may be applied by the downmix processor as discussed above, can be obtained for different processing modes.
4.1.2.2 Mono to Binaural “x-1-b” Processing Mode
In the following, a processing mode will be discussed in which the regular audio objects are represented by a single channel downmix signal 134, 264, 322, 497a and in which a binaural rendering is desired.
The upmix parameters Gl,m and P2l,m are computed as
The gains PLl,m and PRl,m for the left and right output channels are
The desired covariance matrix Fl,m of size 2×2 with elements fi,jl,m is given as
Fl,m=Al,mEl,m(Al,m)*.
The scalar vl,m is computed as
vl,m=DlEl,m(Dl)*+ε2.
The inter channel phase difference φCl,m is given as
The inter channel coherence ρCl,m is computed as
The rotation angles αl,m and βl,m are given as
4.1.2.3 Mono-to-Stereo “x-1-2” Processing Mode
In the following, a processing mode will be described in which the regular audio objects are represented by a single-channel signal 134, 264, 222, and in which a stereo rendering is desired.
In case of stereo output the “x-1-b” processing mode can be applied without using HRTF information. This can be done by deriving all elements αx,yl,m of the rendering matrix A, yielding:
al,yl,m=mLf,yl,m, a2,yl,m=mRf,yl,m.
4.1.2.4 Mono-to-Mono “x-1-1” Processing Mode
In the following, a processing mode will be described in which the regular audio objects are represented by a signal channel 134, 264, 322, 497a and in which a two-channel rendering of the regular audio objects is desired.
In case of mono output the “x-1-2” processing mode can be applied with the following entries:
a1,yl,m=mC,yl,m, a2,yl,m=0
4.1.2.5 Stereo-to-Binaural “x-2-b” Processing Mode
In the following, a processing mode will be described in which regular audio objects are represented by a two-channel signal 134, 264, 322, 497a, and in which a binaural rendering of the regular audio objects is desired.
The upmix parameters Gl,m and P2l,m are computed as
The corresponding gains, PLl,m,x, PRl,m,x and PLl,m, PRl,m for the left and right output channels are
The desired covariance matrix Fl,m,x of size 2×2 with elements fu,vl,m,x is given as
Fl,m,x=Al,mEl,m,x(Al,m)*.
The covariance matrix Cl,m of size 2×2 with elements cu,vl,m of the “dry” binaural signal is estimated as
Cl,m={tilde over (G)}l,mDlEl,m(Dl)*({tilde over (G)}l,m)*,
where
The corresponding scalars vl,m,x and vl,m are computed as
vl,m,x=Dl,xEl,m(Dl,x)*+ε2, vl,m=(Dl,1+Dl,2)El,m(Dl,1+Dl,2)*+ε2.
The downmix matrix Dl,x of size 1×N with elements dil,x can be found as
The stereo downmix matrix Dl of size 2×N with elements dx,jl can be found as
dx,il=dil,x.
The matrix El,m,x with elements ei,jl,m,x are derived from the following relationship
The inter channel phase differences φCl,m are given as
The ICCs ρCl,m and ρTl,m are computed as
The rotation angles αl,m and βl,m are given as
4.1.2.6 Stereo-to-Stereo “x-2-2” Processing Mode
In the following, a processing mode will be described in which the regular audio objects are described by a two-channel (stereo) signal 134, 264, 322, 497a and in which a 2-channel (stereo) rendering is desired.
In case of stereo output, the stereo preprocessing is directly applied, which will be described below in Section 4.2.2.3.
4.1.2.7 Stereo-to-Mono “x-2-1” Processing Mode
In the following, a processing mode will be described in which the regular audio objects are represented by a two-channel (stereo) signal 134, 264, 322, 497a, and in which a one-channel (mono) rendering is desired.
In case of mono output, the stereo preprocessing is applied with a single active rendering matrix entry, as described below in Section 4.2.2.3.
4.1.2.8 Conclusion
Taking reference again to
4.2. Operation in the Transcoding Modes
4.2.1 Introduction
In the following, a method for combining SAOC parameters and panning information (or rendering information) associated with each audio object (or with each regular audio object) in a standard compliant MPEG surround bitstream (MPS bitstream) is explained.
The SAOC transcoder 490 is depicted in
The SAOC transcoder 490 may, for example, take over the functionality of the audio signal processor 140. Alternatively, the SAOC transcoder 490 may take over the functionality of the SAOC downmix pre-processor 270 when taken in combination with the SAOC parameter processor 252.
For example, the SAOC parameter processor 491 may receive an SAOC bitstream 491a, which is equivalent to the object-related parametric information 110 or the SAOC bitstream 212. Also, the SAOC parameter processor 491 may receive a rendering matrix information 491b, which may be included in the object-related parametric information 110, or which may be equivalent to the rendering matrix information 214. The SAOC parameter processor 491 may also provide downmix processing information 491c to the downmix processor 492, which may be equivalent to the information 240. Moreover, the SAOC parameter processor 491 may provide an MPEG surround bitstream (or MPEG surround parameter bitstream) 491d, which comprises a parametric surround information which is compatible with the MPEG surround standard. The MPEG surround bitstream 491d may, for example, be part of the processed version 142 of the second audio information, or may, for example be part of or take the place of the MPS bitstream 222.
The downmix processor 492 is configured to receive a downmix signal 492a, which is a one-channel downmix signal or a two-channel downmix signal, and which is equivalent to the second audio information 134, or to the second audio object signal 264, 322. The downmix processor 492 may also provide an MPEG surround downmix signal 492b, which is equivalent to (or part of) the processed version 142 of the second audio information 134, or equivalent to (or part of) the processed version 272 of the second audio object signal 264.
However, there are different ways of combining the MPEG surround downmix signal 492b with the enhanced audio object signal 132, 262. The combination may be performed in the MPEG surround domain.
Alternatively, however, the MPEG surround representation, comprising the MPEG surround parameter bitstream 491d and the MPEG surround downmix signal 492b, of the regular audio objects may be converted back to a multi-channel time domain representation or a multi-channel frequency domain representation (individually representing different audio channels) by an MPEG surround decoder and may be subsequently combined with the enhanced audio object signals.
It should be noted that the transcoding modes comprise both one or more mono downmix processing modes and one or more stereo downmix processing modes. However, in the following only the stereo downmix processing mode will be described, because the processing of the regular audio object signals is more elaborate in the stereo downmix processing mode.
4.2.2 Downmix Processing in the Stereo Downmix (“x-2-5”) Processing Mode
4.2.2.1 Introduction
In the following section, a description of the SAOC transcoding mode for the stereo downmix case will be given.
The object parameters (object level difference OLD, inter-object correlation IOC, downmix gain DMG and downmix channel level difference DCMD) from the SAOC bitstream are transcoded into spatial (advantageously channel-related) parameters (channel level difference CLD, inter-channel-correlation ICC, channel prediction coefficient CPC) for the MPEG surround bitstream according to the rendering information. The downmix is modified according to object parameters and a rendering matrix.
Taking reference now to
c shows a block representation of a processing which is performed for modifying the downmix signal, for example the downmix signal 134, 264, 322, 492a describing the one or more regular audio objects. As can be seen from
In the following, the rendering of the object energy, which is performed in order to obtain the MPEG surround parameters, will be discussed. Also, the stereo preprocessing, which is performed in order to obtain the processed version 142, 272,492b of the second audio information 134, 264,492a representing the regular audio objects will be described.
4.2.2.2 Rendering of Object Energies
The transcoder determines the parameters for the MPS decoder according to the target rendering as described by the rendering matrix Mren. The six channel target covariance is denoted with F and given by
F=YY*=MrenS(MrenS)*=Mren(SS*)M*ren=MrenEM*ren.
The transcoding process can conceptually be divided into two parts. In one part a three channel rendering is performed to a left, right and center channel. In this stage the parameters for the downmix modification as well as the prediction parameters for the TTT box for the MPS decoder are obtained. In the other part the CLD and ICC parameters for the rendering between the front and surround channels (OTT parameters, left front—left surround, right front—right surround) are determined.
4.2.2.2.1 Rendering to Left, Right and Center Channel
In this stage the spatial parameters are determined that control the rendering to a left and right channel, consisting of front and surround signals. These parameters describe the prediction matrix of the TTT box for the MPS decoding CTTT (CPC parameters for the MPS decoder) and the downmix converter matrix G.
CTTT is the prediction matrix to obtain the target rendering from the modified downmix {circumflex over (X)}=GX:
CTTT{circumflex over (X)}=CTTTGX≈A3S.
A3 is a reduced rendering matrix of size 3×N, describing the rendering to the left, right and center channel respectively. It is obtained as A3=D36Mren with the 6 to 3 partial downmix matrix D36 defined by
The partial downmix weights wp, p=1, 2, 3 are adjusted such that the energy of wp(y2p-1+y2p) is equal to the sum of energies ∥y2p-1∥2+∥y2p∥2 to a limit factor.
where fi,j denote the elements of F.
For the estimation of the desired prediction matrix CTTT and the downmix preprocessing matrix G we define a prediction matrix C3 of size 3×2, that leads to the target rendering
C3X≈A3S.
Such a matrix is derived by considering the normal equations
C3(DED*)≈A3ED*.
The solution to the normal equations yields the best possible waveform match for the target output given the object covariance model. G and CTTT are now obtained by solving the system of equations
CTTTG=C3.
To avoid numerical problems when calculating the term J=(DED*)−1, J is modified. First the eigenvalues λ1,2 of J are calculated, solving det(J−λ1,2I)=0.
Eigenvalues are sorted in descending (λ1≧λ2) order and the eigenvector corresponding to the larger eigenvalue is calculated according to the equation above. It is assured to lie in the positive x-plane (first element has to be positive). The second eigenvector is obtained from the first by a −90 degrees rotation:
A weighting matrix is computed from the downmix matrix D and the prediction matrix C3, W=(D diag(C3)).
Since CTTT is a function of the MPS prediction parameters c1 and c2 (as defined in ISO/IEC 23003-1:2007), CTTTG=C3 is rewritten in the following way, to find the stationary point or points of the function,
with Γ=(DTTT C3)w(DTTT C3)* and b=GWC3v,
where
and v=(1 1 −1).
If Γ does not provide a unique solution (det(Γ)<10−3), the point is chosen that lies closest to the point resulting in a TTT pass through. As a first step, the row i of Γ is chosen γ=[γi,1 γi,2] where the elements contain most energy, thus γi,12+γi,22≧γj,12+γj,22, j=1, 2. Then a solution is determined such that
If the obtained solution for {tilde over (c)}1 and {tilde over (c)}2 is outside the allowed range for prediction coefficients that is defined as −2≦{tilde over (c)}j≦3 (as defined in ISO/IEC 23003-1:2007), {tilde over (c)}j shall be calculated according to below.
First define the set of points, xp as:
and the distance function,
distFunc(xp)=x*pΓxp1−2bxp.
Then the prediction parameters are defined according to:
The prediction parameters are constrained according to:
c1=(1−λ){tilde over (c)}1+λγ1, c2=(1−λ){tilde over (c)}2+λγ2,
where λ, γ1 and γ2 are defined as
For the MPS decoder, the CPCs and corresponding ICCTTT are provided as follows
DCPC
4.2.2.2.2 Rendering Between Front and Surround Channels
The parameters that determine the rendering between front and surround channels can be estimated directly from the target covariance matrix F
with (a,b)=(1,2) and (3,4).
The MPS parameters are provided in the form
CLDhl,m=DCLD(h,l,m) and ICChl,m=DICC(h,l,m),
for every OTT box h.
4.2.2.3 Stereo Processing
In the following, a stereo processing of the regular audio object signal 134 to 64, 322 will be described. The stereo processing is used to derive a process to general representation 142, 272 on the basis of a two-channel representation of the regular audio objects.
The stereo downmix X, which is represented by the regular audio object signals 134, 264, 492a is processed into the modified downmix signal {circumflex over (X)}, which is represented by the processed regular audio object signals 142, 272:
{circumflex over (X)}=GX,
where
G=DTTTC3=DTTTMrenED*J.
The final stereo output from the SAOC transcoder {circumflex over (X)} is produced by mixing X with a decorrelated signal component according to:
{circumflex over (X)}=GModX+P2Xd,
where the decorrelated signal Xd is calculated as described above, and the mix matrices GMod and P2 according to below.
First, define the render upmix error matrix as
R=AdiffEA*diff,
where
Adiff=DTTTA3−GD,
and moreover define the covariance matrix of the predicted signal {circumflex over (R)} as
The gain vector gvec can subsequently be calculated as:
and the mix matrix GMod is given as:
Similarly, the mix matrix P2 is given as:
To derive vR and Wd, the characteristic equation of R needs to be solved:
det(R−λ1,2I)=0, giving the eigenvalues, λ1 and λ2.
The corresponding eigenvectors vR1 and vR2 of R can be calculated solving the equation system:
(R−λ1,2I)vR1,R2=0.
Eigenvalues are sorted in descending (λ1≧λ2) order and the eigenvector corresponding to the larger eigenvalue is calculated according to the equation above. It is assured to lie in the positive x-plane (first element has to be positive). The second eigenvector is obtained from the first by a −90 degrees rotation:
Incorporating P1=(1 1)G, Rd can be calculated according to:
which gives
and finally the mix matrix,
4.2.2.4 Dual Mode
The SAOC transcoder can let the mix matrices P1, P2 and the prediction matrix C3 be calculated according to an alternative scheme for the upper frequency range. This alternative scheme is particularly useful for downmix signals where the upper frequency range is coded by a non-waveform preserving coding algorithm e.g. SBR in High Efficiency AAC.
For the upper parameter bands, defined by bsTttBandsLow≦pb<numBands, P1, P2 and C3 should be calculated according to the alternative scheme described below:
Define the energy downmix and energy target vectors, respectively:
and the help matrix
Then calculate the gain vector
which finally gives the new prediction matrix
In the following, a brief description of the combined EKS SAOC processing scheme will be given. A “combined EKS SAOC” processing scheme is proposed, where the EKS processing is integrated into the regular SAOC decoding/transcoding chain by a cascaded scheme.
5.1. Audio Signal Encoder According to
In a first step, objects dedicated to EKS processing (enhanced Karaoke/solo processing) are identified as foreground objects (FGO) and their number NFGO (also designated as NEAO) is determined by a bitstream variable “bsNumGroupsFGO”. Said bitstream variable may, for example, be included in an SAOC bitstream, as described above.
For the generation of the bitstream (in an audio signal encoder), the parameters of all input objects Nobj are reordered such that the foreground objects FGO comprise the last NFGO (or alternatively, NEAO) parameters in each case, for example, OLDi for [Nobj−NFGO≦i≦Nobj−1].
From the remaining objects which are, for example, background objects BGO or non-enhanced audio objects, a downmix signal in the “regular SAOC style” is generated which at the same time serves as a background object BGO. Next, the background object and the foreground objects are downmixed in the “EKS processing style” and residual information is extracted from each foreground object. This way, no extra processing steps need to be introduced. Thus, no change of the bitstream syntax is necessitated.
In other words, at the encoder side, non-enhanced audio objects are distinguished from enhanced audio objects. A one-channel or two-channels regular audio objects downmix signal is provided which represents the regular audio objects (non-enhanced audio objects), wherein there may be one, two or even more regular audio objects (non-enhanced audio objects). The one-channel or two-channel regular audio object downmix signal is then combined with one or more enhanced audio object signals (which may, for example, be one-channel signals or two-channel signals), to obtain a common downmix signal (which may, for example, be a one-channel downmix signal or a two-channel downmix signal) combining the audio signals of the enhanced audio objects and the regular audio object downmix signal.
In the following, the basic structure of such a cascaded encoder will be briefly described taking reference to
The encoder 1000 also comprises a second SAOC downmixer 1020, which is typically configured to provide a residual information. The second SAOC downmixer 1020 is configured to receive one or more enhanced audio object signals 1022 and also to receive the regular audio object downmix signal 1014.
The second SAOC downmixer 1020 is also configured to provide a common SAOC downmix signal 1024 on the basis of the enhanced audio object signals 1022 and the regular audio object downmix signal 1014. When providing the common SAOC downmix signal, the second SAOC downmixer 1020 typically treats the regular audio object downmix signal 1014 as a single one-channel or two-channel object signal.
The second SAOC downmixer 1020 is also configured to provide an enhanced audio object SAOC information which describes, for example, downmix channel level difference values DCLD associated with the enhanced audio objects, object level difference values OLD associated with the enhanced audio objects and inter-object correlation values IOC associated with the enhanced audio objects. In addition, the second SAOC 1020 is configured to provide residual information associated with each of the enhanced audio objects, such that the residual information associated with the enhanced audio objects describes the difference between an original individual enhanced audio object signal and an expected individual enhanced audio object signal which can be extracted from the downmix signal using the downmix information DMG, DCLD and the object information OLD, IOC.
The audio encoder 1000 is well-suited for cooperation with the audio decoder described herein.
5.2. Audio Signal Decoder According to
In the following, the basic structure of a combined EKS SAOC decoder 500, a block schematic diagram of which is shown in
The audio decoder 500 according to
In the following, the functionality of the audio decoder 500 will be discussed in some more detail. At the SAOC decoding/transcoding side, the upmix process results in a cascaded scheme comprising firstly an enhanced Karaoke-Solo processing (EKS processing) to decompose the downmix signal into the background object (BOO) and foreground objects (FGOs). The necessitated object level differences (OLDs) and inter-object correlations (IOCs) for the background object are derived from the object and downmix information (which is both object-related parametric information, and which is both typically included in the SAOC bitstream):
In addition, this step (which is typically executed by the EKS processing and foreground object rendering 520) includes mapping the foreground objects to the final output channels (such that, for example, the first audio object signal 562 is a multi-channel signal in which the foreground objects are mapped to one or more channels each). The background object (which typically comprises a plurality of so-called “regular audio objects”) is rendered to the corresponding output channels by a regular SAOC decoding process (or, alternatively, in some cases by an SAOC transcoding process). This process may, for example, be performed by the regular SAOC decoding 570. The final mixing stage (for example, the combiner 580) provides a desired combination of rendered foreground objects and background object signals at the output.
This combined EKS SAOC system represents a combination of all beneficial properties of the regular SAOC system and its EKS mode. This approach allows to achieve the corresponding performance using the proposed system with the same bitstream for both classic (moderate rendering) and Karaoke/Solo-similar (extreme rendering) playback scenarios.
5.3. Generalized Structure According to
In the following, a generalized structure of a combined EKS SAOC system 590 will be described taking reference to
The combined EKS SAOC system 590 is configured to receive a downmix signal 510a, an SAOC bitstream information 512a and the rendering matrix information 514a. Also, the combined EKS SAOC system 590 is configured to provide an output signal 520a on the basis thereof.
The combined EKS SAOC system 590 comprises an SAOC type processing stage i 520a, which receives the downmix signal 510a, the SAOC bitstream information 512a (or at least a part thereof) and the rendering matrix information 514a (or at least a part thereof). In particular, the SAOC type processing stage I 520a receives first stage object level difference values (OLDs). The SAOC type processing stage I 520a provides one or more signals 562a describing a first set of objects (for example, audio objects of a first audio object type). The SAOC type processing stage I 520a also provides one or more signal 564a describing a second set of objects.
The combined EKS SAOC system also comprises an SAOC type processing stage II 570a, which is configured to receive the one or more signals 564a describing the second set of objects and to provide, on the basis thereof, one or more signals 572a describing a third set of objects using second stage object level differences, which are included in the SAOC bitstream information 512a, and also at least a part of the rendering matrix information 514. The combined EKS SAOC system also comprises a combiner 580a, which may, for example, be a summer, to provide the output signals 520a by combining the one or more signals 562a describing the first set of objects and the one or more signals 570a describing the third set of objects (wherein the third set of objects may be a processed version of the second set of objects).
To summarize the above,
6.1 Test Methodology, Design and Items
This subjective listening tests were conducted in an acoustically isolated listening room that is designed to permit high-quality listening. The playback was done using headphones (STAX SR Lambda Pro with Lake-People D/A-Converter and STAX SRM-Monitor). The test method followed the standard procedures used in the spatial audio verification tests, based on the “multiple stimulus with hidden reference and anchors” (MUSHRA) method for the subjective assessment of intermediate quality audio (see reference [7]).
A total of eight listeners participated in the performed test. All subjects can be considered experienced listeners. In accordance with the MUSHRA methodology, the listeners were instructed to compare all test conditions against the reference. The test conditions were randomized automatically for each test item and for each listener. The subjective responses were recorded by a computer-based MUSHRA program on a scale ranging from 0 to 100. An instantaneous switching between the items under test was allowed. The MUSHRA test has been conducted in order to assess the perceptual performance of the considered SAOC modes and the proposed system described in the table of
The corresponding downmix signals were coded using an AAC core-coder with a bitrate of 128 kbps. In order to assess the perceptual quality of the proposed combined EKS SAOC system, it is compared against the regular SAOC RM system (SAOC reference model system) and the current EKS mode (enhanced-Karaoke-Solo mode) for two different rendering test scenarios described in the table of
Residual coding with a bit rate of 20 kbps was applied for the current EKS mode and a proposed combined EKS SAOC system. It should be noted that for the current EKS mode it is necessitated to generate a stereo background object (BGO) prior to the actual encoding/decoding procedure, since this mode has limitations on the number and type of input objects.
The listening test material and the corresponding downmix and rendering parameters used in the performed tests have been selected from the set of the call-for-proposals (CfP) audio items described in the document [2]. The corresponding data for “Karaoke” and “Classic” rendering application scenarios can be found in the table of
6.2 Listening Test Results
A short overview in terms of the diagrams demonstrating the obtained listening test results can be found in
The following conclusions can be drawn based upon the results of the conducted listening tests:
Therefore, it can be concluded that the proposed unified system combining the EKS mode with the regular SAOC preserves the advantages in subjective audio quality for the corresponding types of a rendering.
Taking into account the fact that the proposed combined EKS SAOC system has no longer restrictions on the BGO object, but has entirely flexible rendering capability of the regular SAOC mode and can use the same bitstream for all types of rendering, it appears to be advantageous to incorporate it into the MPEG SAOC standard.
In the following, a method for providing an upmix signal representation in dependence on a downmix signal representation and an object-related parametric information will be described with reference to
The method 700 comprises a step 710 of decomposing a downmix signal representation, to provide a first audio information describing a first set of one or more audio objects of a first audio object type and a second audio information describing a second set of one or more audio objects of a second audio object type in dependence on the downmix signal representation and at least a part of the object-related parametric information. The method 700 also comprises a step 720 of processing the second audio information in dependence on the object-related parametric information, to obtain a processed version of the second audio information.
The method 700 also comprises a step 730 of combining the first audio information with the processed version of the second audio information, to obtain the upmix signal representation.
The method 700 according to
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. Some or all of the method steps may be executed by (or using) a hardware apparatus, like for example, a microprocessor, a programmable computer or an electronic circuit. In some embodiments, some one or more of the most important method steps may be executed by such an apparatus.
The inventive encoded audio 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 Blue-Ray, 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. Therefore, the digital storage medium may be computer readable.
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, 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. The data carrier, the digital storage medium or the recorded medium are typically tangible and/or non-transmitting.
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.
The above described embodiments are merely illustrative for the principles of the present invention. It is understood that modifications and variations of the arrangements and the details described herein will be apparent to others skilled in the art. It is the intent, therefore, to be limited only by the scope of the impending patent claims and not by the specific details presented by way of description and explanation of the embodiments herein.
In the following, some aspects and advantages of the combined EKS SAOC system according to the present invention will be briefly summarized. For Karaoke and Solo playback scenarios, the SAOC EKS processing mode supports both reproduction of the background objects/foreground objects exclusively and an arbitrary mixture (defined by the rendering matrix) of these object groups.
Also, the first mode is considered to be the main objective of EKS processing, the latter provides additional flexibility.
It has been found that a generalization of the EKS functionality consequently involves the effort of combining EKS with the regular SAOC processing mode to obtain one unified system. The potentials of such a unified system are:
These advantages can be obtained by the unified system described herein.
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.
This application is a continuation of copending International Application No. PCT/EP2010/058906, filed Jun. 23, 2010, which is incorporated herein by reference in its entirety, and additionally claims priority from U.S. Application No. 61/220,042, filed Jun. 24, 2009, which is also incorporated herein by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
20030236583 | Baumgarte et al. | Dec 2003 | A1 |
20070236858 | Disch et al. | Oct 2007 | A1 |
20080170711 | Breebaart et al. | Jul 2008 | A1 |
20080269929 | Oh et al. | Oct 2008 | A1 |
20090051637 | Chen et al. | Feb 2009 | A1 |
20090125313 | Hellmuth et al. | May 2009 | A1 |
20090125314 | Hellmuth et al. | May 2009 | A1 |
20090287495 | Breebaart et al. | Nov 2009 | A1 |
20100017195 | Villemoes | Jan 2010 | A1 |
20100094631 | Engdegard et al. | Apr 2010 | A1 |
Number | Date | Country |
---|---|---|
1647144 | Jul 2005 | CN |
200813981 | Mar 2008 | TW |
200910325 | Mar 2009 | TW |
200910328 | Mar 2009 | TW |
WO-2006016735 | Feb 2006 | WO |
2008060111 | May 2008 | WO |
Entry |
---|
Engdegord et al “Spatial Audio Object Codig (SAOC)—The Upcoming MPEG Standard on Parametric Object Based Audio Coding” 124th AES Convention, Audio Engineering Society, Paper 7377, May 17, 2008, pp. 1-15. |
ISO, “Study on ISO/IEC FCD 23003-2:200x, Spatial Audio Object Coding (SAOC)”, Apr. 2009, Hawaii, USA, p. 1-45. |
ISO/IEC JTC1/SC29/WG11 (MPEG), Document N8853, “Call for Proposals on Spatial Audio Object Coding”, 79th MPEG Meeting, Marrakech, Jan. 2007. |
ISO/IEC JTC1/SC29/WG11 (MPEG), Document N9099, “Final Spatial Audio Object Coding Evaluation Procedures and Criterion”, 80th MPEG Meeting, San Jose, Apr. 2007. |
ISO/IEC JTC1/SC29/WG11 (MPEG), Document N9250, “Report on Spatial Audio Object Coding RM0 Selection”, 81st MPEG Meeting, Lausanne, Jul. 2007. |
ISO/IEC JTC1/SC29/WG11 (MPEG), Document M15123, “Information and Verification Results for CE on Karaoke/Solo system improving the performance of MPEG SAOC RM0”, 83rd MPEG Meeting, Antalya, Turkey, Jan. 2008. |
ISO/IEC JTC1/SC29/WG11 (MPEG), Document N10659, “Study on ISO/IEC 23003-2:200x Spatial Audio Object Coding (SAOC)”, 88th MPEG Meeting, Maui, USA, Apr. 2009. |
ISO/IEC JTC1/SC29/WG11 (MPEG), Document M10660, “Status and Workplan on SAOC Core Experiments”, 88th MPEG Meeting Maui, USA, Apr. 2009. |
EBU Technical recommendation: “MUSHRA-EBU Method for Subjective Listening Tests of Intermediate Audio Quality”, Doc. B/AIM022, Oct. 1999. |
ISO/IEC 23003-1:2007, Information technology—MPEG audio technologies—Part 1: MPEG Surround. |
Engdegard J. et al: “Spatial Audio Object Coding (SAOC)—The Upcoming MPEG Standard on Parametric Object Based Audio Coding”, 124th AES Convention, Audio Engineering Society, Paper 7377, May 17, 2008, pp. 1-15. |
Number | Date | Country | |
---|---|---|---|
20120177204 A1 | Jul 2012 | US |
Number | Date | Country | |
---|---|---|---|
61220042 | Jun 2009 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2010/058906 | Jun 2010 | US |
Child | 13335047 | US |