The invention refers to an apparatus and a method for processing an encoded audio signal.
Recently, parametric techniques for the bitrate-efficient transmission/storage of audio scenes containing multiple audio objects have been proposed in the field of audio coding (see the following references [BCC, JSC, SAOC, SAOC1, SAOC2]) and informed source separation (see e.g. the following references [ISS1, ISS2, ISS3, ISS4, ISS5, ISS6]).
These techniques aim at reconstructing a desired output audio scene or audio source objects based on additional side information describing the transmitted/stored audio signals and/or source objects in the audio scene. This reconstruction takes place in the decoder using a parametric informed source separation scheme.
Unfortunately, it has been found that in some cases the parametric separation schemes can lead to severe audible artifacts causing an unsatisfactory hearing experience.
According to an embodiment, an apparatus for processing an encoded audio signal including a plurality of downmix signals associated with a plurality of input audio objects and object parameters E may have: a grouper configured to group said plurality of downmix signals into a plurality of groups of downmix signals associated with a set of input audio objects of said plurality of input audio objects, a processor configured to perform at least one processing step individually on the object parameters Ek of each set of input audio objects in order to provide group results, and a combiner configured to combine said group results or processed group results in order to provide a decoded audio signal.
According to another embodiment, a method for processing an encoded audio signal including a plurality of downmix signals associated with a plurality of input audio objects and object parameters E may have the steps of: grouping said downmix signals into a plurality of groups of downmix signals associated with a set of input audio objects of said plurality of input audio objects, performing at least one processing step individually on the object parameters Ek of each set of input audio objects in order to provide group results, and combining said group results in order to provide a decoded audio signal.
The grouper is configured to group the plurality of downmix signals into a plurality of groups of downmix signals. Each group of downmix signals is associated with a set of input audio objects (or input audio signals) of the plurality of input audio objects. In other words: the groups cover sub-sets of the set of the input audio signals represented by the encoded audio signal. Each group of downmix signals is also associated with some of the object parameters E describing the input audio objects. In the following, the individual groups Gk are identified with an index k with 1≤k≤K with K as the number of groups of downmix signals.
Further, the processor—following the grouping—is configured to perform at least one processing step individually the object parameters of each set of input audio objects. Hence, at least one processing step is performed not simultaneously on all object parameters but individually on the object parameters belonging to the respective group of downmix signals. In one embodiment just one step is performed individually. In a different embodiment more than one step is performed, whereas in an alternative embodiment, the entire processing is performed individually on the groups on downmix signals. The processor provides group results for the individual groups.
In a different embodiment, the processor—following the grouping—is configured to perform at least one processing step individually on each group of the plurality of groups of downmix signals. Hence, at least one processing step is performed not simultaneously on all downmix signals but individually on the respective groups of downmix signals.
Eventually, the combiner is configured to combine the group results or processed group results in order to provide a decoded audio signal. Hence, the group results or the results of further processing steps performed on the group results are combined to provide a decoded audio signal. The decoded audio signal corresponds to the plurality of input audio objects which are encoded by the encoded audio signal.
The grouping done by the grouper is done at least under the constriction that each input audio object of the plurality of input audio objects belongs to just or exactly one set of input audio objects. This implies that each input audio object belongs to just one group of downmix signals. This also implies that each downmix signal belongs to just one group of downmix signals.
According to an embodiment, the grouper is configured to group the plurality of downmix signals into the plurality of groups of downmix signals so that each input audio object of each set of input audio objects either is free from a relation signaled in the encoded audio signal with other input audio objects or has a relation signaled in the encoded audio signal only with at least one input audio object belonging to the same set of input audio objects. This implies that no input audio object has a signaled relation to an input audio object belonging to a different group of downmix signals. Such a signaled relation is in one embodiment that two input audio objects are the stereo signals stemming from one single source.
The inventive apparatus processes an encoded audio signal comprising downmix signals. Downmixing is a part of the process of encoding a given number of individual audio signals and implies that a certain number of input audio objects is combined into a downmixing signal. The number of input audio objects is, thus, reduced to a smaller number of downmix signals. Due to this are the downmix signals associated with a plurality of input audio objects.
The downmix signals are grouped into groups of downmix signals and are subjected individually—i.e. as single groups—to at least one processing step. Hence, the apparatus performs at least one processing step not jointly on all downmix signals but individually on the individual groups of downmix signals. In a different embodiment the object parameters of the groups are treated separately in order to obtain the matrices to be applied to the encoded audio signal.
In one embodiment is the apparatus a decoder of encoded audio signals. The apparatus is in an alternative embodiment a part of a decoder.
In one embodiment, each downmix signal is attributed to one group of downmix signals and is, consequently, processed individually with respect to at least one processing step. In this embodiment the number of groups of downmix signals equals the number of downmix signals. This implies that the grouping and the individual processing coincide.
In one embodiment the combination is one of the final steps of the processing of the encoded audio signal. In a different embodiment, the group results are further subjected to different processing steps which are either performed individually or jointly on the group results.
The grouping (or the detection of the groups) and the individual treatment of the groups have shown to lead to an audio quality improvement. This especially holds, e.g., for parametric coding techniques.
According to an embodiment, the grouper of the apparatus is configured to group the plurality of downmix signals into the plurality of groups of downmix signals while minimizing a number of downmix signals within each group of downmix signals. In this embodiment, the apparatus tries to reduce the number of downmix signals belonging to each group. In one case, to at least one group of downmix signals belongs just one downmix signal.
According to an embodiment, the grouper is configured to group said plurality of downmix signals into said plurality of groups of downmix signals so that just one single downmix signal belongs to one group of downmix signals. In other words: The grouping leads to various groups of downmix signals wherein at least one group of downmix signal is given to which just one downmix signal belongs. Thus, at least one group of downmix signals refers to just one single downmix signal. In a further embodiment, the number of groups of downmix signals to which just one downmix signals belongs is maximized.
In one embodiment, the grouper of the apparatus is configured to group the plurality of downmix signals into the plurality of groups of downmix signals based on information within the encoded audio signal. In a further embodiment, the apparatus uses only information within the encoded audio signal for grouping the downmix signals. Using the information within the bitstream of the encoded audio signal comprises—in one embodiment—taking the correlation or covariance information into account. The grouper, especially, extracts from the encoded audio signal the information about the relation between different input audio objects.
In one embodiment, the grouper is configured to group said plurality of downmix signals into said plurality of groups of downmix signals based on bsRelatedTo-values within said encoded audio signal. Concerning these values refer, for example, to WO 2011/039195 A1.
According to an embodiment, the grouper is configured to group the plurality of downmix signals into the plurality of groups of downmix signals by applying at least the following steps (to each group of downmix signals):
If a relation signaled in the encoded audio signal is also taken into account, then another detecting step will be added leading to an addition requirement for assigning and combining the downmix signals.
According to an embodiment, the processor is configured to perform various processing steps individually on the object parameters (Ek) of each set of input audio objects (or of each group of downmix signals) in order to provide individual matrices as group results. The combiner is configured to combine the individual matrices in order to provide said decoded audio signal. The object parameters (Ek) belong to the input audio objects of the respective group of downmix signals with index k and are processed to obtain individual matrices for this group having index k.
According to a different embodiment, the processor is configured to perform various processing steps individually on each group of said plurality of groups of downmix signals in order to provide output audio signals as group results. The combiner is configured to combine the output audio signals in order to provide said decoded audio signal.
In this embodiment the groups of downmix signals are such processed that the output audio signals are obtained which correspond to the input audio objects belonging to the respective group of downmix signals. Hence, combining the output audio signals to the decoded audio signals is close to the final steps of the decoding processes performed on the encoded audio signal. In this embodiment, thus, each group of downmix signals is individually subjected to all processing steps following the detection of the groups of downmix signals.
In a different embodiment, the processor is configured to perform at least one processing step individually on each group of said plurality of groups of downmix signals in order to provide processed signals as group results. The apparatus further comprises a post-processor configured to process jointly said processed signals in order to provide output audio signals. The combiner is configured to combine the output audio signals as processed group results in order to provide said decoded audio signal.
In this embodiment the groups of downmix signal are subjected to at least one processing step individually and to at least one processing step jointly with other groups. The individual processing leads to processed signals which—in an embodiment—are processed jointly.
Referring to the matrices, in one embodiment, the processor is configured to perform at least one processing step individually on the object parameters (Ek) of each set of input audio objects in order to provide individual matrices. A post-processor comprised by the apparatus is configured to process jointly object parameters in order to provide at least one overall matrix. The combiner is configured to combine said individual matrices and said at least one overall matrix. In one embodiment the post-processors performs at least one processing step jointly on the individual matrices in order to obtain at least one overall matrix.
The following embodiments refer to processing steps performed by the processor. Some of these steps are also suitable for the post-processor mentioned in the foregoing embodiment.
In one embodiment, the processor comprises an un-mixer configured to un-mix the downmix signals of the respective groups of said plurality of groups of downmix signals. By un-mixing the downmix signals the processor obtains representations of the original input audio objects which were down-mixed into the downmix signal.
According to an embodiment, the un-mixer is configured to un-mix the downmix signals of the respective groups of said plurality of groups of downmix signals based on a Minimum Mean Squared Error (MMSE) algorithm. Such an algorithm will be explained in the following description.
In a different embodiment, wherein the processor comprises an un-mixer configured to process the object parameters of each set of input audio objects individually in order to provide individual un-mix matrices.
In one embodiment, the processor comprises a calculator configured to compute individually for each group of downmix signals matrices with sizes depending on at least one of a number of input audio objects of the set of input audio objects associated with the respective group of downmix signals and a number of downmix signals belonging to the respective group of downmix signals. As the groups of downmix signals are smaller than the entire ensemble of downmix signals and as the groups of downmix signals refer to smaller numbers of input audio signals, the matrices used for the processing of the groups of downmix signals are smaller than these used in the state of art. This facilitates the computation.
According to an embodiment, the calculator is configured to compute for the individual unmixing matrices an individual threshold based on a maximum energy value within the respective group of downmix signals.
According to an embodiment, the processor is configured to compute an individual threshold based on a maximum energy value within the respective group of downmix signals for each group of downmix signals individually.
In one embodiment, the calculator is configured to compute for a regularization step for un-mixing the downmix signals of each group of downmix signals an individual threshold based on a maximum energy value within the respective group of downmix signals. The thresholds for the groups of downmix signals are computed in a different embodiment by the un-mixer itself.
The following discussion will show the interesting effect of computing the threshold for the groups (one threshold for each group) and not for all downmix signals.
According to an embodiment, the processor comprises a renderer configured to render the un-mixed downmix signals of the respective groups for an output situation of said decoded audio signal in order to provide rendered signals. The rendering is based on input provided by the listener or based on data about the actual output situation.
In an embodiment, the processor comprises a renderer configured to process the object parameters in order to provide at least one render matrix.
The processor comprises in an embodiment a post-mixer configured to process the object parameters in order to provide at least one decorrelation matrix.
According to an embodiment, the processor comprises a post-mixer configured to perform at least one decorrelation step on said rendered signals and configured to combine results (Ywet) of the performed decorrelation step with said respective rendered signals (Ydry).
According to an embodiment, the processor is configured to determine an individual downmixing matrix (Dk) for each group of downmix signals (k being the index of the respective group), the processor is configured to determine an individual group covariance matrix (Ek) for each group of downmix signals, the processor is configured to determine an individual group downmix covariance matrix (Δk) for each group of downmix signals based on the individual downmixing matrix (Dk) and the individual group covariance matrix (Ek), and the processor is configured to determine an individual regularized inverse group matrix (Jk) for each group of downmix signals.
According to an embodiment, the combiner is configured to combine the individual regularized inverse group matrices (Jk) to obtain an overall regularized inverse group matrix (J).
According to an embodiment, the processor is configured to determine an individual group parametric un-mixing matrix (Uk) for each group of downmix signals based on the individual downmixing matrix (Dk), the individual group covariance matrix (Ek), and the individual regularized inverse group matrix (Jk), and the combiner is configured to combine the an individual group parametric un-mixing matrix (Uk) to obtain an overall group parametric unmixing matrix (U).
According to an embodiment, the processor is configured to determine an individual group parametric un-mixing matrix (Uk) for each group of downmix signals based on the individual downmixing matrix (Dk), the individual group covariance matrix (Ek), and the individual regularized inverse group matrix (Jk), and the combiner is configured to combine the individual group parametric un-mixing matrix (Uk) to obtain an overall group parametric unmixing matrix (U).
According to an embodiment, the processor is configured to determine an individual group rendering matrix (Rk) for each group of downmix signals.
According to an embodiment, the processor is configured to determine an individual upmixing matrix (RkUk) for each group of downmix signals based on the individual group rendering matrix (Rk) and the individual group parametric un-mixing matrix (Uk), and the combiner is configured to combine the individual upmixing matrices (RkUk) to obtain an overall upmixing matrix (RU).
According to an embodiment, the processor is configured to determine an individual group covariance matrix (Ck) for each group of downmix signals based on the individual group rendering matrix (Rk) and the individual group covariance matrix (Ek),and the combiner is configured to combine the individual group covariance matrices (Ck) to obtain an overall group covariance matrix (C).
According to an embodiment, the processor is configured to determine an individual group covariance matrix of the parametrically estimated signal (Eydry)k based on the individual group rendering matrix (Rk), the individual group parametric un-mixing matrix (Uk), the individual downmixing matrix (Dk), and the individual group covariance matrix (Ek),and the combiner is configured to combine the individual group covariance matrices of the parametrically estimated signal (Eydry)k to obtain an overall parametrically estimated signal Eydry.
According to an embodiment, the processor is configured to determine a regularized inverse matrix (J) based on a singular value decomposition of a downmix covariance matrix (EDMX).
According to an embodiment, the processor is configured to determine sub-matrix (Δk) for a determination of a parametric un-mixing matrix (U), by selecting elements (Δ(m, n)) corresponding to the downmix signals (m, n) assigned to the respective group (having index k) of downmix signals. Each group of downmix signals covers a specified number of downmix signals and an associated set of input audio objects and is denoted here by an index k.
According to this embodiment, the individual sub-matrices (Δk) are obtained by selecting or picking the elements from the downmix covariance matrix Δ which belong to the respective group k.
In one embodiment, the individual sub-matrices (Δk) are inverted individually and the results are combined in the regularized inverse matrix (J).
In a different embodiment, the sub-matrix (Δk) are obtained using their definition as Δk=DkEkDk* with the individual the individual downmixing matrix (Dk)
According to an embodiment, the combiner is configured to determine a post-mixing matrix (P) based on the individually determined matrices for each group of downmix signals and the combiner is configured to apply the post-mixing matrix (P) to the plurality of downmix signals in order to obtain the decoded audio signal. In this embodiment, from the objects parameters a post-mixing matrix is computed which is applied to the encoded audio signal in order to obtain the decoded audio signal.
According to one embodiment, the apparatus and its respective components are configured to perform for each group of downmix signals individually at least one of the following computations:
In this respect, k denotes a group index of the respective group of downmix signals, Nk denotes the number of input audio objects of the associated set of input audio objects, Mk denotes the number of downmix signals belonging to the respective group of downmix signals, and Nout denotes the number of upmixed or rendered output channels.
The computed matrices are in size smaller than those used in the state of art. Accordingly, in one embodiment as many as possible processing steps are performed individually on the groups of downmix signals.
The object of the invention is also achieved by a corresponding method for processing an encoded audio signal. The encoded audio signal comprises a plurality of downmix signals associated with a plurality of input audio objects and object parameters. The method comprises the following steps:
The grouping is performed with at least the constriction that each input audio object of the plurality of input audio objects belongs to just one set of input audio objects.
The above mentioned embodiments of the apparatus can also be performed by steps of the method and corresponding embodiments of the method. Therefore, the explanations given for the embodiments of the apparatus also hold for the method.
Embodiments of the present invention will be detailed subsequently referring to the appended drawings, in which:
In the following an overview on parametric separation schemes will be given, using the example of MPEG Spatial Audio Object Coding (SAOC) technology ([SAOC]) and SAOC 3D processing part of MPEG-H 3D Audio ([SAOC3D, SAOC3D2]). The mathematical properties of these methods are considered.
Without loss of generality, in order to improve readability of equations, for all introduced variables the indices denoting time and frequency dependency are omitted.
Parametric Object Separation Systems:
General parametric separation schemes aim to estimate a number of audio sources from signal mixture (downmix) using auxiliary parametric information. Typical solution of this task is based on application of the Minimum Mean Squared Error (MMSE) estimation algorithms. The SAOC technology is one example of such parametric audio coding systems.
The general parametric downmix/upmix processing is carried out in a time/frequency selective way and can be described as a sequence of the following steps:
The “decoder” restores the original “audio objects” from the decoded “downmix signals” using the transmitted side information (this information provides the object parameters). The “side info processor” estimates the un-mixing coefficients to be applied on the “downmix signals” within “parametric object separator” to obtain the parametric object reconstruction of S. The reconstructed “audio objects” are rendered to a (multi-channel) target scene, represented by the output channels Y, by applying a “rendering parameters” R.
Same general principle and sequential steps are applied in SAOC 3D processing, which incorporates an additional decorrelation path.
Using the example of SAOC 3D technique, part of MPEG-H 3D Audio, the main processing steps of such a parametric separation system can be summarized as follows:
The SAOC 3D decoder produces the modified rendered output Y as a mixture of the parametrically reconstructed and rendered signal (dry signal) Ydry and its decorrelated version (wet signal) Ywet.
The—for the discussion of the invention relevant—processing steps can be differentiated as illustrated in
The parametric object separation is obtained from the downmix signal X using the unmixing matrix U based on the additional side information: Ŝ=UX.
The rendering information R is used to obtain the dry signal as: Ydry=RŜ=RUX.
The final output signal Y is computed from the signals Ydry and Ywet as
The mixing matrix P is computed, for example, based on rendering information, correlation information, energy information, covariance information, etc.
In the invention, this will be the post-mixing matrix applied to the encoded audio signal in order to obtain the decoded audio signal.
In the following, the common parametric object separation operation using MMSE will be explained.
The un-mixing matrix U is obtained based on information derived from variables contained in the bitstream (for example the downmixing matrix D and the covariance information E), using the Minimum Mean Squared Error (MMSE) estimation algorithm: U=ED*J.
The matrix J of size Ndmx times Ndmx represents an approximation of the pseudo-inverse of the downmix covariance matrix EDMX=DED* as: J≈EDMX−1.
The computation of the matrix J is derived according to: J=V Λinv V*,
where the matrices V and Λ are determined using the singular value decomposition (SVD) of the matrix EDMX as: EDMX=V ΛV*.
To be noted that similar results can be obtained using different decomposition methods such as: eigenvalue decomposition, Schur decomposition, etc.
The regularized inverse operation (⋅)inv, used for the diagonal singular value matrix Λ, can be determined, for example, as done in SAOC 3D, using a truncation of the singular values relative to the highest singular value:
In a different embodiment, the following formula is used:
The relative regularization scalar TregΛ is determined using absolute threshold Treg and maximal value of Λ as:
with Treg=10−2, for example.
Depending on definition of the singular values, λi,i can be restricted only to positive values (if λi,i<0 then λi,i=abs(λi,i) and sign (λi,i) is multiplied with the corresponding left or right singular vector) or negative values can be allowed.
In the second case with negative values of λi,i the relative regularization scalar TregΛ is computed as:
For simplicity, in the following the second definition of TregΛ will be used.
Similar results can be obtained using truncation of the singular values relative to an absolute value or other regularization methods used for matrix inversion.
Inversion of very small singular values may lead to very high un-mixing coefficients and consequently to high amplifications of the corresponding downmix channels. In such a case, channels with very small energy levels may be amplified using high gains and this may lead to audible artifacts. In order to reduce this undesired effect, the singular values smaller than the relative threshold TregΛ are truncated to zero.
Now, the discovered drawbacks in parametric object separation technique of the state of art are explained.
The described state of the art parametric object separation methods specify using regularized inversion of the downmix covariance matrix in order to avoid separation artifacts. However, for some real use case mixing scenarios, harmful artifacts caused by too aggressive regularization were identified in the output of the system.
In the following an example of such a scenario is constructed and analyzed.
A number N=5 of input audio objects (S) are encoded using the described technique (more precisely, the method of SAOC 3D processing part of MPEG-H 3D Audio) into a number Ndmx=3 of downmix channels (X).
The input audio objects of the example may consist of:
The input signals are downmixed into three groups of transport channels:
such that Ndmx=M1+M2+M3.
The downmixing matrices Dk corresponding to each group Gk, for k=1, 2, 3, are constructed using unitary mixing gains, and the complete downmixing matrix D is given by:
One can note the absence of cross-mixing between the group of first two object signals, the third object signal, and the group of the last two object signals. Also note that the third object signal containing the speech is mixed alone into one downmix channel. Therefore, a good reconstruction of this object is expected and consequently also a good rendering. The spectrograms of the input signals and the obtained downmix signal are illustrated in
The possible downmix signal core coding used in a real system is omitted here for better outlining of the undesired effect. At the decoder side the SAOC 3D parametric decoding is used to reconstruct and to render the audio object signals to a 3-channel setup (Nout=3): Left (L), Center (C), and Right (R) channels.
A simple remix of the input audio objects of the example is used in the following:
Accordingly, the rendering matrix used is given by:
The reference output can be computed by applying the specified rendering matrix directly to the input signals: Yref=RS.
The spectrograms of the reference output and the output signals from SAOC 3D decoding and rendering are illustrated by the two columns of
From the shown spectrograms of the SAOC 3D decoder output, the following observations can be noted:
Based on the mentioned observations, it can be concluded that:
The spectral gaps, especially the ones in the center channel, indicate that some useful information contained in the downmix channels is discarded by the processing. This loss of information can be traced back to parametric object separation step, more precisely to the downmix covariance matrix inversion regularization step.
By definition the downmixing matrix in the example has a block-diagonal structure:
Further, due to specified relation between input objects (e.g., signaling of parametric correlations) also the input object signal covariance matrix available in the decoder has a block-diagonal structure:
As a consequence, the downmix covariance matrix can be represented in a block-diagonal form:
In this case, the matrix EDMX is already block-diagonal, but for the general case its block-diagonal form can be obtained after the permutation of rows/columns using the permutation operator Φ: ĒDMX=ΦEDMXΦ*.
A permutation operator Φ is defined as a matrix obtained by permutation of the rows of an identity matrix. If a symmetric matrix A can be represented in a block-diagonal form by permuting rows and columns, the permutation operator can be used to express the resulting matrix Ā as: Ā=Φ AΦ*.
If Φ is a permutation operator then the following properties hold:
As a consequence, the permutation operators are transparent to singular value decomposition algorithms. This means that the original matrix A and the permuted matrix Ā share the same singular values and permuted singular vectors:
Due to the block-diagonal representation, the singular values of matrix EDMX can be computed by applying the SVD to matrix EDMX or by applying the SVD to the block-diagonal sub-matrices EDMXk and combining the results:
Since the singular values of the downmix covariance matrix are directly related to the energy levels of the downmix channels (which are described by the main diagonal of matrix EDMX):
and objects contained in one channel are not contained in any other downmix channel, one can conclude that each singular value corresponds to one downmix channel.
Therefore, if one of the downmix channels has much smaller energy level than the rest of the downmix channels, the singular value corresponding to this channel will be much smaller than the rest of the singular values.
The truncation step used in the inversion of the matrix containing the singular values of matrix EDMX:
can lead to truncation of singular values corresponding to the downmix channel with the small energy level (with respect to the downmix channel with the highest energy). Because of this, the information present in this downmix channel with small relative energy is discarded and the spectral gaps observed in the spectrogram figures and audio output are generated.
For a better understanding, it has to be taken into account that the downmixing of the input audio objects happens for each sample and for each frequency band separately. Especially the separation into different bands helps to understand why gaps can be found in the spectrograms of the output signals at different frequencies.
The identified problem can be isolated down to the fact that the relative regularization threshold is computed for singular values without considering that the matrix to be inverted is block-diagonal:
Each block-diagonal matrix corresponds to one independent group of downmix channels. The truncation is realized relative to the largest singular value, but this value describes only one group of channels. Thus, the reconstruction of objects contained in all independent groups of downmix channels becomes dependent on the group which contains this largest singular value.
In the following the invention will be explained based on the embodiment discussed above concerning the state of art:
Considering the example described above, the three covariance matrices can be associated to three different groups of downmix channels Gk with 1≤k≤3. The audio objects or input audio objects contained in the downmix channels of each group are not contained in any other group. Additionally, no relation (e.g., correlation) is signaled between objects contained in downmix channels from different groups.
In order to solve the identified problem of the parametric reconstruction system, the inventive method proposes to apply the regularization step independently for each group. This implies that three different thresholds are computed for the inversion of the three independent downmix covariance matrices:
where 1≤k≤3. Hence, in the invention in one embodiment such a threshold is computed for each group separately and not as in the state of art one overall threshold for the respective frequency bands and samples.
The inversion of the singular values is obtained accordingly by applying the regularization independently for the sub-matrices EDMXk, with 1≤k≤3:
In a different embodiment, the following formula is used:
Using the proposed inventive method in an otherwise identical SAOC 3D system for the example discussed in the previous section, the audio output quality of the decoded and rendered output improves. The resulting signals are illustrated in
Comparing the spectrograms in the right column of
The described solution for processing three independent groups of downmix channels can be easily generalized to any number of groups.
The inventive method proposes to modify the parametric object separation technique by making use of grouping information in the inversion of the downmix signal covariance matrix. This leads into significant improvement of the audio output quality.
The grouping can be obtained, e.g., from mixing and/or correlation information already available in the decoder without additional signaling.
More precisely one group is defined in one embodiment by the smallest set of downmix signals with the following two properties in this example:
Based on the introduced group definition, a number of K (1≤K≤Ndmx) groups can be defined: Gk (1≤k≤K) and the downmix covariance matrix EDMX can be expressed using a block-diagonal form by applying a permutation operator Φ:
The sub-matrices EDMXk are constructed by selecting elements of the downmix covariance matrix corresponding to the independent groups Gk. For each group Gk, the matrix EDMXk of size Mk times Mk is expressed using SVD as: EDMXk=Vk Λk Vk* with:
The pseudo-inverse of matrix EDMXk is computed as (EDMXk)−1=Vk Λinv V k* where the regularized inverse matrix Λinvk is given in one embodiment by:
and in a different embodiment by:
The relative regularization scalar TregΛ
with Treg=10−2 for example.
The inverse of the permuted downmix covariance matrix ĒDMX is obtained as:
and the inverse of the downmix covariance matrix is computed by applying the inverse permutation operation: EDMX1=Φ*ĒDMX1Φ.
Additionally, the inventive method proposes in one embodiment to determine the groups based entirely on information contained in the bitstream. For example, this information can be given by downmixing information and correlation information.
More precisely, one group Gk is defined by the smallest set of downmix channels with the following properties:
The groups can be determined once per frame or once per parameter set for all processing bands, or once per frame or once per parameter set for each processing band.
The inventive method also allows in one embodiment to reduce significantly the computational complexity of the parametric separation system (e.g., SAOC 3D decoder) by making use of the grouping information in the most computational expensive parametric processing components.
Therefore, the inventive method proposes to remove computations which do not bring any contribution to final output audio quality. These computations can be selected based on the grouping information.
More precisely, the inventive method proposes to compute all the parametric processing steps independently for each pre-determined group and to combine the results in the end.
Using the example of SAOC 3D processing part of MPEG-H 3D Audio the computationally complex operations are given by:
The Object Level Differences (OLD) refers to the relative energy of one object to the object with most energy for a certain time and frequency band and Inter-Object Cross Coherence (IOC) describes the amount of similarity, or cross-correlation for two objects in a certain time and frequency band.
The inventive method is proposing to reduce the computational complexity by computing all the parametric processing steps for all pre-determined K groups Gk with 1≤k≤K independently, and combining the results in the end of the parameter processing.
One group Gk contains Mk downmix channels and Nk input audio objects such that:
For each group Gk, a group downmixing matrix is defined as Dk by selecting elements of downmixing matrix D corresponding to downmix channels and input audio objects contained by group Gk.
Similarly a group rendering matrix Rk is obtained out of the rendering matrix R by selecting the rows corresponding to input audio objects contained by group Gk.
Similarly a group vector OLDk and a group matrix IOCk are obtained out of the vector OLD and the matrix IOC by selecting the elements corresponding to input audio objects contained by group Gk.
For each group Gk, the described processing steps are replaced with less computationally processing steps as following:
And the results of individual group processing steps are combined in the end:
Summarizing the processing steps according to the structure of the downmix processor illustrated in
Using the proposed inventive method the computation complexity is reduced using the group detection as illustrated in
An example of an implementation of a group detection function, called: [K,Gk]=groupDetect(D,RelatedTo), is given in
The proposed inventive method proves to be significantly computationally much more efficient than performing the operations without grouping. It also allows better memory allocation and usage, supports computation parallelization, reduces numerical error accumulation, etc.
The proposed inventive method and the proposed inventive apparatus solve an existing problem of the state of the art parametric object separation systems and offer significantly higher output audio quality.
Proposed inventive method describes a group detection method which is entirely realized based on the existing bitstream information.
The proposed inventive grouping solution leads to a significant reduction in computational complexity. In general, the singular value decomposition is computationally expensive and its complexity grows exponentially with the size of the matrix to be inverted: O(Ndmx3).
For large number of downmix channels, computing K times an SVD operation for smaller sized matrix is computationally much more efficient:
Using the same considerations, all the parametric processing steps in the decoder can be efficiently implemented by computing all the matrix multiplications described in the system only for the independent groups and combining the results.
An estimation of the complexity reduction for different number of input audio objects, i.e.
input audio objects, downmix channels, and a fixed number of 24 output channels is given in the following table:
The invention presents the following additional advantages:
The invention leads to the following proposed exemplary modifications for the standard text.
Add in “9.5.4.2.4 Regularized inverse operation”:
The regularized inverse matrix J approximating J≈Δ−1 is calculated as J=VΛinvV*.
The matrices V and Λ are determined as the singular value decomposition of the matrix Δ as: Δ=V Λ V*.
The regularized inverse Λinv of the diagonal singular value matrix Λ is computed according to 9.5.4.2.5.
In the case the matrix Δ is used in the calculation of the parametric un-mixing matrix U, the operations described are applied for all sub-matrices Δk. A sub-matrix Δk is obtained by selecting the elements Δ (m, n) corresponding to the downmix channels m and n assigned to the group k.
The group k is defined by the smallest set of downmix channels with the following properties:
The results of the independent regularized inversion operations Jk≈Δk−1 are combined for obtaining the matrix J.
The invention also leads to the following proposed exemplary modifications for the standard text.
9.5.4.2.5 Regularized Inverse Operation
The regularized inverse matrix J approximating J≈Δ−1 is calculated as:
J=VΛinvV*.
The matrices V and Λ are determined as the singular value decomposition of the matrix Δ as:
VΛV*=Δ.
The regularized inverse Λinv of the diagonal singular value matrix Λ is computed according to 9.5.4.2.6.
In the case the matrix Δ is used in the calculation of the parametric un-mixing matrix U, the operations described are applied for all sub-matrices Δq. A sub-matrix Δq of size Ngq×Ngq, with elements Δq (idx1,idx2), is obtained by selecting the elements Δ(ch1,ch2) corresponding to the downmix channels ch1 and ch2 assigned to the group gq (i.e., gq(idx1)=ch1 and gq(idx2)=ch2).
The group gq of size 1×Ngq is defined by the smallest set of downmix channels with the following properties:
The results of the independent regularized inversion operations Jq=Δq−1 are combined for obtaining the matrix J as:
9.5.4.2.6 Regularization of Singular Values
The regularized inverse operation (⋅)inv used for the diagonal singular value matrix Λ is determined as:
The relative regularization scalar TregΛ is determined using absolute threshold Treg and maximal value of Λ as follows:
In some of the following figures individual signals are shown as being obtained from different processing steps. This is done for a better understanding of the invention and is one possibility to realize the invention, i.e., extracting individual signals and performing processing steps on these signals or processed signals.
The other embodiment is calculating all significant matrices and applying them as a last step to the encoded audio signal in order to obtain the decoded audio signal. This includes the calculation of the different matrices and their respective combinations.
An embodiment combines both ways.
The input audio objects 111 are allocated or down-mixed into downmix signals 101. In the shown embodiment four of the five input audio objects 111 are assigned to two downmix signals 101. One input audio object 111 alone is assigned to a third downmix signal 101. Thus, five input audio objects 111 are represented by three downmix signals 101.
These downmix signals 101 afterwards—possibly following some not shown processing steps—are combined to the encoded audio signal 100.
Such an encoded audio signal 100 is fed to an inventive apparatus 1, for which one embodiment is shown in
From the encoded audio signal 100 the three downmix signals 101 (compare
The downmix signals 101 are grouped—in the shown example—into two groups of downmix signals 102.
As each downmix signal 101 is associated with a given number of input audio objects, each group of downmix signals 102 refers to a given number of input audio objects (a corresponding expression is input object). Hence, each group of downmix signals 102 is associated with a set of input audio objects of the plurality of input audio objects which are encoded by the encoded audio signal 100 (compare
The grouping happens in the shown embodiment under the following constrictions:
The (here: two) groups of downmix signals 102 are processed individually in the following to obtain five output audio signals 103 corresponding to the five input audio objects 111.
One group of downmix signals 102 which is associated with the two downmix signals 101 covering two pairs of input audio objects 111 (compare
The other group of downmix signals 102 leads to one output signal 103 as the single downmix signal 101 or this group of downmix signals 102 (or more precisely: group of one signal downmix signal) refers to one input audio object 111 (compare
The five output audio signals 103 are combined into one decoded audio signal 110 as output of the apparatus 1.
In the embodiment of
The embodiment of the apparatus 1 shown in
From the encoded audio signal 100 the three downmix signals 101 (for three transport channels) are obtained and grouped into two groups of downmix signals 102. These groups 102 are individually processed to obtain five processed signals 104 corresponding to the five input audio objects shown in
In the following steps, from the five processed signals 104 jointly eight output audio signals 103 are obtained, e.g., rendered to be used for eight output channels. The output audio signals 103 are combined into the decoded audio signal 110 which is output from the apparatus 1. In this embodiment, an individual as well as a joint processing is performed on the groups of the downmix signals 102.
In step 200 the downmix signals are extracted from the encoded audio signal. In the following step 201, the downmix signals are allocated to groups of downmix signals.
In step 202 each group of downmix signals is processed individually in order to provide individual group results. The individual handling of the groups comprises at least the unmixing for obtaining representations of the audio signals which were combined via the downmixing of the input audio objects in the encoding process. In one embodiment—not shown here—the individual processing is followed by a joint processing.
In step 203 these group results are combined into a decoded audio signal to be output.
The apparatus 1 shown in
Due to this, the processor 3 in this embodiment is configured to perform just some or at least one processing step individually. The result of the processing are processed signals 104 which are processed jointly by the post-processor 5. The obtained output audio signals 103 are finally combined by the combiner 4 leading to the decoded audio signal 110.
In
The processor 3 comprises an un-mixer 300 configured to un-mix the downmix signals 101 of the respective groups of downmix signals 102. The un-mixer 300, thus, reconstructs the individual input audio objects which were combined by the encoder into the respective downmix signals 101.
The reconstructed or separated input audio objects are submitted to a renderer 302. The renderer 302 is configured to render the un-mixed downmix signals of the respective groups for an output situation of said decoded audio signal 110 in order to provide rendered signals 112. The rendered signals 112, thus, are adapted to the kind of replay scenario of the decoded audio signal. The rending depends, e.g., on the number of loudspeakers to be used, to their arrangement or to the kind of effects to be obtained by the playing of the decoded audio signal.
The rendered signals 112, Ydry, further, are submitted to a post-mixer 303 configured to perform at least one decorrelation step on said rendered signals 112 and configured to combine results Ywet of the performed decorrelation step with said respective rendered signals 112, Ydry. The post-mixer 303, thus, performs steps to decorrelate the signals which were combined in one downmix signal.
The resulting output audio signals 103 are finally submitted to a combiner as shown above.
For the steps, the processor 3 relies on a calculator 301 which is here separate from the different units of the processor 3 but which is in an alternative—not shown—embodiment a feature of grouper 300, renderer 302, and post-mixer 303, respectively.
Relevant is the fact, that the significant matrices, values etc. are calculated individually for the respective groups of downmix signals 102. This implies that, e.g., the matrices to be computed are smaller than the matrices used in the state of art. The matrices have sizes depending on a number of input audio objects of the respective set of input audio objects associated with the groups of downmix signals and/or on a number of downmix signals belonging to the respective group of downmix signals.
In the state of art, the matrix to be used for the un-mixing has a size of the number of input audio objects or input audio signals times this number. The invention allows to compute a smaller matrix with a size depending on the number of input audio signals belonging to the respective group of downmix signals.
In
The apparatus 1 receives an encoded audio signal 100 and decodes it providing a decoded audio signal 110.
This decoded audio signal 110 is played in a specific output situation or output scenario 400. The decoded audio signal 110 is in the example to be output by five loudspeakers 401: Left, Right, Center, Left Surround, and Right Surround. The listener 402 is in the middle of the scenario 400 facing the Center loudspeaker.
The renderer in the apparatus 1 distributes the reconstructed audio signals to be delivered to the individual loudspeakers 401 and, thus, to distribute a reconstructed representation of the original audio objects as sources of the audio signals in the given output situation 400.
The rendering, therefore, depends on the kind of output situation 400 and on the individual taste of preferences of the listener 402.
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, one or more of the most important method steps may be executed by such an apparatus.
Depending on certain implementation requirements, embodiments of the invention can be implemented in hardware or in software or at least partially in hardware or at least partially in software. The implementation can be performed using a digital storage medium, for example a floppy disk, a DVD, a Blu-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-transitory.
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.
A further embodiment according to the invention comprises an apparatus or a system configured to transfer (for example, electronically or optically) a computer program for performing one of the methods described herein to a receiver. The receiver may, for example, be a computer, a mobile device, a memory device or the like. The apparatus or system may, for example, comprise a file server for transferring the computer program to the receiver.
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 may be performed by any hardware apparatus.
The apparatus described herein may be implemented using a hardware apparatus, or using a computer, or using a combination of a hardware apparatus and a computer.
The methods described herein may be performed using a hardware apparatus, or using a computer, or using a combination of a hardware apparatus and a computer.
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.
Number | Date | Country | Kind |
---|---|---|---|
15153486.4 | Feb 2015 | EP | regional |
This application is a continuation of copending U.S. patent application Ser. No. 16/197,299, filed on Nov. 20, 2018, which in turn is a continuation of copending U.S. patent application Ser. No. 15/656,301, filed on Jul. 21, 2017, now U.S. Pat. No. 10,152,979, which in turn is a continuation of copending International Application No. PCT/EP2016/052037, filed Feb. 1, 2016, which is incorporated herein by reference in its entirety, and additionally claims priority from European Application No. EP 15 153 486.4, filed Feb. 2, 2015, which is incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 16197299 | Nov 2018 | US |
Child | 16693084 | US | |
Parent | 15656301 | Jul 2017 | US |
Child | 16197299 | US | |
Parent | PCT/EP2016/052037 | Feb 2016 | US |
Child | 15656301 | US |