In modern digital audio systems, it is a major trend to allow for audio-object related modifications of the transmitted content on the receiver side. These modifications include gain modifications of selected parts of the audio signal and/or spatial re-positioning of dedicated audio objects in case of multi-channel playback via spatially distributed speakers. This may be achieved by individually delivering different parts of the audio content to the different speakers.
In other words, in the art of audio processing, audio transmission, and audio storage, there is an increasing desire to allow for user interaction on object-oriented audio content playback and also a demand to utilize the extended possibilities of multi-channel playback to individually render audio contents or parts thereof in order to improve the hearing impression. By this, the usage of multi-channel audio content brings along significant improvements for the user. For example, a three-dimensional hearing impression can be obtained, which brings along an improved user satisfaction in entertainment applications. However, multi-channel audio content is also useful in professional environments, for example, in telephone conferencing applications, because the talker intelligibility can be improved by using a multi-channel audio playback. Another possible application is to offer to a listener of a musical piece to individually adjust playback level and/or spatial position of different parts (also termed as “audio objects”) or tracks, such as a vocal part or different instruments. The user may perform such an adjustment for reasons of personal taste, for easier transcribing one or more part(s) from the musical piece, educational purposes, karaoke, rehearsal, etc.
The straightforward discrete transmission of all digital multi-channel or multi-object audio content, e.g., in the form of pulse code modulation (PCM) data or even compressed audio formats, demands very high bitrates. However, it is also desirable to transmit and store audio data in a bitrate efficient way. Therefore, one is willing to accept a reasonable tradeoff between audio quality and bitrate requirements in order to avoid an excessive resource load caused by multi-channel/multi-object applications.
Recently, in the field of audio coding, parametric techniques for the bitrate-efficient transmission/storage of multi-channel/multi-object audio signals have been introduced by, e.g., the Moving Picture Experts Group (MPEG) and others. One example is MPEG Surround (MPS) as a channel oriented approach [MPS, BCC], or MPEG Spatial Audio Object Coding (SAOC) as an object oriented approach [JSC, SAOC, SAOC1, SAOC2]. Another object-oriented approach is termed as “informed source separation” [ISS1, ISS2, ISS3, ISS4, ISS5, ISS6]. These techniques aim at reconstructing a desired output audio scene or a desired audio source object on the basis of a downmix of channels/objects and additional side information describing the transmitted/stored audio scene and/or the audio source objects in the audio scene.
The estimation and the application of channel/object related side information in such systems is done in a time-frequency selective manner. Therefore, such systems employ time-frequency transforms such as the Discrete Fourier Transform (DFT), the Short Time Fourier Transform (STFT) or filter banks like Quadrature Mirror Filter (QMF) banks, etc. The basic principle of such systems is depicted in
In case of the STFT, the temporal dimension is represented by the time-block number and the spectral dimension is captured by the spectral coefficient (“bin”) number. In case of QMF, the temporal dimension is represented by the time-slot number and the spectral dimension is captured by the sub-band number. If the spectral resolution of the QMF is improved by subsequent application of a second filter stage, the entire filter bank is termed hybrid QMF and the fine resolution sub-bands are termed hybrid sub-bands.
As already mentioned above, in SAOC the general processing is carried out in a time-frequency selective way and can be described as follows within each frequency band, as depicted in
Increasing bandwidth/storage available and ongoing improvements in the field of audio coding allows the user to select from a steadily increasing choice of multi-channel audio productions. Multi-channel 5.1 audio formats are already standard in DVD and Blue-Ray productions. New audio formats like MPEG-H 3D Audio with even more audio transport channels appear at the horizon, which will provide the end-users a highly immersive audio experience.
Parametric audio object coding schemes are currently restricted to a maximum of two downmix channels. They can only be applied to some extend on multi-channel mixtures, for example on only two selected downmix channels. The flexibility these coding schemes offer to the user to adjust the audio scene to his/her own preferences is thus severely limited, e.g., with respect to changing audio level of the sports commentator and the atmosphere in sports broadcast.
Moreover, current audio object coding schemes offer only a limited variability in the mixing process at the encoder side. The mixing process is limited to time-variant mixing of the audio objects; and frequency-variant mixing is not possible.
It would therefore be highly appreciated if improved concepts for audio object coding would be provided.
According to an embodiment, a decoder for generating an audio output signal having one or more audio output channels from a downmix signal having one or more downmix channels, wherein the downmix signal encodes two or more audio object signals may have: a threshold determiner for determining a threshold value depending on a signal energy or a noise energy of at least one of the two or more audio object signals or depending on a signal energy or a noise energy of at least one of the one or more downmix channels, and a processing unit for generating the one or more audio output channels from the one or more downmix channels depending on the threshold value.
According to another embodiment, a method for generating an audio output signal having one or more audio output channels from a downmix signal having one or more downmix channels, wherein the downmix signal encodes two or more audio object signals may have the steps of: determining a threshold value depending on a signal energy or a noise energy of at least one of the two or more audio object signals or depending on a signal energy or a noise energy of at least one of the one or more downmix channels, and generating the one or more audio output channels from the one or more downmix channels depending on the threshold value.
Another embodiment may have a computer program for implementing the method of claim 13 when being executed on a computer or signal processor.
A decoder for generating an audio output signal comprising one or more audio output channels from a downmix signal comprising one or more downmix channels is provided. The downmix signal encodes one or more audio object signals. The decoder comprises a threshold determiner for determining a threshold value depending on a signal energy and/or a noise energy of at least one of the of or more audio object signals and/or depending on a signal energy and/or a noise energy of at least one of the one or more downmix channels. Moreover, the decoder comprises a processing unit for generating the one or more audio output channels from the one or more downmix channels depending on the threshold value.
According to an embodiment, the downmix signal may comprise two or more downmix channels, and the threshold determiner may be configured to determine the threshold value depending on a noise energy of each of the two or more downmix channels.
In an embodiment, the threshold determiner may be configured to determine the threshold value depending on the sum of all noise energy in the two or more downmix channels.
According to an embodiment, the downmix signal may encode two or more audio object signals, and the threshold determiner may be configured to determine the threshold value depending on a signal energy of the audio object signal of the two or more audio object signals which has the greatest signal energy of the two or more audio object signals.
In an embodiment, the downmix signal may comprise two or more downmix channels, and the threshold determiner may be configured to determine the threshold value depending on the sum of all noise energy in the two or more downmix channels.
According to an embodiment, the downmix signal may encode the one or more audio object signals for each time-frequency tile of a plurality of time-frequency tiles. The threshold determiner may be configured to determine a threshold value for each time-frequency tile of the plurality of time-frequency tiles depending on the signal energy or the noise energy of at least one of the of or more audio object signals or depending on the signal energy or the noise energy of at least one of the one or more downmix channels, wherein a first threshold value of a first time-frequency tile of the plurality of time-frequency tiles may differ from a second time-frequency time of the plurality of time-frequency tiles. The processing unit may be configured to generate for each time-frequency tile of the plurality of time-frequency tiles a channel value of each of the one or more audio output channels from the one or more downmix channels depending on the threshold value if said time-frequency tile.
In an embodiment, the decoder may be configured to determine the threshold value T in decibel according to the formula
T [dB]=Enoise [dB]−Eref [dB]−Z or according to the formula
T [dB]=Enoise [dB]−Eref [dB],
wherein T [dB] indicates the threshold value in decibel, wherein Enoise [dB] indicates the sum of all noise energy in the two or more downmix channels in decibel, wherein Eref [dB] indicates the signal energy of one of the audio object signals in decibel, and wherein Z indicates an additional parameter being a number. In an alternative embodiment, Enoise [dB] indicates the sum of all noise energy in the two or more downmix channels in decibel divided by the number of the downmix channels.
According to an embodiment, the decoder may be configured to determine the threshold value T according to the formula
wherein T indicates the threshold value, wherein Enoise indicates the sum of all noise energy in the two or more downmix channels, wherein Eref indicates the signal energy of one of the audio object signals, and wherein Z indicates an additional parameter being a number. In an alternative embodiment, Enoise [dB] indicates the sum of all noise energy in the two or more downmix channels divided by the number of the downmix channels.
According to an embodiment, the processing unit may be configured to generate the one or more audio output channels from the one or more downmix channels depending on an object covariance matrix (E) of the one or more audio object signals, depending on a downmix matrix (D) for downmixing the two or more audio object signals to obtain the two or more downmix channels, and depending on the threshold value.
In an embodiment, the processing unit is configured to generate the one or more audio output channels from the one or more downmix channels by applying the threshold value in a function to inverse a downmix channel cross correlation matrix Q, wherein Q is defined as Q=DED*, wherein D is the downmix matrix for downmixing the two or more audio object signals to obtain the two or more downmix channels, and wherein E is the object covariance matrix of the one or more audio object signals.
For example, the processing unit may be configured to generate the one or more audio output channels from the one or more downmix channels by computing the eigenvalues of the downmix channel cross correlation matrix Q or by calculating the singular values of the downmix channel cross correlation matrix Q.
E.g., the processing unit may be configured to generate the one or more audio output channels from the one or more downmix channels by multiplying the largest eigenvalue of the eigenvalues of the downmix channel cross correlation matrix Q with the threshold value to obtain a relative threshold.
For example, the processing unit may be configured to generate the one or more audio output channels from the one or more downmix channels by generating a modified matrix. The processing unit may be configured to generate the modified matrix depending on only those eigenvectors of the downmix channel cross correlation matrix Q, which have an eigenvalue of the eigenvalues of the downmix channel cross correlation matrix Q, which is greater than or equal to the modified threshold. Moreover, the processing unit may be configured to conduct a matrix inversion of the modified matrix to obtain an inverted matrix. Furthermore, the processing unit may be configured to apply the inverted matrix on one or more of the downmix channels to generate the one or more audio output channels.
Moreover, a method for generating an audio output signal comprising one or more audio output channels from a downmix signal comprising one or more downmix channels is provided. The downmix signal encodes one or more audio object signals. The decoder comprises:
Moreover, a computer program for implementing the above-described method when being executed on a computer or signal processor is provided.
Embodiments of the present invention will be detailed subsequently referring to the appended drawings, in which:
Before describing embodiments of the present invention, more background on state-of-the-art-SAOC systems is provided.
In the case of a stereo downmix, the channels of the downmix signal 18 are denoted L0 and R0, in case of a mono downmix same is simply denoted L0. In order to enable the SAOC decoder 12 to recover the individual objects s1 to sN, side-information estimator 17 provides the SAOC decoder 12 with side information including SAOC-parameters. For example, in case of a stereo downmix, the SAOC parameters comprise object level differences (OLD), inter-object correlations (IOC) (inter-object cross correlation parameters), downmix gain values (DMG) and downmix channel level differences (DCLD).
The side information 20, including the SAOC-parameters, along with the downmix signal 18, forms the SAOC output data stream received by the SAOC decoder 12.
The SAOC decoder 12 comprises an up-mixer which receives the downmix signal 18 as well as the side information 20 in order to recover and render the audio signals ŝ1 and ŝN onto any user-selected set of channels ŷ1 to ŝM, with the rendering being prescribed by rendering information 26 input into SAOC decoder 12.
The audio signals s1 to sN may be input into the encoder 10 in any coding domain, such as, in time or spectral domain. In case the audio signals s1 to sN are fed into the encoder 10 in the time domain, such as PCM coded, encoder 10 may use a filter bank, such as a hybrid QMF bank, in order to transfer the signals into a spectral domain, in which the audio signals are represented in several sub-bands associated with different spectral portions, at a specific filter bank resolution. If the audio signals s1 to sN are already in the representation expected by encoder 10, same does not have to perform the spectral decomposition.
More flexibility in the mixing process allows an optimal exploitation of signal object characteristics. A downmix can be produced which is optimized for the parametric separation at the decoder side regarding perceived quality.
The embodiments extends the parametric part of the SAOC scheme to an arbitrary number of downmix/upmix channels. The following figure provides overview of the Generalized Spatial Audio Object Coding (G-SAOC) parametric upmix concept:
Inter alia,
Let us consider the following common notation:
All introduced matrices are (in general) time and frequency variant.
In the following, the constitutive relationship for parametric upmixing is provided.
At first, general downmix/upmix concepts are provided with reference to
More particularly,
The ideal (modeled) rendered output scene signal z is defined as, see Fig (left):
Rx=z. (1)
The downmix audio signal y is determined as, see
Dx=y. (2)
The constitutive relationship (applied to the downmix audio signal) for the parametric output scene signal reconstruction can be represented as, see
Gy=z. (3)
The parametric upmix matrix can be defined from (1) and (2) as the following function of the downmix and rendering matrices G=G(D,R):
G=RED*(DED*)−1. (4)
In the following, improving the stability of the parametric source estimation according to embodiments is considered.
The parametric separation scheme within MPEG SAOC is based on a Least Mean Square (LMS) estimation of the sources in the mixture. The LMS estimation involves the inversion of the parametrically described downmix-channel covariance matrix Q=DED*. Algorithms for matrix inversion are in general sensitive to ill-conditioned matrices. The inversion of such a matrix can cause unnatural sounds, called artifacts, in the rendered output scene. A heuristically determined fixed threshold T in MPEG SAOC currently avoids this. Although artifacts are avoided by this method, a sufficient possible separation performance at the decoder side can thereby not be achieved.
The decoder comprises a threshold determiner 110 for determining a threshold value depending on a signal energy and/or a noise energy of at least one of the of or more audio object signals and/or depending on a signal energy and/or a noise energy of at least one of the one or more downmix channels.
Moreover, the decoder comprises a processing unit 120 for generating the one or more audio output channels from the one or more downmix channels depending on the threshold value.
In contrast to the state of the art, the threshold value determined by the threshold determiner 110 depends on a signal energy or a noise energy of the one or more downmix channels or of the encoded one or more audio object signals. In embodiments, as the signal and noise energies of the one or more downmix channels and/or of the one or more audio object signal values varies, so varies the threshold value, e.g., from time instance to time instance, or from time-frequency tile to time-frequency tile.
Embodiments provide an adaptive threshold method for matrix inversion to achieve an improved parametric separation of the audio objects at the decoder side. The separation performance is on the average better but never less the currently utilized fixed threshold scheme used in MPEG SAOC in the algorithm for inverting the Q matrix.
The threshold T is dynamically adapted to the precision of the data for each processed time-frequency tile. Separation performance is thus improved and artifacts in the rendered output scene caused by inversion of ill-conditioned matrices are avoided.
According to an embodiment, the downmix signal may comprise two or more downmix channels, and the threshold determiner 110 may be configured to determine the threshold value depending on a noise energy of each of the two or more downmix channels.
In an embodiment, the threshold determiner 110 may be configured to determine the threshold value depending on the sum of all noise energy in the two or more downmix channels.
According to an embodiment, the downmix signal may encode two or more audio object signals, and the threshold determiner 110 may be configured to determine the threshold value depending on a signal energy of the audio object signal of the two or more audio object signals which has the greatest signal energy of the two or more audio object signals.
In an embodiment, the downmix signal may comprise two or more downmix channels, and the threshold determiner 110 may be configured to determine the threshold value depending on the sum of all noise energy in the two or more downmix channels.
According to an embodiment, the downmix signal may encode the one or more audio object signals for each time-frequency tile of a plurality of time-frequency tiles. The threshold determiner 110 may be configured to determine a threshold value for each time-frequency tile of the plurality of time-frequency tiles depending on the signal energy or the noise energy of at least one of the of or more audio object signals or depending on the signal energy or the noise energy of at least one of the one or more downmix channels, wherein a first threshold value of a first time-frequency tile of the plurality of time-frequency tiles may differ from a second time-frequency time of the plurality of time-frequency tiles. The processing unit 120 may be configured to generate for each time-frequency tile of the plurality of time-frequency tiles a channel value of each of the one or more audio output channels from the one or more downmix channels depending on the threshold value if said time-frequency tile.
According to an embodiment, the decoder may be configured to determine the threshold value T according to the formula
wherein T indicates the threshold value, wherein Enoise indicates the sum of all noise energy in the two or more downmix channels, wherein Eref indicates the signal energy of one of the audio object signals, and wherein Z indicates an additional parameter being a number. In an alternative embodiment, Enoise indicates the sum of all noise energy in the two or more downmix channels divided by the number of the downmix channels.
In an embodiment, the decoder may be configured to determine the threshold value T in decibel according to the formula
T [dB]=Enoise [dB]−Eref [dB]−Z or according to the formula
T [dB]=Enoise [dB]−Eref [dB],
wherein T [dB] indicates the threshold value in decibel, wherein Enoise [dB] indicates the sum of all noise energy in the two or more downmix channels in decibel, wherein Eref [dB] indicates the signal energy of one of the audio object signals in decibel, and wherein Z indicates an additional parameter being a number. In an alternative embodiment, Enoise [dB] indicates the sum of all noise energy in the two or more downmix channels in decibel divided by the number of the downmix channels.
In particular, a rough estimation of the threshold can be given for each time-frequency tile by:
T [dB]=Enoise [dB]−Eref [dB]−Z. (5)
Enoise may indicate the noise floor level, e.g., the sum of all noise energy in the downmix channels. The noise floor can be defined by the resolution of the audio data, e.g., a noise floor caused by PCM-coding of the channels. Another possibility is to account for coding noise if the downmix is compressed. For such a case, the noise floor caused by the coding algorithm can be added. In an alternative embodiment, Enoise [dB] indicates the sum of all noise energy in the two or more downmix channels in decibel divided by the number of the downmix channels.
Eref may indicate a reference signal energy. In the simplest form, this can be the energy of the strongest audio object:
E
ref=max(E). (6)
Z may indicate a penalty factor to cope for additional parameters that affect the separation resolution, e.g. the difference of the number of downmix channels and number of source objects. Separation performance decreases with increasing number of audio objects. Moreover, the effects of the quantization of the parametric side info on the separation can also be included.
In an embodiment, the processing unit 120 is configured to generate the one or more audio output channels from the one or more downmix channels depending on the object covariance matrix E of the one or more audio object signals, depending on the downmix matrix D for downmixing the two or more audio object signals to obtain the two or more downmix channels, and depending on the threshold value.
According to an embodiment, for generating the one or more audio output channels from the one or more downmix channels depending on the threshold value, the processing unit 120 may be configured to proceed as follows:
The threshold (which may be referred to as a “separation-resolution threshold”) is applied at the decoder side in the function to inverse the parametrically estimated downmix channel cross correlation matrix Q.
The singular values of Q or the eigenvalues of Q are computed.
The largest eigenvalue is taken and multiplied with the threshold T.
All except the largest eigenvalue are compared to this relative threshold and omitted if they are smaller.
The matrix inversion is then carried out on a modified matrix, wherein the modified matrix may, for example, be the matrix defined by the reduced set of vectors. It should be noted that for the case that all except the highest eigenvalue are omitted, the highest eigenvalue should be set to the noise floor level if the eigenvalue is below.
For example, the processing unit 120 may be configured to generate the one or more audio output channels from the one or more downmix channels by generating the modified matrix. The modified matrix may be generated depending on only those eigenvectors of the downmix channel cross correlation matrix Q, which have an eigenvalue of the eigenvalues of the downmix channel cross correlation matrix Q, which is greater than or equal to the modified threshold. The processing unit 120 may be configured to conduct a matrix inversion of the modified matrix to obtain an inverted matrix. Then, the processing unit 120 may be configured to apply the inverted matrix on one or more of the downmix channels to generate the one or more audio output channels. For example, the inverted matrix may be applied on one or more of the downmix channels in one of the ways as the inverted matrix of the matrix product DED* is applied on the downmix channels (see, e.g. [SAOC], see, in particular, for example: ISO/IEC, “MPEG audio technologies—Part 2: Spatial Audio Object Coding (SAOC),” ISO/IEC JTC1/SC29/WG11 (MPEG) International Standard 23003-2:2010, in particular, see, chapter “SAOC Processing”, more particularly, see subchapter “Transcoding modes” and subchapter “Decoding modes”).
The parameters which may be employed for estimating the threshold T can be either determined at the encoder and embedded in the parametric side information or estimated directly at the decoder side.
A simplified version of the threshold estimator can be used at the encoder side to indicate potential instabilities in the source estimation at the decoder side. In its simplest form, neglecting all noise terms, the norm of the downmix matrix can be computed indicating that the full potential of the available downmix channels for parametrically estimating the source signals at the decoder side cannot be exploited. Such an indicator can be used during the mixing process to avoid mixing matrices that are critical for estimating the source signals.
Regarding parameterization of the object covariance matrix, one can see that the described parametric upmix method based on the constitutive relationship (4) is invariant to the sign of off-diagonal entities of the object covariance matrix E. This results in possibility of more efficient (in comparison with SAOC) parameterization (quantization and coding) of the values representing inter-object correlations.
Regarding transport of information representing the downmix matrix, generally, the audio input and downmix signals x, y together with the covariance matrix E are determined at the encoder side. The coded representation of the audio downmix signal y and information describing covariance matrix E are transmitted to the decoder side (via bitstream payload). The rendering matrix R is set and available at the decoder side.
The information representing the downmix matrix D (applied at the encoder and used as the decoder) can be determined (at the encoder) and obtained (at the decoder) using the following principle methods.
The downmix matrix D can be:
The provided embodiments can be applied on an arbitrary number of downmix/upmix channels. It can be combined with any current and also future audio formats.
The flexibility of the inventive method allows bypassing of unaltered channels to reduce computational complexity, reduce bitstream payload/reduced data amount.
An audio encoder, method or computer program for encoding is provided. Moreover, an audio decoder, method or computer program for decoding is provided. Furthermore, an encoded signal is provided.
Although some aspects have been described in the context of an apparatus, it is clear that these aspects also represent a description of the corresponding method, where a block or device corresponds to a method step or a feature of a method step. Analogously, aspects described in the context of a method step also represent a description of a corresponding block or item or feature of a corresponding apparatus.
The inventive decomposed signal can be stored on a digital storage medium or can be transmitted on a transmission medium such as a wireless transmission medium or a wired transmission medium such as the Internet.
Depending on certain implementation requirements, embodiments of the invention can be implemented in hardware or in software. The implementation can be performed using a digital storage medium, for example a floppy disk, a DVD, a CD, a ROM, a PROM, an EPROM, an EEPROM or a FLASH memory, having electronically readable control signals stored thereon, which cooperate (or are capable of cooperating) with a programmable computer system such that the respective method is performed.
Some embodiments according to the invention comprise a non-transitory data carrier having electronically readable control signals, which are capable of cooperating with a programmable computer system, such that one of the methods described herein is performed.
Generally, embodiments of the present invention can be implemented as a computer program product with a program code, the program code being operative for performing one of the methods when the computer program product runs on a computer. The program code may for example be stored on a machine readable carrier.
Other embodiments comprise the computer program for performing one of the methods described herein, stored on a machine readable carrier.
In other words, an embodiment of the inventive method is, therefore, a computer program having a program code for performing one of the methods described herein, when the computer program runs on a computer.
A further embodiment of the inventive methods is, therefore, a data carrier (or a digital storage medium, or a computer-readable medium) comprising, recorded thereon, the computer program for performing one of the methods described herein.
A further embodiment of the inventive method is, therefore, a data stream or a sequence of signals representing the computer program for performing one of the methods described herein. The data stream or the sequence of signals may for example be configured to be transferred via a data communication connection, for example via the Internet.
A further embodiment comprises a processing means, for example a computer, or a programmable logic device, configured to or adapted to perform one of the methods described herein.
A further embodiment comprises a computer having installed thereon the computer program for performing one of the methods described herein.
In some embodiments, a programmable logic device (for example a field programmable gate array) may be used to perform some or all of the functionalities of the methods described herein. In some embodiments, a field programmable gate array may cooperate with a microprocessor in order to perform one of the methods described herein. Generally, the methods are advantageously performed by any hardware apparatus.
While this invention has been described in terms of several embodiments, there are alterations, permutations, and equivalents which fall within the scope of this invention. It should also be noted that there are many alternative ways of implementing the methods and compositions of the present invention. It is therefore intended that the following appended claims be interpreted as including all such alterations, permutations and equivalents as fall within the true spirit and scope of the present invention.
This application is a continuation of copending International Application No. PCT/EP2013/066405, filed Aug. 5, 2013, which claims priority from U.S. Provisional Application No. 61/679,404, filed Aug. 3, 2012, each of which is incorporated herein in its entirety by this reference thereto. The present invention relates to an apparatus and a method for a generalized spatial-audio-object-coding parametric concept for multichannel downmix/upmix cases.
Number | Date | Country | |
---|---|---|---|
61679404 | Aug 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2013/066405 | Aug 2013 | US |
Child | 14608139 | US |