METHOD AND DEVICE FOR DECODING A HIGHER-ORDER AMBISONICS (HOA) REPRESENTATION OF AN AUDIO SOUNDFIELD
20230080860 · 2023-03-16
Assignee
Inventors
Cpc classification
H04S7/30
ELECTRICITY
H04S2420/11
ELECTRICITY
International classification
Abstract
The invention discloses rendering sound field signals, such as Higher-Order Ambisonics (HOA), for arbitrary loudspeaker setups, where the rendering results in highly improved localization properties and is energy preserving. This is obtained by rendering an audio sound field representation for arbitrary spatial loudspeaker setups and/or by a decoder that decodes based on a decode matrix (D). The decode matrix (D) is based on smoothing and scaling of a first decode matrix {circumflex over (D)} with smoothing coefficients. The first decode matrix {circumflex over (D)} is based on a mix matrix G and a mode matrix {tilde over (Ψ)}, where the mix matrix G was determined based on L speakers and positions of a spherical modelling grid related to a HOA order N, and the mode matrix {tilde over (Ψ)} was determined based on the spherical modelling grid and the HOA order N.
Claims
1. A method for decoding a Higher-Order Ambisonics (HOA) representation of a sound or sound field, the method comprising: receiving a smoothed decode matrix {circumflex over (D)} that is based on a mix matrix G and a mode matrix {tilde over (Ψ)}, wherein the mix matrix G was determined based on L speakers and positions of a spherical modelling grid wherein the mode matrix {tilde over (Ψ)} was determined based on the spherical modelling grid and a HOA order N, wherein the smoothed decode matrix {tilde over (D)} was determined based on smoothing of a first decode matrix {circumflex over (D)} with smoothing coefficients, wherein the first decode matrix {circumflex over (D)} was determined based on {circumflex over (D)}=V Ŝ U.sup.H, wherein U,V are based on Unitary matrices, wherein a compact singular value decomposition of a product of the mode matrix {tilde over (Ψ)} with a transposed mix matrix is determined based on U S V.sup.H={tilde over (Ψ)}G.sup.T wherein S is based on a diagonal matrix with singular value elements, and wherein Ŝ is a truncated compact singular value decomposition matrix that is either an identity matrix or a modified diagonal matrix, the modified diagonal matrix being determined based on the diagonal matrix with singular value elements by replacing a singular value element that is larger or equal than a threshold by ones, and replacing a singular value element that is smaller than the threshold by zeros; and rendering coefficients of the HOA representation from a time domain to a spatial domain based on the smoothed decode matrix {circumflex over (D)}.
2. The method of claim 1, further comprising buffering and serializing a spatial signal W, wherein time samples w(t) for a plurality of channels are obtained; and delaying time samples w(t) individually for each of the channels in delay lines, wherein corresponding digital signals are obtained, wherein the delay lines compensate different loudspeaker distances.
3. A non-transitory computer readable medium having stored thereon executable instructions to cause a computer to perform the method of claim 1.
4. An apparatus for decoding a Higher-Order Ambisonics (HOA) representation of a sound or sound field for audio playback, comprising: a decoder configured to decode coefficients of the HOA sound field representation, the decoder including: a receiver configured to receive a smoothed decode matrix {tilde over (D)} that is based on a mix matrix G and a mode matrix {tilde over (Ψ)}, wherein the mix matrix G was determined based on L speakers and positions of a spherical modelling grid, wherein the mode matrix {tilde over (Ψ)} was determined based on the spherical modelling grid and a HOA order N, and wherein the smoothed decode matrix {tilde over (D)} is determined based on smoothing a first decode matrix {circumflex over (D)} with smoothing coefficients, wherein the first decode matrix {circumflex over (D)} is determined based on {circumflex over (D)}=V Ŝ U.sup.H, wherein U,V are based on Unitary matrices, wherein a compact singular value decomposition of a product of the mode matrix {tilde over (Ψ)} with a transposed mix matrix is determined based on U S V.sup.B={tilde over (Ψ)}G.sup.T, wherein S was determined based on a diagonal matrix with singular value elements, wherein Ŝ is a truncated compact singular value decomposition matrix that is either an identity matrix or a modified diagonal matrix, the modified diagonal matrix being determined based on the diagonal matrix with singular value elements by replacing a singular value element that is larger or equal than a threshold by ones, and replacing a singular value element that is smaller than the threshold by zeros; and a renderer configured for rendering coefficients of the HOA representation from a time domain to a spatial domain based on the smoothed decode matrix {tilde over (D)}.
Description
BRIEF DESCRIPTION OF THE DRAWINGS
[0021] Exemplary embodiments of the invention are described with reference to the accompanying drawings, which show in
[0022]
[0023]
[0024]
[0025]
[0026]
[0027]
[0028]
[0029]
[0030]
[0031]
[0032]
[0033]
[0034]
[0035]
DETAILED DESCRIPTION OF THE INVENTION
[0036] In general, the invention relates to rendering (i.e. decoding) sound field formatted audio signals such as Higher Order Ambisonics (HOA) audio signals to loudspeakers, where the loudspeakers are at symmetric or asymmetric, regular or non-regular positions. The audio signals may be suitable for feeding more loudspeakers than available, e.g. the number of HOA coefficients may be larger than the number of loudspeakers. The invention provides energy preserving decode matrices for decoders with very good directional properties, i.e. speaker directivity lobes generally comprise a stronger directive main lobe and smaller side lobes than speaker directivity lobes obtained with conventional decode matrices. Energy preserving means that the energy within the HOA directive signal is preserved after decoding, so that e.g. a constant amplitude directional spatial sweep will be perceived with constant loudness.
[0037] .sub.L of the loudspeakers, a spherical modeling grid
.sub.s and an order N (e.g. HOA order) are determined 11. From the positions
.sub.L of the speakers and the spherical modeling grid
.sub.s, a mix matrix G is generated 12, and from the spherical modeling grid
.sub.s and the HOA order N, a mode matrix {tilde over (Ψ)} is generated 13. A first decode matrix {circumflex over (D)} is calculated 14 from the mix matrix G and the mode matrix {tilde over (Ψ)}. The first decode matrix {circumflex over (D)} is smoothed 15 with smoothing coefficients, wherein a smoothed decode matrix {circumflex over (D)} is obtained, and the smoothed decode matrix {circumflex over (D)} is scaled 16 with a scaling factor obtained from the smoothed decode matrix {circumflex over (D)}, wherein the decode matrix {circumflex over (D)} is obtained. In one embodiment, the smoothing 15 and scaling 16 is performed in a single step.
[0038] In one embodiment, the smoothing coefficients are obtained by one of two different methods, depending on the number of loudspeakers L and the number of HOA coefficient channels O.sub.3D=(N+1).sup.2. If the number of loudspeakers L is below the number of HOA coefficient channels O.sub.3D, a new method for obtaining the smoothing coefficients is used.
[0039] In one embodiment, a plurality of decode matrices corresponding to a plurality of different loudspeaker arrangements are generated and stored for later usage. The different loudspeaker arrangements can differ by at least one of the number of loudspeakers, a position of one or more loudspeakers and an order N of an input audio signal. Then, upon initializing the rendering system, a matching decode matrix is determined, retrieved from the storage according to current needs, and used for decoding.
[0040] In one embodiment, the decode matrix {circumflex over (D)} is obtained by performing a compact singular value decomposition of the product of the mode matrix {tilde over (Ψ)} with the Hermitian transposed mix matrix G.sup.H according to U S V.sup.H={tilde over (Ψ)}G.sup.H, and calculating a first decode matrix b from the matrices U,V according to {circumflex over (D)}=V U.sup.H. The U,V are derived from Unitary matrices, and S is a diagonal matrix with singular value elements of said compact singular value decomposition of the product of the mode matrix {tilde over (Ψ)} with the Hermitian transposed mix matrix G.sup.H. Decode matrices obtained according to this embodiment are often numerically more stable than decode matrices obtained with an alternative embodiment described below. The Hermitian transposed of a matrix is the conjugate complex transposed of the matrix.
[0041] In the alternative embodiment, the decode matrix {circumflex over (D)} is obtained by performing a compact singular value decomposition of the product of the Hermitian transposed mode matrix {tilde over (Ψ)} with the mix matrix G according to U S V.sup.H=G{tilde over (Ψ)}.sup.H, wherein a first decode matrix is derived by {circumflex over (D)}=U V.sup.H.
[0042] In one embodiment, a compact singular value decomposition is performed on the mode matrix {tilde over (Ψ)} and mix matrix G according to U S V.sup.H=G{tilde over (Ψ)}.sup.H, where a first decode matrix is derived by {circumflex over (D)}=U S V.sup.H, where N is a truncated compact singular value decomposition matrix that is derived from the singular value decomposition matrix S by replacing all singular values larger or equal than a threshold thr by ones, and replacing elements that are smaller than the threshold thr by zeros. The threshold thr depends on the actual values of the singular value decomposition matrix and may be, exemplarily, in the order of 0,06*S.sub.1 (the maximum element of S).
[0043] In one embodiment, a compact singular value decomposition is performed on the mode matrix {tilde over (Ψ)} and mix matrix G according to S U.sup.H=G{tilde over (Ψ)}.sup.H, where a first decode matrix is derived by {circumflex over (D)}=VŜU.sup.H. The 3 and threshold thr are as described above for the previous embodiment. The threshold thr is usually derived from the largest singular value.
[0044] In one embodiment, two different methods for calculating the smoothing coefficients are used, depending on the HOA order N and the number of target speakers L: if there are less target speakers than HOA channels, i.e. if O.sub.3D=(N.sup.2+1)>L, the smoothing and scaling coefficients corresponds to a conventional set of max r.sub.E coefficients that are derived from the zeros of the Legendre polynomials of order N+1; otherwise, if there are enough target speakers, i.e. if O.sub.3D=(N.sup.2+1)≤L, the coefficients of
are constructed from the elements
of a Kaiser window with len=(2N+1) and width=2N according to
=c.sub.f[
.sub.N+1,
.sub.N+2,
.sub.N+2,
.sub.N+2,
.sub.N+3,
.sub.N+3, . . . ,
.sub.2N].sup.T with a scaling factor Cf. The used elements of the Kaiser window begin with the (N+1)′ element, which is used only once, and continue with subsequent elements which are used repeatedly: the (N+2).sup.nd element is used three times, etc.
[0045] In one embodiment, the scaling factor is obtained from the smoothed decoding matrix. In particular, in one embodiment it is obtained according to
[0046] In the following, a full rendering system is described. A major focus of the invention is the initialization phase of the renderer, where a decode matrix {circumflex over (D)} is generated as described above. Here, the main focus is a technology to derive the one or more decoding matrices, e.g. for a code book. For generating a decode matrix, it is known how many target loudspeakers are available, and where they are located (i.e. their positions).
[0047]
[0048] The following section gives a brief introduction to Higher Order Ambisonics (HOA) and defines the signals to be processed, i.e. rendered for loudspeakers. Higher Order Ambisonics (HOA) is based on the description of a sound field within a compact area of interest, which is assumed to be free of sound sources. In that case the spatiotemporal behavior of the sound pressure p(t, x) at time t and position x=[r, θ, ϕ].sup.T within the area of interest (in spherical coordinates: radius r, inclination θ, azimuth ϕ) is physically fully determined by the homogeneous wave equation. It can be shown that the Fourier transform of the sound pressure with respect to time, i.e.,
P(ω,x)=.sub.t{p(t,x)} (1)
where ω denotes the angular frequency (and .sub.t { } corresponds to∫.sub.−∞.sup.∞p(t, x) e.sup.−ωtdt), may be expanded into the series of Spherical Harmonics (SHs) according to [13]:
[0049] In eq. (2), c.sub.s denotes the speed of sound and
the angular wave number. Further, j.sub.n(.Math.) indicate the spherical Bessel functions of the first kind and order n and Y.sub.n.sup.m(.Math.) denote the Spherical Harmonics (SH) of order n and degree m. The complete information about the sound field is actually contained within the sound field coefficients A.sub.n.sup.m (k).
[0050] It should be noted that the SHs are complex valued functions in general. However, by an appropriate linear combination of them, it is possible to obtain real valued functions and perform the expansion with respect to these functions.
[0051] Related to the pressure sound field description in eq. (2) a source field can be defined as:
with the source field or amplitude density [12] D(k c.sub.s, Ω) depending on angular wave number and angular direction Ω=[θ,ϕ].sup.T. A source field can consist of far-field/nearfield, discrete/continuous sources [1]. The source field coefficients B.sub.n.sup.m are related to the sound field coefficients A.sub.n.sup.m by, [1]:
where it h.sub.n.sup.(2) is the spherical Hankel function of the second kind and r.sub.s is the source distance from the origin.
[0052] Signals in the HOA domain can be represented in frequency domain or in time domain as the inverse Fourier transform of the source field or sound field coefficients. The following description will assume the use of a time domain representation of source field coefficients:
b.sub.n.sup.m=i.sub.t{B.sub.n.sup.m} (5)
of a finite number: The infinite series in eq. (3) is truncated at n=N. Truncation corresponds to a spatial bandwidth limitation. The number of coefficients (or HOA channels) is given by:
O.sub.3D=(N+1).sup.2 for 3D (6)
or by O.sub.2D=2N+1 for 2D only descriptions. The coefficients b.sub.n.sup.m comprise the Audio information of one time sample t for later reproduction by loudspeakers. They can be stored or transmitted and are thus subject of data rate compression. A single time sample t of coefficients can be represented by vector b(t) with O.sub.3D elements:
b(t):=[b.sub.0.sup.0(t),b.sub.1.sup.−1(t),b.sub.1.sup.0(t),b.sub.1.sup.1(t),b.sub.2.sup.−2(t), . . . ,b.sub.N.sup.N(t)].sup.T (7)
and a block of M time samples by matrix B ∈ .sup.O3D×M
B:=[b(t.sub.START+1),b(t.sub.START+2), . . . ,b(t.sub.START+M)] (8)
[0053] Two dimensional representations of sound fields can be derived by an expansion with circular harmonics. This is a special case of the general description presented above using a fixed inclination of
different weighing of coefficients and a reduced set to O.sub.2D coefficients (m=±n). Thus, all of the following considerations also apply to 2D representations; the term “sphere” then needs to be substituted by the term “circle”.
[0054] In one embodiment, metadata is sent along the coefficient data, allowing an unambiguous identification of the coefficient data. All necessary information for deriving the time sample coefficient vector b(t) is given, either through transmitted metadata or because of a given context. Furthermore, it is noted that at least one of the HOA order N or O.sub.3D, and in one embodiment additionally a special flag together with r.sub.s to indicate a nearfield recording are known at the decoder.
[0055] Next, rendering a HOA signal to loudspeakers is described. This section shows the basic principle of decoding and some mathematical properties.
[0056] Basic decoding assumes, first, plane wave loudspeaker signals and, second, that the distance from speakers to origin can be neglected. A time sample of HOA coefficients b rendered to L loudspeakers that are located at spherical directions {circumflex over (Ω)}.sub.l=[θ.sub.l, .sub.l].sup.T with 1=1, . . . , L can be described by [10]:
w=Db (9)
where w ∈.sup.L×1 represents a time sample of L speaker signals and decode matrix D ∈
.sup.L×O3D A decode matrix can be derived by
D=Ψ.sup.+ (10)
where Ψ.sup.+ is the pseudo inverse of the mode matrix Ψ. The mode-matrix Ψ is defined as
Ψ=[y.sub.1, . . . ,y.sub.L] (11)
with Ψ∈ .sup.O3D×L and y.sub.l=[Y.sub.0.sup.0({circumflex over (Ω)}.sub.l), Y.sub.1.sup.−1({circumflex over (Ω)}.sub.1), . . . , Y.sub.N.sup.N({circumflex over (Ω)}.sub.l)].sup.H consisting of the Spherical Harmonics of the speaker directions {circumflex over (Ω)}.sub.l=[{circumflex over (θ)}.sub.l,
].sup.T where .sup.H denotes conjugate complex transposed (also known as Hermitian).
[0057] Next, a pseudo inverse of a matrix by Singular Value Decomposition (SVD) is described. One universal way to derive a pseudo inverse is to first calculate the compact SVD:
Ψ=U S V.sup.H (12)
where U ∈ .sup.O3D×K, V ∈
.sup.L×K are derived from rotation matrices and S=diag(S.sub.1, . . . , S.sub.K) ∈
.sup.K×K is a diagonal matrix of the singular values in descending order S.sub.1≥S.sub.2≥ . . . ≥S.sub.K with K>0 and K≤min(O.sub.3D, L). The pseudo inverse is determined by
Ψ.sup.+=V ŜU.sup.H (13)
where Ŝ=diag(, S.sub.1.sup.−1, . . . , S.sub.K.sup.−1). For bad conditioned matrices with very small values of S.sub.K, the corresponding inverse values S.sub.k.sup.−1 are replaced by zero. This is called Truncated Singular Value Decomposition. Usually a detection threshold with respect to the largest singular value S.sub.1 is selected to identify the corresponding inverse values to be replaced by zero.
[0058] In the following, the energy preservation property is described. The signal energy in HOA domain is given by
E=b.sup.Hb (14)
[0059] and the corresponding energy in the spatial domain by
Ê=w.sup.Hw=b.sup.Hd.sup.HDb (15)
[0060] The ratio Ê/E for an energy preserving decoder matrix is (substantially) constant. This can only be achieved if D.sup.HD=cI, with identity matrix I and constant c∈. This requires D to have a norm-2 condition number cond(D)=1. This again requires that the SVD (Singular Value Decomposition) of D produces identical singular values: D=U S V.sup.H with
S=diag(S.sub.K, . . . ,S.sub.K).
[0061] Generally, energy preserving renderer design is known in the art. An energy preserving decoder matrix design for L≥O.sub.3D is proposed in [14] by
D=V U.sup.H (16)
where Ŝ from eq. (13) is forced to be Ŝ=I and thus can be dropped in eq. (16). The product D.sup.HD=U V.sup.HV U.sup.H=I and the ratio Ê/E becomes one. A benefit of this design method is the energy preservation which guarantees a homogenous spatial sound impression where spatial pans have no fluctuations in perceived loudness. A drawback of this design is a loss in directivity precision and strong loudspeaker beam side lobes for asymmetric, non-regular speaker positions (see
[0062] Also, a renderer design for non-regular positioned speakers is known in the art: In [2], a decoder design method for L≥O.sub.3D and L<O.sub.3D is described which allows rendering with high precision in reproduced directivity. A drawback of this design method is that the derived renderers are not energy preserving (see
[0063] Spherical convolution can be used for spatial smoothing. This is a spatial filtering process, or a windowing in the coefficient domain (convolution). Its purpose is to minimize the side lobes, so-called panning lobes. A new coefficient {tilde over (b)}.sub.n.sup.m is given by the weighted product of the original HOA coefficient {tilde over (b)}.sub.n.sup.m and a zonal coefficient h.sub.n.sup.0[5]:
[0064] This is equivalent to a left convolution on S.sup.2 in the spatial domain [5]. Conveniently this is used in [5] to smooth the directive properties of loudspeaker signals prior to rendering/decoding by weighting the HOA coefficients B by:
B=diag()B, (18)
with vector
containing usually real valued weighting coefficients and a constant factor d.sub.f. The idea of smoothing is to attenuate HOA coefficients with increasing order index n. A well-known example of smoothing weighting coefficients are so called max r.sub.v, max r.sub.E and inphase coefficients [4]. The first offers the default amplitude beam (trivial,
=(1, 1, . . . , 1).sup.T, a vector of length O.sub.3D with only ones), the second provides evenly distributed angular power and inphase features full side lobe suppression.
[0065] In the following, further details and embodiments of the disclosed solution are described.
[0066] First, a renderer architecture is described in terms of its initialization, start-up behavior and processing.
[0067] Every time the loudspeaker setup, i.e. the number of loudspeakers or position of any loudspeaker relative to the listening position changes, the renderer needs to perform an initialization process to determine a set of decoding matrices for any HOA-order N that supported HOA input signals have. Also, the individual speaker delays d.sub.l for the delay lines and speaker gains .sub.l are determined from the distance between a speaker and a listening position. This process is described below. In one embodiment, the derived decoding matrices are stored within a code book. Every time the HOA audio input characteristics change, a renderer control unit determines currently valid characteristics and selects a matching decode matrix from the code book. Code book key can be the HOA order N or, equivalently, O.sub.3D (see eq. (6)).
[0068] The schematic steps of data processing for rendering are explained with reference to
[0069] The HOA time samples with time-index t and O.sub.3D HOA coefficient channels b(t) are first stored in the first buffer 31 to form blocks of M samples with block index μ. The coefficients of B(μ) are frequency filtered in the Frequency Domain Filtering unit 32 to obtain frequency filtered blocks {circumflex over (B)}(μ). This technology is known (see [3]) for compensating for the distance of the spherical loudspeaker sources and enabling the handling of near field recordings. The frequency filtered block signals {circumflex over (B)}(μ) are rendered to the spatial domain in the rendering processing unit 33 by:
W(μ)=D{circumflex over (B)}(μ) (19)
with W(μ) ∈.sup.L×M representing a spatial signal in L channels with blocks of M time samples. The signal is buffered in the second buffer 34 and serialized to form single time samples with time index t in L channels, referred to as w(t) in
.sub.l can be considered before D/A conversion or by adapting the speaker channel amplification in analog domain.
[0070] The renderer initialization works as follows.
[0071] First, speaker number and positions need to be known. The first step of the initialization is to make available the new speaker number L and related positions .sub.L=[r.sub.1, r.sub.2, . . . , r.sub.L], with r.sub.l=[r.sub.1, {circumflex over (θ)}.sub.l,
].sup.T=[r.sub.l, {circumflex over (Ω)}.sub.1.sup.T] where r.sub.1 is the distance from a listening position to a speaker l, and where {circumflex over (θ)}.sub.l,
are the related spherical angles. Various methods may apply, e.g. manual input of the speaker positions or automatic initialization using a test signal. Manual input of the speaker positions
.sub.L may be done using an adequate interface, like a connected mobile device or a device-integrated user-interface for selection of predefined position sets. Automatic initialization may be done using a microphone array and dedicated speaker test signals with an evaluation unit to derive
.sub.L. The maximum distance r.sub.max is determined by r.sub.max=max(r.sub.1, . . . , r.sub.L), the minimal distance r.sub.min by r.sub.min=min(r.sub.1, . . . , r.sub.L).
[0072] The L distances r.sub.l and r.sub.max are input to the delay line and gain compensation 35. The number of delay samples for each speaker channel d.sub.l are determined by
d.sub.l=[(r.sub.max−r.sub.l)f.sub.s/c+0.5] (20)
with sampling rate f.sub.s, speed of sound c (c≅343 m/s at a temperature of 20° celsius) and [x+0.5] indicating rounding to next integer. To compensate the speaker gains for different r.sub.l, loudspeaker gains .sub.l are determined by
or are derived using an acoustical measurement.
[0073] Calculation of decoding matrices, e.g. for the code book, works as follows. Schematic steps of a method for generating the decode matrix, in one embodiment, are shown in .sub.L, a spherical modeling grid
.sub.s and the HOA-order N.
[0074] The speaker directions .sub.L=[{circumflex over (Ω)}.sub.1, . . . , {circumflex over (Ω)}.sub.L] can be expressed as spherical angles {circumflex over (Ω)}.sub.s={circumflex over (Ω)}.sub.l=[{circumflex over (θ)}.sub.l,
].sup.T, and the spherical modeling grid
.sub.s=[Ω.sub.s, . . . , Ω.sub.S] by spherical angles Ω.sub.S=[θ.sub.s, ϕ.sub.s].sup.T. The number of directions is selected larger than the number of speakers (S>L) and larger than the number of HOA coefficients (S>O.sub.3D). The directions of the grid should sample the unit sphere in a very regular manner. Suited grids are discussed in [6], [9] and can be found in [7], [8]. The grid
.sub.s is selected once. As an example, a S=324 grid from [6] is sufficient for decoding matrices up to HOA-order N=9. Other grids may be used for different HOA orders. The HOA-order N is selected incremental to fill the code book from N=1, . . . , N.sub.max, with N.sub.max as the maximum HOA-order of supported HOA input content.
[0075] The speaker directions .sub.L and the spherical modeling grid
.sub.s are input to a Build Mix-Matrix block 41, which generates a mix matrix G thereof. The a spherical modeling grid
.sub.s and the HOA order N are input to a Build Mode-Matrix block 42, which generates a mode matrix {tilde over (Ψ)} thereof. The mix matrix G and the mode matrix {tilde over (Ψ)} are input to a Build Decode Matrix block 43, which generates a decode matrix {circumflex over (D)} thereof. The decode matrix is input to a Smooth Decode Matrix block 44, which smoothes and scales the decode matrix. Further details are provided below. Output of the Smooth Decode Matrix block 44 is the decode matrix {circumflex over (D)}, which is stored in the code book with related key N (or alternatively O.sub.3D). In the Build Mode-Matrix block 42, the spherical modeling grid
.sub.s is used to build a mode matrix analogous to eq. (11): {tilde over (Ψ)}=[y.sub.1, . . . y.sub.s] with y.sub.s=[Y.sub.0.sup.0(Ω.sub.s), Y.sub.1.sup.−1, . . . , Y.sub.N.sup.N(Ω.sub.s)].sup.H. It is noted that the mode matrix {tilde over (Ψ)} is referred to as F in [2].
[0076] In the Build Mix-Matrix block 41, a mix matrix G is created with G ∈ .sup.L×S. It is noted that the mix matrix G is referred to as W in [2]. An l.sup.th row of the mix matrix G consists of mixing gains to mix S virtual sources from directions
.sub.s to speaker l. In one embodiment, Vector Base Amplitude Panning (VBAP) [11] is used to derive these mixing gains, as also in [2].
[0077] The algorithm to derive G is summarized in the following.
TABLE-US-00001 1 Create G with zero values (i.e. initialize G) 2 for every s = 1 ... S 3 { 4 Find 3 speakers l.sub.1, l.sub.2, l.sub.3 that surround the position [1, Ω.sub.s.sup.T].sup.T, assuming unit radii and build matrix R = [r.sub.l.sub.
[0078] In the Build Decode Matrix block 43, the compact singular value decomposition of the matrix product of the mode matrix and the transposed mixing matrix is calculated. This is an important aspect of the present invention, which can be performed in various manners. In one embodiment, the compact singular value decomposition S of the matrix product of the mode matrix {tilde over (Ψ)} and the transposed mixing matrix G.sup.T is calculated according to:
U S V.sup.H={tilde over (Ψ)}G.sup.T
[0079] In an alternative embodiment, the compact singular value decomposition S of the matrix product of the mode matrix {tilde over (Ψ)} and the pseudo-inverse mixing matrix G.sup.+ is calculated according to:
U S V.sup.H={tilde over (Ψ)}G.sup.+
where G.sup.+ is the pseudo-inverse of mixing matrix G.
[0080] In one embodiment, a diagonal matrix where Ŝ=diag (Ŝ.sub.1, . . . , Ŝ.sub.K) is created where the first diagonal element is the inverse diagonal element of S: Ŝ.sub.1=1, and the following diagonal elements are set to a value of one (
=1) if
≥a S.sub.1, where a is a threshold value, or are set to a value of zero (
=0) if
≤a S.sub.1.
[0081] A suitable threshold value a was found to be around 0.06. Small deviations e.g. within a range of ±0.01 or a range of ±10% are acceptable. The decode matrix is then calculated as follows: {circumflex over (D)}=V Ŝ U.sup.H.
[0082] In the Smooth Decode Matrix block 44, the decode matrix is smoothed. Instead of applying smoothing coefficients to the HOA coefficients before decoding, as known in prior art, it can be combined directly with the decode matrix. This saves one processing step, or processing block respectively.
D={circumflex over (D)}diag() (21)
[0083] In order to obtain good energy preserving properties also for decoders for HOA content with more coefficients than loudspeakers (i.e. O.sub.3D>L), the applied smoothing coefficients are selected depending on the HOA order N (O.sub.3D=(N+1).sup.2):
[0084] For L≥O.sub.3D, It corresponds to max r.sub.E coefficients derived from the zeros of the Legendre polynomials of order N+1, as in [4].
[0085] For L≤O.sub.3D, the coefficients of constructed from a Kaiser window as follows:
=KaiserWindow(len,width) (22)
with len=2N+1, width=2N, where is a vector with 2N+1 real valued elements. The elements are created by the Kaiser window formula
[0086] where l.sub.0( ) denotes the zero-order Modified Bessel function of first kind. The vector It is constructed from the elements of: [0087] =c.sub.f[
.sub.N+1,
.sub.N+2,
.sub.N+2,
.sub.N+3,
.sub.N+3, . . . ,
.sub.2N].sup.T where every element
.sub.N+1+n gets 2n+1 repetitions for HOA order index n=0.. N, and c.sub.f is a constant scaling factor for keeping equal loudness between different HOA-order programs. That is, the used elements of the Kaiser window begin with the (N+1)′ element, which is used only once, and continue with subsequent elements which are used repeatedly: the (N+2)nd element is used three times, etc.
[0088] In one embodiment, the smoothed decode matrix is scaled. In one embodiment, the scaling is performed in the Smooth Decode Matrix block 44, as shown in
[0089] In one embodiment, the constant scaling factor is obtained from the decoding matrix. In particular, it can be obtained according to the so-called Frobenius norm of the decoding matrix:
where {tilde over (d)}.sub.l,q is a matrix element in line l and column q of the matrix {circumflex over (D)} (after smoothing).
[0090] The normalized matrix is D=c.sub.f {tilde over (D)}.
[0091] .sub.L of the speakers, means 1y for determining positions a spherical modeling grid
.sub.s and means 1z for obtaining a HOA order N, and first processing unit 141 for generating a mix matrix G from the positions of the spherical modeling grid
.sub.s and the positions of the speakers, second processing unit 142 for generating a mode matrix {tilde over (Ψ)} from the spherical modeling grid
.sub.s and the HOA order N, third processing unit 143 for performing a compact singular value decomposition of the product of the mode matrix with the Hermitian transposed mix matrix G according to U S V.sup.H={tilde over (Ψ)}G.sup.H, where U,V are derived from Unitary matrices and S is a diagonal matrix with singular value elements, calculating means 144 for calculating a first decode matrix {circumflex over (D)} from the matrices U,V according to {circumflex over (D)}=V U.sup.H, and a smoothing and scaling unit 145 for smoothing and scaling the first decode matrix {circumflex over (D)} with smoothing coefficients
, wherein the decode matrix {circumflex over (D)} is obtained. In one embodiment, the smoothing and scaling unit 145 as a smoothing unit 1451 for smoothing the first decode matrix {circumflex over (D)}, wherein a smoothed decode matrix {tilde over (D)} is obtained, and a scaling unit 1452 for scaling smoothed decode matrix {tilde over (D)}, wherein the decode matrix {circumflex over (D)} is obtained.
[0092]
[0093] In the following, obtained example results with the speaker setup as in
[0094] On the other hand, a decoder matrix that is designed as in [2], with N=3, produces a ratio Ê/E as shown in
[0095]
[0096] It is noted that whenever a speaker is mentioned herein, a sound emitting device such as a loudspeaker is meant.
[0097] The flowchart and/or block diagrams in the figures illustrate the configuration, operation and functionality of possible implementations of systems, methods and computer program products according to various embodiments of the present invention. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical functions.
[0098] It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, or blocks may be executed in an alternative order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of the blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions. While not explicitly described, the present embodiments may be employed in any combination or sub-combination.
[0099] Further, as will be appreciated by one skilled in the art, aspects of the present principles can be embodied as a system, method or computer readable medium. Accordingly, aspects of the present principles can take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, and so forth), or an embodiment combining software and hardware aspects that can all generally be referred to herein as a “circuit,” “module”, or “system.” Furthermore, aspects of the present principles can take the form of a computer readable storage medium. Any combination of one or more computer readable storage medium(s) may be utilized. A computer readable storage medium as used herein is considered a non-transitory storage medium given the inherent capability to store the information therein as well as the inherent capability to provide retrieval of the information therefrom.
[0100] Also, it will be appreciated by those skilled in the art that the block diagrams presented herein represent conceptual views of illustrative system components and/or circuitry embodying the principles of the invention. Similarly, it will be appreciated that any flow charts, flow diagrams, state transition diagrams, pseudocode, and the like represent various processes which may be substantially represented in computer readable storage media and so executed by a computer or processor, whether or not such computer or processor is explicitly shown.
CITED REFERENCES
[0101] [1] T. D. Abhayapala. Generalized framework for spherical microphone arrays: Spatial and frequency decomposition. In Proc. IEEE International Conference on Acoustics, Speech, and Signal Processing (ICASSP), (accepted) Vol. X, pp., April 2008, Las Vegas, USA. [0102] [2] Johann-Markus Batke, Florian Keiler, and Johannes Boehm. Method and device for decoding an audio soundfield representation for audio playback. International Patent Application WO2011/117399 (PD100011). [0103] [3] Jérôme Daniel, Rozenn Nicol, and Sebastien Moreau. Further investigations of high order ambisonics and wavefield synthesis for holophonic sound imaging. In AES Convention Paper 5788 Presented at the 114th Convention, March 2003. Paper 4795 presented at the 114th Convention. [0104] [4] Jérôme Daniel. Representation de champs acoustiques, application a la transmission et a la reproduction de scenes sonores complexes dans un contexte multimedia. PhD thesis, Universite Paris 6, 2001. [0105] [5] James R. Driscoll and Dennis M. Healy Jr. Computing Fourier transforms and convolutions on the 2-sphere. Advances in Applied Mathematics, 15:202-250, 1994. [0106] [6] Jörg Fliege. Integration nodes for the sphere. http://www.personal.soton.ac.uk/jf1w07/nodes/nodes.html, Online, accessed 2012-06-01. [0107] [7] Jörg Fliege and Ulrike Maier. A two-stage approach for computing cubature formulae for the sphere. Technical Report, Fachbereich Mathematik, Universitat Dortmund, 1999. [0108] [8] R. H. Hardin and N. J. A. Sloane. Webpage: Spherical designs, spherical t-designs. http://www2.research.att.com/˜njas/sphdesigns/. [0109] [9] R. H. Hardin and N. J. A. Sloane. Mclaren's improved snub cube and other new spherical designs in three dimensions. Discrete and Computational Geometry, 15:429-441, 1996. [0110] M. A. Poletti. Three-dimensional surround sound systems based on spherical harmonics. J. Audio Eng. Soc., 53(11):1004-1025, November 2005. [0111] [11] Ville Pulkki. Spatial Sound Generation and Perception by Amplitude Panning Techniques. PhD thesis, Helsinki University of Technology, 2001.
[0112] [12] Boaz Rafaely. Plane-wave decomposition of the sound field on a sphere by spherical convolution. J. Acoust. Soc. Am., 4(116):2149-2157, October 2004. [0113] [13] Earl G. Williams. Fourier Acoustics, volume 93 of Applied Mathematical Sciences. Academic Press, 1999. [0114] [14] F. Zotter, H. Pomberger, and M. Noisternig. Energy-preserving ambisonic decoding. Acta Acustica united with Acustica, 98(1):37-47, January/February 2012.