The invention relates to a data structure for Higher Order Ambisonics audio data, which includes 2D and/or 3D spatial audio content data and which is also suited for HOA audio data having on order of greater than ‘3’.
3D Audio may be realised using a sound field description by a technique called Higher Order Ambisonics (HOA) as described below. Storing HOA data requires some conventions and stipulations how this data must be used by a special decoder to be able to create loudspeaker signals for replay at a given reproduction speaker setup. No existing storage format defines all of these stipulations for HOA. The B-Format (based on the extensible ‘Riff/wav’ structure) with its *.amb file format realisation as described as of 30 Mar. 2009 for example in Martin Leese, “File Format for B-Format”, http://www.ambisonia.com/Members/etienne/Members/mleese/file-format-for-b-format, is the most sophisticated format available today.
As of 16 Jul. 2010, an overview of existing file formats is disclosed on the Ambisonics Xchange Site: “Existing formats”, http://ambisonics.iem.at/xchange/format/existing-formats, and a proposal for an Ambisonics exchange format is also disclosed on that site: “A first proposal to specify, define and determine the parameters for an Ambisonics exchange format”, http://ambisonics.iem.at/xchange/format/afirst-proposal-for-the-format.
Regarding HOA signals, for 3D a collection of M=(N+1)2 ((2N+1) for 2D) different Audio objects from different sound sources, all at the same frequency, can be recorded (encoded) and reproduced as different sound objects provided they are spatially even distributed. This means that a 1st order Ambisonics signal can carry four 3D or three 2D Audio objects and these objects need to be separated uniformly around a sphere for 3D or around a circle in 2D. Spatial overlapping and more then M signals in the recording will result blur—only the loudest signals can be reproduced as coherent objects, the other diffuse signals will somehow degenerate the coherent signals depending on the overlap in space, frequency and loudness similarity.
Regarding the acoustic situation in a cinema, high spatial sound localisation accuracy is required for the frontal screen area in order to match the visual scene. Perception of the surrounding sound objects is less critical (reverb, sound objects with no connection to the visual scene). Here the density of speakers can be smaller compared to the frontal area.
The HOA order of the HOA data, relevant for frontal area, needs to be large to enable holophonic replay at choice. A typical order is N=10. This requires (N+1)2=121 HOA coefficients. In theory we could encode also M=121 audio objects, if this audio objects would be evenly spatially distributed. But in our scenario they are constricted to the frontal area (because only here we need such high orders). In fact we can only code about M=60 Audio objects without blur (the frontal area is at most half a sphere of directions, thus M/2).
Regarding the above-mentioned B-Format, it enables a description only up to an Ambisonics order of 3, and the file size is restricted to 4 GB. Other special information items are missing, like the wave type or the reference decoding radius which are vital for modern decoders. It is not possible to use different sample formats (word widths) and bandwidths for the different Ambisonics components (channels). There is also no standardisation for storing side information and metadata for Ambisonics.
In the known art, recording Ambisonics signals using a microphone array is restricted to orders of one. This might change in the future if experimental prototypes of HOA microphones will be developed. For the creation of 3D content a description of the ambience sound field could be recorded using a microphone array in first order Ambisonics, whereby the directional sources are captured using close-up mono microphones or highly directional microphones together with directional information (i.e. the position of the source). The directional signals can then be encoded into a HOA description, or this might be performed by a sophisticated decoder. Anyhow, a new Ambisonics file format needs to be able to store more than one sound field description at once, but it appears that no existing format can encapsulate more than one Ambisonics description.
A problem to be solved by the invention is to provide an Ambisonics file format that is capable of storing two or more sound field descriptions at once, wherein the Ambisonics order can be greater than 3. This problem is solved by the data structure disclosed in claim 1 and the method disclosed in claim 12.
For recreating realistic 3D Audio, next-generation Ambisonics decoders will require either a lot of conventions and stipulations together with stored data to be processed, or a single file format where all related parameters and data elements can be coherently stored.
The inventive file format for spatial sound content can store one or more HOA signals and/or directional mono signals together with directional information, wherein Ambisonics orders greater than 3 and files >4 GB are feasible. Furthermore, the inventive file format provides additional elements which existing formats do not offer:
This file format for 2D and 3D audio content covers the storage of both Higher Order Ambisonics descriptions (HOA) as well as single sources with fixed or time-varying positions, and contains all information enabling next-generation audio decoders to provide realistic 3D Audio.
Using appropriate settings, the inventive file format is also suited for streaming of audio content. Thus, content-dependent side info (header data) can be sent at time instances as selected by the creator of the file. The inventive file format serves also as scene description where tracks of an audio scene can start and end at any time.
In principle, the inventive data structure is suited for Higher Order Ambisonics HOA audio data, which data structure includes 2D and/or 3D spatial audio content data for one or more different HOA audio data stream descriptions, and which data structure is also suited for HOA audio data that have on order of greater than ‘3’, and which data structure in addition can include single audio signal source data and/or microphone array audio data from fixed or time-varying spatial positions.
In principle, the inventive method is suited for audio presentation, wherein an HOA audio data stream containing at least two different HOA audio data signals is received and at least a first one of them is used for presentation with a dense loudspeaker arrangement located at a distinct area of a presentation site, and at least a second and different one of them is used for presentation with a less dense loudspeaker arrangement surrounding said presentation site.
Advantageous additional embodiments of the invention are disclosed in the respective dependent claims.
Exemplary embodiments of the invention are described with reference to the accompanying drawings, which show in:
With the growing spread of 3D video, immersive audio technologies are becoming an interesting feature to differentiate. Higher Order Ambisonics (HOA) is one of these technologies which can provide a way to introduce 3D Audio in an incremental way into cinemas. Using HOA sound tracks and HOA decoders, a cinema can start with existing audio surround speaker setups and invest for more loudspeakers step-by-step, improving the immersive experience with each step.
a shows holophonic reproduction in cinema with dense loudspeaker arrangements 11 at the frontal region and coarser loudspeaker density 12 surrounding the listening or seating area 10, providing a way of accurate reproduction of sounds related to the visual action and of sufficient accuracy of reproduced ambient sounds.
b shows the perceived direction of arrival of reproduced frontal sound waves, wherein the direction of arrival of plane waves matches different screen positions, i.e. plane waves are suitable to reproduce depth.
c shows the perceived direction of arrival of reproduced spherical waves, which lead to better consistency of perceived sound direction and 3D visual action around the screen.
The need for two different HOA streams is caused in the fact that the main visual action in a cinema takes place in the frontal region of the listeners. Also, the perceptive precision of detecting the direction of a sound is higher for frontal sound sources than for surrounding sources. Therefore the precision of frontal spatial sound reproduction needs to be higher than the spatial precision for reproduced ambient sounds. Holophonic means for sound reproduction, a high number of loudspeakers, a dedicated decoder and related speaker drivers are required for the frontal screen region, while less costly technology is needed for ambient sound reproduction (lower density of speakers surrounding the listening area and less perfect decoding technology).
Due to content creation and sound reproduction technologies, it is advantageous to supply one HOA representation for the ambient sounds and one HOA representation for the foreground action sounds, cf.
A more sophisticated cinema equipped with full immersive reproduction means can use two decoders—one for decoding the ambient sounds and one specialised decoder for high-accuracy positioning of virtual sound sources for the foreground main action, as shown in the sophisticated decoding system in
A special HOA file contains at least two tracks which represent HOA sound fields for ambient sounds Anm(t) and for frontal sounds related to the visual main action Cnm(t). Optional streams for directional effects may be provided. Two corresponding decoder systems together with a panner provide signals for a dense frontal 3D holophonic loudspeaker system 21 and a less dense (i.e. coarse) 3D surround system 22. The HOA data signal of the Track 1 stream represents the ambience sounds and is converted in a HOA converter 231 for input to a Decoder1232 specialised for reproduction of ambience. For the Track 2 data stream, HOA signal data (frontal sounds related to visual scene) is converted in a HOA converter 241 for input to a distance corrected (Eq. (26)) filter 242 for best placement of spherical sound sources around the screen area with a dedicated Decoder2243. The directional data streams are directly panned to L speakers. The three speaker signals are PCM mixed for joint reproduction with the 3D speaker system.
It appears that there is no known file format dedicated to such scenario. Known 3D sound field recordings use either complete scene descriptions with related sound tracks, or a single sound field description when storing for later reproduction. Examples for the first kind are WFS (Wave Field Synthesis) formats and numerous container formats. The examples for the second kind are Ambisonics formats like the B or AMB formats, cf. the above-mentioned article “File Format for B-Format”. The latter restricts to Ambisonics orders of three, a fixed transmission format, a fixed decoder model and single sound fields.
The processing for generating HOA sound field descriptions is depicted in
In
Artistic sound field representations are usually created using multiple directional single source streams. As shown in
More complex wave field descriptions are generated by HOA mixing Ambisonics signals as depicted in
The process of content generation for 3D cinema is depicted in
Optionally, directional sounds (e.g. Track 3) can be multiplexed to the file. These sounds can be special effects sounds, dialogs or sportive information like a narrative speech for visually impaired.
The bottom part corresponds to
When using spherical Harmonic/Bessel descriptions, the solution of the acoustic wave equation is provided in Eq. (1), cf. M. A. Poletti, “Three-dimensional surround sound systems based on spherical harmonics”, Journal of Audio Engineering Society, 53(11), pp. 1004-1025, November 2005, and Earl G. Williams, “Fourier Acoustics”, Academic Press, 1999. The sound pressure is a function of spherical coordinates r,Θ,φ (see
The description is valid for audio sound sources outside the region of interest or validity (interior domain problem, as shown in
p(r,θ,φ,k)=Σn=0∞Σm=−nnAnm(k)jn(kr)Ynm(θ,φ) (1)
The Anm(k) are called Ambisonic Coefficients, jn(kr) is the spherical Bessel function of first kind, Ynm(θ,φ) are called Spherical Harmonics (SH), n is the Ambisonics order index, and m indicates the degree.
Due to the nature of the Bessel function which has significant values for small kr values only (small distances from origin or low frequencies), the series can be stopped at some order n and restricted to a value N with sufficient accuracy. When storing HOA data, usually the Ambisonics coefficients Anm,Bnm in or some derivates (details are described below) are stored up to that order N. N is called the Ambisonics order.
N is called the Ambisonics order, and the term ‘order’ is usually also used in combination with the n in Bessel jn(kr) and Hankel hn(kr) functions.
The solution of the wave equations for the exterior case, where the sources lie within a region of interest or validity as depicted in
p(r,θ,φ,k)=Σn=0∞Σm=−nnBnm(k)hn(1)(kr)Ynm(θ,φ) (2)
The Bnm(k) are again called Ambisonics coefficients and hn(1)(kr) denotes the spherical Hankel function of first kind and nth order. The formula assumes orthogonal-normalised SH.
Remark: Generally the spherical Hankel function of first kind hn(1) is used for describing outgoing waves (related to eikr) for or positive frequencies and the spherical Hankel function of second kind hn(2) is used for incoming waves (related to e−ikr), cf. the above-mentioned “Fourier Acoustics” book.
The spherical harmonics Ynm may be either complex or real valued. The general case for HOA uses real valued spherical harmonics. A unified description of Ambisonics using real and complex spherical harmonics may be reviewed in Mark Poletti, “Unified description of Ambisonics using real and complex spherical harmonics”, Proceedings of the Ambisonics Symposium 2009, Gras, Austria, June 2009.
There are different ways to normalise the spherical harmonics (which is independent from the spherical harmonics being real or complex), cf. the following web pages regarding (real) spherical harmonics, and normalisation schemes: http://www.ipgp.fr/˜wiecsor/SHTOOLS/www/conventions.html, http://en.citisendium.org/wiki/Spherical harmonics. The normalisation corresponds to the orthogonally relationship between Ynm and Yn′m′*
wherein S2 is the unit sphere and Kroneker delta δaa′ equals 1 for a=a′, 0 else.
Complex spherical harmonics are described by:
Y
n
m(Θ,φ)=smΘnm(θ)eimφ=smNn,mPn,|m|(cos(θ))eimφ (3)
wherein i=√{square root over (−1)} and
for an alternating sign for positive m like in the above-mentioned “Fourier Acoustics” book. (Remark: the sm is a term of convention and may be omitted for positive-only SH). Nn,m is a normalisation term which takes form for an orthogonal-normalised representation (! denotes factorial):
Below Table 1 shows some commonly used normalisation schemes for the complex valued spherical harmonics. Pn,|m|(x) are the associated Legendre functions, wherein it is followed the notation with |m| from the above article “Unified description of Ambisonics using real and complex spherical harmonics” which avoids the phase term (−1)m called the Condon-Shortley phase, and which sometimes is included within the representation of Pnm within other notations. The associated Legendre functions Pn,|m|:[−1,1]→,n≧|m|≧0 can be expressed using the Rodrigues formula as:
Numerically it is advantageous to derive Pn,|m|(x) in a progressive manner from a recurrence relationship, see William H. Press, Saul A. Teukolsky, William T. Vetterling, Brian P. Flannery, “Numerical Recipes in C”, Cambridge University Press, 1992. The associated Legendre functions up to n=4 are given in Table 2:
Real valued SH are derived by combining complex conjugate Ynm corresponding to opposite values of m (the term (−1)m in the definition (6) is introduced to obtain unsigned expressions for the real SH, which is the usual case in Ambisonics):
which can be rewritten as Eq. (7) for highlighting the connection to circular harmonics with φm(φ)=φn=|m|m(φ) just holding the azimuth term:
The total number of spherical components Snm for a given Ambisonics order N equals (N+1)2. Common normalisation schemes of the real valued spherical harmonics are given in Table 3.
For two-dimensional representations only a subset of harmonics is needed. The SH degree can only take values mε{−n,n}. The total number of components for a given N reduces to 2N+1 because components representing the inclination θ become obsolete and the spherical harmonics can be replaced by the circular harmonics given in Eq. (8).
There are different normalisation Nm schemes for circular harmonics, which need to be considered when converting 3D Ambisonics coefficients to 2D coefficients. The more general formula for circular harmonics becomes:
Some common normalisation factors for the circular harmonics are provided in Table 4, wherein the normalisation term is introduced by the factor before the horizontal term φm(φ):
Conversion between different normalisations is straightforward. In general, the normalisation has an effect on the notation describing the pressure (cf. Eqs. (1), (2)) and all derived considerations. The kind of normalisation also influences the Ambisonics coefficients. There are also weights that can be applied for scaling these coefficients, e.g. Furse-Malham (FuMa) weights applied to Ambisonics coefficients when storing a file using the AMB-format.
Regarding 2D-3D conversion, CH to SH conversion and vice versa can also be applied to Ambisonics coefficients, for example when decoding a 3D Ambisonics representation (recording) with a 2D decoder for a 2D loudspeaker setting. The relationship between, Snm and {hacek over (φ)}n=|m|m for 3D-2D conversion is depicted in the following scheme up to an Ambisonics order of 4:
The conversion factor 2D to 3D can be derived for the horizontal pane at
as follows:
Conversion from 3D to 2D uses
Details are presented in connection with Eqs. (28) (29) (30) below.
A conversion 2D normalised to orthogonal-normalised becomes:
The Ambisonics coefficients have the unit scale of the sound pressure:
The Ambisonics coefficients form the Ambisonics signal and in general are a function of discrete time. Table 5 shows the relationship between dimensional representation, Ambisonics order N and number of Ambisonics coefficients (channels):
When dealing with discrete time representations usually the Ambisonics coefficients are stored in an interleaved manner like PCM channel representations for multichannel recordings (channel=Ambisonics coefficient Anm of sample ν), the coefficient sequence being a matter of convention. An example for 3D, N=2 is:
A
0
0(ν)A1−1(ν)A10(ν)A11(ν)A2−2(ν)A2−1(ν)A20(ν)A21(ν)A22(ν)A00(ν+1) (12)
A
0
0(ν)A1−1(ν)A11(ν)A2−2(ν)A22(ν)A00(ν+1)A1−1(ν+1) (13)
The A00(n) signal can be regarded as a mono representation of the Ambisonics recording, having no directional information but being a representative for the general timbre impression of the recording.
The normalisation of the Ambisonics coefficients is generally performed according to the normalisation of the SH (as will become apparent below, see Eq. (15)), which must be taken into account when decoding an external recording (Anm are based on SH with normalisation factor Nn,m, {hacek over (A)}nm are based on SH with normalisation factor {hacek over (N)}n,m):
which becomes AN3D
The B-Format and the AMB format use additional weights (Gerson, Furse-Malham (FuMa), MaxN weights) which are applied to the coefficients. The reference normalisation then usually is SN3D, cf. Jérôme Daniel, “Représentation de champs acoustiques, application à la transmission et à la reproduction de scènes sonores complexes dans un contexte multimédia”, PhD thesis, Université Paris 6, 2001, and Dave Malham, “3-D acoustic space and its simulation using ambisonics”, http://www.dxarts.washington.edu/courses/567/current/malham 3d.pdf.
The following two specific realisations of the wave equations for ideal plane waves or spherical waves present more details about the Ambisonics coefficients:
Solving the wave equation for plane waves Anm becomes independent of k and rs; θs,φs describe the source angles, ‘*’ denotes conjugate complex:
A
n
m(θs,φs)=4πinPS
Here PS
are transmitted or stored. This assumption offers the possibility of superposition of different directional signals as well as a simple decoder design. This is also true for signals of a Soundfield™ microphone recorded in first-order B-format (N=1), which becomes obvious when comparing the phase progression of the equalising filters (for theoretical progression, see the above-mentioned article “Unified description of Ambisonics using real and complex spherical harmonics”, chapter 2.1, and for a patent-protected progression see U.S. Pat. No. 4,042,779. Eq. (1) becomes:
p(r,θ,φ,k)=Σn=0∞Σm=−nnjn(kr)Ynm(θ,φ)4πinPS
The coefficients dnm can either be derived by post-processed microphone array signals or can be created synthetically using a mono signal PS
d=ΨP
S
(18)
wherein d is an Ambisonics signal, holding dnm(θs,φs), (example for N=2: d(t)=[d00, d1−1, d10, d11, d2−2, d2−1, d20, d21, d22]′), size (d)=(N+1)2×1=O×1, PS
Ambisonics coefficients describing incoming spherical waves generated by point sources (near field sources) for r<rs are:
This equation is derived in connection with Eqs. (31) to (36) below. PS
which, having Eq. (11) in mind, can be found in M. A. Gerson, “General metatheory of auditory localisation”, 92th AES Convention, 1992, Preprint 3306, where Gerson describes the proximity effect for first-degree signals.
Synthetic creation of spherical Ambisonics signals is less common for higher Ambisonics orders N because the frequency responses of
are hard to numerically handle for low frequencies. These numeric problems can be overcome by considering a spherical model for decoding/reproduction as described below.
In general, Ambisonics assumes a reproduction of the sound field by L loudspeakers which are uniformly distributed on a circle or on a sphere. When assuming that the loudspeakers are placed far enough from the listener position, a plane-wave decoding model is valid at the centre (rs>λ). The sound pressure generated by L loudspeakers is described by:
p(r,θ,φ,k)=Σn=0∞Σm=−nnjn(kr)Ynm(θ,φ)4πinΣl=1LwlYnm(θl,φl)* (20)
with wl being the signal for loudspeaker/and having the unit scale of a sound pressure, 1 Pa. wl is often called driving function of loudspeaker l.
It is desirable that this Eq. (20) sound pressure is identical to the pressure described by Eq. (17). This leads to:
This can be rewritten in matrix form, known as ‘re-encoding formula’ (compare to Eq. (18)):
d=Ψy (22)
wherein d is an Ambisonics signal, holding dnm(θs,φs) or
(example for N=2: d(n)=[d00, d1−1, d10, d11, d2−2, d2−1, d20, d21, d22]′), size(d)=(N+1)2×1=O×1, Ψ is the (re-encoding) matrix, holding Ynm(θl,φl)*, sise(Ψ)=O×L, and y are the loudspeaker signals wl, sise(y(n), 1)=L.
y can then be derived using a couple of known methods, e.g. mode matching, or by methods which optimise for special speaker panning functions.
A more general decoding model again assumes equally distributed speakers around the origin with a distance rl radiating point like spherical waves. The Ambisonics coefficients Anm are given by the general description from Eq. (1) and the sound pressure generated by L loudspeakers is given according to Eq. (19):
A more sophisticated decoder can filter the Ambisonics coefficients Anm in order to retrieve
and thereafter apply Eq. (17) with d=[C00, C1−1, C11, C2−2, C2−1, C20, C21, C22, . . . ]′ for deriving the speaker weights. With this model the speaker signals wl are determined by the pressure in the origin. There is an alternative approach which uses the simple source approach first described in the above-mentioned article “Three-dimensional surround sound systems based on spherical harmonics”. The loudspeakers are assumed to be equally distributed on the sphere and to have secondary source characteristics. The solution is derived in Jens Ahrens, Sascha Spors, “Analytical driving functions for higher order ambisonics”, Proceedings of the ICASSP, pages 373-376, 2008, Eq. (13), which may be rewritten for truncation at Ambisonics order N and a loudspeaker gain gl as a generalisation:
Creating Cnm at the Ambisonics encoder using a reference speaker distance rl
Transmitted or stored are Cnm, the reference distance rl
by filtering before the Ambisonics decoding is required.
Other decoding models like Eq. (24) result in different formulations for distance coded Ambisonics:
Also the normalisation of the Spherical Harmonics can have an influence of the formulation of distance coded Ambisonics, i.e. Distance Coded Ambisonics coefficients need a defined context.
The details for the above-mentioned 2D-3D conversion are as follows:
The conversion factor
to convert a 2D circular component into a 3D spherical component by multiplication, can be derived as follows:
Using the common identity (cf. Wikipedia as of 12 Oct. 2010, “Associated Legendre polynomials”, http://en.wikipedia .org/w/index.php?title=Associated Legendre polynomials&oldid=363001511),
Pl,l(x)=(2l−1)!!(1−x2)l/2, where (2l−1)!!=Πi=1l(2i−1) is double factorial and P|m|,|m| can be expressed as:
Eq. (29) inserted into Eq. (28) leads to Eq. (10).
Conversion from 2D to ortho-3D is derived by
using relation
and substituting l=2m.
The details for the above-mentioned Spherical Wave expansion are as follows:
Solving Eq. (1) for spherical waves, which are generated by point sources for r<rs and incoming waves, is more complicated because point sources with vanishing infinitesimal size need to be described using a volume flow QS, wherein the radiated pressure for a field point at r and the source positioned at rs is given by (cf. the above-mentioned book “Fourier Acoustics”):
p(r|rs)=−iρ0ckQSG(r|rs) (31)
with ρ0 being the specific density and G(r|rs) being Green's function
G(r|rs) can also be expressed in spherical harmonics for r<rs
by G(r|rs)=ikΣn=0∞Σm=−nnjn(kr)hn(2)(krs)Ynm(θ,φ)Ynm(Θs,φs)* (33)
wherein hn(2) is the Hankel function of second kind. Note that the Green's function has a scale of unit meter−1 (1/m due to k). Eqs. (31), (33) can be compared to Eq. (1) for deriving the Ambisonics coefficients of spherical waves:
A
n
m(k,Θs,φs,rs)=ρ0ck2QShn(2))(krs)Ynm(Θs,φs)* (34)
where QS is the volume flow in unit m3s−1, and ρ0 is the specific density in kg m−3.
To be able to synthetically create Ambisonics signals and to relate to the above plane wave considerations, it is sensible to express Eq. (34) using the sound pressure generated at the origin of the coordinate system:
which leads to
The storage format according to the invention allows storing more than one HOA representation and additional directional streams together in one data container. It enables different formats of HOA descriptions which enable decoders to optimise reproduction, and it offers an efficient data storage for sizes >4 GB. Further advantages are:
A) By the storage of several HOA descriptions using different formats together with related storage format information an Ambisonics decoder is able to mix and decode both representations.
B) Information items required for next-generation HOA decoders are stored as format information:
Table 6 summarises the parameters required to be defined for a non-ambiguous exchange of HOA signal data. The definition of the spherical harmonics is fixed for the complex-valued and the real-valued cases, cf. Eqs. (3) (6).
In the following, the file format for storing audio scenes composed of Higher Order Ambisonics (HOA) or single sources with position information is described in detail. The audio scene can contain multiple HOA sequences which can use different normalisation schemes. Thus, a decoder can compute the corresponding loudspeaker signals for the desired loudspeaker setup as a superposition of all audio tracks from a current file. The file contains all data required for decoding the audio content. The file format according to the invention offers the feature of storing more than one HOA or single source signal in single file. The file format uses a composition of frames, each of which can contain several tracks, wherein the data of a track is stored in one or more packets called TrackPackets.
All integer types are stored in little-endian byte order so that the least significant byte comes first. The bit order is always most significant bit first. The notation for integer data types is ‘int’. A leading ‘u’ indicates unsigned integer. The resolution in bit is written at the end of the definition. For example, an unsigned 16 bit integer field is defined as ‘uint16’. PCM samples and HOA coefficients in integer format are represented as fix point numbers with the decimal point at the most significant bit.
All floating point data types conform to the IEEE specification IEEE-754, “Standard for binary floating-point arithmetic”, http://grouper.ieee.org/groups/754/. The notation for the floating point data type is ‘float’. The resolution in bit is written at the end of the definition. For example, a 32 bit floating point field is defined as ‘float32’. Constant identifiers ID, which identify the beginning of a frame, track or chunk, and strings are defined as data type byte. The byte order of byte arrays is most significant byte and bit first. Therefore the ID ‘TRCK’ is defined in a 32-bit byte field wherein the bytes are written in the physical order ‘T’, ‘R’, ‘C’ and ‘K’ (<0x54; 0x52; 0x42; 0x4b>). Hexadecimal values start with ‘0x’ (e.g. 0xAB64C5). Single bits are put into quotation marks (e.g. ‘1’), and multiple binary values start with ‘0b’ (e.g. 0b0011=0x3). Header field names always start with the header name followed by the field name, wherein the first letter of each word is capitalised (e.g. TrackHeaderSize). Abbreviations of fields or header names are created by using the capitalised letters only (e.g. TrackHeaderSize=THS).
The HOA File Format can include more than one Frame, Packet or Track. For the discrimination of multiple header fields a number can follow the field or header name. For example, the second TrackPacket of the third Track is named ‘Track3Packet2’.
The HOA file format can include complex-valued fields. These complex values are stored as real and imaginary part wherein the real part is written first. The complex number 1+i2 in ‘int8’ format would be stored as ‘0x01’ followed by ‘0x02’. Hence fields or coefficients in a complex-value format type require twice the storage size as compared to the corresponding real-value format type.
The Higher Order Ambisonics file format includes at least one FileHeader, one FrameHeader, one TrackHeader and one TrackPacket as depicted in
Therefore the basic structure of a HOA file is one FileHeader followed by a Frame that includes at least one Track. A Track consists always of a TrackHeader and one or more TrackPackets.
In contrast to the FileHeader, the HOA File can contain more than one Frame, wherein a Frame can contain more than one Track. A new FrameHeader is used if the maximal size of a Frame is exceeded or Tracks are added, or removed from one Frame to the other. The structure of a multiple Track and Frame HOA File is shown in
The structure of a multiple Track Frame starts with the FrameHeader followed by all TrackHeaders of the Frame. Consequently, the TrackPackets of each Track are sent successively to the FrameHeaders, wherein the TrackPackets are interleaved in the same order as the TrackHeaders.
In a multiple Track Frame the length of a Packet in samples is defined in the FrameHeader and is constant for all Tracks. Furthermore, the samples of each Track are synchronised, e.g. the samples of Track1Packet1 are synchronous to the samples of Track2Packet1. Specific TrackCodingTypes can cause a delay at decoder side, and such specific delay needs to be known at decoder side, or is to be included in the TrackCodingType dependent part of the TrackHeader, because the decoder synchronises all TrackPackets to the maximal delay of all Tracks of a Frame.
Meta data that refer to the complete HOA File can optionally be added after the FileHeader in MetaDataChunks. A MetaDataChunk starts with a specific General User ID (GUID) followed by the MetaDataChunkSize. The essence of the MetaDataChunk, e.g. the Meta Data information, is packed into an XML format or any user-defined format.
A Track of the HOA Format differentiates between a general HOATrack and a SingleSourceTrack. The HOATrack includes the complete sound field coded as HOACoefficients. Therefore, a scene description, e.g. the positions of the encoded sources, is not required for decoding the coefficients at decoder side. In other words, an audio scene is stored within the HOACoefficients.
Contrary to the HOATrack, the SingleSourceTrack includes only one source coded as PCM samples together with the position of the source within an audio scene. Over time, the position of the SingleSourceTrack can be fixed or variable. The source position is sent as TrackHOAEncodingVector or TrackPositionVector. The TrackHOAEncodingVector contains the HOA encoding values for obtaining the HOACoefficient for each sample. The TrackPositionVector contains the position of the source as angle and distance with respect to the centre listening position.
The FileHeader includes all constant information for the complete HOA File. The FileID is used for identifying the HOA File Format. The sample rate is constant for all Tracks even if it is sent in the FrameHeader. HOA Files that change their sample rate from one frame to another are invalid. The number of Frames is indicated in the FileHeader to indicate the Frame structure to the decoder.
The FrameHeader holds the constant information of all Tracks of a Frame and indicates changes within the HOA File. The FrameID and the FrameSize indicate the beginning of a Frame and the length of the Frame. These two fields allow an easy access of each frame and a crosscheck of the Frame structure. If the Frame length requires more than 32 bit, one Frame can be separated in several Frames. Each Frame has a unique FrameNumber. The FrameNumber should start with 0 and should be incremented by one for each new Frame.
The number of samples of the Frame is constant for all Tracks of a Frame. The number of Tracks within the Frame is constant for the Frame. A new Frame Header is sent for ending or starting Tracks at a desired sample position. The samples of each Track are stored in Packets. The size of these TrackPackets is indicated in samples and is constant for all Tracks. The number of Packets is equal to the integer number that is required for storing the number of samples of the Frame. Therefore the last Packet of a Track can contain fewer samples than the indicated Packet size.
The sample rate of a frame is equal to the FileSampleRate and is indicated in the FrameHeader to allow decoding of a Frame without knowledge of the FileHeader. This can be used when decoding from the middle of a multi frame file without knowledge of the FileHeader, e.g. for streaming applications.
The term ‘dyn’ refers to a dynamic field size due to conditional fields. The TrackHeader holds the constant information for the Packets of the specific Track. The TrackHeader is separated into a constant part and a variable part for two TrackSourceTypes. The TrackHeader starts with a constant TrackID for verification and identification of the beginning of the TrackHeader. A unique TrackNumber is assigned to each Track to indicate coherent Tracks over Frame borders. Thus, a track with the same TrackNumber can occur in the following frame. The TrackHeaderSize is provided for skipping to the next TrackHeader and it is indicated as an offset from the end of the TrackHeaderSize field. The TrackMetaDataOffset provides the number of samples to jump directly to the beginning of the TrackMetaData field, which can be used for skipping the variable length part of the TrackHeader. A TrackMetaDataOffset of zero indicates that the TrackMetaData field does not exist. Reliant on the TrackSourceType, the HOATrackHeader or the SingleSourceTrackHeader is provided. The HOATrackHeader provides the side information for standard HOA coefficients that describe the complete sound field. The SingleSourceTrackHeader holds information for the samples of a mono PCM track and the position of the source. For SingleSourceTracks the decoder has to include the Tracks into the scene.
At the end of the TrackHeader an optional TrackMetaData field is defined which uses the XML format for providing track dependent Metadata, e.g. additional information for A-format transmission (microphone-array signals).
The HOATrackHeader is a part of the TrackHeader that holds information for decoding a HOATrack. The TrackPackets of a HOATrack transfer HOA coefficients that code the entire sound field of a Track. Basically the HOATrackHeader holds all HOA parameters that are required at decoder side for decoding the HOA coefficients for the given speaker setup. The TrackComplexValueFlag and the TrackSampleFormat define the format type of the HOA coefficients of each TrackPacket. For encoded or compressed coefficients the TrackSampleFormat defines the format of the decoded or uncompressed coefficients. All format types can be real or complex numbers. More information on complex numbers is provided in the above section File Format Details.
All HOA dependent information is defined in the TrackHOAParams. The TrackHOAParams are re-used in other TrackSourceTypes. Therefore, the fields of the TrackHOAParams are defined and described in section TrackHOAParams.
The TrackCodingType field indicates the coding (compression) format of the HOA coefficients. The basic version of the HOA file format includes e.g. two CodingTypes.
One CodingType is the PCM coding type (TrackCodingType==‘0’), wherein the uncompressed real or complex coefficients are written into the packets in the selected TrackSampleFormat. The order and the normalisation of the HOA coefficients are defined in the TrackHOAParams fields.
A second CodingType allows a change of the sample format and to limit the bandwidth of the coefficients of each HOA order. A detailed description of that CodingType is provided in section TrackRegion Coding, a short explanation follows: The TrackBandwidthReductionType determines the type of processing that has been used to limit the bandwidth of each HOA order. If the bandwidth of all coefficients is unaltered, the bandwidth reduction can be switched off by setting the TrackBandwidthReductionType field to zero. Two other bandwidth reduction processing types are defined. The format includes a frequency domain MDCT processing and optionally a time domain filter processing. For more information on the MDCT processing see section Bandwidth reduction via MDCT. The HOA orders can be combined into regions of same sample format and bandwidth. The number of regions is indicated by the TrackNumberOfOrderRegions field. For each region the first and last order index, the sample format and the optional bandwidth reduction information has to be defined. A region will obtain at least one order. Orders that are not covered by any region are coded with full bandwidth using the standard format indicated in the TrackSampleFormat field. A special case is the use of no region (TrackNumberOfOrderRegions==0). This case can be used for deinterleaved HOA coefficients in PCM format, wherein the HOA components are not interleaved per sample. The HOA coefficients of the orders of a region are coded in the TrackRegionSampleFormat. The TrackRegionUseBandwidthReduction indicates the usage of the bandwidth reduction processing for the coefficients of the orders of the region. If the TrackRegionUseBandwidthReduction flag is set, the bandwidth reduction side information will follow. For the MDCT processing the window type and the first and last coded MDCT bin are defined. Hereby the first bin is equivalent to the lower cut-off frequency and the last bin defines the upper cut-off frequency. The MDCT bins are also coded in the TrackRegionSampleFormat, cf. section Bandwidth reduction via MDCT.
Single Sources are subdivided into fixed position and moving position sources. The source type is indicated in the TrackMovingSourceFlag. The difference between the moving and the fixed position source type is that the position of the fixed source is indicated only once in the TrackHeader and in each TrackPackage for moving sources. The position of a source can be indicated explicitly with the position vector in spherical coordinates or implicitly as HOA encoding vector. The source itself is a PCM mono track that has to be encoded to HOA coefficients at decoder side in case of using an Ambisonics decoder for playback.
The fixed position source type is defined by a TrackMovingSourceFlag of zero. The second field indicates the TrackPositionType that gives the coding of the source position as vector in spherical coordinates or as HOA encoding vector. The coding format of the mono PCM samples is indicated by the TrackSampleFormat field. If the source position is sent as TrackPositionVector, the spherical coordinates of the source position are defined in the fields TrackPositionTheta (inclination from s-axis to the x-, y-plane), TrackPositionPhi (azimuth counter clockwise starting at x-axis) and TrackPositionRadius.
If the source position is defined as an HOA encoding vector, the TrackHOAParams are defined first. These parameters are defined in section TrackHOAParams and indicate the used normalisations and definitions of the HOA encoding vector. The TrackEncodeVectorComplexFlag and the TrackEncodeVectorFormat field define the format type of the following TrackHOAEncoding vector. The TrackHOAEncodingVector consists of TrackHOAParamNumberOfCoeffs values that are either coded in the ‘float32’ or ‘float64’ format.
The moving position source type is defined by a TrackMovingSourceFlag of ‘1’. The header is identical to the fix source header except that the source position data fields TrackPositionTheta, TrackPositionPhi, TrackPositionRadius and TrackHOAEncodingVector are absent. For moving sources these are located in the TrackPackets to indicate the new (moving) source position in each Packet.
Several approaches for HOA encoding and decoding have been discussed in the past. However, without any conclusion or agreement for coding HOA coefficients. Advantageously, the format according to the invention allows storage of most known HOA representations. The TrackHOAParams are defined to clarify which kind of normalisation and order sequence of coefficients has been used at the encoder side. These definitions have to be taken into account at decoder side for the mixing of HOA tracks and for applying the decoder matrix.
HOA coefficients can be applied for the complete three-dimensional sound field or only for the two-dimensional x/y-plane. The dimension of the HOATrack is defined by the TrackHOAParamDimension field.
The TrackHOAParamRegionOfInterest reflects two sound pressure expansions in series whereby the sources reside inside or outside the region of interest, and the region of interest does not contain any sources. The computation of the sound pressure for the interior and exterior cases is defined in above equations (1) and (2), respectively, whereby the directional information of the HOA signal Anm(k) is determined by the conjugated complex spherical harmonic tion Ynm(θ,φ)*. This function is defined in a complex and the real number version. Encoder and decoder have to apply the spherical harmonic function of equivalent number type. Therefore the TrackHOAParamSphericalHarmonicType indicates which kind of spherical harmonic function has been applied at encoder side.
As mentioned above, basically the spherical harmonic function is defined by the associated Legendre functions and a complex or real trigonometric function. The associated Legendre functions are defined by Eq. (5). The complex-valued spherical harmonic representation is
where Nn,m is a scaling factor (cf. Eq. (3)). This complex-valued representation can be transformed into a real-valued representation using the following equation:
where the modified scaling factor for real-valued spherical harmonics is
For 2D representations the circular Harmonic function has to be used for encoding and decoding of the HOA coefficients. The complex-valued representation of the circular harmonic is defined by {hacek over (Y)}m(φ))={hacek over (N)}meimφ.
The real-valued representation of the circular harmonic is defined by
Several normalisation factors Nn,m, Ñn,m, {hacek over (N)}m and {hacek over (Ñ)}m are used for adapting the spherical or circular harmonic functions to the specific applications or requirements. To ensure correct decoding of the HOA coefficients the normalisation of the spherical harmonic function used at encoder side has to be known at decoder side. The following Table 7 defines the normalisations that can be selected with the TrackHOAParamSphericalHarmonicNorm field.
For future normalisations the dedicated value of the TrackHOAParamSphericalHarmonicNorm field is available. For a dedicated normalisation the scaling factor for each HOA coefficient is defined at the end of the TrackHOAParams. The dedicated scaling factors TrackScalingFactors can be transmitted as real or complex ‘float32’ or ‘float64’ values. The scaling factor format is defined in the TrackComplexValueScalingFlag and TrackScalingFormat fields in case of dedicated scaling.
The Furse-Malham normalisation can be applied additionally to the coded HOA coefficients for equalising the amplitudes of the coefficients of different HOA orders to absolute values of less than ‘one’ for a transmission in integer format types. The Furse-Malham normalisation was designed for the SN3D real valued spherical harmonic function up to order three coefficients. Therefore it is recommended to use the Furse-Malham normalisation only in combination with the SN3D real-valued spherical harmonic function. Besides, the TrackHOAParamFurseMalhamFlag is ignored for Tracks with an HOA order greater than three. The Furse-Malham normalisation has to be inverted at decoder side for decoding the HOA coefficients. Table 8 defines the Furse-Malham coefficients.
The TrackHOAParamDecoderType defines which kind of decoder is at encoder side assumed to be present at decoder side. The decoder type determines the loudspeaker model (spherical or plane wave) that is to be used at decoder side for rendering the sound field. Thereby the computational complexity of the decoder can be reduced by shifting parts of the decoder equation to the encoder equation. Additionally, numerical issues at encoder side can be reduced. Furthermore, the decoder can be reduced to an identical processing for all HOA coefficients because all inconsistencies at decoder side can be moved to the encoder. However, for spherical waves a constant distance of the loudspeakers from the listening position has to be assumed. Therefore the assumed decoder type is indicated in the TrackHeader, and the loudspeakers radius rls for the spherical wave decoder types is transmitted in the optional field TrackHOAParamReferenceRadius in millimetres. An additional filter at decoder side can equalise the differences between the assumed and the real loudspeakers radius.
The TrackHOAParamDecoderType normalisation of the HOA coefficients Cnm depends on the usage of the interior or exterior sound field expansion in series selected in TrackHOAParamRegionOfInterest. Remark: coefficients dnm in Eq. (18) and the following equations correspond to coefficients Cnm in the following. At encoder side the coefficients Cnm are determined from the coefficients Anm or Bnm as defined in Table 9, and are stored. The used normalisation is indicated in the TrackHOAParamDecoderType field of the TrackHOAParam header:
The HOA coefficients for one time sample comprise TrackHOAParamNumberOfCoeffs(0) number of coefficients Cnm. N depends on the dimension of the HOA coefficients. For 2D soundfields ‘O’ is equal to 2N+1 where N is equal to the TrackHOAParamHorizontalOrder field from the TrackHOAParam header. The 2D HOA Coefficients are defined as C|m|m=Cm with −N≦m≦N and can be represented as a subset of the 3D coefficients as shown in Table 10.
For 3D sound fields O is equal to (N+1)2 where N is equal to the TrackHOAParamVerticalOrder field from the TrackHOAParam header. The 3D HOA coefficients Cnm are defined for 0≦n≦N and −n≦m≦n. A common representation of the HOA coefficients is given in Table 10:
C
0
0
C
1
−1
C
1
1
C
2
−2
C
2
2
C
3
−3
C
3
3
C
4
−4
C
4
4
In case of 3D sound fields and TrackHOAParamHorizontalOrder greater than TrackHOAParamVerticalOrder, the mixed-order decoding will be performed. In mixed-order-signals some higher-order coefficients are transmitted only in 2D. The TrackHOAParamVerticalOrder field determines the vertical order where all coefficients are transmitted. From the vertical order to the TrackHOAParamHorizontalOrder only the 2D coefficients are used. Thus the TrackHOAParamHorizontalOrder is equal or greater than the TrackHOAParamVerticalOrder. An example for a mixed-order representation of a horizontal order of four and a vertical order of two is depicted in Table 11:
The HOA coefficients Cnm are stored in the Packets of a Track. The sequence of the coefficients, e.g. which coefficient comes first and which follow, has been defined differently in the past. Therefore, the field TrackHOAParamCoeffSequence indicates three types of coefficient sequences. The three sequences are derived from the HOA coefficient arrangement of Table 10.
The B-Format sequence uses a special wording for the HOA coefficients up to the order of three as shown in Table 12:
For the B-Format the HOA coefficients are transmitted from the lowest to the highest order, wherein the HOA coefficients of each order are transmitted in alphabetic order. For example, the coefficients of a 3D setup of the HOA order three are stored in the sequence W, X, Y, S, R, S, T, U, V, K, L, M, N, O, P and Q. The B-format is defined up to the third HOA order only. For the transmission of the horizontal (2D) coefficients the supplemental 3D coefficients are ignored, e.g. W, X, Y, U, V, P, Q.
The coefficients Cnm for 3D HOA are transmitted in TrackHOAParamCoeffSequence in a numerically upward or downward manner from the lowest to the highest HOA order (n=0 . . . N). The numerical upward sequence starts with m=−n and increases to m=n (C00, C1−1, C11, C2−2, C2−1, C20, C21, C22, . . . ), which is the ‘CG’ sequence defined in Chris Travis, “Four candidate component sequences”, http://ambisonics.googlegroups.com/web/Four+candidate+component+sequences+V09 pdf, 2008. The numerical downward sequence m runs the other way around from m=n to m=−n (C00, C11, C10, C1−1, C22, C21, C20, C2−1, C2−2, . . . ), which is the ‘QM’ sequence defined in that publication.
For 2D HOA coefficients the TrackHOAParamCoeffSequence numerical upward and downward sequences are like in the 3D case, but wherein the unused coefficients with |m|≠n (i.e. only the sectoral HOA coefficients C|m|m=Cm of Table 10) are omitted. Thus, the numerical upward sequence leads to (C00, C1−1, C11, C2−2, C22, . . . ) and the numerical downward sequence to (C00, C11, C1−1, C22, C2−2, . . . ).
This Packet contains the HOA coefficients Cnm in the order defined in the TrackHOAParamCoeffSequence, wherein all coefficients of one time sample are transmitted successively. This Packet is used for standard HOA Tracks with a TrackSourceType of zero and a TrackCodingType of zero.
The dynamic resolution package is used for a TrackSourceType of ‘zero’ and a TrackCodingType of ‘one’. The different resolutions of the TrackOrderRegions lead to different storage sizes for each TrackOrderRegion. Therefore, the HOA coefficients are stored in a de-interleaved manner, e.g. all coefficients of one HOA order are stored successively.
Single Source Track Packets
Single Source fixed Position Packet
The Single Source fixed Position Packet is used for a TrackSourceType of ‘one’ and a TrackMovingSourceFlag of ‘zero’. The Packet holds the PCM samples of a mono source.
The Single Source moving Position Packet is used for a TrackSourceType of ‘one’ and a TrackMovingSourceFlag of ‘one’. It holds the mono PCM samples and the position information for the sample of the TrackPacket.
The PacketDirectionFlag indicates if the direction of the Packet has been changed or the direction of the previous Packet should be used. To ensure decoding from the beginning of each Frame, the PacketDirectionFlag equals ‘one’ for the first moving source TrackPacket of a Frame.
For a PacketDirectionFlag of ‘one’ the direction information of the following PCM sample source is transmitted. Dependent on the TrackPositionType, the direction information is sent as TrackPositionVector in spherical coordinates or as TrackHOAEncodingVector with the defined TrackEncodingVectorFormat. The TrackEncodingVector generates HOA Coefficients that are conforming to the HOAParamHeader field definitions. Successively to the directional information the PCM mono Samples of the TrackPacket are transmitted.
HOA signals can be derived from Soundfield recordings with microphone arrays. For example, the Eigenmike disclosed in WO 03/061336 A1 can be used for obtaining HOA recordings of order three. However, the finite size of the microphone arrays leads to restrictions for the recorded HOA coefficients. In WO 03/061336 A1 and in the above-mentioned article “Three-dimensional surround sound systems based on spherical harmonics” issues caused by finite microphone arrays are discussed.
The distance of the microphone capsules results in an upper frequency boundary given by the spatial sampling theorem. Above this upper frequency the microphone array can not produce correct HOA coefficients. Furthermore the finite distance of the microphone from the HOA listening position requires an equalisation filter. These filters obtain high gains for low frequencies which even increase with each HOA order. In WO 03/061336 A1 a lower cut-off frequency for the higher order coefficients is introduced in order to handle the dynamic range of the equalisation filter. This shows that the bandwidth of HOA coefficients of different HOA orders can differ. Therefore the HOA file format offers the TrackRegionBandwidthReduction that enables the transmission of only the required frequency bandwidth for each HOA order. Due to the high dynamic range of the equalisation filter and due to the fact that the zero order coefficient is basically the sum of all microphone signals, the coefficients of different HOA orders can have different dynamical ranges. Therefore the HOA file format offers also the feature of adapting the format type to the dynamic range of each HOA order.
As shown in
The TrackRegion encoding path includes an optional bandwidth reduction step or stage 1221 and a format conversion step or stage 1231 and performs a parallel processing for each HOA coefficient buffer. The bandwidth reduction is performed if the TrackRegionUseBandwidthReduction field is set to ‘one’. Depending on the selected TrackBandwidthReductionType a processing is selected for limiting the frequency range of the HOA coefficients and for critically downsampling them. This is performed in order to reduce the number of HOA coefficients to the minimum required number of samples. The format conversion converts the current HOA coefficient format to the TrackRegionSampleFormat defined in the HOATrack header. This is the only step/stage in the standard processing path that converts the HOA coefficients to the indicated TrackSampleFormat of the HOA Track Header.
The multiplexer TrackPacket step or stage 124 multiplexes the HOA coefficient buffers into the TrackPacket data file stream as defined in the selected TrackHOAParamCoeffSequence field, wherein the coefficients Cnm for one combination of n and m indices stay de-interleaved (within one buffer).
As shown in
Step/stage 134 initialises TrackNumberOfOrderRegion plus ‘one’ processing paths and passes the content of the deinterleaved HOA coefficient buffers to the appropriate processing path. The coefficients of each TrackRegion are defined by the TrackRegionLastOrder and TrackRegionFirstOrder fields of the HOA Track Header. HOA orders that are not covered by the selected TrackRegions are processed in the standard processing path including a format conversion step or stage 136 and a remaining coefficients interleaving step or stage 135. The standard processing path corresponds to a TrackProcessing path without a bandwidth reduction step or stage.
In the TrackProcessing paths, a format conversion step/stage 1331 to 133N converts the HOA coefficients that are encoded in the TrackRegionSampleFormat into the data format that is used for the processing of the decoder. Depending on the TrackRegionUseBandwidthReduction data field, an optional bandwidth reconstruction step or stage 1321 to 132N follows in which the band limited and critically sampled HOA coefficients are reconstructed to the full bandwidth of the Track. The kind of reconstruction processing is defined in the TrackBandwidthReductionType field of the HOA Track Header. In the following interleaving step or stage 1311 to 131N the content of the de-interleaved buffers of HOA coefficients are interleaved by grouping HOA coefficients of one time sample, and the HOA coefficients of the current TrackRegion are combined with the HOA coefficients of the previous TrackRegions. The resulting sequence of the HOA coefficients can be adapted to the processing of the Track. Furthermore, the interleaving steps/stages deal with the delays between the TrackRegions using bandwidth reduction and TrackRegions not using bandwidth reduction, which delay depends on the selected TrackBandwidthReductionType processing. For example, the MDCT processing adds a delay of FramePacketSize samples and therefore the interleaving steps/stages of processing paths without bandwidth reduction will delay their output by one packet.
(buffer)
C
n
m
=[C
n
m(0), Cnm(1), . . . , Cnm(FramePacketSize−1)].
The number M of buffers is the same as the number of Ambisonics components ((N+1)2 for a full 3D sound field of order N). The buffer handling performs a 50% overlap for the following MDCT processing by combining the previous buffer content with the current buffer content into a new content for the MDCT processing in corresponding steps or stages 1431 to 143M, and it stores the current buffer content for the processing of the following buffer content. The MDCT processing re-starts at the beginning of each Frame, which means that all coefficients of a Track of the current Frame can be decoded without knowledge of the previous Frame, and following the last buffer content of the current Frame an additional buffer content of zeros is processed. Therefore the MDCT processed TrackRegions produce one extra TrackPacket. In the window adding steps/stages the corresponding buffer content is multiplied with the selected window function w(t), which is defined in the HOATrack header field TrackRegionWindowType for each TrackRegion.
The Modified Discrete Cosine Transform is first mentioned in J. P. Princen, A. B. Bradley, “Analysis/Synthesis Filter Bank Design Based on Time Domain Aliasing Cancellation”, IEEE Transactions on Acoustics, Speech and Signal Processing, vol.ASSP-34, no. 5, pages 1153-1161, October 1986. The MDCT can be considered as representing a critically sampled filter bank of FramePacketSize subbands, and it requires a 50% input buffer overlap. The input buffer has a length of twice the subband size. The MDCT is defined by the following equation with T equal to FramePacketSize:
The coefficients C′nm(k) are called MDCT bins. The MDCT computation can be implemented using the Fast Fourier Transform. In the following frequency region cut-out step or stages 1441 to 144M the bandwidth reduction is performed by removing all MDCT bins C′nm(k) with k<TrackRegionFirstBin and k>TrackRegionLastBin, for the reduction of the buffer length to TrackRegionLastBin−TrackRegionFirstBin+1, wherein TrackRegionFirstBin is the lower cut-off frequency for the TrackRegion and TrackRegionLastBin is the upper cut-off frequency. The neglecting of MDCT bins can be regarded as representing a bandpass filter with cut-off frequencies corresponding to the TrackRegionLastBin and TrackRegionFirstBin frequencies. Therefore only the MDCT bins required are transmitted.
Like the MDCT, the inverse MDCT can be implemented using the inverse Fast Fourier Transform.
The MDCT window adding steps or stages 1521 to 152M multiply the reconstructed time domain coefficients with the window function defined by the TrackRegionWindowType. The following buffers 1511 to 151M add the first half of the current TrackPacket buffer content to the second half of the last
TrackPacket buffer content in order to reconstruct FramePacketSize time domain coefficients. The second half of the current TrackPacket buffer content is stored for the processing of the following TrackPacket, which overlap-add processing removes the contrary aliasing components of both buffer contents.
For multi-Frame HOA files the encoder is prohibited to use the last buffer content of the previous frame for the overlap-add procedure at the beginning of a new Frame. Therefore at Frame borders or at the beginning of a new Frame the overlap-add buffer content is missing, and the reconstruction of the first TrackPacket of a Frame can be performed at the second TrackPacket, whereby a delay of one FramePacket and decoding of one extra TrackPacket is introduced as compared to the processing paths without bandwidth reduction. This delay is handled by the interleaving steps/stages described in connection with
Number | Date | Country | Kind |
---|---|---|---|
10306211.3 | Nov 2010 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2011/068782 | 10/26/2011 | WO | 00 | 5/2/2013 |