1. Field of the Invention
The present invention relates to acoustics, and, in particular, to microphone arrays.
2. Description of the Related Art
A microphone array-based audio system typically comprises two units: an arrangement of (a) two or more microphones (i.e., transducers that convert acoustic signals (i.e., sounds) into electrical audio signals) and (b) a beamformer that combines the audio signals generated by the microphones to form an auditory scene representative of at least a portion of the acoustic sound field. This combination enables picking up acoustic signals dependent on their direction of propagation. As such, microphone arrays are sometimes also referred to as spatial filters. Their advantage over conventional directional microphones, such as shotgun microphones, is their high flexibility due to the degrees of freedom offered by the plurality of microphones and the processing of the associated beamformer. The directional pattern of a microphone array can be varied over a wide range. This enables, for example, steering the look direction, adapting the pattern according to the actual acoustic situation, and/or zooming in to or out from an acoustic source. All this can be done by controlling the beamformer, which is typically implemented in software, such that no mechanical alteration of the microphone array is needed.
There are several standard microphone array geometries. The most common one is the linear array. Its advantage is its simplicity with respect to analysis and construction. Other geometries include planar arrays, random arrays, circular arrays, and spherical arrays. Spherical arrays have several advantages over the other geometries. The beampattern can be steered to any direction in three-dimensional (3-D) space, without changing the shape of the pattern. Spherical arrays also allow full 3-D control of the beampattern. Notwithstanding these advantages, there is also one major drawback. Conventional spherical arrays typically require many microphones. As a result, their implementation costs can be relatively high.
Certain embodiments of the present disclosure are directed to microphone array-based audio systems that are designed to support representations of auditory scenes using second-order (or higher) harmonic expansions based on the audio signals generated by the microphone array. For example, in one embodiment, the present disclosure comprises a plurality of microphones (i.e., audio sensors) mounted on the surface of an acoustically rigid polyhedron. The number and location of the audio sensors on the polyhedron are designed to enable the audio signals generated by those sensors to be decomposed into a set of eigenbeams having at least one eigenbeam of order two (or higher). Beamforming (e.g., steering, weighting, and summing) can then be applied to the resulting eigenbeam outputs to generate one or more channels of audio signals that can be utilized to accurately render an auditory scene. As used in this specification, a full set of eigenbeams of order n refers to any set of mutually orthogonal beampatterns that form a basis set that can be used to represent any beampattern having order n or lower.
According to one embodiment, the present disclosure is a method for processing audio signals. A plurality of audio signals are received, where each audio signal has been generated by a different sensor of a microphone array. The plurality of audio signals are decomposed into a plurality of eigenbeam outputs, wherein each eigenbeam output corresponds to a different eigenbeam for the microphone array and at least one of the eigenbeams has an order of two or greater.
According to another embodiment, the present disclosure is a microphone comprising a plurality of sensors mounted in an arrangement, wherein the number and positions of sensors in the arrangement enable representation of a beampattern for the microphone as a series expansion involving at least one second-order eigenbeam.
According to yet another embodiment, the present disclosure is a method for generating an auditory scene. Eigenbeam outputs are received, the eigenbeam outputs having been generated by decomposing a plurality of audio signals, each audio signal having been generated by a different sensor of a microphone array, wherein each eigenbeam output corresponds to a different eigenbeam for the microphone array and at least one of the eigenbeam outputs corresponds to an eigenbeam having an order of two or greater. The auditory scene is generated based on the eigenbeam outputs and their corresponding eigenbeams.
Other aspects, features, and advantages of the present disclosure will become more fully apparent from the following detailed description, the appended claims, and the accompanying drawings in which like reference numerals identify similar or identical elements.
According to certain embodiments of the present disclosure, a microphone array generates a plurality of (time-varying) audio signals, one from each audio sensor in the array. The audio signals are then decomposed (e.g., by a digital signal processor or an analog multiplication network) into a (time-varying) series expansion involving discretely sampled, (at least) second-order (e.g., spherical) harmonics, where each term in the series expansion corresponds to the (time-varying) coefficient for a different three-dimensional eigenbeam. Note that a discrete second-order harmonic expansion involves zero-, first-, and second-order eigenbeams. The set of eigenbeams form an orthonormal set such that the inner-product between any two discretely sampled eigenbeams at the microphone locations, is ideally zero and the inner-product of any discretely sampled eigenbeam with itself is ideally one. This characteristic is referred to herein as the discrete orthonormality condition. Note that, in real-world implementations in which relatively small tolerances are allowed, the discrete orthonormality condition may be said to be satisfied when (1) the inner-product between any two different discretely sampled eigenbeams is zero or at least close to zero and (2) the inner-product of any discretely sampled eigenbeam with itself is one or at least close to one. The time-varying coefficients corresponding to the different eigenbeams are referred to herein as eigenbeam outputs, one for each different eigenbeam. Beamforming can then be performed (either in real-time or subsequently, and either locally or remotely, depending on the application) to create an auditory scene by selectively applying different weighting factors to the different eigenbeam outputs and summing together the resulting weighted eigenbeams.
In order to make a second-order harmonic expansion practicable, embodiments of the present disclosure are based on microphone arrays in which a sufficient number of audio sensors are mounted on the surface of a suitable structure in a suitable pattern. For example, in one embodiment, a number of audio sensors are mounted on the surface of an acoustically rigid sphere in a pattern that satisfies or nearly satisfies the above-mentioned discrete orthonormality condition. (Note that the present disclosure also covers embodiments whose sets of beams are mutually orthogonal without requiring all beams to be normalized.) As used in this specification, a structure is acoustically rigid if its acoustic impedance is much larger than the characteristic acoustic impedance of the medium surrounding it. The highest available order of the harmonic expansion is a function of the number and location of the sensors in the microphone array, the upper frequency limit, and the radius of the sphere.
Some polyhedral shapes can be good mathematical approximations to a sphere. For acoustic diffraction and scattering of sound around an acoustically rigid (or semi-rigid) object, the scalar acoustic wave equation and boundary conditions determine the acoustic field. The wave equation can be represented in spatial wavenumber frequency space as the Helmholtz equation. The Helmholtz equation recasts the standard time-domain wave equation via the Fourier transform into the frequency domain. The Helmholtz equation explicitly shows that acoustic wave propagation can be understood as a spatial low-pass filter. Thus, small deviations compared to the acoustic wavelength in shape of an acoustically rigid object perturb the soundfield in small ways due to the spatial low-pass nature of sound propagation. As a result, for low-order of spherical harmonics components, polyhedral approximations to the acoustically rigid sphere can result in sound fields components that are very close to those that would be found on an acoustically rigid sphere. Therefore, one can use a polyhedral surface as a good approximation to a spherical scattering object.
Each audio sensor 102 in system 100 generates a time-varying analog or digital (depending on the implementation) audio signal corresponding to the sound incident at the location of that sensor. Modal decomposer 104 decomposes the audio signals generated by the different audio sensors to generate a set of time-varying eigenbeam outputs, where each eigenbeam output corresponds to a different eigenbeam for the microphone array. These eigenbeam outputs are then processed by beamformer 106 to generate an auditory scene. In this specification, the term “auditory scene” is used generically to refer to any desired output from an audio system, such as system 100 of
In certain implementations of system 100, audio sensors 102 are mounted on the surface of an acoustically rigid sphere to form the microphone array.
Referring again to
Audio system 100 with the spherical array geometry of
Audio system 100 offers another advantage: it supports decomposition of the sound field into mutually orthogonal components, the eigenbeams (e.g., spherical harmonics) that can be used to reproduce the sound field. The eigenbeams are also suitable for wave field synthesis (WFS) methods that enable spatially accurate sound reproduction in a fairly large volume, allowing reproduction of the sound field that is present around the recording sphere. This allows all kinds of general real-time spatial audio applications.
A plane-wave G from the z-direction can be expressed according to Equation (1) as follows:
where:
in general, in spherical coordinates, r represents the distance from the origin (i.e., the center of the microphone array), φ is the angle in the horizontal (i.e., x-y) plane from the x-axis, and θ is the elevation angle in the vertical direction from the z-axis;
here the spherical coordinates r and θ determine the observation point;
k represents the wavenumber, equal to (ω/c, where c is the speed of sound and ω is the frequency of the sound in radians/second;
t is time;
i is the imaginary constant (i.e., √{square root over (−1)});
jn stands for the spherical Bessel function of the first kind of order n; and
Pn denotes the Legendre function.
G can be seen as a function that describes the behavior of a plane-wave from the z-direction with unity magnitude and referenced to the origin. An important characteristic of the spherical Bessel functions jn is that they converge towards zero if the order n is larger than the argument kr. Therefore, only the series terms up to approximately n=┌kr┐ have to be taken into account. In the following sections, the sound pressure around acoustically rigid and soft spheres will be derived.
Acoustically Rigid Sphere
From Equation (1), the sound velocity for an impinging plane-wave on the surface of a sphere can be derived using Euler's Equation. In theory, if the sphere is acoustically rigid, then the sum of the radial velocities of the incoming and the reflected sound waves on the surface of the sphere is zero. Using this boundary condition, the reflected sound pressure can be determined, and the resulting sound pressure field becomes the superposition of the impinging and the reflected sound pressure fields, according to Equation (2) as follows:
where:
a is the radius of the sphere;
a prime (′) denotes the derivative with respect to the argument; and
hn(2) represent the spherical Hankel function of the second kind of order n.
In order to find a general expression that gives the sound pressure at a point [rs, θsφs] for an impinging sound wave from direction [θ, φ], an addition theorem given by Equation (3) as follows is helpful:
where θ is the angle between the impinging sound wave and the radius vector of the observation point. Substituting Equation (3) into Equation (2) yields the normalized sound pressure around a spherical scatterer according to Equation (4) as follows:
where the coefficients bn are the radial-dependent terms given by Equation (5) as follows:
To simplify the notation further, spherical harmonics Y are introduced in Equation (4) resulting in Equation (6) as follows:
where the superscripted asterisk (*) denotes the complex conjugate.
In theory, for an acoustically soft sphere, the pressure on the surface is zero. Using this boundary condition, the sound pressure field around a soft spherical scatterer is given by Equation (7) as follows:
Setting r equal to a, one sees that the boundary condition is fulfilled. The more general expressions for the sound pressure, like Equations (4) or (6) do not change, except for using a different bn given by Equation (8) as follows:
where the superscript (s) denotes the soft scatterer case.
Spherical Wave Incidence
The general case of spherical wave incidence is interesting since it will give an understanding of the operation of a spherical microphone array for nearfield sources. Another goal is to obtain an understanding of the nearfield-to-farfield transition for the spherical array. Typically, a farfield situation is assumed in microphone array beamforming. This implies that the sound pressure has planar wave-fronts and that the sound pressure magnitude is constant over the array aperture. If the array is too close to a sound source, neither assumption will hold. In particular, the wave-fronts will be curved, and the sound pressure magnitude will vary over the array aperture, being higher for microphones closer to the sound source and lower for those further away. This can cause significant errors in the nearfield beampattern (if the desired pattern is the farfield beampattern).
A spherical wave can be described according to Equation (9) as follows:
where R is the distance between the source and the microphone, and A can be thought of as the source dimension. This brings two advantages: (a) G becomes dimensionless and (b) the problem of R=0 does not occur. With the source location described by the vector rl, the sensor location described by rs and θ being the angle between rl and rs, R may be given according to Equation (10) as follows:
R=√{square root over (rl2+rs2−2rlrs cos(θ))}
Equation (9) can be expressed in spherical coordinates according to Equation (11) as follows:
where rl is the magnitude of vector rl, and the time dependency has been omitted. If this sound field hits an acoustically rigid spherical scatterer, the superposition of the impinging and the reflected sound fields may be given according to Equation (12) as follows:
To show the connection to the farfield, assume krl>>1. The Hankel function can then be replaced by Equation (13) as follows:
Substituting Equation (13) in Equation (12) yields Equation (14) as follows:
Except for an amplitude scaling and a phase shift, Equation (14) equals the farfield solution, given in Equation (6). The next section will give more details about the transition from nearfield to farfield, based on the results presented above.
Modal beamforming is a powerful technique in beampattern design. Modal beamforming is based on an orthogonal decomposition of the sound field, where each component is multiplied by a given coefficient to yield the desired pattern. This procedure will now be described in more detail for a continuous spherical pressure sensor on the surface of an acoustically rigid sphere.
Assume that the continuous spherical microphone array has an aperture weighting function given by h(θ, φ, ω). Since this is a continuous function on a sphere, h can be expanded into a series of spherical harmonics according to Equation (15) as follows:
The array factor F, which describes the directional response of the array, is given by Equation (16) as follows:
where Ω symbolizes the 4π space. To simplify the notation, the array factor is first computed for a single mode n′m′, where n′ is the order and m′ is the degree. In the following analysis, a spherical scatterer with plane-wave incidence is assumed. Changes to adopt this derivation for a soft scatterer and/or spherical wave incidence are straightforward. For the plane-wave case, the array factor becomes Equation (17) as follows:
This means that the farfield pattern for a single mode is identical to the sensitivity function of this mode, except for a frequency-dependent scaling. The complete array factor can now be obtained by adding up all modes according to Equation (18) as follows:
Comparing Equation (18) with Equation (15), if C is normalized according to Equation (19) as follows:
then the array factor equals the aperture weighting function. This results in the following steps to implement a desired beampattern:
(1) Determine the desired beampattern h;
(2) Compute the series coefficients C;
(3) Normalize the coefficients according to Equation (19); and
(4) Apply the aperture weighting function of Equation (15) to the array using the normalized coefficients from step (3).
Equation (18) is a spherical harmonic expansion of the array factor. Since the spherical harmonics Y are mutually orthogonal, a desired beampattern can be easily designed. For example, if C00 and C10 are chosen to be unity and all other coefficients are set to zero, then the superposition of the omnidirectional mode (Y0) and the dipole mode)(Y10) will result in a cardioid pattern.
From Equation (19), the term inbn plays an important role in the beamforming process. This term will be analyzed further in the following sections. Also, the corresponding terms for a velocity sensor, a soft sphere, and spherical wave incidence will be given.
Acoustically Rigid Sphere
For an array on an acoustically rigid sphere, the coefficients bn are given by Equation (5). These coefficients give the strength of the mode dependent on the frequency.
Instead of mounting the array of sensors on the surface of the sphere, in alternative embodiments, one or more or even all of the sensors can be mounted at elevated positions over the surface of the sphere.
Acoustically Rigid Sphere with Velocity Microphones
Instead of using pressure sensors, velocity sensors could be used. From Equation (2), the radial velocity is given by Equation (20) as follows:
According to the boundary condition on the surface of an acoustically rigid sphere, the velocity for r=a will be zero, as indicated by Equation (20). The mode coefficients for the radial velocity sensors are given by Equation (21) as follows:
The difference between
For a fixed distance, the velocity increases with frequency. This is true as long as the distance is greater than one quarter of the wavelength. Since, at the same time, the energy is spread over an increasing number of modes, the mode magnitude does not roll off with a −6 dB slope, as is the case for the pressure modes.
Unfortunately, there are no true velocity microphones of very small sizes. Typically, a velocity microphone is implemented as an equalized first-order pressure differential microphone. Comparing this to Equation (20), the coefficients bn are then scaled by k. Since usually the pressure differential is approximated by only the pressure difference between two omnidirectional microphones, an additional scaling of 20 log(l) is taken into account, where l is the distance between the two microphones.
For a plane-wave impinging onto an acoustically soft sphere, the pressure mode coefficients become inbn(s). The magnitude of these is plotted in
Acoustically Soft Sphere with Velocity Microphones
For velocity microphones on the surface of a soft sphere, the mode coefficients are given by Equation (22) as follows:
The magnitude of these coefficients is plotted in
One way to implement an array with velocity sensors on the surface of a soft sphere might be to use vibration sensors that detect the normal velocity at the surface. However, the bigger problem will be to build a soft sphere. The term “soft” ideally means that the specific impedance of the sphere is zero. In practice, it will be sufficient if the impedance of the sphere is much less that the impedance of the medium surrounding the sphere. Since the specific impedance of air is quite low (Zs=ρoc=414 kg/m2s), building a soft sphere for airborne sound in essentially infeasible. However, a soft sphere can be implemented for underwater applications. Since water has a specific impedance of 1.48*106 kg/m2s, an elastic shell filled with air could be used as a soft sphere.
Spherical Wave Incidence
This section describes the case of a spherical wave impinging onto an acoustically rigid spherical scatterer. Since the pressure modes are the most practical ones, only they will be covered. The results will give an understanding of the nearfield-to-farfield transition.
According to Equation (12), the mode coefficients for spherical sound incidence are given by Equation (23) as follows:
b
n
(p)(ka,krs,krl)=khn(2)(kr1)bn(ka,krs) (23)
where the superscript (p) indicates spherical wave incidence. The mode coefficients are a scaled version of the farfield pressure modes.
In
Thus, for low krl, the scaling factor has a slope of about −6n dB, which compensates the 6n dB slope of bn and results in a constant. The appearance of the higher-order modes at low ka's becomes clear by keeping in mind that the modes correspond to a spherical harmonic decomposition of the sound pressure distribution on the surface of the sphere. The shorter the distance of the source from the sphere, the more unequal will be the sound pressure distribution even for low frequencies, and this will result in higher-order terms in the spherical harmonics series. This also means that, for short source distances, a higher directivity at low frequencies could be achieved since more modes can be used for the beampattern. However, this beampattern will be valid only for the designed source distance. For all other distances, the modes will experience a scaling that will result in the beampattern given by Equation (25) as follows:
The design distance is rl, while the actual source distance is denoted r1′.
To allow a better comparison, the mode magnitude in
For the high argument limit, it was already shown that the mode coefficients are equal to the plane-wave incidence. Comparing the spherical wave incidence for larger source distances (
So far, only a continuous array has been treated. On the other hand, an actual array is implemented using a finite number of sensors corresponding to a sampling of the continuous array. Intuitively, this sampling should be as uniform as possible. Unfortunately, there exist only five possibilities to divide the surface of a sphere in equivalent areas. These five geometries, which are known as regular polyhedrons or Platonic Solids, consist of 4, 6, 8, 12, and 20 faces, respectively. Another geometry that comes close to a regular division is the so-called truncated icosahedron, which is an icosahedron having vertices cut off. Thus, the term “truncated.” This results in a solid consisting of 20 hexagons and 12 pentagons. A microphone array based on a truncated icosahedron is referred to herein as a TIA (truncated icosahedron array).
Other possible microphone arrangements include the center of the faces (20 microphones) of an icosahedron or the center of the edges of an icosahedron (30 microphones). In general, the more microphones used, the higher will be the upper maximum frequency. On the other hand, the cost usually increases with the number of microphones.
Referring again to the TIA of
where c is the speed of sound. For a sphere with radius a=5 cm, this results in an upper frequency limit of 4.7 kHz. In practice, a slightly higher maximum frequency can be expected since most microphone distances are less than 0.73a, namely 0.65a. The upper frequency limit can be increased by reducing the radius of the sphere. On the other hand, reducing the radius of the sphere would reduce the achievable directivity at low frequencies. Therefore, a radius of 5 cm is a good compromise.
Equation (15) gives the aperture weighting function for the continuous array. Using discrete elements, this function will be sampled at the sensor location, resulting in the sensor weights given by Equation (27) as follows:
where the index s denotes the s-th sensor. The array factor given in Equation (16) now turns into a sum according to Equation (28) as follows:
With a discrete array, spatial aliasing should be taken into account. Similar to time aliasing, spatial aliasing occurs when a spatial function, e.g., the spherical harmonics, is undersampled. For example, in order to distinguish 16 harmonics, at least 16 sensors are needed. In addition, the positions of the sensors are important. For this description, it is assumed that there are a sufficient number of sensors located in suitable positions such that spatial aliasing effects can be neglected. In that case, Equation (28) will become Equation (29) as follows:
which requires Equation (30) to be (at least substantially) satisfied as follows:
To account for deviations, a correction factor αnm can be introduced. For best performance, this factor should be close to one for all n,m of interest.
The white noise gain (WNG), which is the inverse of noise sensitivity, is a robustness measure with respect to errors in the array setup. These errors include the sensor positions, the filter weights, and the sensor self-noise. The WNG as a function of frequency is defined according to Equation (31) as follows:
The numerator is the signal energy at the output of the array, while the denominator can be seen as the output noise caused by the sensor self-noise. The sensor noise is assumed to be independent from sensor to sensor. This measure also describes the sensitivity of the array to errors in the setup.
The goal is now to find some general approximations for the WNG that give some indications about the sensitivity of the array to noise, position errors, and magnitude and phase errors. To simplify the notations, the look direction is assumed to be in the z-direction. The numerator can then be found from Equation (28) according to Equation (32) as follows:
where N is the highest-order mode used for the beamforming. The number of all spherical harmonics up to Nth order is (N+1)2. The denominator is given by Equation (27) according to Equation (33) as follows:
Given Equations (32) and (33), a general prediction of the WNG is difficult. Two special cases will be treated here: first, for a desired pattern that has only one mode and, second, for a superdirectional pattern for which bN<<bN-1 (compare
If only mode N is present in the pattern, the WNG becomes Equation (34) as follows:
For the omnidirectional (zero-order) mode, the numerator of Equation (34) equals M. Since b0 is unity for low frequency (compare
Another coarse approximation can be given for the superdirectional case when bN<<bN-1. In this case, the sum over the (N+1)2 modes in the nominator is dominated by the N-th mode and, using Equations (32) and (33), the WNG results in Equation (35) as follows:
Equation (35) can be further simplified if the term Cn√(2n+1/(4π)) is constant for all modes. This would result in a sinc-shaped pattern. In this case, the WNG becomes Equation (36) as follows:
This result is similar to Equation (34), except that the WNG is increased by a factor of (N+1)2. This is reasonable, since every mode that is picked up by the array increases the output signal level.
This section will give two suggestions on how to get the coefficients Cnm that are used to compute the sensor weights hs according to Equation (27). The first approach implements a desired beampattern h(θ,φ,ω), while the second one maximizes the directivity index (DI). There are many more ways to design a beampattern. Both methods described below will assume a look direction towards θ=0. After those two methods, the subsequent section describes how to turn the pattern, e.g., to steer the main lobe to any desired direction in 3-D space.
Implementing a Desired Beampattern
For a beampattern with look direction θ=0 and rotational symmetry in φ-direction, the coefficients Cnm can be computed according to Equation (37) as follows:
The question remains how to choose the pattern h itself. This depends very much on the application for which the array will be used. As an example, Table 1 gives the coefficients Cn in order to get a hypercardioid pattern of order n, where the pattern h is normalized to unity for the look direction. The coefficients are given up to third order.
If the pattern from
Instead of choosing a constant pattern, it may make more sense to design for a constant WNG. The quality of the sensors used and the accuracy with which the array is built determine the allowable minimum WNG that can be accepted. A reasonable value is a WNG of −10 dB. Using hypercardioid patterns results in the following frequency bands: 50 Hz to 400 Hz first-order, 400 Hz to 900 Hz second-order, and 900 Hz to 5 kHz third-order. The upper limit is determined by the TIA and the radius of the sphere of 5 cm.
Maximizing the Directivity Index
This section describes a method to compute the coefficients C that result in a maximum achievable directivity index (DI). A constraint for the white noise gain (WNG) is included in the optimization.
The directivity index is defined as the ratio of the energy picked up by a directive microphone to the energy picked up by an omnidirectional microphone in an isotropic noise field, where both microphones have the same sensitivity towards the look direction. If the directive microphone is operated in a spherically isotropic noise field, the DI can be seen as the acoustical signal-to-noise improvement achieved by the directive microphone.
For an array, the DI can be written in matrix notation according to Equation (38) as follows:
where the frequency dependence is omitted for better readability. The vector h contains the sensor weights at frequency ω0 according to Equation (39) as follows:
h=[h
0
,h
1
,h
2
, . . . ,h
M-1]T. (39)
The superscript T denotes “transpose.” G0 is a vector describing the source array transfer function for the look direction at ω0. For a pressure sensor close to an acoustically rigid sphere, these values can be computed from Equation (6). R is the spatial cross-correlation matrix. The matrix elements are defined by Equation (40) as follows:
In matrix notation, the WNG is given by Equation (41) as follows:
The last required piece is to express the sensor weights using the coefficients Cnm. This is provided by Equation (27), which can again be written in matrix notation according to Equation (42) as follows:
h=Ac. (42)
The vector c contains the spherical harmonic coefficients Cnm, for the beampattern design. This is the vector that has to be determined. According to Equations (27) and (19), the coefficients of A for the acoustically rigid sphere case with plane-wave incidence are given by Equation (43) as follows:
The notation assumes that only the spherical harmonics of degree 0 are used for the pattern. If necessary, any other spherical harmonic can be included. The goal is now to maximize the DI with a constraint on the WNG. This is the same as minimizing the function 1/ƒ, where the Lagrange multiplier ε is used to include the constraint, according to Equation (44) as follows:
One ends up with the following Equation (45), which has to be maximized with respect to the coefficient vector c:
where I is the unity matrix. Equation (45) is a generalized eigenvalue problem. Since A, R, and I are full rank, the solution is the eigenvector corresponding to Equation (46) as follows:
max{λ((AH(R+εI)A)−1(AHPA))}, (46)
where λ(·) means “eigenvalue from.” Unfortunately, Equation 45 cannot be solved for ε. Therefore, one way to find the maximum DI for a desired WNG is as follows:
Step (1): Find the solution to Equation (46) for an arbitrary ε.
Step (2): From the resulting vector c, compute the WNG.
Step (3): If the WNG is larger than desired, then return to Step (1) using a smaller ε. If the WNG is too small, then return to Step (1) using a larger ε. If the WNG matches the desired WNG, then the process is complete.
Notice that the choice of ε=0 results in the maximum achievable DI. On the other hand, ε→∞ results in a delay-and-sum beamformer. The latter one has the maximum achievable WNG, since all sensor signals will be summed up in phase, yielding the maximum output signal. ƒ(c) depends monotonically on ε.
Rotating the Directivity Pattern
After the pattern is generated for the look direction θ=0, it is relatively straightforward to turn it to a desired direction. Using Equation (27), the weights for a φ-symmetric pattern are given by Equation (47) as follows:
Substituting Equation (3) in Equation (47), one ends up with Equation (48) as follows:
Comparing Equation (48) with Equation (27), one yields for the new coefficients Equation (49) as follows:
Equation (49) enables control of the θ and φ directions independently. Also the pattern itself can be implemented independently from the desired look direction.
This section provides a layout for the beamformer based on the theory described in the previous sections. Of course, the spherical array can be implemented using a filter-and-sum beamformer as indicated in Equation (28). The filter-and-sum approach has the advantage of utilizing a standard technique. Since the spherical array has a high degree of symmetry, rotation can be performed by shifting the filters. For example, the TIA can be divided into 60 very similar triangles. Only one set of filters is computed with a look direction normal to the center of one triangle. Assigning the filters to different sensors allows steering the array to 60 different directions.
Alternatively, a scheme based on the structure of the modal beamformer of
Referring again to
In audio system 100 of
Modal Decomposer
Decomposer 104 of
the array output F given by Equation (52) as follows:
F
n′m′(θ,φ)=4πin′bn′(ka)Re{Yn′m′(θ,φ)} (52)
If the sensitivity equals the imaginary part of a spherical harmonic, then the beampattern of the corresponding array factor will also be the imaginary part of this spherical harmonic. The output spherical harmonic is frequency weighted. To compensate for this frequency dependence, compensation unit 110 of
For a practical implementation, the continuous spherical sensor is replaced by a discrete spherical array. In this case, the integrals in the equations become sums. As before, the sensor should substantially satisfy (as close as practicable) the orthonormality property given by Equation (53) as follows:
where S is the number of sensors, and [θs, φs] describes their positions ps. If the right side of Equation (53) does not result to unity for n=n′ and m=m′, then a simple scaling weight should be inserted to compensate this error. In general, for a spheroidal array, the orthonormality property can be represented by Equation (53a) as follows:
Deviations from exact equality in Equation (53a) are due to the finite spatial sampling geometry of the microphones on the sphere. There are some specific finite spatial sampling geometries that can exactly satisfy the equality in the orthonormality property of Equation (53) up to an certain order of the spherical harmonics. However, in practice, it is not necessary to fulfill exact equality in the orthonormality property, since, in reality, the terms where n=n′ and m=m′ can be made small enough so that their error contribution results in a negligible distortion to the overall desired beamformer spatial output. Allowing for some small deviation from exact equality in the orthonormality property allows the designer to have some freedom in microphone array geometry on the sphere. Also, real-world microphone sensors have manufacturing magnitude and phase mismatch as well as self-noise. Thus, orthonormality property errors due to the microphone geometric positions having the same magnitude or smaller than real-world transducer mismatch and noise should have negligible impact on the beamformer. It can also be expected that the minor diffraction and scattering effects from the edges and vertices of a soft or rigid polyhedral baffle would also result in a sound field where the orthonormality property of Equation (53) would be slightly violated as in Equation (53a). For example, if the (n=n′ and m=m′) terms are K-orders of magnitude higher in power than the (n≠n′ and/or m≠m′) terms then the error terms will contribute 10*K dB below the main eigenbeam powers. Thus, if K=6, the error terms would be 60 dB down and therefore not contribute enough of a perturbation to significantly impact the performance of the overall desired beamformer. A design that has error terms that are more than 30 dB down would most likely be practically acceptable.
f
d
=Ys, (54)
where fd describes the output of the decomposer, s is a vector containing the sensor signals, and Y is a (2N+1)2×S matrix, where N is the highest order in the spherical harmonic expansion. The columns of Y give the real and imaginary parts of the spherical harmonics for the corresponding sensor position. Table 2 shows the convention that is used for numbering the rows of matrix Y up to fifth-order spherical harmonics, where n corresponds to the order of the spherical harmonic, m corresponds to the degree of the spherical harmonic, and the label nm identifies the row number. For a fifth-order expansion, matrix Y has (2N+1)2 or 36 rows, labeled in Table 2 from nm=0 to nm=35. For example, as indicated in Table 2, Row nm=21 in matrix Y corresponds to the real part (Re) of the spherical harmonic of order (n=4) and degree (m=3), while Row nm=22 corresponds to the imaginary part (Im) of that same spherical harmonic. Note that the zero-degree (m=0) spherical harmonics have only real parts.
Steering Unit
Compensation Unit
As described previously, the output of the decomposer is frequency dependent. Frequency-response correction, as performed by generic correction unit 1710 of
Summation Unit
Summation unit 112 of
The three major design parameters for a spherical microphone array are:
The number of audio sensors (S);
The radius of the sphere (a); and
The location of the sensors.
The parameters S and a determine the array properties of which the most important ones are:
The white noise gain (WNG), which indirectly specifies the lower end of the operating frequency range;
The upper frequency limit, which is determined by spatial aliasing; and
The maximum order of the beampattern (spherical harmonic) that can be realized with the array (this is also dependent on the WNG). This will also determine the maximum directivity that can be achieved with the array.
From a performance point of view, the best choices are big spheres with large numbers of sensors. However, the number of sensors may be restricted in a real-time implementation by the ability of the hardware to perform the required processing on all of the signals from the various sensors in real time. Moreover, the number of sensors may be effectively limited by the capacity of available hardware. For example, the availability of 32-channel processors (24-channel processors for mobile applications) may impose a practical limit on the number of sensors in the microphone array. The following sections will give some guidance to the design of a practical system.
Upper Frequency Limit
In order to find the upper frequency limit, depending on a and S, the approximation of Equation (56), which is based on the sampling theorem, can be used as follows:
The square-root term gives the approximate sensor distance, assuming the sensors are equally distributed and positioned in the center of a circular area. The speed of sound is c.
Maximum Directivity Index
The minimum number of sensors required to pick up all harmonic components is (N+1)2, where N is the order of the pattern. This means that, for a second-order array, at least nine elements are needed and, for a third-order array, at least 16 sensors are needed to pick up all harmonic components. These numbers assume the ability to generate an arbitrary beampattern of the given order. If the beampatterns can be restricted somehow, e.g., the look direction is fixed or needs to be steered only in one plane, then the number of sensors can be reduced since, in those situations, all of the harmonic components (i.e., the full set of eigenbeams) are not needed.
Robustness Measure
A general expression of the white noise gain (WNG) as a function of the number of microphones and radius of the sphere cannot be given, since it depends on the sensor locations and, to a great extent, on the beampattern. If the beampattern consists of only a single spherical harmonic, then an approximation of the WNG is given by Equation (57) as follows:
WNG(a,S,ƒ)˜S2|bn(a,ƒ)|2. (57)
The factor bn represents the mode strength (see
Table 3 shows the gain that is achieved due to the number of sensors. It can be seen that the gain in general is quite significant, but increases by only 6 dB when the number of sensors is doubled.
Preferred Array Parameters
To provide all beampatterns up to order three, the minimum number of sensors is 16. For a mobile (e.g., laptop) real-time solution, given currently available hardware, the maximum number of sensors is assumed to be 24. For an upper frequency limit of at least 5 kHz, the radius of the sphere should be no larger than about 4 cm. On the other hand, it should not be much smaller because of the WNG. A good compromise seems to be an array with 20 sensors on a sphere with radius of 37.5 mm (about 1.5 inches). A good choice for the sensor locations is the center of the faces of an icosahedron, which would result in regular sensor spacing on the surface of the sphere. Table 4 identifies the sensor locations for one possible implementation of the icosahedron sampling scheme. Another configuration would involve 24 sensors arranged in an “extended icosahedron” scheme. Table 5 identifies the sensor locations for one possible implementation of the extended icosahedron sampling scheme. Another possible configuration is based on a truncated icosahedron scheme of
One problem that exists to at least some extent with each of these configurations relates to spatial aliasing. At higher frequencies, a continuous soundfield cannot be uniquely represented by a finite number of sensors. This causes a violation of the discrete orthonormality property that was discussed previously. As a result, the eigenbeam representation becomes problematic. This problem can be overcome by using sensors that integrate the acoustic pressure over a predefined aperture. This integration can be characterized as a “spatial low-pass filter.”
Spherical Array with Integrating Sensors
Spatial aliasing is a serious problem that causes a limitation of usable bandwidth. To address this problem, a modal low-pass filter may be employed as an anti-aliasing filter. Since this would suppress higher-order modes, the frequency range can be extended. The new upper frequency limit would then be caused by other factors, such as the computational capability of the hardware, the A/D conversion, or the “roundness” of the sphere. It should also be noted here that modal low-pass spatial averaging also improves the approximation of using a polyhedral scattering surface to that of a perfect acoustically rigid spherical baffle. This is accomplished by the modal low-pass filter further reducing higher-order spatial wave components that would be excited by the edges of the vertices of the polygons that represent the polyhedral surface.
One way to implement a modal low-pass filter is to use microphones with large membranes. These microphones act as a spatial low-pass filter. For example, in free field, the directional response of a microphone with a circular piston in an infinite baffle is given by Equation (58) as follows:
where J is the Bessel function, a is the radius of the piston, and θ is the angle off-axis. This is referred to as a spatial low-pass filter since, for small arguments (ka sin θ<<1), the sensitivity is high, while, for large arguments, the sensitivity goes to zero. This means, that only sound from a limited region is recorded. Generally this behavior is true for pressure sensors with a significant (relative to the acoustic wavelength) membrane size. The following provides a derivation for an expression for a conformal patch microphone on the surface of an acoustically rigid sphere.
The microphone output M will be the integration of the sound pressure over the microphone area. Assuming a constant microphone sensitivity m0 over the microphone area, the microphone output M is then given by Equation (59) as follows:
where Ωs symbolizes the integration over the microphone area, and G is the sound pressure at location [θs, φs] on the surface of the sphere caused by plane wave incidence from direction [θ, φ], assuming plane wave incidence with unity magnitude. Simplifying Equation (59) yields Equation (60) as follows:
Equation (60) assumes an active microphone area from θ=0, . . . ,θ0 and φ=0, . . . , 2π. Mnm is the sensitivity to mode n,m.
Array of Finite-Sized Sensors
Ideally, a spherical array that works in combination with the modal beamformer of
Unfortunately, it is difficult if not impossible to solve this equation analytically. An alternative approach is to use common sense to come up with a sensor layout and then check if Equation (70) is (at least substantially) satisfied.
For a discrete spherical sensor array based on the 24-element “extended icosahedron” of Table 5, one issue relates to the choice of microphone shape.
Practical Implementation of Patch Microphones
This section describes a possible physical implementation of the spherical array using patch microphones. Since these microphones have almost arbitrary shape and follow the curvature of the sphere, patch microphones are preferred over conventional large-membrane microphones. Nevertheless, conventional large-membrane microphones are a good compromise since they have very good noise performance, they are a proven technology, and they are easier to handle.
One solution might come with a material called EMFi. See J. Lekkala and M. Paajanen, “EMFi-New electret material for sensors and actuators,” Proceedings of the 10th International Symposium on Electrets, Delphi (IEEE, Piscataway, N.J., 1999), pp. 743-746, the teachings of which are incorporated herein by reference. EMFi is a charged cellular polymer that shows piezo-electric properties. The reported sensitivity of this material to air-borne sound is about 0.7 mV/Pa. The polymer is provided as a foil with a thickness of 70 μm. In order to use it as a microphone, metalization is applied on both sides of the foil, and the voltage between these electrodes is picked up. Since the material is a thin polymer, it can be glued directly onto the surface of the sphere. Also the shape of the sensor can be arbitrary. A problem might be encountered with the sensor self-noise. An equivalent noise level of about 50 dBA is reported for a sensor of size of 3.1 cm2.
Both arrays—the point sensor array and the patch sensor array—can be combined using a simple first- or second-order crossover network. The crossover frequency will depend on the array dimensions. For a 24-element array with a radius of 37.5 mm, a crossover frequency of 3 kHz could be chosen if all modes up to third order are to be used. The crossover frequency is a compromise between the WNG, the aliasing, and the order of the crossover network. Concerning the WNG, the patch sensor array should be used only if there is maximum WNG from the array (e.g., at about 5 kHz). However, at this frequency, spatial aliasing already starts to occur. Therefore, significant attenuation for the point sensor array is desired at 5 kHz. If it is desirable to keep the order of the crossover low (first or second order), the crossover frequency should be about 3 kHz.
There are other ways to implement modal low-pass filters. For example, instead of using a continuous patch microphone, a “sampled patch microphone” can be used. As represented in
Alternative Approaches to Overcome Spatial Aliasing
The previous sections describe the use of patch sensors or sampled patch sensors to address the spatial aliasing problem. Although from a technical point of view, this is an optimal solution, it might cause problems in the implementation. These problems relate to either the difficulty involved in building the patch sensors for a continuous patch solution or the possibly large number of sensors for the sampled patch solution. This section describes two other approaches: (a) using nested spherical arrays and (b) exploiting the natural diffraction of the sphere.
In
A particularly efficient implementation is possible if all of the sensor arrays have their sensors located at the same set of spherical coordinates. In this case, instead of using a different beamformer for each different array, a single beamformer can be used for all of the arrays, where the signals from the different arrays are combined, e.g., using a crossover network, before the signals are fed into the beamformer. As such, the overall number of input channels can be the same as for a single-array embodiment having the same number of sensors per array.
According to another approach, instead of using the entire sensor array to cover the high frequencies, fewer than all—and as few as just a single one—of the sensors in the array could be used for high frequencies. In a single-sensor implementation, it would be preferable to use the microphone closest to the desired steering angle. This approach exploits the directivity introduced by the natural diffraction of the sphere. For an acoustically rigid sphere, this is given by Equation 6.
As shown in
In order to produce a substantially constant sound pressure field, enclosure 2906 is kept as small as practicable (e.g., 180 mm3), where the dimensions of the volume are preferably much less than the wavelength of the maximum desired measurement frequency. To keep the errors as low as possible for higher frequencies, enclosure 2906 should be built symmetrically. As such, enclosure 2906 is preferably cylindrical in shape, where reference sensor 2808 is configured at one end of the cylinder, and the open end of probe 2902 forms the other end of the cylinder.
The size of the microphones 102 used in array 200 determines the minimum diameter of cylindrical enclosure 2906. Since a perfect frequency response is not necessarily a goal, the same microphone type can be used for both the array and the reference sensor. This will result in relatively short equalization filters, since only slight variations are expected between microphones.
In order to position calibration probe 2902 precisely above the array sensor 102, some kind of indexing can be used on the array sphere. For example, the sphere can be configured with two little holes (not shown) on opposite sides of each sensor, which align with two small pins (not shown) on the probe to ensure proper positioning of the probe during calibration processing.
Calibration probe 2902 enables the sensors of a microphone array, like array 200 of
The present disclosure has been described primarily in the context of spherical and other spheroidal arrays. Alternatively, microphone arrays of the present disclosure can be implemented in the context of polyhedral arrays that can be built to approximate spherical and other spheroidal arrays.
Microphone arrays can also be implemented using other polyhedrons that satisfy the orthonormality property, such as (without limitation) icosahedrons, truncated icosahedrons, and dodecahedrons. Note that the Pentakis dodecahedron is a dual polyhedron to the truncated icosahedron.
Previously it was discussed that one could use multiple microphones to form composite output signals for the spherical microphone array to reduce higher-frequency spatial aliasing while also simultaneously increasing the effective signal-to-noise ratio of the microphone signal by averaging multiple microphones to form the composite microphone signal. Using a polyhedral base geometry has the advantage that one could place the multiple microphones on flat (rigid or flexible) PCBs and mount these PCBs onto the flat polygonal sides that form the polyhedral structure. Using PCB technology and surface-mounted MEMS microphones and associated electronics can greatly simplify the construction of the 3D array and thereby result in a design that costs less to manufacture.
The physical microphone design results in some physical limitations that are made to optimize the acoustic performance of the microphone. Designing a condenser MEMS microphone with as high an SNR as possible usually translates to a limitation of the dynamic range of the microphone. Reciprocally, stiffening the microphone diaphragm to increase the dynamic range lowers the signal level created by transducing an acoustic signal. Therefore, it could be beneficial to design the MEMS microphone using multiple microphone elements where one or more elements have high dynamic range (but have higher self-noise) and one or more other elements maximize the SNR but have limited dynamic range. By combining multiple MEMS microphones to increase SNR and diminish spatial aliasing, it would be possible to provide a subsection of the MEMS elements that use both high dynamic range microphones and high SNR microphones. The beamforming signal processing could then be designed to select combinations of the high dynamic range microphones when the signal level exceeds some threshold level and use a subsection of the high SNR microphones when the acoustic level goes below some (possibly different) threshold level. This transition could be done gradually over some defined region of acoustic level.
In one possible implementation, a single high-SPL (sound pressure level) microphone element is place at the center of a polygonal side among a cluster of other lower-SPL elements, where the single high-SPL element constitutes one sub-array of elements. In another possible implementation, different microphone elements can have different high-pass characteristics. For instance, a microphone having a 200 Hz high-pass response could be placed on the array and then chosen to mitigate wind noise by having a natural high-pass. Alternatively, if a high dynamic range microphone is employed, the high-pass filtering could be implemented in a digital processor.
There might be conditions were one would want to form a larger aggregate composite output than being limited to one polygon that defines one side of the polyhedron. Thus, one could average over neighbor polygonal sections or subsections of neighboring polygons. For example, one or more field-programmable gate arrays (FPGAs) could be used to combine the outputs from digital output microphones to form all the patch outputs that then are fed to the eigenbeam-former. Digital microphones that allow serial connectivity can self organize and stream a serial bit stream to an FPGA. For lower-order spherical harmonics, one could use large aggregate combinations to significantly improve the SNR of the aggregate signal. Since the frequency responses of the eigenbeams are generally high-pass in nature, having the SNR of the aggregate array increase as the frequency is lowered naturally combats the standard SNR loss of the eigenbeams due to the high-pass nature.
Eigenbeam-forming requires at least (N+1)̂2 microphones for N-th order processing. When using patch subarrays, the number of microphones will most likely be much larger that the number of signals needed for the eigenbeam-former. It would most likely be useful then to do some preprocessing that combines the microphone signals from the patches in some predetermined way so as to minimize the number of signals that have to be transmitted to the eigenbeam-former. The preprocessing could for instance combine patches in different ways depending on frequency, where more patches and microphones are used for lower frequencies. One could also allow some dynamic control of the weighting to allow for the elimination of noisy or failed microphones or to change the weighting of the individual microphone signals from patches to allow for dynamic control of the aggregate signals that are then fed to the eigenbeam-former.
One could go further and actually use local processing to form the eigenbeams. By computing the eigenbeams, it would be possible to reduce the number of independent data signals needed to do the beamforming and thereby reduce the bit-rate or communication bandwidth to the modal beamformer that is the final step in eigenbeam-forming.
Referring again to
In one implementation, modal decomposer 104 and beamformer 106 are co-located and operate together in real time. In this case, the eigenbeam outputs generated by modal decomposer 104 are provided immediately to beamformer 106 for use in generating one or more auditory scenes in real time. The control of the beamformer can be performed on-site or remotely.
In another implementation, modal decomposer 104 and beamformer 106 both operate in real time, but are implemented in different (i.e., non-co-located) nodes. In this case, data corresponding to the eigenbeam outputs generated by modal decomposer 104, which is implemented at a first node, are transmitted (via wired and/or wireless connections) from the first node to one or more other remote nodes, within each of which a beamformer 106 is implemented to process the eigenbeam outputs recovered from the received data to generate one or more auditory scenes.
In yet another implementation, modal decomposer 104 and beamformer 106 do not both operate at the same time (i.e., beamformer 106 operates subsequent to modal decomposer 104). In this case, data corresponding to the eigenbeam outputs generated by modal decomposer 104 are stored, and, at some subsequent time, the data is retrieved and used to recover the eigenbeam outputs, which are then processed by one or more beamformers 106 to generate one or more auditory scenes. Depending on the application, the beamformers may be either co-located or non-co-located with the modal decomposer.
Each of these different implementations is represented generically in
In certain applications, a single beamformer, such as beamformer 106 of
This specification describes the theory behind a spherical microphone array that uses modal beamforming to form a desired spatial response to incoming sound waves. It has been shown that this approach brings many advantages over a “conventional” array. For example, (1) it provides a very good relation between maximum directivity and array dimensions (e.g., DImax of about 16 dB for a radius of the array of 5 cm); (2) it allows very accurate control over the beampattern; (3) the look direction can be steered to any angle in 3-D space; (4) a reasonable directivity can be achieved at low frequencies; and (5) the beampattern can be designed to be frequency-invariant over a wide frequency range.
This specification also proposes an implementation scheme for the beamformer, based on an orthogonal decomposition of the sound field. The computational costs of this beamformer are less expensive than for a comparable conventional filter-and-sum beamformer, yet yielding a higher flexibility. An algorithm is described to compute the filter weights for the beamformer to maximize the directivity index under a robustness constraint. The robustness constraint ensures that the beamformer can be applied to a real-world system, taking into account the sensor self-noise, the sensor mismatch, and the inaccuracy in the sensor locations. Based on the presented theory, the beamformer design can be adapted to optimization schemes other than maximum directivity index.
The spherical microphone array has great potential in the accurate recording of spatial sound fields where the intended application is for multichannel or surround playback. It should be noted that current home theatre playback systems have five or six channels. Currently, there are no standardized or generally accepted microphone-recording methods that are designed for these multichannel playback systems. Microphone systems that have been described in this specification can be used for accurate surround-sound recording. The systems also have the capability of supplying, with little extra computation, many more playback channels. The inherent simplicity of the beamformer also allows for a computationally efficient algorithm for real-time applications. The multiple channels of the orthogonal modal beams enable matrix decoding of these channels in a simple way that would allow easy tailoring of the audio output for any general loudspeaker playback system that includes monophonic up to in excess of sixteen channels (using up to third-order modal decomposition). Thus, the spherical microphone systems described here could be used for archival recording of spatial audio to allow for future playback systems with a larger number of loudspeakers than current surround audio systems in use today.
Although the present disclosure has been described primarily in the context of a microphone array comprising a plurality of audio sensors mounted on the surface of an acoustically rigid sphere, the present disclosure is not so limited. In reality, no physical structure is ever perfectly acoustically rigid or perfectly spherical, and the present disclosure should not be interpreted as having to be limited to such ideal structures. Moreover, the present disclosure can be implemented in the context of shapes other than spheres that support orthogonal harmonic expansion, such as “spheroidal” oblates and prolates, where, as used in this specification, the term “spheroidal” also covers spheres. In general, the present disclosure can be implemented for any shape that supports orthogonal harmonic expansion of order two or greater. It will also be understood that certain deviations from ideal shapes are expected and acceptable in real-world implementations. The same real-world considerations apply to satisfying the discrete orthonormality condition applied to the locations of the sensors. Although, in an ideal world, satisfaction of the condition corresponds to the mathematical delta function, in real-world implementations, certain deviations from this exact mathematical formula are expected and acceptable. Similar real-world principles also apply to the definitions of what constitutes an acoustically rigid or acoustically soft structure.
The present disclosure may be implemented as circuit-based processes, including possible implementation on a single integrated circuit. As would be apparent to one skilled in the art, various functions of circuit elements may also be implemented as processing steps in a software program. Such software may be employed in, for example, a digital signal processor, micro-controller, or general-purpose computer.
The present disclosure can be embodied in the form of methods and apparatuses for practicing those methods. The present disclosure can also be embodied in the form of program code embodied in tangible media, such as floppy diskettes, CD-ROMs, hard drives, or any other machine-readable non-transitory storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the disclosure. The present disclosure can also be embodied in the form of program code, for example, whether stored in a non-transitory storage medium or loaded into and/or executed by a machine, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing the disclosure. When implemented on a general-purpose processor, the program code segments combine with the processor to provide a unique device that operates analogously to specific logic circuits.
Unless explicitly stated otherwise, each numerical value and range should be interpreted as being approximate as if the word “about” or “approximately” preceded the value of the value or range.
It will be further understood that various changes in the details, materials, and arrangements of the parts which have been described and illustrated in order to explain the nature of this disclosure may be made by those skilled in the art without departing from the principle and scope of the disclosure as expressed in the following claims. Although the steps in the following method claims, if any, are recited in a particular sequence with corresponding labeling, unless the claim recitations otherwise imply a particular sequence for implementing some or all of those steps, those steps are not necessarily intended to be limited to being implemented in that particular sequence.
The subject matter of this application is related to the subject matter of U.S. Pat. No. 7,587,054, U.S. patent application Ser. No. 12/501,741, and U.S. patent application Ser. No. 13/516,842, the teachings of all of which are incorporated herein by reference in their entirety.