The present application claims priority from Australian Provisional Patent Application No. 2009904871 filed on 7 Oct. 2009, the contents of which are incorporated herein by reference in their entirety.
The present disclosure relates, generally, to reconstruction of a recorded sound field and, more particularly, to equipment for, and a method of, recording and then reconstructing a sound field using techniques related to at least one of compressive sensing and independent component analysis.
Various means exist for recording and then reproducing a sound field using microphones and loudspeakers (or headphones). The focus of this disclosure is accurate sound field reconstruction and/or reproduction compared with artistic sound field reproduction where creative modifications are allowed. Currently, there are two primary and state-of-the-art techniques used for accurately recording and reproducing a sound field: higher order ambisonics (HOA) and wave-field synthesis (WFS). The WFS technique generally requires a spot microphone for each sound source. In addition, the location of each sound source must be determined and recorded. The recording from each spot microphone is then rendered using the mathematical machinery of WFS. Sometimes spot microphones are not available for each sound source or spot microphones may not be convenient to use. In such cases, one generally uses a more compact microphone array such as a linear, circular, or spherical array. Currently, the best available technique for reconstructing a sound field from a compact microphone array is HOA. However, HOA suffers from two major problems: (1) a small sweet spot and (2) degradation in the reconstruction when the mathematical system is under-constrained (for example, when too many loudspeakers are used). The small sweet spot phenomenon refers to the fact that the sound field is only accurate for a small region of space.
Several terms relating to this disclosure are defined below.
“Reconstructing a sound field” refers, in addition to reproducing a recorded sound field, to using a set of analysis plane-wave directions to determine a set of plane-wave source signals and their associated source directions. Typically, analysis is done in association with a dense set of plane-wave source directions to obtain a vector, g, of plane-wave source signals in which each entry of g is clearly matched to an associated source direction.
“Head-related transfer functions” (HRTFs) or “Head-related impulse responses” (HRIRs) refer to transfer functions that mathematically specify the directional acoustic properties of the human auditory periphery including the outer ear, head, shoulders, and torso as a linear system. HRTFs express the transfer functions in the frequency domain and HRIRs express the transfer functions in the time domain.
“HOA-domain” and “HOA-domain Fourier Expansion” refer to any mathematical basis set that may be used for analysis and synthesis for Higher Order Ambisonics such as the Fourier-Bessel system, circular harmonics, and so forth. Signals can be expressed in terms of their components based on their expansion in the HOA-domain mathematical basis set. When signals are expressed in terms of these components, it is said that the signals are expressed in the “HOA-domain”. Signals in the HOA-domain can be represented in both the frequency and time domain in a manner similar to other signals.
“HOA” refers to Higher Order Ambisonics which is a general term encompassing sound field representation and manipulation in the HOA-domain.
“Compressive Sampling” or “Compressed Sensing” or “Compressive Sensing” all refer to a set of techniques that analyse signals in a sparse domain (defined below).
“Sparsity Domain” or “Sparse Domain” is a compressive sampling term that refers to the fact that a vector of sampled observations y can be written as a matrix-vector product, e.g., as:
y=Ψx
where Ψ is a basis of elementary functions and nearly all coefficient in x are null. If S coefficients in x are non-null, we say the observed phenomenon is S-sparse in the sparsity domain Ψ.
The function “pinv” refers to a pseudo-inverse, a regularised pseudo-inverse or a Moore-Penrose inverse of a matrix.
The L1-norm of a vector x is denoted ∥x∥1 and is given by
The L2-norm of a vector x is denoted by ∥x∥2 and is given by
The L1-L2 norm of a matrix A is denoted by ∥A∥1-2 and is given by:
∥A∥1-2=∥u∥1,
where
is the i-th element of u, and A[i, j] is the element in the i-th row and j-th column of A.
“ICA” is Independent Component Analysis which is a mathematical method that provides, for example, a means to estimate a mixing matrix and an unmixing matrix for a given set of mixed signals. It also provides a set of separated source signals for the set of mixed signals.
The “sparsity” of a recorded sound field provides a measure of the extent to which a small number of sources dominate the sound field.
“Dominant components” of a vector or matrix refer to components of the vector or matrix that are much larger in relative value than some of the other components. For example, for a vector x, we can measure the relative value of component xi compared to xj by computing the ratio
or the logarithm or the ratio, log
If the ratio or log-ratio exceeds some particular threshold value, say θth, xi may be considered a dominant component compared to xj.
“Cleaning a vector or matrix” refers to searching for dominant components (as defined above) in the vector or matrix and then modifying the vector or matrix by removing or setting to zero some of its components which are not dominant components.
“Reducing a matrix M” refers to an operation that may remove columns of M that contain all zeros and/or an operation that may remove columns that do not have a Dominant Component. Instead, “Reducing a matrix M” may refer to removing columns of the matrix M depending on some vector x. In this case, the columns of the matrix M that do not correspond to Dominant Components of the vector x are removed. Still further, “Reducing a matrix M” may refer to removing columns of the matrix M depending on some other matrix N. In this case, the columns of the matrix M must correspond somehow to the columns or rows of the matrix N. When there is this correspondence, “Reducing the matrix M” refers to removing the columns of the matrix M that correspond to columns or rows of the matrix N which do not have a Dominant Component.
“Expanding a matrix M” refers to an operation that may insert into the matrix M a set of columns that contains all zeros. An example of when such an operation may be required is when the columns of matrix M correspond to a smaller set of basis functions and it is required to express the matrix M in a manner that is suited to a larger set of basis functions.
“Expanding a vector of time signals x(t)” refers to an operation that may insert into the vector of time signals x(t), signals that contain all zeros. An example of when such an operation may be required is when the entries of x(t) correspond to time signals that match a smaller set of basis functions and it is required to express the vector of time signals x(t) in a manner that is suited to a larger set of basis functions.
“FFT” means a Fast Fourier Transform.
“IFFT” means an Inverse Fast Fourier Transform.
A “baffled spherical microphone array” refers to a spherical array of microphones which are mounted on a rigid baffle, such as a solid sphere. This is in contrast to an open spherical array of microphones which does not have a baffle.
Several notations related to this disclosure are described below:
Time domain and frequency domain vectors are sometimes expressed using the following notation: A vector of time domain signals is written as x(t). In the frequency domain, this vector is written as x. In other words, x is the FFT of x(t). To avoid confusion with this notation, all vectors of time signals are explicitly written out as x(t).
Matrices and vectors are expressed using bold-type. Matrices are expressed using capital letters in bold-type and vectors are expressed using lower-case letters in bold-type.
A matrix of filters is expressed using a capital letter with bold-type and with an explicit time component such as M(t) when expressed in the time domain or with an explicit frequency component such as M(ω) when expressed in the frequency domain. For the remainder of this definition we assume that the matrix of filters is expressed in the time domain. Each entry of the matrix is then itself a finite impulse response filter. The column index of the matrix M(t) is an index that corresponds to the index of some vector of time signals that is to be filtered by the matrix. The row index of the matrix M(t) corresponds to the index of the group of output signals. As a matrix of filters operates on a vector of time signals, the “multiplication operator” is the convolution operator described in more detail below.
“” is a mathematical operator which denotes convolution. It may be used to express convolution of a matrix of filters (represented as a general matrix) with a vector of time signals. For example, y(t)=M(t)x(t) represents the convolution of the matrix of filters M(t) with the corresponding vector of time signals in x(t). Each entry of M(t) is a filter and the entries running along each column of M(t) correspond to the time signals contained in the vector of time signals x(t). The filters running along each row of M(t) correspond to the different time signals in the vector of output signals y(t). As a concrete example, x(t) may correspond to a set of microphone signals, while y(t) may correspond to a set of HOA-domain time signals. In this case, the equation y(t)=M(t)x(t) indicates that the microphone signals are filtered with a set of filters given by each row of M(t) and then added together to give a time signal corresponding to one of the HOA-domain component signals in y(t).
Flow charts of signal processing operations are expressed using numbers to indicate a particular step number and letters to indicate one of several different operational paths. Thus, for example, Step 1.A.2.B.1 indicates that in the first step, there is an alternative operational path A, which has a second step, which has an alternative operational path B, which has a first step.
In a first aspect there is provided equipment for reconstructing a recorded sound field, the equipment including
a sensing arrangement for measuring the sound field to obtain recorded data; and
a signal processing module in communication with the sensing arrangement and which processes the recorded data for the purposes of at least one of (a) estimating the sparsity of the recorded sound field and (b) obtaining plane-wave signals and their associated source directions to enable the recorded sound field to be reconstructed.
The sensing arrangement may comprise a microphone array. The microphone array may be one of a baffled array and an open spherical microphone array.
The signal processing module may be configured to estimate the sparsity of the recorded data according to the method of one of aspects three and four below.
Further, the signal processing module may be configured to analyse the recorded sound field, using the methods of aspects five to seven below, to obtain a set of plane-wave signals that separate the sources in the sound field and identify the source locations and allow the sound field to be reconstructed.
The signal processing module may be configured to modify the set of plane-wave signals to reduce unwanted artifacts such as reverberations and/or unwanted sound sources. To reduce reverberations, the signal processing module may reduce the signal values of some of the signals in the plane-wave signals. To separate sound sources in the sound field reconstruction so that the unwanted sound sources can be reduced, the signal processing module may be operative to set to zero some of the signals in the set of plane-wave signals.
The equipment may include a playback device for playing back the reconstructed sound field. The playback device may be one of a loudspeaker array and headphones. The signal processing module may be operative to modify the recorded data depending on which playback device is to be used for playing back the reconstructed sound field.
In a second aspect, there is provided, a method of reconstructing a recorded sound field, the method including
analysing recorded data in a sparse domain using one of a time domain technique and a frequency domain technique; and
obtaining plane-wave signals and their associated source directions generated from the selected technique to enable the recorded sound field to be reconstructed.
The method may include recording a time frame of audio of the sound field to obtain the recorded data in the form of a set of signals, smic(t), using an acoustic sensing arrangement. Preferably, the acoustic sensing arrangement comprises a microphone array. The microphone array may be a baffled or open spherical microphone array.
In a third aspect, the method may include estimating the sparsity of the recorded sound field by applying ICA in an HOA-domain to calculate the sparsity of the recorded sound field.
The method may include analysing the recorded sound field in the HOA domain to obtain a vector of HOA-domain time signals, bHOA(t), and computing from bHOA(t) a mixing matrix, MICA, using signal processing techniques. The method may include using instantaneous Independent Component Analysis as the signal processing technique.
The method may include projecting the mixing matrix, MICA, on the HOA direction vectors associated with a set of plane-wave basis directions by computing Vsource=Ŷplw-HOATMICA, where Ŷplw-HOAT is the transpose (Hermitian conjugate) of the real-value (complex-valued) HOA direction matrix associated with the plane-wave basis directions and the hat-operator on Ŷplw-HOAT indicates it has been truncated to an HOA-order M.
The method may include estimating the sparsity, S, of the recorded data by first determining the number, Nsource, of dominant plane-wave directions represented by Vsource and then computing
where Nplw is the number of analysis plane-wave basis directions.
In a fourth aspect, the method may include estimating the sparsity of the recorded sound field by analysing recorded data using compressed sensing or convex optimization techniques to calculate the sparsity of the recorded sound field.
The method may include analysing the recorded sound field in the HOA domain to obtain a vector of HOA-domain time signals, bHOA(t), and sampling the vector of HOA-domain time signals over a given time frame, L, to obtain a collection of time samples at time instances t1 to tN to obtain a set of HOA-domain vectors at each time instant: bHOA(t1), bHOA(t2), . . . , bHOA(tN) expressed as a matrix, BHOA by:
B
HOA
=[b
HOA(t1)bHOA(t2) . . . bHOA(tN)].
The method may include applying singular value decomposition to BHOA to obtain a matrix decomposition:
B
HOA
=USV
T.
The method may include forming a matrix Sreduced by keeping only the first m columns of S, where m is the number of rows of BHOA and forming a matrix, Ω, given by
Ω=USreduced.
The method may include solving the following convex programming problem for a matrix Γ:
minimize ∥Γ∥L1-L2
subject to ∥YplwΓ−Ω∥L2≦ε1,
where Yplw is the matrix(truncated to a high spherical harmonic order) whose columns are the values of the spherical harmonic functions for the set of directions corresponding to some set of analysis plane waves, and
ε1 is a non-negative real number.
The method may include obtaining Gplw from Γ using:
G
plw
=ΓV
T
where VT is obtained from the matrix decomposition of BHOA.
The method may include obtaining an unmixing matrix, ΠL, for the L-th time frame, by calculating:
ΠL=(1−α)ΠL-1+αΓpinv(Ω),
where;
ΠL-1 is an unmixing matrix for the L−1 time frame,
α is a forgetting factor such that 0≦α≦1.
The method may include obtaining Gplw-smooth using:
G
plw-smooth=ΠLBHOA.
The method may include obtaining the vector of plane-wave signals, gplw-cs(t), from the collection of plane-wave time samples, Gplw-smooth, using standard overlap-add techniques. Instead when obtaining the vector of plane-wave signals gplw-cs(t), the method may include obtaining, gplw-cs(t), from the collection of plane-wave time samples, Gplw, without smoothing using standard overlap-add techniques.
The method may include estimating the sparsity of the recorded data by first computing the number, Ncomp, of dominant components of gplw-cs(t) and then computing
where Nplw is the number of analysis plane-wave basis directions.
In a fifth aspect the method may include reconstructing the recorded sound field, using frequency-domain techniques to analyse the recorded data in the sparse domain; and obtaining the plane-wave signals from the frequency-domain techniques to enable the recorded sound field to be reconstructed.
The method may include transforming the set of signals, smic(t), to the frequency domain using an FFT to obtain smic.
The method may include analysing the recorded sound field in the frequency domain using plane-wave analysis to produce a vector of plane-wave amplitudes, gplw-cs.
In a first embodiment of the fifth aspect, the method may include conducting the plane-wave analysis of the recorded sound field by solving the following convex programming problem for the vector of plane-wave amplitudes, gplw-cs:
where:
Tplw/mic is a transfer matrix between plane-waves and the microphones,
smic is the set of signals recorded by the microphone array, and
ε1 is a non-negative real number.
In a second embodiment of the fifth aspect, the method may include conducting the plane-wave analysis of the recorded sound field by solving the following convex programming problem for the vector of plane-wave amplitudes, gplw-cs:
where:
Tplw/mic is a transfer matrix between the plane-waves and the microphones,
smic is the set of signals recorded by the microphone array, and
ε1 is a non-negative real number,
Tplw/HOA is a transfer matrix between the plane-waves and the HOA-domain Fourier expansion,
bHOA is a set of HOA-domain Fourier coefficients given by bHOA=Tmic/HOAsmic where Tmic/HOA is a transfer matrix between the microphones and the HOA-domain Fourier expansion, and
ε2 is a non-negative real number.
In a third embodiment of the fifth aspect, the method may include conducting the plane-wave analysis of the recorded sound field by solving the following convex programming problem for the vector of plane-wave amplitudes, gplw-cs:
where:
Tplw/mic is a transfer matrix between plane-waves and the microphones,
Tmic/HOA is a transfer matrix between the microphones and the HOA-domain Fourier expansion,
bHOA is a set of HOA-domain Fourier coefficients given by bHOA=Tmic/HOAsmic,
ε1 is a non-negative real number.
In a fourth embodiment of the fifth aspect, the method may include conducting the plane-wave analysis of the recorded sound field by solving the following convex programming problem for the vector of plane-wave amplitudes, gplw-cs:
where:
Tplw/mic is a transfer matrix between plane-waves and the microphones,
ε1 is a non-negative real number,
Tplw/HOA is a transfer matrix between the plane-waves and the HOA-domain Fourier expansion,
bHOA is a set of HOA-domain Fourier coefficients given by bHOA=Tmic/HOAsmic where Tmic/HOA is a transfer matrix between the microphones and the HOA-domain Fourier expansion, and
ε2 is a non-negative real number.
The method may include setting ε1 based on the resolution of the spatial division of a set of directions corresponding to the set of analysis plane-waves and setting the value of ε2 based on the computed sparsity of the sound field. Further, the method may include transforming gplw-cs back to the time-domain using an inverse FFT to obtain gplw-cs(t). The method may include identifying source directions with each entry of gplw-cs or gplw-cs(t).
In a sixth aspect, the method may include using a time domain technique to analyse recorded data in the sparse domain and obtaining parameters generated from the selected time domain technique to enable the recorded sound field to be reconstructed.
The method may include analysing the recorded sound field in the time domain using plane-wave analysis according to a set of basis plane-waves to produce a set of plane-wave signals, gplw-cs(t). The method may include analysing the recorded sound field in the HOA domain to obtain a vector of HOA-domain time signals, bHOA(t), and sampling the vector of HOA-domain time signals over a given time frame, L, to obtain a collection of time samples at time instances t1 to tN to obtain a set of HOA-domain vectors at each time instant: bHOA(t1), bHOA(t2), . . . bHOA(tN) expressed as a matrix, BHOA by:
B
HOA
[b
HOA(t1)bHOA(t2) . . . bHOA(tN)].
The method may include computing a correlation vector, γ, as γ=BHOAbomni, where bomni is an omni-directional HOA-component of bHOA(t).
In a first embodiment of the sixth aspect, the method may include solving the following convex programming problem for a vector of plane-wave gains, εplw-cs:
where:
γ=BHOAbomni,
Tplw/HOA is a transfer matrix between the plane-waves and the HOA-domain Fourier expansion,
ε1 is a non-negative real number.
In a second embodiment, of the sixth aspect, the method may include solving the following convex programming problem for a vector of plane-wave gains, βplw-cs:
where:
γ=BHOAbomni,
Tplw/HOA is a transfer matrix between the plane-waves and the HOA-domain Fourier expansion,
ε1 is a non-negative real number,
ε2 is a non-negative real number.
The method may include setting ε1 based on the resolution of the spatial division of a set of directions corresponding to the set of analysis plane-waves and setting the value of ε2 based on the computed sparsity of the sound field. The method may include thresholding and cleaning βplw-cs to set some of its small components to zero.
The method may include forming a matrix, Ŷplw-HOA, according to the plane-wave basis and then reducing Ŷplw-HOA to Ŷplw-HOA-reduced by keeping only the columns corresponding to the non-zero components in βplw-cs, where Ŷplw-HOA is an HOA direction matrix for the plane-wave basis and the hat-operator on Ŷplw-HOA indicates it has been truncated to some HOA-order M.
The method may include computing gplw-cs-reduced(t) as gplw-cs-reduced(t)=pinv(Ŷplw-HOA-reduced)bHOA(t). Further, the method may include expanding gplw-cs-reduced(t) to obtain gplw-cs(t) by inserting rows of time signals of zeros so that gplw-cs(t) matches the plane-wave basis.
In a third embodiment of the sixth aspect, the method may include solving the following convex programming problem for a matrix Gplw:
minimize ∥Gplw∥L1-L2
subject to ∥YplwGplw−BHOA∥L2≦ε1,
where Yplw is a matrix(truncated to a high spherical harmonic order) whose columns are the values of the spherical harmonic functions for the set of directions corresponding to some set of analysis plane waves, and
ε1 is a non-negative real number.
The method may include obtaining an unmixing matrix, ΠL, for the L-th time frame, by calculating:
ΠL=(1−α)ΠL-1αGplwpinv(BHOA),
where
ΠL-1 refers to the unmixing matrix for the L−1 time frame and
α is a forgetting factor such that 0≦α≦1.
In a fourth embodiment of the fifth aspect, the method may include applying singular value decomposition to BHOA to obtain a matrix decomposition:
B
HOA
=USV
T.
The method may include forming a matrix Sreduced by keeping only the first m columns of S, where m is the number of rows of BHOA and forming a matrix, Ω, given by
Ω=USreduced.
The method may include solving the following convex programming problem for a matrix Γ:
minimize ∥Γ∥L1-L2
subject to ∥YplwΓ−Ω∥L2≦ε1,
where ε1 and Yplw are as defined above.
The method may include obtaining Gplw from Γ using:
G
plw
=ΓV
T
where VT is obtained from the matrix decomposition of BHOA.
The method may include obtaining an unmixing matrix, ΠL, for the L-th time frame, by calculating:
ΠL=(1−α)ΠL-1+αΓpinv(Ω),
where;
ΠL-1 is an unmixing matrix for the L−1 time frame,
α is a forgetting factor such that 0≦α≦1.
The method may include obtaining Gplw-smooth using:
G
plw-smooth=ΠLBHOA.
The method may include obtaining the vector of plane-wave signals, gplw-cs(t), from the collection of plane-wave time samples, Gplw-smooth, using standard overlap-add techniques. Instead when obtaining the vector of plane-wave signals gplw-cs(t), the method may include obtaining, gplw-cs(t), from the collection of plane-wave time samples, Gplw, without smoothing using standard overlap-add techniques. The method may include identifying source directions with each entry of gplw-cs(t).
The method may include modifying gplw-cs(t) to reduce unwanted artifacts such as reverberations and/or unwanted sound sources. Further, the method may include, to reduce reverberations, reducing the signal values of some of the signals in the signal vector, gplw-cs(t). The method may include, to separate sound sources in the sound field reconstruction so that the unwanted sound sources can be reduced, setting to zero some of the signals in the signal vector, gplw-cs(t).
Further, the method may include modifying gplw-cs(t) dependent on the means of playback of the reconstructed sound field. When the reconstructed sound field is to be played back over loudspeakers, in one embodiment, the method may include modifying gplw-cs(t) as follows:
g
spk(t)=Pplw/spkgplw-cs(t)
where:
Pplw/spk is a loudspeaker panning matrix.
In another embodiment, when the reconstructed sound field is to be played back over loudspeakers, the method may include converting gplw-cs(t) back to the HOA-domain by computing:
b
HOA-highres(t)=Ŷplw-HOAgplw-cs(t)
where bHOA-highres(t) is a high-resolution HOA-domain representation of gplw-cs(t) capable of expansion to arbitrary HOA-domain order, where Ŷplw-HOA is an HOA direction matrix for a plane-wave basis and the hat-operator on Ŷplw-HOA indicates it has been truncated to some HOA-order M. The method may include decoding bHOA-highres(t) to gspk(t) using HOA decoding techniques.
When the reconstructed sound field is to be played back over headphones, the method may include modifying gplw-cs(t) to determine headphone gains as follows:
g
hph(t)=Pplw/hph(t)gplw-cs(t)
where:
Pplw/hph(t) is a head-related impulse response matrix of filters corresponding to the set of plane wave directions.
In a seventh aspect, the method may include using time-domain techniques of Independent Component Analysis (ICA) in the HOA-domain to analyse recorded data in a sparse domain, and obtaining parameters from the selected time domain technique to enable the recorded sound field to be reconstructed.
The method may include analysing the recorded sound field in the HOA-domain to obtain a vector of HOA-domain time signals bHOA(t). The method may include analysing the HOA-domain time signals using ICA signal processing to produce a set of plane-wave source signals, gplw-ica(t).
In a first embodiment of the seventh aspect, the method may include computing from bHOA(t) a mixing matrix, MICA, using signal processing techniques. The method may include using instantaneous Independent Component Analysis as the signal processing technique. The method may include projecting the mixing matrix, MICA, on the HOA direction vectors associated with a set of plane-wave basis directions by computing Vsource=Ŷplw-HOATMICA, where Ŷplw-HOAT is the transpose (Hermitian conjugate) of the real-value (complex-valued) HOA direction matrix associated with the plane-wave basis and the hat-operator on Ŷplw-HOAT indicates it has been truncated to some HOA-order M.
The method may include using thresholding techniques to identify the columns of Vsource that indicate a dominant source direction. These columns may be identified on the basis of having a single dominant component.
The method may include reducing the matrix Ŷplw-HOA to obtain a matrix, Ŷplw-HOA-reduced, by removing the plane-wave direction vectors in Ŷplw-HOA that do not correspond to dominant source directions associated with matrix Vsource.
The method may include estimating gplw-ica-reduced(t) as gplw-ica-reduced(t)=pinv(Ŷplw-HOA-reduced)bHOA(t). Instead, the method may include estimating gplw-ica-reduced(t) by working in the frequency domain and computing smic as the FFT of smic(t).
The method may include, for each frequency, reducing a transfer matrix, between the plane-waves and the microphones, Tplw/mic, to obtain a matrix, Tplw/mic-reduced, by removing the columns in Tplw/mic that do not correspond to dominant source directions associated with matrix Vsource.
The method may include estimating gplw-ica-reduced by computing: gplw-ica-reduced=pinv(Tplw/mic-reduced)smic and transforming gplw-ica-reduced back to the time-domain using inverse FFT to obtain gplw-ica-reduced(t). The method may include domain expanding gplw-ica-reduced(t) to obtain gplw-ica(t) by inserting rows of time signals of zeros so that gplw-ica(t) matches the plane-wave basis.
In a second embodiment of the seventh aspect, the method may include computing from bHOA a mixing matrix, MICA, and a set of separated source signals, gica(t) using signal processing techniques. The method may include using instantaneous Independent Component Analysis as the signal processing technique. The method may include projecting the mixing matrix, MICA, on the HOA direction vectors associated with a set of plane-wave basis directions by computing Vsource=Ŷplw-HOATMICA, where Ŷplw-HOAT is the transpose (Hermitian conjugate) of the real-value (complex-valued) HOA direction matrix associated with the plane-wave basis and the hat-operator on Ŷplw-HOAT indicates it has been truncated to some HOA-order M
The method may include using thresholding techniques to identify from Vsource the dominant plane-wave directions. Further, the method may include cleaning gica(t) to obtain gplw-ica(t) which retains the signals corresponding to the dominant plane-wave directions in Vsource and sets the other signals to zero.
The method may include modifying gplw-ica(t) to reduce unwanted artifacts such as reverberations and/or unwanted sound sources. The method may include, to reduce reverberations, reducing the signal values of some of the signals in the signal vector, gplw-ica(t). Further, the method may include, to separate sound sources in the sound field reconstruction so that the unwanted sound sources can be reduced, setting to zero some of the signals in the signal vector, gplw-ica(t).
Still further, the method may include modifying gplw-ica(t) dependent on the means of playback of the reconstructed sound field. When the reconstructed sound field is to be played back over loudspeakers, in one embodiment the method may include modifying gplw-ica(t) as follows:
g
spk(t)=Pplw/spkgplw-ica(t)
where:
Pplw/spk is a loudspeaker panning matrix.
In another embodiment, when the reconstructed sound field is to be played back over loudspeakers, the method may include converting gplw-ica(t) back to the HOA-domain by computing:
b
HOA-highres(t)=Ŷplw-HOAgplw-ica(t)
where:
bHOA-highres(t) is a high-resolution HOA-domain representation of gplw-ica(t) capable of expansion to arbitrary HOA-domain order,
Ŷplw-HOA is an HOA direction matrix for a plane-wave basis and the hat-operator on Ŷplw-HOA indicates it has been truncated to some HOA-order M.
The method may include decoding bHOA-highres(t) to gspk(t) using HOA decoding techniques.
When the reconstructed sound field is to be played back over headphones, the method may include modifying gplw-cs(t) to determine headphone gains as follows:
g
hph(t)=Pplw/hph(t)gplw-ica(t)
where:
Pplw/hph(t) is a head-related impulse response matrix of filters corresponding to the set of plane wave directions.
The disclosure extends to a computer when programmed to perform the method as described above.
The disclosure also extends to a computer readable medium to enable a computer to perform the method as described above.
In
A data accessing module 16 is connected to the SPM 14. In one embodiment the data accessing module 16 is a memory module in which data are stored. The SPM 14 accesses the memory module to retrieve the required data from the memory module as and when required. In another embodiment, the data accessing module 16 is a connection module, such as, for example, a modem or the like, to enable the SPM 14 to retrieve the data from a remote location.
The equipment 10 includes a playback module 18 for playing back the reconstructed sound field. The playback module 18 comprises a loudspeaker array 20 and/or one or more headphones 22.
The sensing arrangement 12 is a baffled spherical microphone array for recording the sound field to produce recorded data in the form of a set of signals, smic(t)
The SPM 14 analyses the recorded data relating to the sound field using plane-wave analysis to produce a vector of plane-wave signals, gplw(t). Producing the vector of plane-wave signals, gplw(t), is to be understood as also obtaining the associated set of pale-wave source directions. Depending on the particular method used to produce the vector of plane wave amplitudes, gplw(t) is referred to more specifically as gplw-cs(t) if Compressed Sensing techniques are used or gplw-ica(t) if ICA techniques are used. As will be described in greater detail below, the SPM 14 is also used to modify gplw(t), if desired.
Once the SPM 14 has performed its analysis, it produces output data for the output port 24 which may include the sparsity of the sound field, the separated plane-wave source signals and the associated source directions of the plane-wave source signals. In addition, once the SPM 14 has performed its analysis, it generates signals, sout(t), for rendering the determined gplw(t) as audio to be replayed over the loudspeaker array 20 and/or the one or more headphones 22.
The SPM 14 performs a series of operations on the set of signals, smic(t), after the signals have been recorded by the microphone array 12, to enable the signals to be reconstructed into a sound field closely approximating the recorded sound field.
In order to describe the signal processing operations concisely, a set of matrices that characterise the microphone array 12 are defined. These matrices may be computed as needed by the SPM 14 or may be retrieved as needed from data storage using the data accessing module 16. When one of these matrices is referred to, it will be described as “one of the defined matrices”.
The following is a list of Defined Matrices that may be computed or retrieved as required:
{circumflex over (T)}sph/mic is a transfer matrix between the spherical harmonic domain and the microphone signals, the matrix {circumflex over (T)}sph/mic being truncated to order M, as:
{circumflex over (T)}
sph/mic
=Ŷ
mic
T
Ŵ
mic
where:
ŶmicT is the transpose of the matrix whose columns are the values of the spherical harmonic functions, Ŷmn(θ1,φ1), where (r1,θ1,φ1) are the spherical coordinates for the 1-th microphone and the hat-operator on ŶmicT indicates it has been truncated to some order M; and
Ŵmic is the diagonal matrix whose coefficients are defined by
where R is the radius of the sphere of the microphone array, hm(2) is the spherical Hankel function of the second kind of order m, jm is the spherical Bessel function of order m, jm′ and hm′(2) are the derivatives of jm and hm(2), respectively. Once again, the hat-operator on Ŵmic indicates that it has been truncated to some order M.
Tsph/mic is similar to {circumflex over (T)}sph/mic except it has been truncated to a much higher order M′ with (M′>M).
Yplw is the matrix(truncated to the higher order M′) whose columns are the values of the spherical harmonic functions for the set of directions corresponding to some set of analysis plane waves.
Ŷplw is similar to Yplw except it has been truncated to the lower order M with (M<M′).
Tplw/HOA is a transfer matrix between the analysis plane waves and the HOA-estimated spherical harmonic expansion (derived from the microphone array 12) as:
T
plw/HOA
=pinv({circumflex over (T)}sph/mic)Tsph/micYplw.
Tplw/mic is a transfer matrix between the analysis plane waves and the microphone array 12 as:
T
plw/mic
=T
sph/mic
Y
plw,
where:
Tsph/mic is as defined above.
Emic/HOA(t) is a matrix of filters that implements, via a convolution operation, that transformation between the time signals of the microphone array 12 and the HOA-domain time signals and is defined as:
E
mic/HOA(t)=IFFT(Emic/HOA(ω))
where:
each frequency component of Emic/HOA(ω) is given by Emic/HOA=pinv({circumflex over (T)}sph/mic).
The operations performed on the set of signals, smic(t), are now described with reference to the flow charts illustrated in
The operations performed on the set of signals, smic(t), by the SPM 14 to determine the sparsity, S, of the sound field is now described with reference to the flow charts of
The flow chart shown in
b
HOA(t)=Emic/HOA(t)smic(t).
At Step 2.2, there are two different options available: Step 2.2.A and Step 2.2.B. At Step 2.2.A, the SPM 14 estimates the sparsity of the sound field by applying ICA in the HOA-domain. Instead, at Step 2.2.B the SPM 14 estimates the sparsity of the sound field using a Compressed Sampling technique.
The flow chart of
At Step 2.2.A.2, the SPM 14 projects the mixing matrix, MICA, on the HOA direction vectors associated with a set of plane-wave basis directions. This projection is obtained by computing Vsource=ŶplwTMICA, where ŶplwT is the transpose of the Defined Matrix Ŷplw.
At Step 2.2.A.3, the SPM 14 applies thresholding techniques to clean Vsource in order to obtain Vsource-clean. The operation of cleaning Vsource occurs as follows. Firstly, the ideal format for Vsource is defined. Vsource is a matrix which is ideally composed of columns which either have all components as zero or contain a single dominant component corresponding to a specific plane wave direction with the rest of the column's components being zero. Thresholding techniques are applied to ensure that Vsource takes its ideal format. That is to say, columns of Vsource which contain a dominant value compared to the rest of the column's components are thresholded so that all components less than the dominant component are set to zero. Also, columns of Vsource which do not have a dominant component have all of its components set to zero. Applying the above thresholding operations to Vsource gives Vsource-clean.
At Step 2.2.A.4, the SPM 14 computes the sparsity of the sound field. It does this by calculating the number, Nsource, of dominant plane wave directions in Vsource-clean. The SPM 14 then computes the sparsity, S, of the sound field as
where Nplw is the number of analysis plane-wave basis directions.
The flow chart of
B
HOA
=[b
HOA(t1)bHOA(t2) . . . bHOA(tN)].
At Step 2.2.B.2, the SPM 14 calculates a correlation vector, γ, as
γ=BHOAbomni,
where bomni is the omni-directional HOA-component of bHOA(t) expressed as a column vector.
At Step 2.2.B.3, the SPM 14 solves the following convex programming problem to obtain the vector of plane-wave gains, βplw-cs:
where Tplw/HOA is one of the defined matrices and ε1 is a non-negative real number.
At Step 2.2.B.4, the SPM 14 estimates the sparsity of the sound field. It does this by applying a thresholding technique to βplw-cs in order to estimate the number, Ncomp, of its Dominant Components. The SPM 14 then computes the sparsity, S, of the sound field as
where Nplw is the number of analysis plane-wave basis directions.
The operations performed on the set of signals, smic(t), by the SPM 14 to reconstruct the sound field is now described and is illustrated using the flow charts of
In
At Step 3, the SPM 14 estimates the parameters, in the form of plane-wave signals gplw(t), that allow the sound field to be reconstructed. The plane-wave signals gplw(t) are expressed either as gplw-cs(t) or gplw-ica(t) a depending on the method of derivation. At Step 4 there is an optional step (represented by a dashed box) in which the estimated parameters are modified by the SPM 14 to reduce reverberation and/or separate unwanted sounds. At Step 5, the SPM 14 estimates the plane-wave signals, gplw-cs(t) or gplw-ica(t), (possibly modified) that are used to reconstruct and play back the sound field.
The operations of Step 1 and Step 2 having been previously described, the flow of operations contained in Step 3 are now described.
The flow chart of
At Step 3.A, the SPM 14 estimates the plane-wave signals using a Compressive Sampling technique in the time-domain. At Step 3.B, the SPM 14 estimates the plane-wave signals using a Compressive Sampling technique in the frequency-domain. At Step 3.C, the SPM 14 estimates the plane-wave signals using ICA in the HOA-domain. At Step 3.D, the SPM 14 estimates the plane-wave signals using Compressive Sampling in the time domain using a multiple measurement vector technique.
The flow chart shown in
At Step 3.A.2 the correlation vector, γ, is determined by the SPM 14 as described above for Step 2.2.B.2.
At Step 3.A.3 there are two options: Step 3.A.3.A and Step 3.A.3.B. At Step 3.A.3.A, the SPM 14 solves a convex programming problem to determine plane-wave direction gains, βplw-cs. This convex programming problem does not include a sparsity constraint. More specifically, the following convex programming problem is solved:
where:
γ is as defined above and Tplw/HOA is one of the Defined Matrices,
ε1 is a non-negative real number.
At Step 3.A.3.B, the SPM 14 solves a convex programming problem to determine plane-wave direction gains, βplw-cs, only this time a sparsity constraint is included in the convex programming problem. More specifically, the following convex programming problem is solved to determine βplw-cs:
where:
γ, ε1 are as defined above,
Tplw/HOA is one of the Defined Matrices, and
ε2 is a non-negative real number.
For the convex programming problems at Step 3.A.3, ε1 may be set by the SPM 14 based on the resolution of the spatial division of a set of directions corresponding to the set of analysis plane waves. Further, the value of s2 may be set by the SPM 14 based on the computed sparsity of the sound field (optional Step 2).
At Step 3.A.4, the SPM 14 applies thresholding techniques to clean βplw-cs so that some of its small components are set to zero.
At Step 3.A.5, the SPM 14 forms a matrix, Ŷplw-HOA, according to the plane-wave basis and then reduces Ŷplw-HOA to Ŷplw-reduced by keeping only the columns corresponding to the non-zero components in βplw-cs, where Ŷplw-HOA is an HOA direction matrix for the plane-wave basis and the hat-operator on Ŷplw-HOA indicates it has been truncated to some HOA-order M.
At Step 3.A.6, the SPM 14 calculates gplw-cs-reduced(t) as:
g
plw-cs-reduced(t)=pinv(Tplw/HOA-reduced)bHOA(t),
where Ŷplw-reduced and bHOA(t) are as defined above.
At Step 3.A.7, the SPM 14 expands gplw-cs-reduced(t) to obtain gplw-cs(t) by inserting rows of time signals of zeros to match the plane-wave basis that has been used for the analyses.
As indicated, above, an alternative to Step 3.A is Step 3.B. The flow chart of
At Step 3.B.2, the SPM 14 solves one of four optional convex programming problems. The convex programming problem shown at Step 3.B.2.A operates on smic and does not use a sparsity constraint. More precisely, the SPM 14 solves the following convex programming problem to determine gplw-cs:
where:
Tplw/mic is one of the Defined Matrices,
smic is as defined above, and
ε1 is a non-negative real number.
The convex programming problem shown at Step 3.B.2.B operates on smic and includes a sparsity constraint. More precisely, the SPM 14 solves the following convex programming problem to determine gplw-cs:
where:
Tplw/mic, Tplw/HOA are each one of the Defined Matrices,
smic, bHOA, ε1 are as defined above, and
ε2 is a non-negative real number.
The convex programming problem shown at Step 3.B.2.C operates on bHOA and does not use a sparsity constraint. More precisely, the SPM 14 solves the following convex programming problem to determine gplw-cs:
where:
Tplw/mic, Tmic/HOA are each one of the Defined Matrices, and
bHOA, and ε1 are as defined above.
The convex programming problem shown at Step 3.B.2.D operates on bHOA and includes a sparsity constraint. More precisely, the SPM 14 solves the following convex programming problem to determine gplw-cs:
where:
Tplw/mic, Tplw/HOA, Tmic/HOA are each one of the Defined Matrices, and
bHOA, ε1, and ε2 are as defined above.
At Step 3.B.3, the SPM 14 computes an inverse FFT of gplw-cs to obtain gplw-cs(t). When operating on multiple time frames, overlap-and-add procedures are followed.
A further option to Step 3.A or Step 3.B is Step 3.C. The flow chart of
At Step 3.C.2 there are two options, Step 3.C.2.A and Step 3.C.2.B. At Step 3.C.2.A, the SPM 14 uses ICA in the HOA-domain to estimate a mixing matrix which is then used to obtain gplw-ica(t). Instead, at Step 3.C.2.B, the SPM 14 uses ICA in the HOA-domain to estimate a mixing matrix and also a set of separated source signals. Both the mixing matrix and the separated source signals are then used by the SPM 14 to obtain gplw-ica(t).
The flow chart of
At Step 3.C.2.A.2, the SPM 14 projects the mixing matrix, MICA, on the HOA direction vectors associated with a set of plane-wave basis directions as described at Step 2.2.A.2. That is to say, the projection is obtained by computing Vsource=ŶplwTMICA, where ŶplwT is the transpose of the defined matrix Ŷplw.
At Step 3.C.2.A.3, the SPM 14 applies thresholding techniques to Vsource to identify the dominant plane-wave directions in Vsource. This is achieved similarly to the operation described above with reference to Step 2.2.A.3.
At Step 3.C.2.A.4, there are two options, Step 3.C.2.A.4.A and Step 3.C.2.A.4.B. At Step 3.C.2.A.4.A, the SPM 14 uses the HOA domain matrix, ŶplwT, to compute gplw-ica-reduced (t). Instead, at Step 3.C.2.A.4.B, the SPM 14 uses the microphone signals smic(t) and the matrix Tplw/mic to compute gplw-ica-reduced(t).
The flow chart of
At Step 3.C.2.A.4.A.2, the SPM 14 calculates gplw-ica-reduced(t) as:
g
plw-ica-reduced(t)=pinv(Ŷplw-reduced)bHOA(t),
where Ŷplw-reduced and bHOA(t) are as defined above.
An alternative to Step 3.C.2.A.4.A, is Step 3.C.2.A.4.B. The flow chart of
At Step 3.C.2.A.4.B.1, the SPM 14 calculates a FFT, smic, of smic(t). At Step 3.C.2.A.4.B.2, the SPM 14 reduces the matrix Tplw/mic to obtain the matrix, Tplw/mic-reduced, by removing the plane-wave directions in Tplw/mic that do not correspond to dominant source directions associated with matrix Vsource.
At Step 3.C.2.A.4.B.3, the SPM 14 calculates gplw-ica-reduced as:
g
plw-ica-reduced
=pinv(Tplw/mic-reduced)smic,
where Tplw/mic-reduced and smic are as defined above.
At Step 3.C.2.A.4.B.4, the SPM 14 calculates gplw-ica-reduced(t) as the IFFT of gplw-ica-reduced.
Reverting to
An alternative to Step 3.C.2.A is Step 3.C.2.B. The flow chart of
At Step 3.C.2.B.1, the SPM 14 applies ICA to the vector of signals bHOA(t) to obtain the mixing matrix, MICA, and a set of separated source signals gica(t).
At Step 3.C.2.B.2, the SPM 14 projects the mixing matrix, MICA, on the HOA direction vectors associated with a set of plane-wave basis directions as described for Step 2.2.A.2, i.e the projection is obtained by computing Vsource=ŶplwTMICA, where ŶplwT is the transpose of the defined matrix Ŷplw.
At Step 3.C.2.B.3, the SPM 14 applies thresholding techniques to Vsource to identify the dominant plane-wave directions in Vsource. This is achieved similarly to the operation described above for Step 2.2.A.3. Once the dominant plane-wave directions in Vsource have been identified, the SPM 14 cleans gica(t) to obtain gplw-ica(t) which retains the signals corresponding to the dominant plane-wave directions Vsource and sets the other signals to zero.
As described above, a further option to Steps 3.A, 3.B and 3.C, is Step 3.D. The flow chart of
At Step 3.D.1, the SPM 14 computes bHOA(t) as bHOA(t)=Emic/HOA(t)smic(t). The SPM 14 then calculates the matrix, BHOA, from the vector of HOA signals bHOA(t) by setting each signal in bHOA(t) to run along the rows of BHOA so that time runs along the rows of the matrix BHOA and the various HOA orders run along the columns of the matrix BHOA. More specifically, the SPM 14 samples bHOA(t) over a given time frame, L, to obtain a collection of time samples at the time instances t1 to tN. The SPM 14 thus obtains a set of HOA-domain vectors at each time instant: bHOA(t1), bHOA(t2), . . . , bHOA(tN). The SPM 14 forms the matrix, BHOA, by:
B
HOA
=[b
HOA(t1)bHOA(t2) . . . bHOA(tN)].
At Step 3.D.2 there are two options, Step 3.D.2.A and Step 3.D.2.B. At Step 3.D.2.A, the SPM 14 computes gplw-cs using a multiple measurement vector technique applied directly on BHOA. Instead at Step 3.D.2.B, the SPM 14 computes gplw-cs using a multiple measurement vector technique based on the singular value decomposition of BHOA.
The flow chart of
minimize ∥Gplw∥L1-L2
subject to ∥YplwGplw−BHOA∥L2≦ε1,
where:
Yplw is one of the Defined Matrices,
BHOA is as defined above, and
ε1 is a non-negative real number.
At Step 3.D.2.A.2, there are two options, i.e. Step 3.D.2.A.2.A and Step 3.D.2.A.2.B. At Step 3.D.2.A.2.A, the SPM 14 computes gplw-cs(t) directly from Gplw using an overlap-add technique. Instead at Step 3.D.2.A.2.B, the SPM 14 computes gplw-cs(t) using a smoothed version of Gplw and an overlap-add technique.
The flow chart of
At Step 3.D.2.A.2.B.1, the SPM 14 calculates an unmixing matrix, ΠL, for the L-th time frame, by calculating:
ΠL=(1−α)ΠL-1+αGplwpinv(BHOA),
where ΠL-1 refers to the unmixing matrix for the L−1 time frame and α is a forgetting factor such that 0≦α≦1, and BHOA is as defined above.
At Step 3.D.2.A.2.B.2, the SPM 14 calculates Gplw-smooth as:
G
plw-smooth=ΠLBHOA,
where ΠL and BHOA are as defined above.
At Step 3.D.2.A.2.B.3, the SPM 14 calculates gplw-cs(t) from Gplw-smooth using an overlap-add technique.
An alternative to Step 3.D.2.A is Step 3.D.2.B. The flow chart of
At Step 3.D.2.B.1, the SPM 14 computes the singular value decomposition of BHOA to obtain the matrix decomposition:
B
HOA
=USV
T.
At Step 3.D.2.B.2, the SPM 14 calculates the matrix, Sreduced, by keeping only the first m columns of S, where m is the number of rows of BHOA.
At Step 3.D.2.B.3, the SPM 14 calculates matrix Ω as:
Ω=USreduced.
At Step 3.D.2.B.4, the SPM 14 solves the following convex programming problem for matrix Γ:
minimize ∥Γ∥L1-L2
subject to ∥YplwΓ−Ω∥L2≦ε1,
where:
Yplw is one of the defined matrices,
Ω is as defined above, and
ε1 is a non-negative real number.
At Step 3.D.2.B.5, there are two options, Step 3.D.2.B.5.A and Step 3.D.2.B.5.B. At Step 3.D.2.B.5.A, the SPM 14 calculates Gplw from Γ using:
G
plw
=ΓV
T
where VT is obtained from the matrix decomposition of BHOA as described above. The SPM 14 then computes gplw-cs(t) directly from Gplw using an overlap-add technique.
Instead, at Step 3.D.2.B.5.B, the SPM 14 calculates gplw-cs(t) using a smoothed version of Gplw and an overlap-add technique.
The flow chart of
At Step 3.D.2.B.5.B.1, the SPM 14 calculates at unmixing matrix, ΠL, for the L-th time frame, by calculating:
ΠL=(1−α)ΠL-1+αΓpinv(Ω),
where ΠL-1 refers to the unmixing matrix for the L−1 time frame and α is a forgetting factor such that 0≦α≦1, and Γ and Ω are as defined above.
At Step 3.D.2.B.5.B.2, the SPM 14 calculates Gplw-smooth as:
G
plw-smooth=ΠLBHOA,
where ΠL and BHOA are as defined above.
At Step 3.D.2.B.2.B.3, the SPM 14 calculates gplw-cs(t) from Gplw-smooth using an overlap-add technique.
As described above, an optional step of reducing unwanted artifacts is shown at Step 4 of the flow chart of
In Step 5 of the flow chart of
At Step 5.A.1, the SPM 14 computes or retrieves from data storage the loudspeaker panning matrix, Pplw/spk, in order to enable loudspeaker playback of the reconstructed sound field over the loudspeaker array 20. The panning matrix, Pplw/spk, can be derived using any of the various panning techniques such as, for example, Vector Based Amplitude Panning (VBAP). At Step 5.A.2, the SPM 14 calculates the loudspeaker signals gspk(t) as gspk(t)=Pplw/spkgplw(t).
Another option is shown in the flow chart of
At Step 5.B.1, the SPM 14 computes bHOA-highres(t) in order to enable loudspeaker playback of the reconstructed sound field over the loudspeaker array 20. bHOA-highres(t) is a high-resolution HOA-domain representation of gplw(t) that is capable of expansion to an arbitrary HOA-domain order. The SPM 14 calculates bHOA-highres(t) as
b
HOA-highres(t)=Ŷplw-cs(t),
where Ŷplw is one of the Defined Matrices and the hat-operator on Ŷplw indicates it has been truncated to some HOA-order M.
At Step 5.B.2, the SPM 14 decodes bHOA-highres(t) to gspk(t) using HOA decoding techniques.
An alternative to loudspeaker play back is headphone play back. The operations for headphone play back are shown at Step 5.C of the flow chart of
At Step 5.C.1, the SPM 14 computes or retrieves from data storage the head-related impulse response matrix of filters, Pplw/hph(t), corresponding to the set of analysis plane wave directions in order to enable headphone playback of the reconstructed sound field over one or more of the headphones 22. The head-related impulse response (HRIR) matrix of filters, Pplw/hph(t), is derived from HRTF measurements.
At Step 5.C.2, the SPM 14 calculates the headphone signals ghph(t) as ghph(t)=Pplw/hph(t)gplw(t) using a filter convolution operation.
It will be appreciated by those skilled in the art that the basic HOA decoding for loudspeakers is given (in the frequency domain) by:
where:
Nspk is the number of loudspeakers,
ŶspkT is the transpose of the matrix whose columns are the values of the spherical harmonic functions, Ymn(θk, φk), where (rk, θk, φk) are the spherical coordinates for the k-th loudspeaker and the hat-operator on ŶspkT indicates it has been truncated to order M, and
bHOA is the play back signals represented in the HOA-domain.
The basic HOA decoding in three dimensions is a spherical-harmonic-based method that possesses a number of advantages which include the ability to reconstruct the sound field easily using various and arbitrary loudspeaker configurations. However, it will be appreciated by those skilled in the art that it also suffers from limitations related to both the encoding and decoding process. Firstly, as a finite number of sensors is used to observe the sound field, the encoding suffers from spatial aliasing at high frequencies (see N. Epain and J. Daniel, “Improving spherical microphone arrays,” in the Proceedings of the AES 124th Convention, May 2008). Secondly, when the number of loudspeakers that are used for playback is larger than the number of spherical harmonic components used in the sound field description, one generally finds deterioration in the fidelity of the constructed sound field (see A. Solvang, “Spectral impairment of two dimensional higher-order ambisonics,” in the Journal of the Audio Engineering Society, volume 56, April 2008, pp. 267-279).
In both cases, the limitations are related to the fact that an under-determined problem is solved using the pseudo-inverse method. In the case of the present disclosure, these limitations are circumvented in some instances using general principles of compressive sampling or ICA. With regard to compressive sampling, the applicants have found that using a plane-wave basis as a sparsity domain for the sound field and then solving one of the several convex programming problems defined above leads to a surprisingly accurate reconstruction of a recorded sound field. The plane wave description is contained in the defined matrix Tplw/mic.
The distance between the standard HOA solution and the compressive sampling solution may be controlled using, for example, the constraint
When ε2 is zero, the compressive sampling solution is the same as the standard HOA solution. The SPM 14 may dynamically set the value of ε2 according to the computed sparsity of the sound field.
With regard to applying ICA in the HOA-domain, the applicants have found that the application of statistical independence benefits greatly from the fact that the HOA-domain provides an instantaneous mixture of the recorded signals. Further, the application of statistical independence seems similar to compressive sampling in that it also appears to impose a sparsity on the solution.
As described above, it is possible to estimate the sparsity of the sound field using techniques of compressive sampling or techniques of ICA in the HOA-domain.
In
In the HOA case, the microphone gains are HOA-encoded up to order 4. The compressive sampling plane-wave analysis is performed using a frequency-domain technique which includes a sparsity constraint and using a basis of 360 plane waves evenly distributed in the horizontal plane. The values of ε1 and ε2 have been fixed to 10−2 and 2, respectively. In every case, the directions of the sound sources that define the sound field have been randomly chosen in the horizontal plane.
It is an advantage of the described embodiments that an improved and more robust reconstruction of a sound field is provided so that the sweet spot is larger; there is little, if any, degradation in the quality of the reconstruction when parameters defining the system are under-constrained; and the accuracy of the reconstruction improves as the number of the loudspeakers increases.
It will be appreciated by persons skilled in the art that numerous variations and/or modifications may be made to the disclosure as shown in the specific embodiments without departing from the scope of the disclosure as broadly described. The present embodiments are, therefore, to be considered in all respects as illustrative and not restrictive.
Number | Date | Country | Kind |
---|---|---|---|
2009904871 | Oct 2009 | AU | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/AU2010/001312 | 10/6/2010 | WO | 00 | 6/26/2012 |