This disclosure relates generally to audio processing, and more specifically to soundstage-conserving channel summation.
Audio content is typically designed for stereo playback. This assumption is problematic for playback solutions which do not conform to the expectations implied by this convention. Two such cases are mono speakers and multiple speakers arrayed in an unconstrained mesh. In both cases, a common solution is to sum both left and right channels of a stereo audio signal together, which results in the loss of negatively correlated information. Furthermore, in the case of the unconstrained mesh, the lack of knowledge about the mesh geometry results in a lost opportunity for preserving the soundstage information encoded in the original content.
Embodiments relate to using nonlinear unitary filter-banks to provide soundstage-conserving channel summation and irregular mesh diffusion of audio signals. Mono summation via orthogonal correlation transform (also referred to herein as “MON-OCT”) provides for soundstage-conserving channel summation. Applying the MON-OCT to an audio signal may include using a multi-input, multi-output nonlinear unitary filter-bank which may be implemented in the time-domain for minimal latency and optimal transient response.
In some embodiments, a multi-band implementation of the mono summation via orthogonal correlation transform is used to reduce the artifacts associated with the nonlinear filters. A broadband audio signal may be broken into subbands, such as by using a phase-corrected 4th-order Linkwitz-Riley network, or other filter-bank topologies (e.g., wavelet decomposition or short-time-Fourier-transform (STFT)). The nonlinear dynamics of the filter can be described in terms of signal-dependent, time-varying linear dynamics. The unitary constraint ensures the stability of the filter under all conditions.
Some embodiments include a system including circuitry. The circuitry is configured to: generate a first rotated component and a second rotated component by rotating a pair of audio signal components; generate left quadrature components that are out of phase with each other using the first rotated component; generate right quadrature components that are out of phase with each other using the second rotated component; generate orthogonal correlation transform (OCT) components based on the left and right quadrature components, each OCT component including a weighted combination of a left quadrature component and a right quadrature component; generate a mono output channel using one or more of the OCT components; and provide the mono output channel to one or more speakers.
Some embodiments include a method. The method includes, by a circuitry: generating a first rotated component and a second rotated component by rotating a pair of audio signal components; generating left quadrature components that are out of phase with each other using the first rotated component; generating right quadrature components that are out of phase with each other using the second rotated component; generating orthogonal correlation transform (OCT) components based on the left and right quadrature components, each OCT component including a weighted combination of a left quadrature component and a right quadrature component; generating a mono output channel using one or more of the OCT components; and providing the mono output channel to one or more speakers.
Some embodiments include a non-transitory computer readable medium storing instructions that, when executed by at least one processor, configure the at least one processor to: generate a first rotated component and a second rotated component by rotating a pair of audio signal components; generate left quadrature components that are out of phase with each other using the first rotated component; generate right quadrature components that are out of phase with each other using the second rotated component; generate orthogonal correlation transform (OCT) components based on the left and right quadrature components, each OCT component including a weighted combination of a left quadrature component and a right quadrature component; generate a mono output channel using one or more of the OCT components; and provide the mono output channel to one or more speakers.
The figures depict various embodiments for purposes of illustration only. One skilled in the art will readily recognize from the following discussion that alternative embodiments of the structures and methods illustrated herein may be employed without departing from the principles described herein.
The rotation processor 102 receives an input signal u(t) including a left channel u(t)1and a right channel u(t)2. The rotation processor 102 generates a first rotated component x(t)1 by rotating a channel u(t)1 and a channel u(t)2, and a second rotated component x(t)2 by rotating the channel u(t)1 and the channel u(t)2. The channels u(t)1 and u(t)2 are a pair of audio signal components. In one example, the channel u(t)1 is a left channel and the channel u(t)2 is a right channel of a stereo audio signal.
The quadrature processor 104 includes a quadrature filter for each of the rotated components. The quadrature filter 112a receives the first rotated component x(t)1, and generates left quadrature components H(x(t)1)1 and H(x(t)1)2 having a (e.g., 90 degree) phase relationship between each other, and each having a unity magnitude relationship with the first rotated component x(t)1. The quadrature filter 112b receives the second rotated component x(t)2, and generates right quadrature components H(x(t)2)1 and H(x(t)2)2 having a (e.g., 90 degree) phase relationship between each other, and each having a unity magnitude relationship with the second rotated component x(t)2.
The OCT processor 106 receives the quadrature components H(x(t)1)1, H(x(t)1)2, H(x(t)2)1, and H(x(t)2)2, and combines pairs of the quadrature components using weights to generate OCT components OCT1, OCT2, OCT3, and OCT4. The number of OCT components may correspond with the number of quadrature components. Each OCT component includes contributions from the left channel u(t)1 and the right channel u(t)2 of the input signal u(t), but without loss of negatively correlated information that would result by simply combining the left channel u(t)1 and the right channel u(t)2. The use of quadrature components results in summations where amplitude nulls are converted into phase nulls.
The component selector 110 generates a mono output channel O using one or more of the OCT components OCT1, OCT2, OCT3, and OCT4. In some embodiments, the component selector 110 selects one of the OCT components for the output channel O. In other embodiments, the component selector 110 generates the output channel O based on combinations of a plurality of OCT components. For example, multiple OCT components may be combined in the output channel 0, with different OCT components being weighted differently over time. Here, the output channel O is a time varying combination of multiple OCT components.
As such, the audio processing system 100 generates the output channel O from the input signal u(t) including the left channel u(t)1 and the right channel u(t)2. The input signal u(t) may include various numbers of channels. For an n channel input signal, the audio processing system 100 may generate 2n quadrature components and 2n OCT components, and generate an output channel O using one or more of the 2n OCT components.
In some embodiments, a linear, time invariant form of OCT (e.g., as defined in equation 7) may be used to generate a mono output channel from an audio signal including multiple (e.g., n) channels.
A stereo audio signal may be defined according to Equation 1:
u(t)≡[u(t)1 u(t)2]≡[L R] (1)
where u(t)1 may be a left channel L of the stereo audio signal, and u(t)2 may be a right channel R of the stereo audio signal. In other embodiments, the u(t)1 and u(t)2 are a pair of audio signal components other than left and right channels.
If a linear projection from this two-dimensional signal were applied into a single dimension, we should expect a nullspace. The common solution of summing both channels does precisely this. As a result, the nullspace contains vectors of the form u(t)1=−u(t)2.
To generate the rotated components x(t) from input audio signal u(t) (e.g., by the rotation processor 102), a rotation matrix is applied. For n=2 channels, a 2×2 orthogonal rotation matrix may be defined by Equation 2:
where θ determines the angle of rotation. In one example the angle of rotation θ is 45°, resulting in each input signal component being rotated by 45°. In other examples the angle of rotation may be −45°, resulting in a rotation in the opposite direction. In some examples (e.g., as shown in Equation 11 below), the angle of rotation varies with time, or in response to the input signal. However, in this particular case, the rotation is fixed, and it is applied to u(t) to result in x(t) as defined by Equation 3:
To generate quadrature components (e.g., by the quadrature processor 104), a quadrature all-pass filter function H ( ) including a pair of quadrature all-pass filters (e.g., quadrature filters 112a and 112b) for each channel is defined using a continuous-time prototype. For the channel x(t)1, for example, the quadrature all-pass filter function may be defined according to Equation 4:
where H ( ) is a linear operator including the two quadrature all-pass filters H ( )1 and H ( )2. H ( )1 generates a component having a 90 degrees phase relationship with a component generated by H ( )2, and the outputs of H ( )1 and H ( )2 are referred to as quadrature components. {tilde over (x)}(t)1 is a signal with the same magnitude spectrum as x(t)1, but with an unconstrained phase relationship to x(t)1.
The quadrature components defined by H (x(t)1)1 and H (x(t)1)2 have the 90 degrees phase relationship between each other, and each has a unity magnitude relationship with the input channel x(t)1. Similarly, a quadrature all-pass filter function H ( ) may be applied to the channel x(t)2 to generate quadrature components, defined by H (x(t)2)1 and H (x(t)2)2, having the 90 degrees phase relationship between each other, and each having a unity magnitude relationship with the input channel x(t)2.
The audio signal u(t) is not limited to two (e.g., left and right) channels, and could contain n channels. Thus, the dimensionality of x(t) is also variable. More generally, a linear quadrature all-pass filter function Hn (x (t)) may be defined by its action on an n-dimensional vector x(t) including n channel components. The result is a row-vector of dimension 2n defined by Equation 5:
where H ( )1 and H ( )2 are defined according to Equation 4 above. Here, a pair of quadrature components having a 90 degrees phase relationship is generated for each of the n channels of the audio signal. As such, the quadrature all-pass filter function Hn( ) projects an n dimensional vector of the audio signal u(t) into a 2n dimensional space.
To generate the OCT outputs from the quadrature components (e.g., by OCT processor 106), a rotation is applied to each of the quadrature components. Rotation matrices are applied in block form with a permutation matrix to generate a fixed matrix P as defined by Equation 6:
The fixed matrix P is multiplied with the quadrature components of Hn(x(t)). When u(t) is stereo signal (e.g., n=2), and thus the dimensionality of x(t) is also 2, this 4x4 orthonormal matrix P transforms a 4-dimensional vector result of H2 (x(t)) into a 4-dimensional basis defined by four orthogonal components: the OCT components. For example, a first left quadrature component may be combined with an inverted second right quadrature component to generate a first OCT component, a first left quadrature component may be combined with a second right quadrature component to generate a second OCT component, a second left quadrature component may be combined with an inverted first right quadrature component to generate a third OCT component, and a second left quadrature component may be combined with a first right quadrature component to generate a fourth OCT component. As such, pairs of quadrature components are weighted and combined to generate the OCT components. For an audio signal u(t) with more than two channels, larger rotation and permutation matrices may be used to generate a fixed matrix of the correct size. The general equation for deriving the OCT components is defined by Equation 7:
To generate a mono output channel (e.g., by the component selector 110), one of the outputs generated from the OCT may be selected. The mono output channel is provided to a speaker, or multiple speakers.
Simply transforming a 2-dimensional audio vector as described above and selecting a single output will still result in a nullspace. However, for many real-world examples, the odds of having perceptually significant audio information in these subspaces are much worse than the odds of having significant information in a location such as L+R or L−R. This is because of common mixing techniques that have become industry standard.
It is still possible that an OCT output will be missing salient information. To address this, a nonlinear sum may be used, which can be written as a signal dependent, time varying combination of two or more OCT outputs.
For example, the component selector 110 may select two of the OCT outputs and use the selected OCT outputs to generate a nonlinear sum. To enumerate the possible combinations when MON-OCT is applied to a two-channel audio signal u(t) resulting in four OCT outputs, a 4×2 projection matrix Π may be used to select a pair of components from the four OCT outputs. The selected components correspond with the nonzero indices in the projection matrix, for example, as shown by Equation 8:
In this example, the projection matrix Π selects the second and third OCT outputs to generate a two-dimensional vector of orthogonal components Ma(u) and Mb(u), as shown by Equation 9:
The resulting 2-dimensional vector is combined to generate the mono output channel by using a time-varying rotation which depends on the input signal. To temper the nonlinear effect of instantaneous change in rotation angle, let S(x) denote a slope limiting function such as a linear or nonlinear low-pass filter, slew limiter, or some similar element. The action of this filter is to place an upper limit on the absolute frequency of the resulting modulating sinusoid, effectively limiting the maximum nonlinearity resulting from the rotation.
Although many different tests for local optimality could be used, in one example, the peak absolute value between the two orthogonal components is used as input to the slope limiting function S to determine an angle ϑu, as defined by Equation 10.
Other embodiments may use a different measure of optimality as input to the slope limiting function S(x). The angle ϑu points toward a dynamically changing optimum given u. This optimum is extracted with a projection to generate the mono output channel {tilde over (M)}a,b(u), as defined by Equation 11:
Although the projection matrix Π is discussed above as selecting the second and third of the four orthogonal components output from the MON-OCT, any of the OCT outputs may be selected among to generate the mono output channel. In some embodiments, multiple OCT outputs may be selected and provided to different speakers. In some embodiments, orthogonal components may be selected for combination based on other factors, such as RMS maximization or other functions. In some embodiments, Equation 11 does not project but merely rotates the vector [Ma(u) Mb(u)], which results in multi-channel output.
The mono output channel defined by Equation 11 may include nonlinear artifacts which are the result of frequency shifting by the angular velocity of ϑu. This may be mitigated by applying a subband decomposition, where the wideband audio signal u(t) is separated into frequency subband components. The MON-OCT may then be performed on each of the subbands, with the results for each of the subbands being combined into the mono output channel. A frequency band divider may be used to separate the audio signal into subbands. After applying MON-OCT to each of the subbands, a frequency band combiner may be used to combine the subbands into an output channel.
Subband decomposition provides for reducing the nonlinear artifacts. A trade-off can occur between salient and transient response, but for all practical purposes an optimal region is small enough to be set without further parameterization.
The frequency band divider 202 receives a left channel u(t)1 of an input signal u(t), and separates the left channel u(t)1 into left subband components u(t)1(1), u(t)1(2), u(t)1(3), and u(t)1(4). Each of the four left subband components u(t)1(1), u(t)1(2), u(t)1(3), and u(t)1(4) includes audio data of a different frequency band of the left channel u(t)1. The frequency band divider 204 receives a right channel u(t)2 of the input signal u(t), and separates the right channel u(t)2 into right subband components u(t)2(1), u(t)2(2), u(t)2(3), and u(t)2(4). Each of the four right subband components u(t)2(1), u(t)2(2), u(t)2(3), and u(t)2(4) includes audio data of a different frequency band of the right channel u(t)2.
Each of the audio processing systems 100(1), 100(2), 100(3), and 100(4) receives a left subband component and a right subband component, and generates a mono subband component for the subband based on the left and right subband components. The discussion regarding the audio processing system 100 above in connection with
The audio processing system 100(1) receives the left subband component u(t)1(1) and the right subband component u(t)2(1), and generates a mono subband component O(1). The audio processing system 100(2) receives the left subband component u(t)1(2) and the right subband component u(t)2(2), and generates a mono subband component O(2). The audio processing system 100(3) receives the left subband component u(t)1(3) and the right subband component u(t)2(3) and generates a mono subband component O(3). The audio processing system 100(4) receives the left subband component u(t)1(4) and the right subband component u(t)2(4), and generates a mono subband component O(4). The processing performed by the audio processing systems 100(1) through 100(4) may be different for different subband components.
The frequency band combiner 206 receives the mono subband components O(1), O(2), O(3), and O(4), and combines these mono subband components into a mono output channel O.
The frequency band divider includes a cascade of 4th order Linkwitz-Riley crossovers with phase correction to allow for coherent summing at the output. The frequency band divider 300 includes a low-pass filter 302, a high-pass filter 304, an all-pass filter 306, a low-pass filter 308, a high-pass filter 310, an all-pass filter 312, a high-pass filter 316, and a low-pass filter 314.
The low-pass filter 302 and high-pass filter 304 include 4th order Linkwitz-Riley crossovers having a corner frequency (e.g., 300 Hz), and the all-pass filter 306 includes a matching 2nd order all-pass filter. The low-pass filter 308 and high-pass filter 310 include 4th order Linkwitz-Riley crossovers having another corner frequency (e.g., 510 Hz), and the all-pass filter 312 includes a matching 2nd order all-pass filter. The low-pass filter 314 and high-pass filter 316 include 4th order Linkwitz-Riley crossovers having another corner frequency (e.g., 2700 Hz). As such, the frequency band divider 300 produces the subband component 318 corresponding to the frequency subband(1) including 0 to 300 Hz, the subband component 320 corresponding to the frequency subband(2) including 300 to 510 Hz, the subband component 322 corresponding to the frequency subband(3) including 510 to 2700 Hz, and the subband component 324 corresponding to the frequency subband(4) including 2700 Hz to Nyquist frequency. In this example, the frequency band divider 300 generates n=4 subband components. The number of subband components and their corresponding frequency ranges generated by the frequency band divider 300 may vary. The subband components generated by the frequency band divider 300 allow for unbiased perfect summation, such as by the frequency band combiner 206.
The audio processing system 100 provides a multi-input, multi-output nonlinear filter-bank which has been designed to preserve perceptually important components of the soundstage (in some embodiments defined by equation (11), with the linear form defined by equation (7)), where the optimality condition may be satisfied by using more than one output. This implies that audio can be distributed to a mesh of single- or multi-driver speakers, without concern regarding number or placement, and still hope to reproduce a compelling but multi-centered spatial experience of that audio signal. Different nonlinear sums may be selected for each subband, and these associations between subband and nonlinear sum may be permuted for each output. For example, four nonlinear sums (a,b,c,d) my be used to generate three independent outputs comprised of two subbands each (e.g., output1=[subband1, subband2]), then the nonlinear sums for each subband may be permuted using output1=[a, b], output2=[b, c], output3=[c, d]. Depending on the optimality condition and the number of constituent subbands, this could result in a large number of unique signals, each of which contains a slight variation on the same perceptual whole. When each is played alone, the diffused signals each reproduce the entire soundstage. When played simultaneously, such as using a mesh of multiple speakers, the diffused signal takes on an unbiased but undoubtedly spatial quality.
In some embodiments, for a mesh of speakers, one of the outputs generated using MON-OCT may be provided to each of the speakers. In some embodiments, pairs of orthogonal components are used to generate nonlinear sums (e.g., each sum being a mono output channel as defined by Equation 11) defining the mono output channels, with different mono output channels being provided to each of the speakers of the mesh.
The audio processing system generates 405 generates a first rotated component and a second rotated component by rotating a pair of audio signal components. In one example, the pair of audio signal components include a left audio signal component and a right audio signal component of a stereo audio signal. The rotation may use a fixed angle, or the angle of rotation may vary with time. The left component may include a (e.g., wideband) left channel and the right component may include a (e.g., wideband) right channel. In some embodiments and as discussed in greater detail with reference to
The audio processing system generates 410 left quadrature components that are out of phase with each other using the first rotated component. The left quadrature components may have a 90 degrees phase relationship between each other. In some embodiments, the audio processing system generates components having some other phase relationship using the first rotated component, and these components may be processed in a similar way as discussed herein for the left quadrature components. The left quadrature components may each have a unity magnitude relationship with the first rotated component. The audio processing system may apply an all-pass filter function to generate the left quadrature components using the first rotated component.
The audio processing system generates 415 right quadrature components that are out of phase with each other using the second rotated component. The right quadrature components may have a 90 degrees phase relationship between each other. In some embodiments, the audio processing system generates components having some other phase relationship using the second rotated component, and these components may be processed in a similar way as discussed herein for the right quadrature components. The right quadrature components may each have a unity magnitude relationship with the second rotated component. The audio processing system may apply an all-pass filter function to generate the right quadrature components using the second rotated component.
The audio processing system generates 420 orthogonal correlation transform (OCT) components based on the left and right quadrature components, where each OCT component includes a weighted combination of a left quadrature component and a right quadrature component. For example, the audio processing system applies a weight to a left quadrature component and a weight to a right quadrature component, and combines the weighted left and right quadrature components to generate an OCT component. Different combinations of weighted left and right quadrature components may be used to generate different OCT components. The number of OCT components may correspond with the number of quadrature components. Each OCT component includes contributions from the left channel and the right channel of the input signal, but without loss of negatively correlated information that would result by simply combining the left channel and the right channel.
The audio processing system 425 generates a mono output channel using one or more of the OCT components. For example, one of the OCT components may be selected as the mono output channel. In another example, the output channel may include a time varying combination of two or more OCT components.
The audio processing system provides 430 the mono output channel to one or more speakers. For example, the mono output channel may be provided to a speaker of a single speaker system, or multiple speakers of a multiple speaker system. In some embodiments, different mono output channels may be generated and provided to different speakers of a mesh. For example, one of each of the OCT components may be provided to each of the speakers. In another example, pairs of OCT components are used to generate nonlinear sums, with different nonlinear sums being provided to each of the speakers of the mesh
Although the process 400 is discussed using left and right channels, the number of channels in the audio signal may vary. A pair of quadrature components having a 90 degrees phase relationship is generated for each of the n channels of the audio signal, and a mono output channel may be generated based on the quadrature components.
The audio processing system separates 505 a left channel into left subband components and a right channel into right subband components. In one example, each of the left and right channels are separated into four subband components. The number of subbands and associated frequency ranges of the subbands may vary.
The audio processing system generates 510, for each subband, a mono subband component using a left subband component of the subband and a right subband component of the subband. For example, the audio processing system may perform steps 405 through 425 of the process 400 for each subband to generate a mono subband component for the subband. In some embodiments, different nonlinear sums of OCT components may be selected for different subbands to generate the mono subband components. Depending on the optimality condition and the number of constituent subbands, this could result in a large number of possible unique broadband signals, each of which contains a slight variation on the same perceptual whole.
The audio processing system 515 combines the mono subband components of each subband into a mono output channel. For example, the mono subband components may be added to generate the mono output channel.
The audio processing system provides 520 the mono output channel to one or more speakers. The one or more speakers may include a single speaker, or a mesh of speakers. In some embodiments, the audio processing system provides different mono output channels for different speakers.
The storage device 608 includes one or more non-transitory computer-readable storage media such as a hard drive, compact disk read-only memory (CD-ROM), DVD, or a solid-state memory device. The memory 606 holds program code (comprised of one or more instructions) and data used by the processor 602. The program code may correspond to the processing aspects described with reference to
The pointing device 614 is used in combination with the keyboard 610 to input data into the computer system 600. The graphics adapter 612 displays images and other information on the display device 618. In some embodiments, the display device 618 includes a touch screen capability for receiving user input and selections. The network adapter 616 couples the computer system 600 to a network. Some embodiments of the computer 600 have different and/or other components than those shown in
In some embodiments, the circuitry that implements an audio processing system, such as the audio processing system 100 or 200, may include an application-specific integrated circuit (ASIC), a field-programmable gate array (FPGA), or other types of computing circuitry.
The foregoing description of the embodiments has been presented for illustration; it is not intended to be exhaustive or to limit the patent rights to the precise forms disclosed. Persons skilled in the relevant art can appreciate that many modifications and variations are possible considering the above disclosure.
Some portions of this description describe the embodiments in terms of algorithms and symbolic representations of operations on information. These algorithmic descriptions and representations are commonly used by those skilled in the data processing arts to convey the substance of their work effectively to others skilled in the art. These operations, while described functionally, computationally, or logically, are understood to be implemented by computer programs or equivalent electrical circuits, microcode, or the like. Furthermore, it has also proven convenient at times, to refer to these arrangements of operations as modules, without loss of generality. The described operations and their associated modules may be embodied in software, firmware, hardware, or any combinations thereof.
Any of the steps, operations, or processes described herein may be performed or implemented with one or more hardware or software modules, alone or in combination with other devices. In one embodiment, a software module is implemented with a computer program product comprising a computer-readable medium containing computer program code, which can be executed by a computer processor for performing any or all the steps, operations, or processes described.
Embodiments may also relate to an apparatus for performing the operations herein. This apparatus may be specially constructed for the required purposes, and/or it may comprise a general-purpose computing device selectively activated or reconfigured by a computer program stored in the computer. Such a computer program may be stored in a non-transitory, tangible computer readable storage medium, or any type of media suitable for storing electronic instructions, which may be coupled to a computer system bus. Furthermore, any computing systems referred to in the specification may include a single processor or may be architectures employing multiple processor designs for increased computing capability.
Embodiments may also relate to a product that is produced by a computing process described herein. Such a product may comprise information resulting from a computing process, where the information is stored on a non-transitory, tangible computer readable storage medium and may include any embodiment of a computer program product or other data combination described herein.
Finally, the language used in the specification has been principally selected for readability and instructional purposes, and it may not have been selected to delineate or circumscribe the patent rights. It is therefore intended that the scope of the patent rights be limited not by this detailed description, but rather by any claims that issue on an application based hereon. Accordingly, the disclosure of the embodiments is intended to be illustrative, but not limiting, of the scope of the patent rights, which is set forth in the following claims.
This application claims the benefit of U.S. Provisional Application No. 62/791,626, filed Jan. 11, 2019, which is incorporated by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
62791626 | Jan 2019 | US |