Audio coding is the domain of compression that deals with exploiting redundancy and irrelevancy in audio signals. In MPEG USAC [ISO/IEC 23003-3:2012—Information technology—MPEG audio technologies Part 3: Unified speech and audio coding], joint stereo coding of two channels is performed using complex prediction, MPS 2-1-2 or unified stereo with band-limited or full-band residual signals. MPEG surround [ISO/IEC 23003-1:2007—Information technology—MPEG audio technologies Part 1: MPEG Surround] hierarchically combines OTT and TTT boxes for joint coding of multi-channel audio with or without transmission of residual signals. MPEG-H Quad Channel Elements hierarchically apply MPS 2-1-2 stereo boxes followed by complex prediction/MS stereo boxes building a fixed 4×4 remixing tree. AC4 [ETSI TS 103 190 V1.1.1 (2014-04)—Digital Audio Compression (AC-4) Standard] introduces new 3-, 4- and 5-channel elements that allow for remixing transmitted channels via a transmitted mix matrix and subsequent joint stereo coding information. Further, prior publications suggest to use orthogonal transforms like Karhunen-Loeve Transform (KLT) for enhanced multi-channel audio coding [Yang, Dai and Ai, Hongmei and Kyriakakis, Chris and Kuo, C.-C. Jay, 2001: Adaptive Karhunen-Loeve Transform for Enhanced Multichannel Audio Coding, http://ict.usc.edu/pubs/Adaptive %20Karhunen-Loeve %20Transform %20for %20Enhanced %20Multichannel %20Audio %20Coding.pdf].
In the 3D audio context, loudspeaker channels are distributed in several height layers, resulting in horizontal and vertical channel pairs. Joint coding of only two channels as defined in USAC is not sufficient to consider the spatial and perceptual relations between channels. MPEG Surround is applied in an additional pre-/postprocessing step, residual signals are transmitted individually without the possibility of joint stereo coding, e.g. to exploit dependencies between left and right vertical residual signals. In AC-4 dedicated N-channel elements are introduced that allow for efficient encoding of joint coding parameters, but fail for generic speaker setups with more channels as proposed for new immersive playback scenarios (7.1+4, 22.2). MPEG-H Quad Channel element is also restricted to only 4 channels and cannot be dynamically applied to arbitrary channels but only a pre-configured and fixed number of channels.
According to an embodiment, an apparatus for encoding a multi-channel signal having at least three channels may have: an iteration processor for calculating, in a first iteration step, inter-channel correlation values between each pair of the at least three channels, for selecting, in the first iteration step, a pair having a highest value or having a value above a threshold, and for processing the selected pair using a multichannel processing operation to derive first multichannel parameters for the selected pair and to derive first processed channels, wherein the iteration processor is configured to perform the calculating, the selecting and the processing in a second iteration step using at least one of the processed channels to derive second multichannel parameters and second processed channels; a channel encoder for encoding channels resulting from an iteration processing performed by the iteration processor to obtain encoded channels; and an output interface for generating an encoded multi-channel signal having the encoded channels and the first and the second multichannel parameters.
According to another embodiment, an apparatus for decoding an encoded multi-channel signal having encoded channels and at least first and second multichannel parameters may have: a channel decoder for decoding the encoded channels to obtain decoded channels; and a multichannel processor for performing a multichannel processing using a second pair of the decoded channels identified by the second multichannel parameters and using the second multichannel parameters to obtain processed channels, and for performing a further multichannel processing using a first pair of channels identified by the first multichannel parameters and using the first multichannel parameters, wherein the first pair of channels includes at least one processed channel.
According to another embodiment, a method for encoding a multi-channel signal having at least three channels may have the steps of: calculating, in a first iteration step, inter-channel correlation values between each pair of the at least three channels, selecting, in the first iteration step, a pair having a highest value or having a value above a threshold, and processing the selected pair using a multichannel processing operation to derive first multichannel parameters for the selected pair and to derive first processed channels, performing the calculating, the selecting and the processing in a second iteration step using at least one of the processed channels to derive second multichannel parameters and second processed channels; encoding channels resulting from an iteration processing performed by the iteration processor to obtain encoded channels; and generating an encoded multi-channel signal having the encoded channels and the first and the second multichannel parameters.
According to another embodiment, a method of decoding an encoded multi-channel signal having encoded channels and at least first and second multichannel parameters may have the steps of: decoding the encoded channels to obtain decoded channels; and performing a multichannel processing using a second pair of the decoded channels identified by the second multichannel parameters and using the second multichannel parameters to obtain processed channels, and performing a further multichannel processing using a first pair of channels identified by the first multichannel parameters and using the first multichannel parameters, wherein the first pair of channels includes at least one processed channel.
According to another embodiment, a non-transitory digital storage medium may have a computer program stored thereon to perform the inventive methods, when said computer program is run by a computer.
Embodiments provide an apparatus for encoding a multi-channel signal having at least three channels. The apparatus comprises an iteration processor, a channel encoder and an output interface. The iteration processor is configured to calculate, in a first iteration step, inter-channel correlation values between each pair of the at least three channels, for selecting, in the first iteration step, a pair having a highest value or having a value above a threshold, and for processing the selected pair using a multi-channel processing operation to derive first multi-channel parameters for the selected pair and to derive first processed channels. Further, the iteration processor is configured to perform the calculating, the selecting and the processing in a second iteration step using at least one of the processed channels to derive second multi-channel parameters and second processed channels. The channel encoder is configured to encode channels resulting from an iteration processing performed by the iteration processor to obtain encoded channels. The output interface is configured to generate an encoded multi-channel signal having the encoded channels and the first and the second multi-channel parameters.
Further embodiments provide an apparatus for decoding an encoded multi-channel signal, the encoded multi-channel signal having encoded channels and at least first and second multi-channel parameters. The apparatus comprises a channel decoder and a multi-channel processor. The channel decoder is configured to decode the encoded channels to obtain decoded channels. The multi-channel processor is configured to perform a multi-channel processing using a second pair of the decoded channels identified by the second multi-channel parameters and using the second multi-channel parameters to obtain processed channels and to perform a further multi-channel processing using a first pair of channels identified by the first multi-channel parameters and using the first multi-channel parameters, wherein the first pair of channels comprises at least one processed channel.
In contrast to common multi-channel encoding concepts which use a fixed signal path (e.g., stereo coding tree), embodiments of the present invention use a dynamic signal path which is adapted to characteristics of the at least three input channels of the multi-channel input signal. In detail, the iteration processor 102 can be adapted to build the signal path (e.g, stereo tree), in the first iteration step, based on an inter-channel correlation value between each pair of the at least three channels CH1 to CH3, for selecting, in the first iteration step, a pair having the highest value or a value above a threshold, and, in the second iteration step, based on inter-channel correlation values between each pair of the at least three channels and corresponding previously processed channels, for selecting, in the second iteration step, a pair having the highest value or a value above a threshold.
Further embodiments provide a method for encoding a multi-channel signal having at least three channels. The method comprises:
Further embodiments provide a method for decoding an encoded multi-channel signal having encoded channels and at least first and second multichannel parameters. The method comprises:
Embodiments of the present invention will be detailed subsequently referring to the appended drawings, in which:
Equal or equivalent elements or elements with equal or equivalent functionality are denoted in the following description by equal or equivalent reference numerals.
In the following description, a plurality of details are set forth to provide a more thorough explanation of embodiments of the present invention. However, it will be apparent to those skilled in the art that embodiments of the present invention may be practiced without these specific details. In other instances, well-known structures and devices are shown in block diagram form rather than in detail in order to avoid obscuring embodiments of the present invention. In addition, features of the different embodiments described hereinafter may be combined with each other, unless specifically noted otherwise.
The iteration processor 102 is configured to calculate, in a first iteration step, inter-channel correlation values between each pair of the at least three channels CH1 to CH3 for selecting, in the first iteration step, a pair having a highest value or having a value above a threshold, and for processing the selected pair using a multi-channel processing operation to derive first multi-channel parameters MCH_PAR1 for the selected pair and to derive first processed channels P1 and P2. Further, the iteration processor 102 is configured to perform the calculating, the selecting and the processing in a second iteration step using at least one of the processed channels P1 or P2 to derive second multi-channel parameters MCH_PAR2 and second processed channels P3 and P4.
For example, as indicated in
In
Further, the iteration processor 102 can be configured to calculate, in the second iteration step, inter-channel correlation values between each pair of the at least three channels CH1 to CH3 and the processed channels P1 and P2, for selecting, in the second iteration step, a pair having a highest inter-channel correlation value or having a value above a threshold. Thereby, the iteration processor 102 can be configured to not select the selected pair of the first iteration step in the second iteration step (or in any further iteration step).
Referring to the example shown in
In
The iteration processor 102 can be configured to only select a pair when the level difference of the pair is smaller than a threshold, the threshold being smaller than 40 dB, 25 dB, 12 dB or smaller than 6 dB. Thereby, the thresholds of 25 or 40 dB correspond to rotation angles of 3 or 0.5 degree.
The iteration processor 102 can be configured to calculate normalized integer correlation values, wherein the iteration processor 102 can be configured to select a pair, when the integer correlation value is greater than e.g. 0.2 or advantageously 0.3.
Further, the iteration processor 102 may provide the channels resulting from the multichannel processing to the channel encoder 104. For example, referring to
The channel encoder 104 can be configured to encode the channels P2 to P4 resulting from the iteration processing (or multichannel processing) performed by the iteration processor 102 to obtain encoded channels E1 to E3.
For example, the channel encoder 104 can be configured to use mono encoders (or mono boxes, or mono tools) 120_1 to 120_3 for encoding the channels P2 to P4 resulting from the iteration processing (or multichannel processing). The mono boxes may be configured to encode the channels such that less bits may be used for encoding a channel having less energy (or a smaller amplitude) than for encoding a channel having more energy (or a higher amplitude). The mono boxes 120_1 to 120_3 can be, for example, transformation based audio encoders. Further, the channel encoder 104 can be configured to use stereo encoders (e.g., parametric stereo encoders, or lossy stereo encoders) for encoding the channels P2 to P4 resulting from the iteration processing (or multichannel processing).
The output interface 106 can be configured to generate and encoded multi-channel signal 107 having the encoded channels E1 to E3 and the first and the second multi-channel parameters MCH_PAR1 and MCH_PAR2.
For example, the output interface 106 can be configured to generate the encoded multi-channel signal 107 as a serial signal or serial bit stream, and so that the second multi-channel parameters MCH_PAR2 are in the encoded signal 107 before the first multi-channel parameters MCH_PAR1. Thus, a decoder, an embodiment of which will be described later with respect to
In
For illustration purposes the multi-channel processing operations performed by the iteration processor 102 in the first iteration step and the second iteration step are exemplarily illustrated in
Thereby, inter-channel signal dependency can be exploited by hierarchically applying known joint stereo coding tools. In contrast to previous MPEG approaches, the signal pairs to be processed are not predetermined by a fixed signal path (e.g., stereo coding tree) but can be changed dynamically to adapt to input signal characteristics. The inputs of the actual stereo box can be (1) unprocessed channels, such as the channels CH1 to CH3, (2) outputs of a preceding stereo box, such as the processed signals P1 to P4, or (3) a combination of an unprocessed channel and an output of a preceding stereo box.
The processing inside the stereo box 110 and 112 can either be prediction based (like complex prediction box in USAC) or KLT/PCA based (the input channels are rotated (e.g., via a 2×2 rotation matrix) in the encoder to maximize energy compaction, i.e., concentrate signal energy into one channel, in the decoder the rotated signals will be retransformed to the original input signal directions).
In a possible implementation of the encoder 100, (1) the encoder calculates an inter channel correlation between every channel pair and selects one suitable signal pair out of the input signals and applies the stereo tool to the selected channels; (2) the encoder recalculates the inter channel correlation between all channels (the unprocessed channels as well as the processed intermediate output channels) and selects one suitable signal pair out of the input signals and applies the stereo tool to the selected channels; and (3) the encoder repeats step (2) until all inter channel correlation is below a threshold or if a maximum number of transformations is applied.
As already mentioned, the signal pairs to be processed by the encoder 100, or more precisely the iteration processor 102, are not predetermined by a fixed signal path (e.g., stereo coding tree) but can be changed dynamically to adapt to input signal characteristics. Thereby, the encoder 100 (or the iteration processor 102) can be configured to construct the stereo tree in dependence on the at least three channels CH1 to CH3 of the multi-channel (input) signal 101. In other words, the encoder 100 (or the iteration processor 102) can be configured to build the stereo tree based on an inter-channel correlation (e.g., by calculating, in the first iteration step, inter-channel correlation values between each pair of the at least three channels CH1 to CH3, for selecting, in the first iteration step, a pair having the highest value or a value above a threshold, and by calculating, in a second iteration step, inter-channel correlation values between each pair of the at least three channels and previously processed channels, for selecting, in the second iteration step, a pair having the highest value or a value above a threshold). According to a one step approach, a correlation matrix may be calculated for possibly each iteration containing the correlations of all, in previous iterations possibly processed, channels.
As indicated above, the iteration processor 102 can be configured to derive first multi-channel parameters MCH_PAR1 for the selected pair in the first iteration step and to derive second multi-channel parameters MCH_PAR2 for the selected pair in the second iteration step. The first multi-channel parameters MCH_PAR1 may comprise a first channel pair identification (or index) identifying (or signaling) the pair of channels selected in the first iteration step, wherein the second multi-channel parameters MCH_PAR2 may comprise a second channel pair identification (or index) identifying (or signaling) the pair of channels selected in the second iteration step.
In the following, an efficient indexing of input signals is described. For example, channel pairs can be efficiently signaled using a unique index for each pair, dependent on the total number of channels. For example, the indexing of pairs for six channels can be as shown in the following table:
For example, in the above table the index 5 may signal the pair consisting of the first channel and the second channel. Similarly, the index 6 may signal the pair consisting of the first channel and the third channel.
The total number of possible channel pair indices for n channels can be calculated to:
numPairs=numChannels*(numChannels−1)/2
Hence, the number of bits needed for signaling one channel pair amount to:
numBits=floor(log2(numPairs−1))+1
Further, the encoder 100 may use a channel mask. The multichannel tool's configuration may contain a channel mask indicating for which channels the tool is active. Thus, LFEs (LFE=low frequency effects/enhancement channels) can be removed from the channel pair indexing, allowing for a more efficient encoding. E.g. for a 11.1 setup, this reduces the number of channel pair indices from 12*11/2=66 to 11*10/2=55, allowing signaling with 6 instead of 7 bit. This mechanism can also be used to exclude channels intended to be mono objects (e.g. multiple language tracks). On decoding of the channel mask (channelMask), a channel map (channelMap) can be generated to allow re-mapping of channel pair indices to decoder channels.
Moreover, the iteration processor 102 can be configured to derive, for a first frame, a plurality of selected pair indications, wherein the output interface 106 can be configured to include, into the multi-channel signal 107, for a second frame, following the first frame, a keep indicator, indicating that the second frame has the same plurality of selected pair indications as the first frame.
The keep indicator or the keep tree flag can be used to signal that no new tree is transmitted, but the last stereo tree shall be used. This can be used to avoid multiple transmission of the same stereo tree configuration if the channel correlation properties stay stationary for a longer time.
The iteration processor 102 can use (or comprise) stereo boxes 110,112 in order to perform the multi-channel processing operations on the input channels and/or processed channels in order to derive (further) processed channels. For example, the iteration processor 102 can be configured to use generic, prediction based or KLT (Karhunen-Loève-Transformation) based rotation stereo boxes 110,112.
A generic encoder (or encoder-side stereo box) can be configured to encode the input signals I1 and I2 to obtain the output signals O1 and O2 based on the equation:
A generic decoder (or decoder-side stereo box) can be configured to decode the input signals I1 and I2 to obtain the output signals O1 and O2 based on the equation:
A prediction based encoder (or encoder-side stereo box) can be configured to encode the input signals I1 and I2 to obtain the output signals O1 and O2 based on the equation
wherein p is the prediction coefficient.
A prediction based decoder (or decoder-side stereo box) can be configured to decode the input signals I1 and I2 to obtain the output signals O1 and O2 based on the equation:
A KLT based rotation encoder (or encoder-side stereo box) can be configured to encode the input signals I1 to I2 to obtain the output signals O1 and O2 based on the equation:
A KLT based rotation decoder (or decoder-side stereo box) can be configured to decode the input signals I1 and I2 to obtain the output signals O1 and O2 based on the equation (inverse rotation):
In the following, a calculation of the rotation angle α for the KLT based rotation is described.
The rotation angle α for the KLT based rotation can be defined as:
with cxy being the entries of a non-normalized correlation matrix, wherein c11, c22 are the channel energies.
This can be implemented using the a tan 2 function to allow for differentiation between negative correlations in the numerator and negative energy difference in the denominator:
alpha=0.5*a tan 2(2*correlation[ch1][ch2],(correlation[ch1][ch1]−correlation[ch2][ch2]));
Further, the iteration processor 102 can be configured to calculate an inter-channel correlation using a frame of each channel comprising a plurality of bands so that a single inter-channel correlation value for the plurality of bands is obtained, wherein the iteration processor 102 can be configured to perform the multi-channel processing for each of the plurality of bands so that the first or the second multi-channel parameters are obtained from each of the plurality of bands.
Thereby, the iteration processor 102 can be configured to calculate stereo parameters in the multi-channel processing, wherein the iteration processor 102 can be configured to only perform a stereo processing in bands, in which a stereo parameter is higher than a quantized-to-zero threshold defined by a stereo quantizer (e.g., KLT based rotation encoder). The stereo parameters can be, for example, MS On/Off or rotation angles or prediction coefficients).
For example, the iteration processor 102 can be configured to calculate rotation angles in the multi-channel processing, wherein the iteration processor 102 can be configured to only perform a rotation processing in bands, in which a rotation angle is higher than a quantized-to-zero threshold defined by a rotation angle quantizer (e.g., KLT based rotation encoder).
Thus, the encoder 100 (or output interface 106) can be configured to transmit the transformation/rotation information either as one parameter for the complete spectrum (full band box) or as multiple frequency dependent parameters for parts of the spectrum.
The encoder 100 can be configured to generate the bit stream 107 based on the following tables:
As indicated in
In a first iteration step, the iteration processor 102 calculates the inter-channel correlation values between each pair of the five channels L, R, Ls, Rs, and C, for selecting, in the first iteration step, a pair having a highest value or having a value above a threshold. In
In a second iteration step, the iteration processor 102 calculates inter-channel correlation values between each pair of the five channels L, R, Ls, Rs, and C and the processed channels P1 and P2, for selecting, in the second iteration step, a pair having a highest value or having a value above a threshold. In
In a third iteration step, the iteration processor 102 calculates inter-channel correlation values between each pair of the five channels L, R, Ls, Rs, and C and the processed channels P1 to P4, for selecting, in the third iteration step, a pair having a highest value or having a value above a threshold. In
In a fourth iteration step, the iteration processor 102 calculates inter-channel correlation values between each pair of the five channels L, R, Ls, Rs, and C and the processed channels P1 to P6, for selecting, in the fourth iteration step, a pair having a highest value or having a value above a threshold. In
The stereo boxes 110 to 116 can be MS stereo boxes, i.e. mid/side stereophony boxes configured to provide a mid-channel and a side-channel. The mid-channel can be the sum of the input channels of the stereo box, wherein the side-channel can be the difference between the input channels of the stereo box. Further, the stereo boxes 110 and 116 can be rotation boxes or stereo prediction boxes.
In
Further, as indicated in
The channel decoder 202 is configured to decode the encoded channels E1 to E3 to obtain decoded channels in D1 to D3.
For example, the channel decoder 202 can comprise at least three mono decoders (or mono boxes, or mono tools) 206_1 to 206_3, wherein each of the mono decoders 206_1 to 206_3 can be configured to decode one of the at least three encoded channels E1 to E3, to obtain the respective decoded channel E1 to E3. The mono decoders 206_1 to 206_3 can be, for example, transformation based audio decoders.
The multi-channel processor 204 is configured for performing a multi-channel processing using a second pair of the decoded channels identified by the second multi-channel parameters MCH_PAR2 and using the second multi-channel parameters MCH_PAR2 to obtain processed channels, and for performing a further multi-channel processing using a first pair of channels identified by the first multi-channel parameters MCH_PAR1 and using the first multi-channel parameters MCH_PAR1, where the first pair of channels comprises at least one processed channel.
As indicated in
Further, the multi-channel processor 204 may provide the third processed channel P3* as first channel CH1, the fourth processed channel P4* as third channel CH3 and the second processed channel P2* as second channel CH2.
Assuming that the decoder 200 shown in
Further, the encoded multi-channel signal 107 can be a serial signal, wherein the second multichannel parameters MCH_PAR2 are received, at the decoder 200, before the first multichannel parameters MCH_PAR1. In that case, the multichannel processor 204 can be configured to process the decoded channels in an order, in which the multichannel parameters MCH_PAR1 and MCH_PAR2 are received by the decoder. In the example shown in
In
For example, the encoder 100 can use KLT based rotation encoders (or encoder-side stereo boxes). In that case, the encoder 100 may derive the first and second multichannel parameters MCH_PAR1 and MCH_PAR2 such that the first and second multichannel parameters MCH_PAR1 and MCH_PAR2 comprise rotation angles. The rotation angles can be differentially encoded. Therefore, the multichannel processor 204 of the decoder 200 can comprise a differential decoder for differentially decoding the differentially encoded rotation angles.
The apparatus 200 may further comprise an input interface 212 configured to receive and process the encoded multi-channel signal 107, to provide the encoded channels E1 to E3 to the channel decoder 202 and the first and second multi-channel parameters MCH_PAR1 and MCH_PAR2 to the multi-channel processor 204.
As already mentioned, a keep indicator (or keep tree flag) may be used to signal that no new tree is transmitted, but the last stereo tree shall be used. This can be used to avoid multiple transmission of the same stereo tree configuration if the channel correlation properties stay stationary for a longer time.
Therefore, when the encoded multi-channel signal 107 comprises, for a first frame, the first or the second multichannel parameters MCH_PAR1 and MCH_PAR2 and, for a second frame, following the first frame, the keep indicator, the multichannel processor 204 can be configured to perform the multichannel processing or the further multichannel processing in the second frame to the same second pair or the same first pair of channels as used in the first frame.
The multichannel processing and the further multichannel processing may comprise a stereo processing using a stereo parameter, wherein for individual scale factor bands or groups of scale factor bands of the decoded channels D1 to D3, a first stereo parameter is included in the first multichannel parameter MCH_PAR1 and a second stereo parameter is included in the second multichannel parameter MCH_PAR2. Thereby, the first stereo parameter and the second stereo parameter can be of the same type, such as rotation angles or prediction coefficients. Naturally, the first stereo parameter and the second stereo parameter can be of different types. For example, the first stereo parameter can be a rotation angle, wherein the second stereo parameter can be a prediction coefficient, or vice versa.
Further, the first or the second multichannel parameters MCH_PAR1 and MCH_PAR2 can comprise a multichannel processing mask indicating which scale factor bands are multichannel processed and which scale factor bands are not multichannel processed. Thereby, the multichannel processor 204 can be configured to not perform the multichannel processing in the scale factor bands indicated by the multichannel processing mask.
The first and the second multichannel parameters MCH_PAR1 and MCH_PAR2 may each include a channel pair identification (or index), wherein the multichannel processor 204 can be configured to decode the channel pair identifications (or indexes) using a predefined decoding rule or a decoding rule indicated in the encoded multi-channel signal.
For example, channel pairs can be efficiently signaled using a unique index for each pair, dependent on the total number of channels, as described above with reference to the encoder 100.
Further, the decoding rule can be a Huffman decoding rule, wherein the multichannel processor 204 can be configured to perform a Huffman decoding of the channel pair identifications.
The encoded multi-channel signal 107 may further comprise a multichannel processing allowance indicator indicating only a sub-group of the decoded channels, for which the multichannel processing is allowed and indicating at least one decoded channel for which the multichannel processing is not allowed. Thereby, the multichannel processor 204 can be configured for not performing any multichannel processing for the at least one decoded channel, for which the multichannel processing is not allowed as indicated by the multichannel processing allowance indicator.
For example, when the multichannel signal is a 5.1 channel signal, the multichannel processing allowance indicator may indicate that the multichannel processing is only allowed for the 5 channels, i.e. right R, left L, right surround Rs, left surround LS and center C, wherein the multichannel processing is not allowed for the LFE channel.
For the decoding process (decoding of channel pair indices) the following c-code may be used. Thereby, for all channel pairs, the number of channels with active KLT processing (nChannels) as well as the number of channel pairs (numPairs) of the current frame is needed.
For decoding the prediction coefficients for non-bandwise angles the following c-code can be used.
For decoding the prediction coefficients for non-bandwise KLT angles the following c-code can be used.
To avoid floating point differences of trigonometric functions on different platforms, the following lookup-tables for converting angle indices directly to sin/cos shall be used:
For decoding of multi-channel coding the following c-code can be used for the KLT rotation based approach.
For bandwise processing the following c-code can be used.
For an application of KLT rotation the following c-code can be used.
Although the present invention has been described in the context of block diagrams where the blocks represent actual or logical hardware components, the present invention can also be implemented by a computer-implemented method. In the latter case, the blocks represent corresponding method steps where these steps stand for the functionalities performed by corresponding logical or physical hardware blocks.
Although some aspects have been described in the context of an apparatus, it is clear that these aspects also represent a description of the corresponding method, where a block or device corresponds to a method step or a feature of a method step. Analogously, aspects described in the context of a method step also represent a description of a corresponding block or item or feature of a corresponding apparatus. Some or all of the method steps may be executed by (or using) a hardware apparatus, like for example, a microprocessor, a programmable computer or an electronic circuit. In some embodiments, some one or more of the most important method steps may be executed by such an apparatus.
The inventive transmitted or encoded signal can be stored on a digital storage medium or can be transmitted on a transmission medium such as a wireless transmission medium or a wired transmission medium such as the Internet.
Depending on certain implementation requirements, embodiments of the invention can be implemented in hardware or in software. The implementation can be performed using a digital storage medium, for example a floppy disc, a DVD, a Blu-Ray, a CD, a ROM, a PROM, and 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 method is, therefore, a data carrier (or a non-transitory storage medium such as 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 invention 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 are advantageously performed by any hardware apparatus.
Embodiments provide an apparatus, method or computer program as described herein wherein multichannel processing means joint stereo processing or joint processing of more than two channels, and wherein a multichannel signal has two channels or more than two channels.
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 |
---|---|---|---|
15158234 | Mar 2015 | EP | regional |
15172492 | Jun 2015 | EP | regional |
This application is a divisional application of U.S. Ser. No. 15/696,861, filed Sep. 6, 2017, which is a continuation of International Application No. PCT/EP2016/054900, filed Mar. 8, 2016, which is incorporated herein by reference in its entirety, and additionally claims priority from European Applications Nos. EP 15158234.3, filed Mar. 9, 2015, and EP 15172492.9, filed Jun. 17, 2015, both of which are incorporated herein by reference in their entirety. The present invention relates to audio coding/decoding and, in particular, to audio coding exploiting inter-channel signal dependencies.
Number | Name | Date | Kind |
---|---|---|---|
8295494 | Oh | Oct 2012 | B2 |
8731204 | Sperschneider | May 2014 | B2 |
8989881 | Popp | Mar 2015 | B2 |
9105264 | Ishikawa | Aug 2015 | B2 |
9154896 | Mahabub | Oct 2015 | B2 |
9659569 | Vasilache | May 2017 | B2 |
20040049379 | Thumpudi et al. | Mar 2004 | A1 |
20050074127 | Herre | Apr 2005 | A1 |
20060233380 | Holzer et al. | Oct 2006 | A1 |
20070071247 | Pang et al. | Mar 2007 | A1 |
20070121954 | Kim et al. | May 2007 | A1 |
20080002842 | Neusinger | Jan 2008 | A1 |
20080015867 | Kraemer | Jan 2008 | A1 |
20080262854 | Jung et al. | Oct 2008 | A1 |
20090112606 | Mehrotra et al. | Apr 2009 | A1 |
20100322429 | Norvell et al. | Dec 2010 | A1 |
20110022402 | Engdegard et al. | Jan 2011 | A1 |
20120057715 | Johnston et al. | Mar 2012 | A1 |
20120259642 | Takada et al. | Oct 2012 | A1 |
20130030819 | Purnhagen | Jan 2013 | A1 |
20130077793 | Moon et al. | Mar 2013 | A1 |
20130279702 | Lang et al. | Oct 2013 | A1 |
20150131799 | Kim | May 2015 | A1 |
20150221314 | Disch et al. | Aug 2015 | A1 |
20150279377 | Disch et al. | Oct 2015 | A1 |
20150380002 | Uhle et al. | Dec 2015 | A1 |
20170134873 | Beack et al. | May 2017 | A1 |
Number | Date | Country |
---|---|---|
101529501 | Sep 2009 | CN |
101930742 | Dec 2010 | CN |
103262158 | Aug 2013 | CN |
2541546 | Jan 2013 | EP |
H07160292 | Jun 1995 | JP |
2004246224 | Sep 2004 | JP |
2008503767 | Feb 2008 | JP |
2008129250 | Jun 2008 | JP |
2008535014 | Aug 2008 | JP |
2015011076 | Jan 2015 | JP |
2367033 | Sep 2009 | RU |
201419266 | May 2014 | TW |
201423729 | Jun 2014 | TW |
201444383 | Nov 2014 | TW |
2002023528 | Mar 2002 | WO |
2007004831 | Jan 2007 | WO |
2007010451 | Jan 2007 | WO |
2010087630 | Aug 2010 | WO |
Entry |
---|
“Information technology—MPEG audio technologies—Part 1: MPEG Sound”, ISO/IEC 23003-1:2007(E), Feb. 15, 2007, 1-288. |
“Information technology—MPEG audio technologies—Part 3: Unified speech and audio coding”, ISO/IEC FDIS 23003-3:2011(E); ISO/IEC JTC 1/SC 29/WG 11; STD Version 2.1c2, 2011, 286 pps. |
ETSI TS 103 190 V1.1.1 (Apr. 2014), “Digital Audio Compression (AC-4) Standard”, Technical Specification, EBU, Operating Eurovision, Apr. 2014, pp. 1-295. |
Yang, D. et al., “Adaptive Karhunen-Loeve Transform for Enhanced Multichannel Audio Coding”, http://ict.usc.edu/pubs/Adaptive%20Karhunen-Loeve%20Transform%20for%20Enhanced%20Multichannel%20Audio%20Coding.pdf, 2001, 12 pages. |
Breebaart, J et al., “MPEG Spatial Audio Coding/MPEG Surround: Overview and Current Status”, Audio Engineering Society Convention Paper presented at the 119th Convention, Oct. 10, 2005, 17 pages. |
Dong, Shi et al., “Three-channel dependent mid/side coding framework for multichannel 3D audio”, Journal on Communications, vol. 35, No. 6, Jun. 25, 2014, 6 pp. |
Number | Date | Country | |
---|---|---|---|
20190333524 A1 | Oct 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15696861 | Sep 2017 | US |
Child | 16413299 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2016/054900 | Mar 2016 | US |
Child | 15696861 | US |