The present disclosure relates generally to audio reproduction, and more specifically to emulating audio at an original three-dimensional space.
As advances in virtual and augmented reality are made, there is a need in the art for techniques to improve the audio experience to better match the corresponding visual experience. For example, in the arena of video technology, video quality has improved considerably with an ever increasing number of pixels per inch of display, which in turn has increased the resolution and therefore the sharpness of the image. In addition, increases in the depth of color representation have significantly improved the accuracy of video quality to as compared to real life.
Historically, advances in audio quality have progressed at a much faster rate than those of video quality. However, in recent years, the situation has reversed, namely, that recent improvements in video quality appear to be outpacing improvements in audio quality.
By utilizing beamforming techniques, it is possible to reproduce a wavelength of sound in a predetermined direction. Sounds may therefore be selectively recorded using beamforming techniques in combination with arrays of microphones, for example as described in U.S. Pat. No. 9,788,108, which is assigned to the common assignee. Sound captured using such beamforming techniques can be processed and then utilized to project sound in any other location.
Existing solutions for producing more accurate audio content assume that a captured sound source provides the sound into space in an outward-facing direction as compared to the recording device using a sphere-like propagation profile. This assumption is a simplified model compared to the actual way in which sounds are projected. For example, when a human speaks, a listener in the direction the human is pointing will hear the sound in one way, and a listener in another direction will hear differently. Further, the sounds produced by objects moving away from or towards each other may be heard differently due to the doppler effect. This is further complicated when multiple sound sources and multiple listeners are occupying the same space.
To overcome the shortcomings of the existing solutions, some improvements thereto utilize multiple audio capturing devices in the relevant location. These solutions attempt to place as many audio capturing devices as possible within spaces that conceivably might be heard by a listener. This configuration is inefficient, and may make processing audio much more difficult.
It would therefore be advantageous to provide a solution that would overcome the challenges noted above.
A summary of several example embodiments of the disclosure follows. This summary is provided for the convenience of the reader to provide a basic understanding of such embodiments and does not wholly define the breadth of the disclosure. This summary is not an extensive overview of all contemplated embodiments, and is intended to neither identify key or critical elements of all embodiments nor to delineate the scope of any or all aspects. Its sole purpose is to present some concepts of one or more embodiments in a simplified form as a prelude to the more detailed description that is presented later. For convenience, the term “some embodiments” or “certain embodiments” may be used herein to refer to a single embodiment or multiple embodiments of the disclosure.
Certain embodiments disclosed herein include an apparatus for spatially emulating a sound source, comprising: a microphone array including a plurality of microphones; and a sound profiler communicatively connected to the microphone array, the sound profiler further comprising a processing circuitry and a memory, the memory containing instructions that, when executed by the processing circuitry, configure the apparatus to: generate synthesized audio based on sound beam metadata, a sound profile, and target listener location data, wherein the sound beam metadata includes a plurality of timed sound beams defining a directional dependence of a spatial sound wave, wherein the sound profile includes a plurality of timed sound coefficients determined based on audio signals captured in a space wherein the target listener location data includes a position and an orientation, wherein the synthesized audio emulates sound that would be heard by a listener at the position and orientation of the target listener location data; and provide the synthesized audio for projection via at least one audio output device.
Certain embodiments disclosed herein also include a method for spatially emulating a sound source, comprising: transforming a plurality of timed audio samples by applying a Fast Fourier Transform (FFT) to the plurality of timed audio samples, wherein the plurality of timed audio samples includes a plurality of audio signals captured in a space at respective times; determining a plurality of relative transfer functions based on a plurality of spatial base functions; generating a plurality of beamforms based on the transformed plurality of audio samples and the plurality of relative transfer functions; and determining a plurality of timed sound coefficients by applying an inverse FFT to the plurality of beamforms, wherein the plurality of timed sound coefficients produce audio emulating sound that would be heard by a target listener in the space when utilized to generate audio based on a target position and a target orientation of the target listener.
Certain embodiments disclosed herein also include a non-transitory computer readable medium having stored thereon causing a processing circuitry to execute a process, the process comprising: transforming a plurality of timed audio samples by applying a Fast Fourier Transform (FFT) to the plurality of timed audio samples, wherein the plurality of timed audio samples includes a plurality of audio signals captured in a space at respective times; determining a plurality of relative transfer functions based on a plurality of spatial base functions; generating a plurality of beamforms based on the transformed plurality of audio samples and the plurality of relative transfer functions; and determining a plurality of timed sound coefficients by applying an inverse FFT to the plurality of beamforms, wherein the plurality of timed sound coefficients produce audio emulating sound that would be heard by a target listener in the space when utilized to generate audio based on a target position and a target orientation of the target listener.
Certain embodiments disclosed herein also include a system for spatially emulating a sound source. The system comprises: a processing circuitry; and a memory, the memory containing instructions that, when executed by the processing circuitry, configure the system to: transform a plurality of timed audio samples by applying a Fast Fourier Transform (FFT) to the plurality of timed audio samples, wherein the plurality of timed audio samples includes a plurality of audio signals captured in a space at respective times; determine a plurality of relative transfer functions based on a plurality of spatial base functions; generate a plurality of beamforms based on the transformed plurality of audio samples and the plurality of relative transfer functions; and determine a plurality of timed sound coefficients by applying an inverse FFT to the plurality of beamforms, wherein the plurality of timed sound coefficients produce audio emulating sound that would be heard by a target listener in the space when utilized to generate audio based on a target position and a target orientation of the target listener.
The subject matter disclosed herein is particularly pointed out and distinctly claimed in the claims at the conclusion of the specification. The foregoing and other objects, features, and advantages of the disclosed embodiments will be apparent from the following detailed description taken in conjunction with the accompanying drawings.
It is important to note that the embodiments disclosed herein are only examples of the many advantageous uses of the innovative teachings herein. In general, statements made in the specification of the present application do not necessarily limit any of the various claimed embodiments. Moreover, some statements may apply to some inventive features but not to others. In general, unless otherwise indicated, singular elements may be in plural and vice versa with no loss of generality. In the drawings, like numerals refer to like parts through several views.
In view of the deficiencies of the existing solutions, it has been identified that techniques which can more accurately emulate audio at a given position would be desirable. To this end, the disclosed embodiments provide methods and systems for emulating audio at a given position that utilize location data indicating positions of sound sources and sound capturing devices within a space of recording in order to more accurately reflect the directionality and travel of objects within the space of recording. Audio modified in accordance with the disclosed embodiments can be projected to another space such that a user in the other space experiences the audio from the perspective of a given position within the space of recording.
Sound source profiles are generated for sound sources within a space. The sound space profiles allow for reconstructing sound from the perspective of a listener at a particular position within the space. The reconstructed sound is more accurate to the actual sound that would be heard by the listener at the particular position in the space than sounds produced according to existing solutions which do not account for the position of the listener relative to the sound source and space.
The walls 110 include a first wall 110-1, a second wall 110-2, and a floor plane 110-3. The walls 110-1 and 110-2 include respective microphone arrays 120-1 and 120-2. Each microphone array 120 includes multiple microphones (not individually depicted in
The microphone arrays 120 capture sounds produced by the sound source 130. These sounds are utilized in accordance with the disclosed embodiments in order to generate audio emulating the audio that would be heard at different positions within the space 100. To this end, the microphone arrays 120 are communicatively connected to a sound analyzer (e.g., the sound space profile generator 200,
The sound space profile generator 200 includes a sound profiler 210 and an audio synthesizer 220. In some embodiments, the sound space profile generator 200 may further include one or more audio output devices 230-1 through 230-M (hereinafter referred to as an audio output device 230 or as audio output devices 230). In another embodiment (not shown), the sound space profile generator 200 may be communicatively connected to external audio output devices. The audio output devices may be, but are not limited to, speakers, headphones, headsets, or any other devices capable of projecting audio.
The sound profiler 210 is configured to generate sound source profile for sound sources within a space (e.g., the sound source 130 in the space 100,
The sound profiler 210 receives audio data from microphone arrays 120-1 through 120-P (hereinafter referred to as a microphone array 120 or as microphone arrays 120). The audio data includes at least sound signals.
The sound profiler 210 further includes a sound analyzer 212 and a beam synthesizer 214. The beam synthesizer 214 is configured to receive sound beam metadata. The sound beam metadata includes sound beams defining a directional (e.g., angular) dependence of the gain of a spatial sound wave. The beam synthesizer 214 is configured to generate synthesized audio using the manipulated sound beam in accordance with the disclosed embodiments and to provide the synthesized audio to the audio synthesizer 220. An example method that may be performed by the beam synthesizer is described further below with respect to
The sound beam metadata and the sound signals are transferred to the sound analyzer 212. The sound analyzer 212 is configured to generate a manipulated sound beam based on audio captured by the microphone arrays 120 in accordance with the disclosed embodiments and to provide the manipulated sound beam to the beam synthesizer 214. To this end, the sound analyzer 212 is configured to generate a profile of a sound source (e.g., the sound source 130,
In an embodiment, the sound profiler 210 is configured to output a profile of a sound source (e.g., the sound source 130,
The sound profiler 210 receives, as an input, sound captured by the microphone arrays 120. The sound profiler 210 further receives sound source location data related to the space in which the microphone arrays 120 are deployed (e.g., the space 100,
The topology data provides a description of the topology of the space (e.g., the space 100,
The sound profiler 210 also receives, for each microphone of the microphone arrays 120, a location of the microphone in a format such as (xi, yi, zi), where “i” is an index that is an integer having a value of 0 or greater. For each of the microphones, audio samples Si{t} are collected. A fast Fourier transform (FFT) is performed on each of the audio samples Si{t} to output a respective Sk, where “k” represents a frequency-bin. A number “N” of spatial base functions are applied to the output Sk values, where N is an integer greater than “1.” In an example implementation, the spatial base functions are harmonic base functions, fj(x,y,z). For each spatial function “j”, processing is performed as follows.
For each frequency-bin “k” (where a frequency-bin may be a given frequency or range of frequencies), the following relative transfer function is calculated:
RTF
k
j
=f
k
j(xi−xt,yi−yt,zi−zt)/fkj(x0−xt,y0−yt,z0−zt) Equation 1
Based on the relative transfer functions, beam forming is performed in accordance with the following expression:
BF
k
j(Sk,RTFkj) Expression 1
Performing the beam forming may include, but is not limited to, minimum variance distortion-less response (MVDR) beam forming, generalized side-lobe canceler (GSC) beam forming, delay and sum beam forming, and the like. Based on the beam forms generated via the beam forming, timed sound coefficients αj{t} (where each “j” is an integer having a value of 1 or greater and t is the respective time) may be determined by performing an inverse Fast Fourier Transform (IFFT) on the beam forms.
The coefficients αj (also referred to herein as timed sound coefficients or sound coefficients) are utilized to generate a profile for the sound source which can in turn be utilized to reconstruct audio as described herein.
The profile (including the extracted timed sound coefficients) is transferred to the audio synthesizer 220 for use in generating audio to be projected via, for example, the audio output devices 230. In some implementations, the profile may be transferred via a wired or wireless connection. In some embodiments, the timed sound coefficients of the profile may be first stored in an intermediate memory and then retrieved, in real-time or near real-time, by the audio synthesizer 220 when reproduced audio is required.
The audio synthesizer 220 further receives target listener location data. Such target listener location data may include, but is not limited to, a target position and a target orientation of a simulated listener within the space.
The audio synthesizer 220 is configured to generate sound to be projected based on the profile, audio metadata, and the target listener location data. The sound to be projected is generated for the position orientation with respect to the sound source. As a result, the generated audio accurately emulates the sound that would be heard by a listener at the position and orientation of the simulated listener. An example method performed by the audio synthesizer 220 is described further below with respect to
The audio data may be received as signals in the frequency domain from microphones of each microphone array. In an embodiment, the sound profiler 210 is configured to perform a Fast Fourier Transform (FFT) for each frequency-bin “k” in accordance with the following equation:
S
k=FFT{s[n]} Equation 2
In Equation 2, s[n] are the sound samples provided by a microphone.
Additionally, the sound profiler 210 is configured to determine respective transfer functions TFjk for each spatial function “j” (where “j” is an integer greater than or equal to 1) applied for each frequency-bin “k” in accordance with the following equation:
TF
j
k
=e
iωr
f(r,θ,φ) Equation 3
In Equation 3, eiωr is a delay value and f(r, θ, φ) is a respective spatial base function. The spatial parameters (r, θ, φ) collectively indicate a point in space 310 as depicted in the illustration 300 of
When the absolute transfer functions have been calculated, beamforming is performed. In an example implementation, a Minimum Variance Distortion-less Response (MVDR) weighting vector is determined for each frequency-bin in accordance with the following equation:
In Equation 4, “R” is an autocorrelation matrix of an incoming signal, “TF” is a respective absolute transfer function for the frequency-bin, and “TFH” is a Hermitian function of the TF, which is a conjugate transposed matrix.
Based on the MVDR weighting vectors, a scalar multiplication is performed for each frequency-bin “k” per harmonic base “j” in accordance with the following equation:
∝jk=[wjk]T×Sk Equation 5
In Equation 5, “T” is the Transpose operand. The values of “α” are included in a profile and utilized by the audio synthesizer 220 to regenerate audio projected in a space that emulates the audio that would be heard at a given position and orientation within the space.
It should also be noted that, when there are multiple sound sources, the audio for each sound source may be generated by repeating the process performed by the sound space profile generator 200 for each sound source.
At S510, sound source location data and topology data are received.
The sound source location data may include, but is not limited to, three-dimensional (3D) coordinates of the sound source at various times in a format such as (xt, yt, zt), where “t” is a time of recording of the sound and “x,” “y,” and “z” are respective 3D coordinates of the sound source at each time “t.”
The topology data provides a description of the topology of the space (e.g., the space 100,
At S520, microphone location data is received. In an example implementation, the microphone location data includes, for each microphone of the microphone arrays 120, a location of the microphone in a format such as (xi, yi, zi), where “i” is an index that is an integer having a value of 0 or greater.
At S530, audio samples are received. The audio samples include at least sound signals captured by microphones deployed in a space.
At S540 the audio samples are transformed. In an embodiment, S540 includes performing a Fast Fourier Transform (FFT) as described above with respect to Equation 2.
At S550, spatial base functions are selected. The spatial base functions may be in the form “f(x, y, z)” or “f(r, θ, φ)”. In an example implementation, the selected spatial base functions include spherical harmonic functions, for example, as depicted in
At S560 beamforms are generated based on the transformed audio samples. In an embodiment, S560 includes determining relative transfer functions as described above with respect to Equations 2 through 5, and beamforming is performed in accordance with Expression 1.
At S570, an inverse FFT is performed on the results of the beamforming to determine timed sound coefficients.
At S580, data is sent to an audio synthesizer (e.g., the audio synthesizer 220,
At S590, it is checked if more audio samples are to be analyzed and, if so, execution continues with S530; otherwise, execution terminates.
At S610, sound beam metadata and a sound profile are received from an audio profiler (e.g., the audio profiler 210,
At S620, target listener location data is received. The target listener location data may include, but is not limited to, a desired position and orientation of a simulated listener within a space for whom audio is to be reproduced. The audio generated for this desired position and orientation will emulate the audio that would be heard by a listener occupying that position and having that orientation in the space in which the original audio was captured. In an example orientation, the desired position is received in a format such as (x, y, z).
At S630, audio is synthesized based on the sound beam metadata, the sound profile, and the target listener location data. The synthesis includes reconstructing and generating the six degrees of freedom (6DoF) sound for the virtual listener in the presence of multiple speakers in space. The calculation of relative position of the virtual listener per speaker is performed using a spatial reconstruction function combined with Head Related Transfer Function (HRTF).
At S640, the synthesized audio is provided to one or more audio output devices for projection to a user. The synthesized audio may be sent to, for example, speakers, headphones, or a headset.
At S650, it is determined if more audio samples are to be synthesized and, if so, execution continues with S610; otherwise, execution terminates. In an example implementation, additional audio samples may need to be synthesized when multiple audio sources are present in the space.
It should be noted that the methods of
The user device (UD) 720 may be, but is not limited to, a personal computer, a laptop, a tablet computer, a smartphone, a wearable computing device (e.g., a virtual reality or augmented reality headset), or any other device capable of receiving and projecting audio.
The profile generator 200 is configured to generate audio featuring spatial representations of sound sources as described herein. More specifically, the profile generator 200 receives audio data from the microphone arrays 120, which are deployed at a space of recording including one or more sound sources. The profile generator 200 is configured to generate audio emulating the sounds projected by the sound sources as they would be heard by a user at a given position within the space of recording.
The processing circuitry 810 may be realized as one or more hardware logic components and circuits. For example, and without limitation, illustrative types of hardware logic components that can be used include field programmable gate arrays (FPGAs), application-specific integrated circuits (ASICs), Application-specific standard products (ASSPs), system-on-a-chip systems (SOCs), graphics processing units (GPUs), tensor processing units (TPUs), general-purpose microprocessors, microcontrollers, digital signal processors (DSPs), and the like, or any other hardware logic components that can perform calculations or other manipulations of information.
The memory 820 may be volatile (e.g., random access memory, etc.), non-volatile (e.g., read only memory, flash memory, etc.), or a combination thereof.
In one configuration, software for implementing one or more embodiments disclosed herein may be stored in the storage 830. In another configuration, the memory 820 is configured to store such software. Software shall be construed broadly to mean any type of instructions, whether referred to as software, firmware, middleware, microcode, hardware description language, or otherwise. Instructions may include code (e.g., in source code format, binary code format, executable code format, or any other suitable format of code). The instructions, when executed by the processing circuitry 810, cause the processing circuitry 810 to perform the various processes described herein.
The storage 830 may be magnetic storage, optical storage, and the like, and may be realized, for example, as flash memory or other memory technology, compact disk-read only memory (CD-ROM), Digital Versatile Disks (DVDs), or any other medium which can be used to store the desired information.
The network interface 840 allows the sound space profile generator 200 to communicate with microphone arrays 120 for the purpose of, for example, receiving audio data, receiving location data, and the like. Further, the network interface 840 allows the sound space profile generator 200 to communicate with the user device 720 for the purpose of sending modified audio data for projection.
It should be understood that the embodiments described herein are not limited to the specific architecture illustrated in
The various embodiments disclosed herein can be implemented as hardware, firmware, software, or any combination thereof. Moreover, the software is preferably implemented as an application program tangibly embodied on a program storage unit or computer readable medium consisting of parts, or of certain devices and/or a combination of devices. The application program may be uploaded to, and executed by, a machine comprising any suitable architecture. Preferably, the machine is implemented on a computer platform having hardware such as one or more central processing units (“CPUs”), a memory, and input/output interfaces. The computer platform may also include an operating system and microinstruction code. The various processes and functions described herein may be either part of the microinstruction code or part of the application program, or any combination thereof, which may be executed by a CPU, whether or not such a computer or processor is explicitly shown. In addition, various other peripheral units may be connected to the computer platform such as an additional data storage unit and a printing unit. Furthermore, a non-transitory computer readable medium is any computer readable medium except for a transitory propagating signal.
All examples and conditional language recited herein are intended for pedagogical purposes to aid the reader in understanding the principles of the disclosed embodiment and the concepts contributed by the inventor to furthering the art, and are to be construed as being without limitation to such specifically recited examples and conditions. Moreover, all statements herein reciting principles, aspects, and embodiments of the disclosed embodiments, as well as specific examples thereof, are intended to encompass both structural and functional equivalents thereof. Additionally, it is intended that such equivalents include both currently known equivalents as well as equivalents developed in the future, i.e., any elements developed that perform the same function, regardless of structure.
It should be understood that any reference to an element herein using a designation such as “first,” “second,” and so forth does not generally limit the quantity or order of those elements. Rather, these designations are generally used herein as a convenient method of distinguishing between two or more elements or instances of an element. Thus, a reference to first and second elements does not mean that only two elements may be employed there or that the first element must precede the second element in some manner. Also, unless stated otherwise, a set of elements comprises one or more elements.
As used herein, the phrase “at least one of” followed by a listing of items means that any of the listed items can be utilized individually, or any combination of two or more of the listed items can be utilized. For example, if a system is described as including “at least one of A, B, and C,” the system can include A alone; B alone; C alone; 2A; 2B; 2C; 3A; A and B in combination; B and C in combination; A and C in combination; A, B, and C in combination; 2A and C in combination; A, 3B, and 2C in combination; and the like.
This application is a continuation of U.S. patent application Ser. No. 16/985,734 filed on Aug. 5, 2020, which in turn claims the benefit of Provisional Application No. 62/883,250 filed on Aug. 6, 2019, the contents of both of which are hereby incorporated by reference.
Number | Date | Country | |
---|---|---|---|
62883250 | Aug 2019 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16985734 | Aug 2020 | US |
Child | 17662338 | US |