The present invention pertains to a method for inter-channel difference (ICD) estimation and a spatial audio coding or parametric multi-channel coding device, in particular for parametric multichannel audio encoding.
Parametric multi-channel audio coding is described in Faller, C., Baumgarte, F.: “Efficient representation of spatial audio using perceptual parametrization”, Proc. IEEE Workshop on Appl. of Sig. Proc. to Audio and Acoust., October 2001, pp. 199-202. Downmixed audio signals may be upmixed to synthesize multi-channel audio signals, using spatial cues to generate more output audio channels than downmixed audio signals. Usually, the downmixed audio signals are generated by superposition of a plurality of audio channel signals of a multi-channel audio signal, for example a stereo audio signal. The downmixed audio signals are waveform coded and put into an audio bitstream together with auxiliary data relating to the spatial cues. The decoder uses the auxiliary data to synthesize the multi-channel audio signals based on the waveform coded audio channels.
There are several spatial cues or parameters that may be used for synthesizing multi-channel audio signals. First, the inter-channel level difference (ILD) indicates a difference between the levels of audio signals on two channels to be compared. Second, the inter-channel time difference (ITD) indicates the difference in arrival time of sound between the ears of a human listener. The ITD value is important for the localization of sound, as it provides a cue to identify the direction or angle of incidence of the sound source relative to the ears of the listener. Third, the inter-channel phase difference (IPD) specifies the relative phase difference between the two channels to be compared. A subband IPD value may be used as an estimate of the subband ITD value. Finally, inter-channel coherence (ICC) is defined as the normalized inter-channel cross-correlation after a phase alignment according to the ITD or IPD. The ICC value may be used to estimate the width of a sound source.
ILD, ITD, IPD and ICC are important parameters for spatial multi-channel coding/decoding, in particular for stereo audio signals and especially binaural audio signals. ITD may for example cover the range of audible delays between −1.5 milliseconds (ms) to 1.5 ms. IPD may cover the full range of phase differences between −π and π. ICC may cover the range of correlation and may be specified in a percentage value between 0 and 1 or other correlation factors between −1 and +1. In current parametric stereo coding schemes, ILD, ITD, IPD and ICC are usually estimated in the frequency domain. For every subband, ILD, ITD, IPD and ICC are calculated, quantized, included in the parameter section of an audio bitstream and transmitted.
Due to restrictions in bitrates for parametric audio coding schemes there are sometimes not enough bits in the parameter section of the audio bitstream to transmit all of the values of the spatial coding parameters. For example, the document U.S. Patent Application Publication 2006/0153408 A1 discloses an audio encoder wherein combined cue codes are generated for a plurality of audio channels to be included as side information into a downmixed audio bitstream. The document U.S. Pat. No. 8,054,981 B2 discloses a method for spatial audio coding using a quantization rule associated with the relation of levels of an energy measure of an audio channel and the energy measure of a plurality of audio channels.
An idea of the present invention is to calculate inter-channel difference (ICD) values for each frequency subband or frequency bin between each pair of a plurality of audio channel signals and to compute a weighted average value on the basis of the ICD values. Dependent on the weighting scheme, the perceptually important frequency subbands or bins are taken into account with a higher priority than the less important ones.
Advantageously, the energy or perceptual importance is taken into account with this technique, so that ambience sound or diffuse sound will not affect the ICD estimation. This is particularly advantageous for meaningfully representing the spatial image of sounds having a strong direct component such as speech audio data.
Moreover, the proposed method reduces the number of spatial coding parameters to be included into an audio bitstream, thereby reducing estimation complexity and transmission bitrate.
Consequently, a first aspect of the present invention relates to a method for the estimation of inter-channel differences, ICDs, the method comprising applying a transformation from a time domain to a frequency domain to a plurality of audio channel signals, calculating a plurality of ICD values for the ICD between at least one of the plurality of audio channel signals and a reference audio channel signal over a predetermined frequency range, each ICD value being calculated over a portion of the predetermined frequency range, calculating, for each of the plurality of ICD values, a weighted ICD value by multiplying each of the plurality of ICD values with a corresponding frequency-dependent weighting factor, and calculating an ICD range value for the predetermined frequency range by adding the plurality of weighted ICD values.
According to a first implementation of the first aspect the ICDs are IPDs or ITDs. These spatial coding parameters are particularly advantageous for audio data reproduction for human hearing.
According to a second implementation of the first aspect the transformation from a time domain to a frequency domain comprises one of the group of Fast Fourier Transformation (FFT), cosine modulated filter bank, Discrete Fourier Transformation (DFT) and complex filter bank.
According to a third implementation of the first aspect the predetermined frequency range comprises one of the group of a full frequency band of the plurality of audio channel signals, a predetermined frequency interval within the full frequency band of the plurality of audio channel signals, and a plurality of predetermined frequency intervals within the full frequency band of the plurality of audio channel signals.
According to a first implementation of the third implementation of the first aspect the predetermined frequency interval lies between 200 Hertz (Hz) and 600 Hz or between 300 Hz and 1.5 kilohertz (kHz). These frequency ranges correspond with the frequency dependent sensitivity of human hearing, in which IPD parameters are most meaningful.
According to a fourth implementation of the first aspect the reference audio channel signal comprises one of the audio channel signals or a downmix audio signal derived from at least two audio channel signals of the plurality of audio channel signals.
According to a fifth implementation of the first aspect calculating the plurality of ICD values comprises calculating the plurality of ICD values on the basis of frequency subbands.
According to a first implementation of the fifth implementation of the first aspect the frequency-dependent weighting factors are determined on the basis of the energy of the frequency subbands normalized on the basis of the overall energy over the predetermined frequency range.
According to a second implementation of the fifth implementation of the first aspect the frequency-dependent weighting factors are determined on the basis of a masking curve for the energy distribution of the frequencies of the audio channel signals normalized over the predetermined frequency range.
According to a third implementation of the fifth implementation of the first aspect the frequency-dependent weighting factors are determined on the basis of perceptual entropy values of the subbands of the audio channel signals normalized over the predetermined frequency range.
According to a sixth implementation of the first aspect the frequency-dependent weighting factors are smoothed between at least two consecutive frames. This may be advantageous since the estimated ICD values are relatively stable between consecutive frames due to the stereo image usually not changing a lot during a short period of time.
According to a second aspect of the present invention, a spatial audio coding device comprises a transformation module configured to apply a transformation from a time domain to a frequency domain to a plurality of audio channel signals, and a parameter estimation module configured to calculate a plurality of ICD values for the ICDs between at least one of the plurality of audio channel signals and a reference audio channel signal over a predetermined frequency range, to calculate, for each of the plurality of ICD values, a weighted ICD value by multiplying each of the plurality of ICD values with a corresponding frequency-dependent weighting factor, and to calculate an ICD range value for the predetermined frequency range by adding the plurality of weighted ICD values.
According to a first implementation of the second aspect, the spatial audio coding device further comprises a downmixing module configured to generate a downmix audio channel signal by downmixing the plurality of audio channel signals.
According to a second implementation of the second aspect, the spatial audio coding device further comprises an encoding module coupled to the downmixing module and configured to generate an encoded audio bitstream comprising the encoded downmixed audio bitstream.
According to a third implementation of the second aspect, the spatial audio coding device further comprises a streaming module coupled to the parameter estimation module and configured to generate an audio bitstream comprising a downmixed audio bitstream and auxiliary data comprising ICD range values for the plurality of audio channel signals.
According to a first implementation of the third implementation of the second aspect the streaming module is further configured to set a flag in the audio bitstream, the flag indicating the presence of auxiliary data comprising the ICD range values in the audio bitstream.
According to a fourth implementation of the second aspect the flag is set for the whole audio bitstream or comprised in the auxiliary data comprised in the audio bitstream.
According to a third aspect of the present invention, a computer program is provided, the computer program comprising a program code for performing the method according to the first aspect or any of its implementations when run on a computer.
The methods described herein may be implemented as software in a Digital Signal Processor (DSP), in a micro-controller or in any other side-processor or as hardware circuit within an application specific integrated circuit (ASIC).
The invention can be implemented in digital electronic circuitry, or in computer hardware, firmware, software, or in combinations thereof.
Additional embodiments and implementations may be readily understood from the following description. In particular, any features from the embodiments, aspects and implementations as set forth hereinbelow may be combined with any other features from the embodiments, aspects and implementations, unless specifically noted otherwise.
The accompanying drawings are included to provide a further understanding of the disclosure. They illustrate embodiments and may help to explain the principles of the invention in conjunction with the description. Other embodiments and many of the intended advantages, envisaged principles and functionalities will be appreciated as they become better understood by reference to the detailed description as following hereinbelow. The elements of the drawings are not necessarily drawn to scale relative to each other. In general, like reference numerals designate corresponding similar parts.
In the following detailed description, reference is made to the accompanying drawings, and in which, by way of illustration, specific embodiments are shown. It should be obvious that other embodiments may be utilized and structural or logical changes may be made without departing from the scope of the present invention. Unless specifically noted otherwise, functions, principles and details of each embodiment may be combined with other embodiments. Generally, this application is intended to cover any adaptations or variations of the specific embodiments discussed herein. Hence, the following detailed description is not to be taken in a limiting sense, and the scope of the present invention is defined by the appended claims.
Embodiments may include methods and processes that may be embodied within machine readable instructions provided by a machine readable medium, the machine readable medium including, but not being limited to devices, apparatuses, mechanisms or systems being able to store information which may be accessible to a machine such as a computer, a calculating device, a processing unit, a networking device, a portable computer, a microprocessor or the like. The machine readable medium may include volatile or non-volatile media as well as propagated signals of any form such as electrical signals, digital signals, logical signals, optical signals, acoustical signals, acousto-optical signals or the like, the media being capable of conveying information to a machine.
In the following, reference is made to methods and method steps, which are schematically and exemplarily illustrated in flow charts and block diagrams. It should be understood that the methods described in conjunction with those illustrative drawings may easily be performed by embodiments of systems, apparatuses and/or devices as well. In particular, it should be obvious that the systems, apparatuses and/or devices capable of performing the detailed block diagrams and/or flow charts are not necessarily limited to the systems, apparatuses and/or devices shown and detailed herein below, but may rather be different systems, apparatuses and/or devices. The terms “first”, “second”, “third”, etc. are used merely as labels, and are not intended to impose numerical requirements on their objects or to establish a certain ranking of importance of their objects.
The spatial audio coding system 100 may be applied for encoding of the stereo extension of ITU-T G.722, G. 722 Annex B, G.711.1 and/or G.711.1 Annex D. Moreover, the spatial audio coding system 100 may be used for speech and audio coding/decoding in mobile applications, such as defined in Third Generation Partnership (3GPP) Enhanced Voice Services (EVS) codec.
The transformation module 15 may be configured to apply a transformation from a time domain to a frequency domain to a plurality of audio channel signals 10a, 10b input to the spatial audio coding device 10. The downmixing module 12 may be configured to receive the transformed audio channel signals 10a, 10b from the transformation module 15 and to generate at least one downmixed audio channel signal by downmixing the plurality of transformed audio channel signals 10a, 10b. The number of downmixed audio channel signals may for example be less than the number of transformed audio channel signals 10a, 10b. For example, the downmixing module 12 may be configured to generate only one downmixed audio channel signal. The encoding module 13 may be configured to receive the downmixed audio channel signals and to generate an encoded audio bitstream 1 comprising the encoded downmixed audio channel signals.
The parameter estimation module 11 may be configured to receive the plurality of audio channel signals 10a, 10b as input and to calculate a plurality of ICD values for the ICDs between at least one of the plurality of audio channel signals 10a and 10b and a reference audio channel signal over a predetermined frequency range. The reference audio channel signal may for example be one of the plurality of audio channel signals 10a and 10b. Alternatively, it may be possible to use a downmixed audio signal derived from at least two audio channel signals of the plurality of audio channel signals 10a and 10b. The parameter estimation module 11 may further be configured to calculate, for each of the plurality of ICD values, a weighted ICD value by multiplying each of the plurality of ICD values with a corresponding frequency-dependent weighting factor, and to calculate an ICD range value for the predetermined frequency range by adding the plurality of weighted ICD values.
The ICD range value may then be input to the streaming module 14 which may be configured to generate the output audio bitstream 1 comprising the encoded audio bitstream from the encoding module 13 and a parameter section comprising a quantized representation of the ICD range value. The streaming module 14 may further be configured to set a parameter type flag in the parameter section of the audio bitstream 1 indicating the type of ICD range value being included into the audio bitstream 1.
Additionally, the streaming module 14 may further be configured to set a flag in the audio bitstream 1, the flag indicating the presence of the ICD range value in the parameter section of the audio bitstream 1. This flag may be set for the whole audio bitstream 1 or comprised in the parameter section of the audio bitstream 1. That way, the signalling of the ICD range value being included into the audio bitstream 1 may be signalled explicitly or implicitly to the spatial audio decoding device 20. It may be possible to switch between the explicit and implicit signalling schemes.
In the case of implicit signalling, the flag may indicate the presence of the secondary channel information in the auxiliary data in the parameter section. A legacy spatial audio decoding device 20 does not check whether such a flag is present and thus only decodes the encoded downmixed audio bitstream 1. On the other hand, a non-legacy, i.e. up-to-date spatial audio decoding device 20 may check the presence of such a flag in the received audio bitstream 1 and reconstruct the multi-channel audio signal 20a, 20b based on the additional full band spatial coding parameters, i.e. the ICD range value included in the parameter section of the audio bitstream 1.
When using explicit signalling, the whole audio bitstream 1 may be flagged as containing an ICD range value. That way, a legacy spatial audio decoding device 20 is not able to decode the bitstream and thus discards the audio bitstream 1. On the other hand, an up-to-date spatial audio decoding device 20 may decide on whether to decode the audio bitstream 1 as a whole or only to decode the encoded downmixed audio bitstream 1 while neglecting the ICD range value. The benefit of the explicit signalling may be seen in that, for example, a new mobile terminal can decide what parts of an audio bitstream 1 to decode in order to save energy and thus extend the battery life of an integrated battery. Decoding spatial coding parameters is usually more complex and requires more energy. Additionally, depending on the rendering system, the up-to-date spatial audio decoding device 20 may decide which part of the audio bitstream 1 should be decoded. For example, for rendering with headphones it may be sufficient to only decode the encoded downmixed audio bitstream 1, while the multi-channel audio signal is decoded only when the mobile terminal is connected to a docking station with such multi-channel rendering capability.
The decoding module 22 may be configured to decode the encoded downmixed audio bitstream 1 and to input the decoded downmixed audio signal into the upmixing module 24. The upmixing module 24 may be coupled to the parameter extraction module 21 and configured to upmix the decoded downmixed audio signal to a plurality of audio channel signals using the read ICD range value from the parameter section of the received audio bitstream 1 as provided by the parameter extraction module 21. Finally, the transformation module 25 may be coupled to the upmixing module 24 and configured to transform the plurality of audio channel signals from a frequency domain to a time domain for reproduction of sound on the basis of the plurality of audio channel signals.
In a second step 31, a cross spectrum c[b] may be computed per subband b as
c[b]=Σk=k
wherein X1[k] and X2[k] are the FFT coefficients of the two channels 1 and 2, for example the left and the right channel in case of stereo. “*” denotes the complex conjugation, kb denotes the start bin of the subband b and kb+1 denotes the start bin of the neighbouring subband b+1. Hence, the frequency bins [k] of the FFT from kb to kb+1 represent the subband b.
Alternatively, the cross spectrum may be computed for each frequency bin k of the FFT. In this case, the subband b corresponds directly to one frequency bin [k].
In a third step 32, ICDs may be calculated per subband b based on the cross spectrum. For example, in case of the IPD such calculation may be conducted as
IPD[b]=∠c[b]
wherein the IPD per subband b is the angle of the cross spectrum c[b] of the respective subband b. The steps 31 and 32 ensure that a plurality of ICD values, in particular IPD values, for the ICDs/IPDs between at least one of the plurality of audio channel signals and a reference audio channel signal over a predetermined frequency range are calculated. Moreover, each ICD value is calculated over a portion of the predetermined frequency range, which is a frequency subband b or at least a single frequency bin.
The calculation scheme as detailed with respect to steps 31 and 32 corresponds to the method as known from Breebart, J., van de Par, S., Kohlrausch, A., Schuijers, E.: “Parametric Coding of Stereo Audio”, EURASIP Journal on Applied Signal Processing, 2005, No. 9, pp. 1305-1322.
This IPD value represents a phase difference for a band limited signal. If the bandwidth is limited enough, this phase difference can be seen as fractional delay between the input signals. For each frequency subband b, IPD and ITDs represent the same information. But for the full bank, the IPD value differs from the ITD value: Full band IPD is the constant phase difference between two channels 1 and 2, whereas full band ITD is the constant time difference between two channels.
In order to calculate the full band IPD on the basis of the subband IPD values, it might be possible to compute the average over all subband IPD values to obtain the full band IPD value, i.e. the IPD range value over the full frequency range of the audio channel signals. However, this estimation method may lead to a wrong estimation of a representative IPD range value, since the frequency subbands have differing perceptual importance.
For computation of an ICD range value a predetermined frequency range may be defined. For example, the predetermined frequency range may be the full frequency band of the plurality of audio channel signals. Alternatively, one or more predetermined frequency interval within the full frequency band of the plurality of audio channel signals may be chosen, which predetermined frequency intervals may be coherent or spaced apart. The predetermined frequency range may for example include the frequency band between 200 Hz and 600 Hz or alternatively between 300 Hz and 1.5 kHz.
In a third step 33 and a fourth step 34, parallel to the first and second steps 31 and 32, the energy E[b] of each portion of the predetermined frequency range, i.e. each frequency subband b or frequency bin b is calculated by
E[b]=(X1[k]2+X2[b]2),
or alternatively
E[b]=Σk=k
and subsequently normalized over the energy envelope group (EG) of the predetermined frequency range, for example the full band:
EG=Σb=M
wherein Mmin and Mmax are the index of the lowest and highest frequency subband or bin within the predetermined frequency range, respectively.
In step 35, for each of the plurality of ICD values, for example the values IPD[b], a weighted ICD value, for example a weighted IPD value IPDw[b], is calculated by multiplying each of the plurality of ICD values with a corresponding frequency-dependent weighting factor Ew[b]:
IPDw[b]=IPD[b]·Ew[b].
The frequency-dependent weighting factor may for example be an associated weighted energy value Ew[b] as computed by
Ew[b]=E[b]/EG.
It may be possible to smooth the weighting factors Ew[b] over consecutive frames, i.e. taking into account a fraction of the weighting factors Ew[b] of previous frames of the plurality of audio channel signals when calculating the current weighting factors Ew[b].
Finally, in a step 36, an ICD range value, for example a full band IPD value IPDF may be calculated for the predetermined frequency range by adding the plurality of weighted ICD values:
IPDF=Σb=M
Alternatively, the weighting factors Ew[b] may be derived from a masking curve for the energy distribution of the frequencies of the audio channel signals normalized over the predetermined frequency range. Such a masking curve may for example be computed as known from Bosi, M., Goldberg, R.: “Introduction to Digital Audio Coding and Standards”, Kluwer Academic Publishers, 2003. It is also possible to determine the frequency-dependent weighting factors on the basis of perceptual entropy values of the subbands b of the audio channel signals normalized over the predetermined frequency range. In that case, the normalized version of the masking curve or the perceptual entropy may be used as weighting function.
The method as shown in
cj[b]=Σk=k
wherein Xj[k] is the FFT coefficient of the channel j and Xref[k] is the FFT coefficient of a reference channel. The reference channel may be a select one of the plurality of channels j. Alternatively, the reference channel may be the spectrum of a mono downmix signal, which is the average over all channels j. In the former case, M−1 spatial cues are generated, whereas in the latter case, M spatial cues are generated, with M being the number of channels j. “*” denotes the complex conjugation, kb denotes the start bin of the subband b and kb+1 denotes the start bin of the neighbouring subband b+1. Hence, the frequency bins [k] of the FFT from kb to kb+1 represent the subband b.
Alternatively, the cross spectrum may be computed for each frequency bin k of the FFT. In this case, the subband b corresponds directly to one frequency bin [k].
The ICDs of channel j may be calculated per subband b based on the cross spectrum. For example, in case of the IPD such calculation may be conducted as
IPDj[b]=∠cj[b],
wherein the IPDj per subband b and channel j is the angle of the cross spectrum cj[b] of the respective subband b and channel j.
The energy Ej[b] per channel j of each portion of the predetermined frequency range, i.e. each frequency subband b or frequency bin b is calculated by
Ej[b]=2·Xj[b]·Xref[b]
or alternatively
E[b]=Σk=k
and subsequently normalized over the energy EGj of the predetermined frequency range, for example the full band:
EGj=Σb=M
wherein Mmin and Mmax are the index of the lowest and highest frequency subband or bin within the predetermined frequency range, respectively.
For each of the plurality of ICD values, for example the values IPDj[b], a weighted ICD value, for example a weighted IPD value IPDwj[b], is calculated by multiplying each of the plurality of ICD values with a corresponding frequency-dependent weighting factor Ewj[b]:
IPDwj[b]=IPDj[b]·Ewj[b].
The frequency-dependent weighting factor may for example be an associated weighted energy value Ewj[b] as computed by
Ewj[b]=Ej[b]/EGj.
It may be possible to smooth the weighting factors Ewj[b] over consecutive frames, i.e. taking into account a fraction of the weighting factors Ewj[b] of previous frames of the plurality of audio channel signals when calculating the current weighting factors Ewj[b].
Finally, an ICD range value, for example a full band IPD value IPDFj may be calculated for the predetermined frequency range by adding the plurality of weighted ICD values:
IPDFj=Σb=M
This application is a continuation of International Application No. PCT/EP2012/056342, filed on Apr. 5 2012, which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5835375 | Kitamura | Nov 1998 | A |
5974380 | Smyth et al. | Oct 1999 | A |
6005946 | Varga et al. | Dec 1999 | A |
6199039 | Chen et al. | Mar 2001 | B1 |
7006636 | Baumgarte et al. | Feb 2006 | B2 |
20050226426 | Oomen et al. | Oct 2005 | A1 |
20080002842 | Neusinger et al. | Jan 2008 | A1 |
20110013790 | Hilpert et al. | Jan 2011 | A1 |
20110046964 | Moon et al. | Feb 2011 | A1 |
Number | Date | Country |
---|---|---|
1647156 | Jul 2005 | CN |
101408615 | Apr 2009 | CN |
2011072729 | Jun 2011 | WO |
Entry |
---|
Foreign Communication From a Counterpart Application, Chinese Application No. 201280023292.X, Chinese Office Action dated Oct. 10, 2014, 3 pages. |
Foreign Communication From a Counterpart Application, Chinese Application No. 201280023292.X, Chinese Search Report dated Sep. 24, 2014, 2 pages. |
Foreign Communication From a Counterpart Application, PCT Application No. PCT/EP2012/056342, International Search Report dated Jan. 2, 2013, 4 pages. |
Foreign Communication From a Counterpart Application, PCT Application No. PCT/EP2012/056342, Written Opinion dated Jan. 2, 2013, 5 pages. |
“Series G: Transmission Systems and Media Digital Systems and Networks, Digital Terminal Equipments—Coding of Voice and Audio Signal, Wideband Embedded Extension for ITU-T G.711 Pulse Code Modulation,” ITU-T, Telecommunication Standardization Sector of ITU, G.711.1, Sep. 2012, 218 pages. |
“Series G: Transmission Systems and Media, Digital Systems and Networks, Digital Terminal Equipments—Coding of Voice and Audio Signals, 7 kHz Audio-Coding within 64 kbit/s,” ITU-T, Telecommunication Standardization Sector of ITU, G.722, Sep. 2012, 274 pages. |
Breebaart, J., et al., “Parametric Coding of Stereo Audio,” EURASIP Journal on Applied Signal Processing, Sep. 2005, 1305-1322. |
Faller, C., et al., “Efficient Representation of Spatial Audio Using Perceptual Parametrization,” Media Signal Processing Research, IEEE Workshop on Applications of Signal Processing to Audio and Acoustics, Oct. 21-24, 2001, pp. 199-202. |
Number | Date | Country | |
---|---|---|---|
20140164001 A1 | Jun 2014 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/EP2012/056342 | Apr 2012 | US |
Child | 14145432 | US |