This disclosure falls into the field of audio coding, in particular it is related to the field of spatial audio coding, where the audio information is represented by multiple signals, where the signals may comprise audio channels or/and audio objects. In particular the disclosure provides a method and apparatus for reconstructing audio objects in an audio decoding system. Furthermore, this disclosure provides a method and apparatus for encoding such audio objects.
In conventional audio systems, a channel-based approach is employed. Each channel may for example represent the content of one speaker or one speaker array. Possible coding schemes for such systems include discrete multi-channel coding or parametric coding such as MPEG Surround.
More recently, a new approach has been developed. This approach is object-based, which may be advantageous when coding complex audio scenes, for example in cinema applications. In system employing the object-based approach, a three-dimensional audio scene is represented by audio objects with their associated metadata (for instance, positional metadata). These audio objects move around in the three-dimensional audio scene during playback of the audio signal. The system may further include so called bed channels, which may be described as signals which are directly mapped to certain output channels of for example a conventional audio system as described above.
A problem that may arise in an object-based audio system is how to efficiently encode and decode the object audio signals and preserve the quality of the coded signal. A possible coding scheme includes, on an encoder side, means for creating a downmix signal comprising a number of channels derived from the audio objects and bed channels, and means for generating side information which facilitates reconstruction of the audio objects and bed channels on a decoder side.
MPEG Spatial Audio Object Coding (MPEG SAOC) describes a system for parametric coding of audio objects. The system sends side information, i.e. an upmix matrix, describing the properties of the objects by means of parameters such as level difference and cross correlation of the objects. These parameters are then used to control the reconstruction of the audio objects on a decoder side. This process can be mathematically complex and often has to rely on assumptions about properties of the audio objects that are not explicitly described by the parameters. The method presented in MPEG SAOC may lower the required bit rate for an object-based audio system, but further improvements may be needed to further increase the efficiency and quality as described above.
Example embodiments will now be described with reference to the accompanying drawings, on which:
All the figures are schematic and generally only show parts which are necessary in order to elucidate the disclosure, whereas other parts may be omitted or merely suggested. Unless otherwise indicated, like reference numerals refer to like parts in different figures.
In view of the above, the objective is to provide encoders and decoders and associated methods aiming at optimizing the trade-off between coding efficacy and reconstruction quality of the coded audio objects.
According to a first aspect, example embodiments propose decoding methods, decoders, and computer program products for decoding. The proposed methods, decoders and computer program products may generally have the same features and advantages.
According to example embodiments there is provided a method for reconstructing an audio object in a time frame comprising a plurality of frequency bands. The method comprises the steps of: receiving M>1 downmix signals, each being a combination of a plurality of audio objects including the audio object, and receiving indicators comprising first indicators that indicate which of the M downmix signals to be used in the plurality of frequency bands when reconstructing the audio object. In a first decoding mode, each of the first indicators indicates a downmix signal to be used for all of the plurality of frequency bands when reconstructing the audio object. The method further comprises the steps of: receiving first parameters each associated with a frequency band and a downmix signal indicated by the first indicators for that frequency band, and reconstructing the audio object in the plurality of frequency bands by forming a weighted sum of at least the downmix signals indicated by the first indicators for that frequency band, wherein each downmix signal is weighted according to its associated first parameter.
An advantage of this method is that the bit rate required for transmitting the parameters for reconstrucing the audio object from at least the M downmix signals is reduced, since only the parameters for the downmix signals indicated by the indicators needs to be received by a decoder implementing the method. A further advantage of this method is that the complexity of reconstructing the audio object may be reduced since the indicators indicate what parameters that are used for reconstruction in any given time frame. Consequently, unnecessary multiplications by zero may be avoided. An advantage of using only one indicator for indicating that a downmix signal should be used for all of the plurality of frequency bands when reconstructing the audio object is that the required bit rate for transmitting the indicators may be reduced.
According to embodiments, the method further comprises the step of: forming K≧1 decorrelated signals, wherein the indicators further comprising second indicators which indicate which of the K decorrelated signals to be used in the plurality of frequency bands when reconstructing the audio object. In the first decoding mode, each of the second indicators indicates a decorrelated signal to be used for all of the plurality of frequency bands when reconstructing the audio object. The method further comprises the step of: receiving second parameters each associated with a frequency band and a decorrelated signal indicated by the second indicators for that frequency band. The step of reconstructing the audio object in the plurality of frequency band further comprises adding to the weighted sum of the downmix signals for a particular frequency band, a weighted sum of the decorrelated signals indicated by the second indicators for that particular frequency band, wherein each decorrelated signal is weighted according to its associated second parameter.
By using decorrelated signals when reconstructing the audio object, any unwanted correlation between reconstructed audio objects may be reduced.
According to embodiments, the indicators are received in the form of a binary vector, each element of the binary vector corresponding to one of the M downmix signals or K decorrelated signals, if applicable.
An advantage of receiving the indicators in the form of a binary vector is that a simple conversion from data received in the form of a bit stream may be provided.
According to embodiments, the received binary vector is coded by entropy coding. This may further reduce the required bit rate for transmitting the indicators.
According to embodiments, the method comprises a second decoding mode. In the second decoding mode, the indicators for each frequency band indicate a single one of the M downmix signals or K decorrelated signals, if applicable, to be used in that frequency band when reconstructing the audio object. This decoding mode may lead to a reduction of the required bit rate for transmitting the parameters since only a single parameter needs to be transmitted for each frequency band of the audio object to be reconstructed.
According to embodiments, the indicators are received in the form of a vector of integers, wherein each element in the vector of integers corresponds to a frequency band and the index of the single downmix signal to be used for that frequency band. This may be an efficient way of indicating what downmix signal should be used for a specific frequency band. A vector of integers may further facilitate efficient coding of the indicators in a bit stream received by the decoder. The received integer vector may according to embodiments be coded by entropy coding.
According to embodiments, the method further comprises the step of receiving a decoding mode parameter indicating which of the first decoding mode and the second decoding mode to be used. This may reduce the decoding complexity since no calculation of what decoding mode should be used may be necessary.
According to embodiments, the indicators are received separately from the parameters. The decoder implementing the disclosed method may first reconstruct an indicator matrix which indicates which downmix signals and decorrelated signals, if applicable, should be used when reconstructing the audio object. The indicator matrix indicates the parameters which are received in a bit stream received by the decoder. This may allow for a generic implementation of the reconstruction step of the method, independently of what decoding mode that is used. By receiving the indicators separately, before the parameters, no buffering of the parameters may be necessary.
According to embodiments, at least some of the received first parameters and second parameters, if applicable, are coded by means of time differential coding and/or frequency differential coding. The first and second parameters, if applicable, may be coded by means of entropy coding. An advantage of coding the parameters using time differential coding and/or frequency differential coding and/or entropy coding may be that the bit rate required for transmitting the parameters for reconstrucing the audio object is reduced
According to example embodiments there is provided a computer-readable medium comprising computer code instructions adapted to carry out any method of the first aspect when executed on a device having processing capability.
According to example embodiments there is provided a decoder for reconstructing an audio object in a time frame comprising a plurality of frequency bands, comprising: a receiving stage configured for: receiving M>1 downmix signals, each being a combination of a plurality of audio objects including the audio object, receiving indicators comprising first indicators that indicate which of the M downmix signals to be used in the plurality of frequency bands when reconstructing the audio object, wherein, in a first decoding mode, each of the first indicators indicates a downmix signal to be used for all of the plurality of frequency bands when reconstructing the audio object, and receiving first parameters each associated with a frequency band and a downmix signal indicated by the indicators for that frequency band. The decoder further comprises a reconstruction stage configured for reconstructing the audio object in the plurality of frequency bands by forming a weighted sum of the downmix signals indicated by the first indicators for that frequency band, wherein each downmix signal is weighted according to its associated first parameter.
According to a second aspect, example embodiments propose encoding methods, encoders, and computer program products for encoding. The proposed methods, encoders and computer program products may generally have the same features and advantages. Generally, features of the second aspect may have the same advantages as corresponding features of the first aspect.
According to example embodiments, a method for encoding an audio object is provided herein. The object is represented by a time frame comprising a plurality of frequency bands. The method comprises the step of: determining M>1 downmix signals, each being a combination of a plurality of audio objects including the audio object. In a first encoding mode, the method comprises the steps of selecting a subset of the M downmix signals to be used when reconstructing the audio object in a decoder in a audio coding system, and representing each downmix signal in the subset of the M downmix signals by an indicator identifying the downmix signal among the M downmix signals, and by a plurality of parameters, one for each of the plurality of frequency bands, and each one associated with a frequency band, wherein each parameter of the plurality of parameters represents a weight for the downmix signal when reconstructing the audio object for the associated frequency band.
According to example embodiments, the method, in the first encoding mode, further comprising the steps of selecting a subset of the K decorrelated signals to be used when reconstructing the audio object in a decoder in an audio coding system, and representing each decorrelated signal in the subset of the K decorrelated signals by an indicator identifying the decorrelated signal among the K decorrelated signals, and by a plurality of parameters, one for each of the plurality of frequency bands, and each one associated with a frequency band, wherein each parameter of the plurality of parameters represents a weight for the decorrelated signal when reconstructing the audio object for the associated frequency band.
According to example embodiments, the method comprises a second encoding mode. In this mode, the method further comprises the step of, for each of the plurality of frequency band, selecting a single one of the M downmix signals or K decorrelated signals, if applicable, and representing the selected signal by an indicator identifying the selected signal among the M downmix signals and K decorrelated signals, if applicable, and by and a parameter representing a weight for the selected signal when reconstructing the audio object for the frequency band.
By having a plurality of different encoding modes, depending on the content of the audio object to be reconstructed, and depending on available bit rate for transmitting the parameters and the indicators, a currently best coding mode may be chosen by an encoder. When using one of the first and the second encoding mode, the used encoding mode may be indicated by a decoding mode parameter included in a data stream for transmittal to the decoder.
According to example embodiments, the indicators identifying downmix signals or decorrelated signals, if applicable, are included in a data stream for transmittal to the decoder separately from the parameters representing weights for the downmix signals or decorrelated signals, if applicable.
When the encoder may choose between different encoding modes when encoding an audio object, it is advantageous to include the indicators in the bit stream separately from the parameters since this may facilitate that a generic decoder which can decode the encoded audio object no matter what encoding mode that is used.
According to example embodiments there is provided a computer-readable medium comprising computer code instructions adapted to carry out any method of the second aspect when executed on a device having processing capability.
According to example embodiments there is provided an encoder for encoding an audio object in a time frame comprising a plurality of frequency bands, comprising: a downmix determining stage configured for determining M>1 downmix signals, each being a combination of a plurality of audio objects including the audio object, a coding stage configure for, in a first encoding mode, selecting a subset of the M downmix signals to be used when reconstructing the audio object in a decoder in a audio coding system, and representing each downmix signal in the subset of the M downmix signals by an indicator identifying the downmix signal among the M downmix signals, and by a plurality of parameters, one for each of the plurality of frequency bands, and each one associated with a frequency band, wherein each parameter of the plurality of parameters represents a weight for the downmix signal when reconstructing the audio object for the associated frequency band.
The specifics of the reconstruction of an audio objects (or channels) will now be described.
In the following it is assumed that there are N original audio signals x which can be either objects or channels.
x
n(t),n=1, . . . , N,
These are reconstructed from M downmix signals y
y
m(t),m=1, . . . , M.
where the time variable t belongs to a time segment or a time-frequency tile. It is convenient to think of the signals as row vectors and collect them in matrices X and Y. A reconstruction matrix (or upmix matrix) Cf for the downmix signals of size N×M and a reconstruction matrix (or upmix matrix) Pf for decorrelated signals of size N×K (K being the number of decorrelated signals) are used to create the output according to
{circumflex over (x)}
n(t)=Σmcnmym(t)+Σzpnkzk(t) equation (1)
where zk(t),k=1, . . . , K are outputs from a decorrelation process and where {circumflex over (x)}n(t) denotes the reconstructed audio object for a certain time segment. In matrix notation, taking a single time-frequency tile, we have
{circumflex over (X)}(t, f)=Cf(t)Y(t, f)+Pf(t)Z(t, f) Equation (2)
The matrices Cf and Pf are typically estimated for time-frequency tiles and represent the decoded upmix matrixes to use when reconstructing the audio object(s) from the downmix signals and the decorrelated signals, respectively. In this case, the subscript f may correspond to a frequency tile. The reconstruction of Cf and Pf will be specified below. A typical update interval in time would be for example 23.4375 Hz (i.e. 48 kHz/2048 samples). The frequency resolution could be between 7 and 12 bands spanning the full-band. Typically the frequency partition is non-uniform and it is optimized on perceptual grounds. The desired time-frequency resolution can be obtained by means of a time-frequency transformation or by a filterbank, for instance, by using QMF.
Audio encoding/decoding systems typically divide the time-frequency space into time/frequency tiles, e.g. by applying suitable filter banks to the input audio signals. By a time/frequency tile is generally meant a portion of the time-frequency space corresponding to a time interval and a frequency band. The time interval may typically correspond to the duration of a time frame used in the audio encoding/decoding system. The frequency band is a part of the entire frequency range of the whole frequency range of the audio signal/object that is being encoded or decoded. The frequency band may typically correspond to one or several neighbouring frequency bands defined by a filter bank used in the encoding/decoding system. In the case the frequency band corresponds to several neighbouring frequency bands defined by the filter bank, this allows for having non-uniform frequency bands in the decoding process of the audio signal, for example wider frequency bands for higher frequencies of the audio signal.
It may be noted that the decorrelated signals, and thus the upmix matrix P may not be needed in some cases, although, in a general case, it is beneficial to use them, in particular, while operating at low bit-rates.
This disclosure deals with transmission of the data in C (and P) to the decoder by reducing the associated bit-rate cost. The reduction of the bit-rate cost is achieved by imposing and exploiting sparsity of the parameter data within the matrices C and P. The exploitation of the sparse stricture of the parametric data is achieved by design of efficient bit stream syntax. In particular, the syntax design takes into account that the matrices C and P may be sparse and thus advantageously the encoder may employ sparse coding and thus sparsify the matrices at the encoder and utilize the knowledge about the sparsification strategy to produce a compact bit-stream.
In
The decoder determines if the first decoding mode should be used from the bit stream. The decoder further determines how many frequency bands this particular time frame includes. The number of frequency bands may be indicated in the bit stream 102 or transmitted from an encoder in the audio coding system to the decoder 100 in any other suitable way (e.g. a predefined value bay be used). With this knowledge, the upmix matrix 206 is decoded. For example, the first value among the indicators 202 indicate that the first of the M downmix signals should not be used for this particular audio object in this particular time frame. The second value among the indicators 202 indicate that the second of the M downmix signals should be used. The third indicator indicate that the third downmix signal should also be used while the fourth indicator tells the decoder 100 that the fourth downmix signal should not be used. Once the indicators are determined at the decoder, the parameters can be decoded. Since the decoder knows the number of frequency bands, e.g. four in this case, it knows that the first four parameters each are associated with subsequent frequency bands and the second downmix signal. Likewise it knows that the next four parameters each are associated with subsequent frequency bands and the third downmix signal. Consequently, the upmix matrix 206 is reconstructed. This upmix matrix (also denoted C) is then used by the reconstruction stage 112 for reconstructing the audio object. The reconstruction stage is configured for reconstructing the audio object in the plurality of frequency bands by forming a weighted sum of at least the downmix signals indicated by the first indicators for that frequency band, wherein each downmix signal is weighted according to its associated first parameter. In other words, the reconstruction stage may be configured to, for each frequency band indicated by the first indicators, forming a weighted sum of at least the downmix signals indicated by the first indicators for that frequency band, wherein each downmix signal is weighted according to its associated first parameter and thereby reconstructing the audio object. The specifics of the reconstruction are described above in conjunction with the equations (1) and (2).
The receiving stage 104 of the decoder 100 may according to some embodiments comprise a substage 122 which is configured for forming K>=1 decorrelated signals 124. The decorrelated signals may be based on a subset of the M downmix signals 110 and decorrelation parameters received from the bit stream 102. The decorrelated signals may also be formed based on any other signal available to the receiving stage such as for example a bed signal or channel. According to this embodiment, the received and decoded indicators 108 comprises further comprises second indicators which indicate which of the K decorrelated signals to be used in the plurality of frequency bands when reconstructing the audio object 114. The received and decoded parameters 106 may further comprise second parameters, each associated with a frequency band and a decorrelated signal indicated by the second indicators for that frequency band. According to the first decoding mode, each of the second indicators indicates a decorrelated signal 124 to be used for all of the plurality of frequency bands when reconstructing the audio object 114. This is further explained in conjunction with
In
According to some embodiments, the bit stream 102 comprises a dedicated decoding mode parameter indicating which of the first decoding mode and the second decoding mode to be used. Further decoding modes may also be used. The dedicated decoding mode parameter may for example indicate that the full matrices C and P are included in the bit stream 102, i.e. the matrices are not sparsified at all. In this case the indicator data could be coded by a single indicator parameter (since the whole matrix is included in the bit stream). The decoding mode parameter may be advantageous in that it inform the decoder which sparsification strategy was used at the encoder side. Moreover, by including the decoding mode in the bit stream 102, the sparsification strategy may be changed from time frame to time frame, such that the encoder can choose the most advantageous strategy at all times.
According to some embodiment, the matrix multiplication (equation 2) for reconstructing the audio objects is only performed for the elements of the matrixes indicated as “active” or “used” by the indicators. This may allow for reducing the computational complexity of the decoder in the signal-processing part related to the implementation of equation (2), since multiplication with zero may be avoided. In other words, the indicators may help to keep track which parameters are actually used in any given time frequency-time slot, which allows for skipping computations for the dimensions (e.g. downmix signals and decorrelated signals, if applicable) that were sparsified. This may be done by constructing an indicator matrix, which for example may includes ones and zeros and be used as a filter when performing the matrix multiplications in equation (2). This may facilitate a decoder implementation where it is possible to go over a list of entries to perform elementary mathematical operations related to equation (2).
Moreover, by using the above strategy for performing the equation (2), a generic implementation of the reconstruction stage 112 of the decoder 100 may be facilitated. The reconstruction stage does not need to know which particular sparsification strategy was used at the encoder as long as the information in the bit stream 102 allows for construction of the indicator matrices. This means that the decoding scheme allows the use of whatever sparsification strategy that is used at the decoder, i.e., the coding complexity is outsourced to the encoder, which is typically advantageous.
As can be seen in
According the embodiments, at least some of the received first parameters and second parameters, if applicable, are coded by means of time differential coding and/or frequency differential coding. In this case, the coding mode may be signalled in the bit stream. In the following, such coding of the parameters is further specified. Differential coding of the parameters is utilized for more efficient coding by exploiting dependencies between different parameters in one or more dimensions, i.e. frequency-differential and/or time-differential coding. First-order differential coding is often a reasonable practical alternative. For all but the first value of a parameter, it is always possible to compute a difference between the current value of the parameter and the value of its previous occurrence. Similarly, one can always compute the difference between the quantization index related to the current parameter and the previous realization of the index. In the case of frequency differential coding, the coding scheme is operating along frequency axis (across frequency bands) and the previous occurrence of the parameter means one of the adjacent frequency bands, for example, the band associated with a lower frequency than the current band. In the case of the time differential coding, the previous parameter is associated with the previous “time slot” or frame, for instance, it may correspond to the same frequency band as the current parameter but to a previous “time slot” or frame. The differential coding needs to be initialized, since, as mentioned above, for the first parameter the previous values are not available. In this case one can use the differential coding for all but the first parameter. Alternatively, one can subtract from the first parameter its mean value. The same approach can also be used when differential coding operates on quantization indices, in which case one can subtract the mean value of the quantization index.
In some embodiments, both frequency-differential and time-differential coding is used and each parameter can be encoded by either of the two methods. The decision selection of the coding method is made by the encoder, typically by checking the resulting total codeword length (i.e., the sum of the lengths of the codewords that would be sent, the codewords being for example Huffman codewords) resulting from selecting a coding method and by selecting the most efficient alternative (i.e. the shortest total codeword length). So called I-frames are an exception, always forcing the use of frequency-differential coding. The makes sure that I-frames are always decodable, independent from whether the previous frame is available or not (similar to “Intra”-frames know in video coding). Typically, the encoder enforces I-frames in regular intervals, for example once per second.
Unlike typical channel-based parametric coding, each reconstructed object is (when not using sparsening) estimated from all available source channels (including downmix channels, possible decorrelator outputs, and possible auxiliary channels). This makes sending of parameters more expensive for object content. To alleviate this, it has been noted that since the two differential methods can vary quite arbitrarily in terms of efficiency, it is beneficial to make the choice between the two whenever possible, even if this produces much signalling bits. For the practical decoder implementation, this means using one signal bit per object for each source channel (i.e. downmix signal or decorrelated signal) where the object is reconstructed from. For example for 15 objects which all are reconstructed from 7 source channels, this would require 15*7=105 signalling bits.
In other words, according to one embodiment, a bit stream syntax construction is proposed, where the existence of the signalling bit determining the mode of the differential coding for a particular combination of an object and a downmix signal or a decorrelated signal is conditioned on the respective indicator in the indicator data, where the indicator indicates if a particular channel or decorrelated signal is used for reconstructing the object.
When sparse coding is utilized, the differential coding may become more complicated due to the fact that the notion of what is considered as the previous parameter is affected. There are instances, where the previous parameter is not available, because the sparse coding did not use the relevant dimensions in the previous frame. This situation is relevant whenever the sparsity indicator changes on a per frame basis or even on a per band basis (depending of which mode of sparsification is used). Also, the encoder selection between frequency-differential and time-differential requires a defined strategy of handling the sparsified dimensions. In a system that facilitates the sparsified coding, it is further beneficial to condition the signalling of the differential coding mode on the indicator data that indicates the sparsity. For example, the sparsified dimensions do not need to be associated with any additional signalling of the differential coding, which reduces the side-information bit rate.
There are many possible approaches to apply the differential coding in the context of sparse coding. The following example should not be construed as limiting but is provided as examples to allow the skilled person to exercise the invention.
According to one embodiment, a full matrix of the parameters based on the indicator data may always be reconstructed, and when employing differential coding, the zero valued parameters (or to the corresponding quantization indices) may be referred to. For example, in the context of the time-differential coding, for an object to be reconstructed, a relevant row of the matrix of parameters (or a matrix of quantization indices corresponding to these parameters) is constructed, where the missing dimensions are reconstructed from the indicator information. The full-dimensional vector of the parameter corresponding to the previous frame is then determined, which renders the differential coding. For instance, in this case, the dimensions that were sparsified in a previous frame are reconstructed by zeroes. Time differential coding may also refer to these dimensions.
Alternatively, according to some embodiments, in the case, where the parameters for the previous frame were sparsified, their values (only for the purpose of coding) may be reconstructed by taking the mean value of the respective parameter instead of zero (the mean value may be determined in a course of an off-line training, and then this value is used as a constant value in the encoder and decoder implementation). In this case, the change of the indicator data from an inactive state to the active state could mean that the parameter in previous frame should be assumed to be equal to the mean value of the parameter. In some cases, where the time differential coding is used, it may be beneficial to use the indicator data to reconstruct the sparsified parameters from the previous frame by using their mean values rather than zero in order to facilitate the coding of the current frame. In particular, in the case where modulo-differential coding is used, as described in the U.S. Provisional application No. 61/827,264 or subsequent applications claiming the priority of this application, for example in FIGS. 9 and 10 and by equation 11-13, this strategy may be beneficial and it may lead to some saving in bit-rate.
It may be noted that according to embodiments, the decoder may handle the coding of the upmix matrix according to what is described in the U.S. Provisional application No. 61/827,264 or subsequent applications claiming the priority of this application, for example in FIG. 13-15 and on page 29. This is from now on referred to as a third decoding mode. According to this embodiment, the decoder receives at least one encoded element representing a subset of M elements of a row in an upmix matrix, each encoded element comprising a value and a position in the row in the upmix matrix, the position indicating one of the M downmix signals to which the encoded element corresponds. The decoder is in this case configured for reconstructing the time/frequency tile of the audio object from the downmix signal by forming a linear combination of the downmix channels that correspond to the at least one encoded element, wherein in said linear combination each downmix channel is multiplied by the value of its corresponding encoded element. This means that the decoder according to embodiments may handle four decoding modes: decoding mode 1-3 and a mode where the full upmix matrix is included in the bit stream. The full upmix matrix may of course be coded in any suitable way.
To be able to reconstruct the audio objects 702 from the downmix signals 706, upmix parameters are determined at an upmix parameter analysis component 710 from the downmix signal 706 and the audio objects 702. For example the upmix parameters may correspond to elements of an upmix matrix which allows reconstruction of the audio objects 702 from the downmix signal 706. The upmix parameter analysis component 710 processes the downmix signal 706 and the audio objects 702 with respect to individual time/frequency tiles. Thus, the upmix parameters are determined for each time/frequency tile. For example, an upmix matrix may be determined for each time/frequency tile. For example, the upmix parameter analysis component 710 may operate in a frequency domain such as a Quadrature Mirror Filters (QMF) domain which allows frequency-selective processing. For this reason, the downmix signal 706 and the audio objects 702 may be transformed to the frequency domain by subjecting the downmix signal 706 and the audio objects 702 to a filter bank 708. This may for example be done by applying a QMF transform or any other suitable transform.
The upmix parameters 714 may be organized in a vector format. A vector may represent an upmix parameter for reconstructing a specific audio object from the audio objects 702 at different frequency bands at a specific time frame. For example, a vector may correspond to a certain matrix element in the upmix matrix, wherein the vector comprises the values of the certain matrix element for subsequent frequency bands. In further embodiments, the vector may represent upmix parameters for reconstructing a specific audio object from the audio objects 702 at different time frames at a specific frequency band. For example, a vector may correspond to a certain matrix element in the upmix matrix, wherein the vector comprises the values of the certain matrix element for subsequent time frames but at the same frequency band.
It may be noted that the encoder described in
The upmix parameters 714 are then received by an upmix matrix encoder 712 in the vector format. The upmix matrix encoder functions will now be described in conjunction with
The first encoding mode may thus be defined as a broad-band sparsification meaning that each indicated downmix signal to be used when reconstructing a timeframe of an audio object is used for all frequency bands of the time frame of the audio object. The number of indicators that has to be transmitted may thus be reduced since only one indicator is transmitted for all frequency bands for each indicated downmix signal. Moreover it has been noted that a specific downmix signal in many cases is advantageously used for reconstructing all frequency bands of a time frame of an audio object, leading to a reduced distortion of the reconstructed audio object.
In the following it is assumed that there are N original audio signals x which can be either objects or channels.
x
n(t),n=1, . . . , N,
It is also assumed that decorrelated signals may be used for reconstructing the audio objects.
The original signals is considered as row vectors and collected in matrix X. The n-th object within the reconstructed version of X is denoted by {circumflex over (x)}n. A single time-frequency slot of the representation of {circumflex over (x)}n is denoted by {circumflex over (x)}n(t, f).The decoder has access to the full down-mix signal Y=[y1, . . . , yM]T and the decorrelated signals Z=[z1, . . . , zK]T. Let us assume that the indicator information for the downmix signal part of the model given by equation (2) is given by a binary vector Ic and Ip is the indicator information for the decorrelated part. A set of integers corresponding to non-zero positions in I, is defined and denote the set by Sc. Similarly, for Ip, we define the set Sp. The reconstruction of {circumflex over (x)}n(t, f) is obtained by
{circumflex over (x)}
n(t, f)=Σm∈S
Note that while synthesis described in equation (3) is performed on a per frequency band basis, the sets Sc and Sp are constructed in a broad-band manner as defined above. Further, note that the matrices C (upmix matrix for downmix signals) and P (upmix matrix for decorrelated signals) are defined as described in conjunction with the decoder.
There are several practical approaches at the encoder that are able to utilize the broad-band sparse coding (i.e. the first encoding mode). They are outside the scope of this invention. Nevertheless, we disclose some practical examples for the sake of clarity of the description. For example, the broad-band sparsification strategy can be implemented at the decoder using a so-called two-pass approach. In the first pass the encoder would estimate the full non-sparse parameter matrices according to equation (2) performing the analysis in the individual sub-bands. In the next step, the encoded may analyze the parameters by concatenating the observations from the individual sub-bands. For example, a cumulative sum of the absolute value of the parameter may be computed yielding a matrix of size [number of objects]×[number of down-mix channels]. By means of thresholding, it is possible to convert the matrix into a broad-band indicator matrix, where the small values can be set to 0 and values larger than the threshold can be set to 1. The indicator matrix can be used by the second pass of the encoder, where the model parameters specified by equation (2) are updated according to the broad-band indicator matrix by using only selected dimensions of Y in the analysis.
In addition to the two-pass approach, one may use a matching pursuit algorithm that operates with a constraint on the number of downmix or decorrelated dimensions kept for the prediction of a particular object (i.e., a number of downmix signals and a number of decorrelated signals).
There are several ways to convert the indicator information into the actual bit stream. Since the indicator matrix already contains binary data, it can be simply converted into a sequence of bits by agreeing upon the convention. For example, a two dimensional binary matrix can be arranged into a one dimensional bit stream by using the major-column order or the major-row order. Once the decoder knows the convention, it is able to perform the decoding. The parameters may be encoded using for example entropy coding (e.g. Huffman code). Any type of multi dimensional coding, as explained in conjunction with the decoder above, are possible for both the indicators and the parameters.
According to embodiments, in the step of selecting an encoding mode S604, a second decoding mode may be selected. In this case, the method further comprising the step of selecting S608 a single one of the M downmix signals (or K decorrelated signals). The selected signal is represented S612 by an indicator identifying the selected signal among the M downmix signals (and K decorrelated signals). The selected signal is further represented S616 by a parameter representing a weight for the selected signal when reconstructing the audio object for the frequency band. The second encoding mode may for example be implemented by an matching pursuit algorithm that operates with a constraint on the number of downmix or decorrelated dimensions kept for the prediction of a particular object, in the case of the second encoding mode, the number is one.
In the second encoding mode, the sparsity is imposed on a per band basis. In this case, an individual band of an object is predicted using only a single downmix signal or decorrelated signal. The indicator data comprises therefore a single index per band, which indicates the downmix signal or decorrelated signal that is used to reconstruct the frequency band of the audio object. The indicator data can be encoded as an integer or as a binary flag. The parameters may be encoded using for example entropy coding (e.g. Huffman code). This second encoding mode leads to a significant reduction of the bit-rate as, for example, for each band of each object, there is only a single parameter that needs to be transmitted.
According to embodiments, the indicators identifying downmix signals or decorrelated signals, if applicable, are included in a data stream for transmittal to the decoder separately from the parameters representing weights for the decorrelated signal or decorrelated signals, if applicable. This may be advantageous in that different coding may be used for the indicators and the parameters.
According to embodiments, the used encoding mode is indicated by a decoding mode parameter included in a data stream for transmittal to the decoder.
Equivalents, Extensions, Alternatives and Miscellaneous
Further embodiments of the present disclosure will become apparent to a person skilled in the art after studying the description above. Even though the present description and drawings disclose embodiments and examples, the disclosure is not restricted to these specific examples. Numerous modifications and variations can be made without departing from the scope of the present disclosure, which is defined by the accompanying claims. Any reference signs appearing in the claims are not to be understood as limiting their scope.
Additionally, variations to the disclosed embodiments can be understood and effected by the skilled person in practicing the disclosure, from a study of the drawings, the disclosure, and the appended claims. In the claims, the word “comprising” does not exclude other elements or steps, and the indefinite article “a” or “an” does not exclude a plurality. The mere fact that certain measures are recited in mutually different dependent claims does not indicate that a combination of these measured cannot be used to advantage.
The systems and methods disclosed hereinabove may be implemented as software, firmware, hardware or a combination thereof. In a hardware implementation, the division of tasks between functional units referred to in the above description does not necessarily correspond to the division into physical units; to the contrary, one physical component may have multiple functionalities, and one task may be carried out by several physical components in cooperation. Certain components or all components may be implemented as software executed by a digital signal processor or microprocessor, or be implemented as hardware or as an application-specific integrated circuit. Such software may be distributed on computer readable media, which may comprise computer storage media (or non-transitory media) and communication media (or transitory media). As is well known to a person skilled in the art, the term computer storage media includes both volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information such as computer readable instructions, data structures, program modules or other data. Computer storage media includes, but is not limited to, RAM, ROM, EEPROM, flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other medium which can be used to store the desired information and which can be accessed by a computer. Further, it is well known to the skilled person that communication media typically embodies computer readable instructions, data structures, program modules or other data in a modulated data signal such as a carrier wave or other transport mechanism and includes any information delivery media.
This application claims priority from U.S. Provisional Patent Application Nos. 61/893,770 filed on 21 Oct. 2013 and 61/973,653 filed 1 Apr. 2014, which is hereby incorporated by reference in its entirety.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/EP2014/072571 | 10/21/2014 | WO | 00 |
Number | Date | Country | |
---|---|---|---|
61973653 | Apr 2014 | US | |
61893770 | Oct 2013 | US |