Audio signal processing techniques such as convolution reverb are used for simulating acoustic properties (e.g., reverberation, etc.) of a physical or virtual 3D space from a particular location within the 3D space. For example, an impulse response can be recorded at the particular location and mathematically applied to (e.g., convolved with) audio signals to simulate a scenario in which the audio signal originates within the 3D space and is perceived by a listener as having the acoustic characteristics of the particular location. In one use case, for instance, a convolution reverb technique could be used to add realism to sound created for a special effect in a movie.
In this type of conventional example (i.e., the movie special effect mentioned above), the particular location of a listener may be well-defined and predetermined before the convolution reverb effect is applied and presented to a listener. For instance, the particular location at which the impulse response is to be recorded may be defined, during production of the movie (long before the movie is released), as a vantage point of the movie camera within the 3D space.
While such audio processing techniques could similarly benefit other exemplary use cases such as extended reality (e.g., virtual reality, augmented reality, mixed reality, etc.) use cases, additional complexities and challenges arise for such use cases that are not well accounted for by conventional techniques. For example, the location of a user in an extended reality use case may continuously and dynamically change as the extended reality user freely moves about in a physical or virtual 3D space of an extended reality world. Moreover, these changes to the user location may occur at the same time that extended reality content, including sound, is being presented to the user.
The accompanying drawings illustrate various embodiments and are a part of the specification. The illustrated embodiments are merely examples and do not limit the scope of the disclosure. Throughout the drawings, identical or similar reference numbers designate identical or similar elements.
Methods and systems for simulating spatially-varying acoustics of an extended reality world are described herein. Given an acoustic environment such as a particular room having particular characteristics (e.g., having a particular shape and size, having particular objects such as furnishings included therein, having walls and floors and ceilings composed of particular materials, etc.), the acoustics affecting sound experienced by a listener in the room may vary from location to location within the room. For instance, given an acoustic environment such as the interior of a large cathedral, the acoustics of sound propagating in the cathedral may vary according to where the listener is located within the cathedral (e.g., in the center versus near a particular wall, etc.), where one or more sound sources are located within the cathedral, and so forth. Such variation of the acoustics of a 3D space from location to location within the space will be referred to herein as spatially-varying acoustics.
As mentioned above, convolution reverb and other such techniques may be used for simulating acoustic properties (e.g., reverberation, acoustic reflection, acoustic absorption, etc.) of a particular space from a particular location within the space. However, whereas traditional convolution reverb techniques are associated only with one particular location in the space, methods and systems for simulating spatially-varying acoustics described herein properly simulate the acoustics even as the listener and/or sound sources move around within the space. For example, if an extended reality world includes an extended reality representation of the large cathedral mentioned in the example above, a user experiencing the extended reality world may move freely about the cathedral (e.g., by way of an avatar) and sound presented to the user will be simulated, using the methods and systems described herein, to acoustically model the cathedral for wherever the user and any sound sources in the room are located from moment to moment. This simulation of the spatially-varying acoustics of the extended reality world may be performed in real time even as the user and/or various sound sources move arbitrarily and unpredictably through the extended reality world.
To simulate spatially-varying acoustics of an extended reality world in these ways, an exemplary acoustics simulation system may be configured, in one particular embodiment, to identify a location within an extended reality world of an avatar of a user who is using a media player device to experience (e.g., via the avatar) the extended reality world from the identified location. The acoustics simulation system may select an impulse response from an impulse response library that includes a plurality of different impulse responses each corresponding to a different subspace of the extended reality world. The impulse response that the acoustics simulation system selects from the impulse response library may correspond to a particular subspace of the different subspaces of the extended reality world. For example, the particular subspace may be a subspace associated with the identified location of the avatar. Based on the selected impulse response, the acoustics simulation system may generate an audio stream associated with the identified location of the avatar. For instance, the audio stream may be configured, when rendered by the media player device, to present sound to the user in accordance with simulated acoustics customized to the identified location of the avatar within the extended reality world.
In certain implementations, the acoustics simulation system may be configured to perform the above operations and/or other related operations in real time so as to provide spatially-varying acoustics simulation of an extended reality world to an extended reality user as the pose of the user (i.e., the location of the user within the extended reality world, the orientation of the user's ears as he or she looks around within the extended reality world, etc.) dynamically changes during the extended reality experience. To this end, the acoustics simulation system may be implemented, in certain examples, by a multi-access edge compute (“MEC”) server associated with a provider network providing network service to the media player device used by the user. The acoustics simulation system implemented by the MEC server may identify a location within the extended reality world of the avatar of the user as the user uses the media player device to experience the extended reality world from the identified location via the avatar. The acoustics simulation system implemented by the MEC server may also select, from the impulse response library including the plurality of different impulse responses that each correspond to a different subspace of the extended reality world, the impulse response that corresponds to the particular subspace associated with the identified location.
In addition to these operations that were described above, the acoustics simulation system implemented by the MEC server may be well adapted (e.g., due to the powerful computing resources that the MEC server and provider network may make available with a minimal latency) to receive and respond practically instantaneously (as perceived by the user) to acoustic propagation data representative of decisions made by the user. For instance, as the user causes the avatar to move from location to location or to turn its head to look in one direction or another, the acoustics simulation system implemented by the MEC server may receive, from the media player device, acoustic propagation data indicative of an orientation of a head of the avatar and/or other relevant data representing how sound is to propagate through the world before arriving at the virtual ears of the avatar. Based on both the selected impulse response and the acoustic propagation data indicative of the orientation of the head, the acoustics simulation system implemented by the MEC server may generate an audio stream that is to be presented to the user. For example, the audio stream may be configured, when rendered by the media player device, to present sound to the user in accordance with simulated acoustics customized to the identified location of the avatar within the extended reality world. As such, the acoustics simulation system implemented by the MEC server may provide the generated audio stream to the media player device for presentation by the media player device to the user.
Methods and systems described herein for simulating spatially-varying acoustics of an extended reality world may provide and be associated with various advantages and benefits. For example, when acoustics of a particular space in an extended reality world are simulated, an extended reality experience of a particular user in that space may be made considerably more immersive and enjoyable than if the acoustics were not simulated. However, merely simulating the acoustics of a space without regard for how the acoustics vary from location to location within the space (as may be done by conventional acoustics simulation techniques) may still leave room for improvement. Specifically, the realism and immersiveness of an experience may be lessened if a user moves around an extended reality space and does not perceive (e.g., either consciously or subconsciously) natural acoustical changes that the user would expect to hear in the real world.
It is thus an advantage and benefit of the methods and systems described herein that the acoustics of a room are simulated to vary dynamically as the user moves about the extended reality world. Moreover, as will be described in more detail below, because each impulse response used for each subspace of the extended reality world may be a spherical impulse response that accounts for sound coming from all directions, sound may be realistically simulated not only from a single fixed orientation at each different location in the extended reality world, but from any possible orientation at each location. Accordingly, not only is audio presented to the user accurate with respect to the location where the user has moved his or her avatar within the extended reality world, but the audio is also simulated to account for the direction that the user is looking within the extended reality world as the user causes his or her avatar to turn its head in various directions without limitation. In all of these ways, the methods and systems described herein may contribute to highly immersive, enjoyable, and acoustically-accurate extended reality experiences for users.
Various embodiments will now be described in more detail with reference to the figures. The disclosed systems and methods may provide one or more of the benefits mentioned above and/or various additional and/or alternative benefits that will be made apparent herein.
Storage facility 102 may store and/or otherwise maintain executable data used by processing facility 104 to perform any of the functionality described herein. For example, storage facility 102 may store instructions 106 that may be executed by processing facility 104. Instructions 106 may be executed by processing facility 104 to perform any of the functionality described herein, and may be implemented by any suitable application, software, code, and/or other executable data instance. Additionally, storage facility 102 may also maintain any other data accessed, managed, generated, used, and/or transmitted by processing facility 104 in a particular implementation.
Processing facility 104 may be configured to perform (e.g., execute instructions 106 stored in storage facility 102 to perform) various functions associated with simulating spatially-varying acoustics of an extended reality world. For example, in certain implementations of system 100, processing facility 104 may identify a location, within an extended reality world, of an avatar of a user. The user may be using a media player device to experience the extended reality world via the avatar. Specifically, since the avatar is located at the identified location, the user may experience the extended reality world from the identified location by viewing the world from that location on a screen of the media player device, hearing sound associated with that location using speakers associated with the media player device, and so forth.
Processing facility 104 may further be configured to select an impulse response associated with the identified location of the avatar. Specifically, for example, processing facility 104 may select an impulse response from an impulse response library that includes a plurality of different impulse responses each corresponding to a different subspace of the extended reality world. The impulse response selected may correspond to a particular subspace that is associated with the identified location of the avatar. For instance, the particular subspace may be a subspace within which the avatar is located or to which the avatar is proximate. As will be described in more detail below, in certain examples, multiple impulse responses may be selected from the library in order to combine the impulse responses or otherwise utilize elements of multiple impulse responses as acoustics are simulated.
Processing facility 104 may also be configured to generate an audio stream based on the selected impulse response. For example, the audio stream may be generated such that, when the audio stream is rendered by the media player device, the audio stream presents sound to the user in accordance with simulated acoustics customized to the identified location of the avatar within the extended reality world. In this way, the sound presented to the user may be immersive to the user by comporting with what the user might expect to hear at the current location of his or her avatar within the extended reality world if the world were entirely real rather than simulated or partially simulated.
In some examples, system 100 may be configured to operate in real time so as to provide, receive, process, and/or use the data described above (e.g., data representative of an avatar location, impulse response data, audio stream data, etc.) immediately as the data is generated, updated, changed, or otherwise becomes available. As a result, system 100 may simulate spatially-varying acoustics of an extended reality based on relevant, real-time data so as to allow downstream processing of the audio stream to occur immediately and responsively to other things happening in the overall system. For example, the audio stream may dynamically change to persistently simulate sound as the sound should be heard at each ear of the avatar based on the real-time pose of the avatar within the extended reality world (i.e., the real time location of the avatar and the real-time direction the avatar's head is turned at any given moment).
As used herein, operations may be performed in “real time” when they are performed immediately and without undue delay. In some examples, real-time data processing operations may be performed in relation to data that is highly dynamic and time sensitive (e.g., data that becomes irrelevant after a very short time such as acoustic propagation data indicative of an orientation of a head of the avatar). As such, real-time operations will be understood to refer to those operations that simulate spatially-varying acoustics of an extended reality world based on data that is relevant and up-to-date, even while it will also be understood that real-time operations are not performed instantaneously.
To illustrate the context in which system 100 may be configured to simulate spatially-varying acoustics of an extended reality world,
In order to experience extended reality world 200,
Along with illustrating user 202 and media player device 204,
In
User 202 may also perceive sound to be different based on where one or more sound sources are located within world 200. For instance, a second avatar 206 representing or otherwise associated with another user (i.e., a user other than user 202 who is not explicitly shown in
While
In various examples, any of various types of virtual sound sources may be present in an extended reality world such as world 200. For example, virtual sound sources may include various types of living characters such as avatars of users experiencing world 200 (e.g., avatars 202, 206, and so forth), non-player characters (e.g., a virtual person, a virtual animal or other creature, etc., that is not associated with a user), embodied intelligent assistants (e.g., an embodied assistant implementing APPLE's “Siri,” AMAZON's “Alexa,” etc.), and so forth. As another example, virtual sound sources may include virtual loudspeakers or other non-character based sources of sound that may present diegetic media content (i.e., media content that is to be perceived as originating at a particular source within world 106 rather than as originating from a non-diegetic source that is not part of world 106), and so forth.
As has been described, system 100 may simulate spatially-varying acoustics of an extended reality world by selecting and updating appropriate impulse responses (e.g., impulse responses corresponding to the respective locations of avatar 202 and/or avatar 206 and other sound sources) from a library of available impulse responses as avatar 202 and/or the sound sources (e.g., avatar 206) move about in world 200. To this end, world 200 may be divided into a plurality of different subspaces, each of which contains or is otherwise associated with various locations in space at which a listener or sound source could be located, and each of which is associated with a particular impulse response within the impulse response library. World 200 may be divided into subspaces in any manner as may serve a particular implementation, and each subspace into which world 200 is divided may have any suitable size, shape, or geometry.
To illustrate,
World 200 is shown from a top view in
Larger numbers of subspaces that a given extended reality world is divided into may correspond with smaller subspace areas or volumes. As such, more subspaces may equate to an increased resolution and more accurate representation, location to location, of the simulated effect of the associated impulse response of each subspace. Consequently, it will be understood that the more impulse responses are available to system 100 in the impulse response library, the more accurately system 100 may model sound for locations across world 200, and, while sixteen subspaces are shown in
In other configurations, it will be understood that system 100 may be partially or fully implemented by other systems or devices. For instance, certain elements of system 100 may be implemented by provider system 402, by a third party cloud computing server, or by any other system as may serve a particular implementation (e.g., including a standalone system dedicated to performing operations for simulating spatially-varying acoustics of extended reality worlds).
System 100 is shown to receive audio data 410 from one or more audio data sources not explicitly shown in configuration 400. System 100 is also shown to include, be coupled with, or have access to an impulse response library 412. In this way, system 100 may perform any of the operations described herein to simulate spatially-varying acoustics of an extended reality world and ultimately generate an audio stream 414 to be transmitted to audio rendering system 204-2 of media player device 402 (e.g., from MEC server 408 if system 100 is implemented by MEC server 408, or from a different part of media player device 204 if system 100 is implemented by media player device 204). Each of the components illustrated in configuration 400 will now be described in more detail.
Provider system 402 may be implemented by one or more computing devices or components managed and maintained by an entity that creates, generates, distributes, and/or otherwise provides extended reality media content to extended reality users such as user 202. For example, provider system 402 may include or be implemented by one or more server computers maintained by an extended reality provider. Provider system 402 may provide video data and/or other non-audio-related data representative of an extended reality world to media player device 204. Additionally, provider system 402 may be responsible for providing at least some of audio data 410 in certain implementations.
Collectively, networks 404 and 406 may provide data delivery means between server-side provider system 402 and client-side devices such as media player device 204 and other media player devices not explicitly shown in
Provider network 406 may provide, for media player device 204 and other media player devices not shown, communication access to provider system 402, to other media player devices, and/or to other systems and/or devices as may serve a particular implementation. Provider network 406 may be implemented by a provider-specific wired or wireless communications network (e.g., a cellular network used for mobile phone and data communications, a 4G or 5G network or network of another suitable technology generation, a cable or satellite carrier network, a mobile telephone network, etc.), and may be operated and/or managed by a provider entity such as a mobile network operator (e.g., a wireless service provider, a wireless carrier, a cellular company, etc.). The provider of provider network 406 may own and/or control all of the elements necessary to provide and deliver communications services for media player device 204 and/or other devices served by provider network 406 (e.g., other media player devices, mobile devices, loT devices, etc.). For example, the provider may own and/or control network elements including radio spectrum allocation, wireless network infrastructure, back haul infrastructure, provisioning of devices, network repair for provider network 406, and so forth.
Other networks 404 may include any interconnected network infrastructure that is outside of provider network 406 and outside of the control of the provider. For example, other networks 404 may include one or more of the Internet, a wide area network, a content delivery network, and/or any other suitable network or networks managed by any third parties outside of the control of the provider of provider network 406.
Various benefits and advantages may result when audio stream generation, including spatially-varying acoustics simulation described herein, is performed using multi-access servers such as MEC server 408. As used herein, a MEC server may refer to any computing device configured to perform computing tasks for a plurality of client systems or devices. MEC server 408 may be configured with sufficient computing power (e.g., including substantial memory resources, substantial storage resources, parallel central processing units (“CPUs”), parallel graphics processing units (“GPUs”), etc.) to implement a distributed computing configuration wherein devices and/or systems (e.g., including, for example, media player device 204) can offload certain computing tasks to be performed by the powerful resources of the MEC server. Because MEC server 408 is implemented by components of provider network 406 and is thus managed by the provider of provider network 406, MEC server 408 may be communicatively coupled with media player device 204 with relatively low latency compared to other systems (e.g., provider system 402 or cloud-based systems) that are managed by third party providers on other networks 404. Because only elements of provider network 406, and not elements of other networks 404, are used to connect media player device 204 to MEC server 408, the latency between media player device 204 and MEC server 408 may be very low and predictable (e.g., low enough that MEC server may perform operations with such low latency as to be perceived by user 202 as being instantaneous and without any delay).
While provider system 402 provides video-based extended reality media content to media player device 204, system 100 may be configured to provide audio-based extended reality media content to media player device 204 in any of the ways described herein. In certain examples, system 100 may operate in connection with another audio provider system (e.g., implemented within MEC server 408) that generates the audio stream that is to be rendered by media player device 204 (i.e., by audio rendering system 204-2) based on data generated by system 100. In other examples, system 100 may itself generate and provide audio stream 414 to the audio rendering system 204-2 of media player device 204 based on audio data 410 and based on one or more impulse responses from impulse response library 412.
Audio data 410 may include any audio data representative of any sound that may be present within world 200 (e.g., sound originating from any of the sound sources described above or any other suitable sound sources). For example, audio data 410 may be representative of voice chat spoken by one user (e.g., user 206) to be heard by another user (e.g., user 202), sound effects originating from any object within world 200, sound associated with media content (e.g., music, television, movies, etc.) being presented on virtual screens or loudspeakers within world 200, synthesized audio generated by non-player characters or automated intelligent assistants within world 200, or any other sound as may serve a particular implementation.
As mentioned above, in certain examples, some or all of audio data 410 may be provided (e.g., along with various other extended reality media content) by provider system 402 over networks 404 and/or 406. In certain of the same or other examples, audio data 410 may be accessed from other sources such as from a media content broadcast (e.g., a television, radio, or cable broadcast), another source unrelated to provider system 402, a storage facility of MEC server 408 or system 100 (e.g., storage facility 102), or any other audio data source as may serve a particular implementation.
Because it is desirable for media player device 204 to ultimately render audio that will mimic sound surrounding avatar 202 in world 200 from all directions (i.e., so as to make world 202 immersive to user 202), audio data 410 may be recorded and received in a spherical format (e.g., an ambisonic format), or, if recorded and received in another format (e.g., a monaural format, a stereo format, etc.), may be converted to a spherical format by system 100. For example, certain sound effects that are prerecorded and stored so as to be presented in connection with certain events or characters of a particular extended reality world may be recorded or otherwise generated using spherical microphones configured to generate ambisonic audio signals. In contrast, voice audio spoken by a user such as user 206 may be captured as a monaural signal by a single microphone, and may thus need to be converted to an ambisonic audio signal. Similarly, a stereo audio stream received as part of media content (e.g., music content, television content, movie content, etc.) that is received and is to be presented within world 200 may also be converted to an ambisonic audio signal.
Moreover, while spherical audio signals received or created in the examples above may be in recorded or generated as A-format ambisonic signals, it may be advantageous, prior to or as part of the audio processing performed by system 100, to convert the A-format ambisonic signals to B-format ambisonic signals that are configured to be readily rendered into binaural signals that can be presented to user 202 by audio rendering system 204-2.
To illustrate,
The A-format signal in
While an A-format signal such as shown in
While
Returning to
In certain implementations, each of the impulse responses included in impulse response library 412 may further correspond, along with corresponding to one of the different listener locations in the extended reality world, to an additional subspace 302 associated with a potential sound source location in world 200. In these implementations, system 100 may select an impulse response based on not only the subspace 302 within which avatar 202 is currently located (and/or a subspace 302 to which avatar 202 is currently proximate), but also based on a subspace 302 within which a sound source is currently located (or to which the sound source is proximate).
As shown in
While a relatively limited number of impulse responses are explicitly illustrated in
Each of the impulse responses included in an impulse response library such as impulse response library 412 may be generated at any suitable time and in any suitable way as may serve a particular implementation. For example, the impulse responses may be created and organized prior to the presentation of the extended reality world (e.g., prior to the identifying of the location of the avatar, as part of the creation of a preconfigured extended reality world or scene thereof, etc.). As another example, some or all of the impulse responses in impulse response library 412 may be generated or revised dynamically while the extended reality world is being presented to a user. For instance, impulse responses may be dynamically revised and updated as appropriate if it is detected that environmental factors within an extended reality world cause the acoustics of the world to change (e.g., as a result of virtual furniture being moved in the world, as a result of walls being broken down or otherwise modified, etc.). As another example in which impulse responses may be generated or revised dynamically, impulse responses may be initially created or modified (e.g., made more accurate) as a user directs an avatar to explore a portion of an extended reality world for the first time and as the portion of the extended reality world is dynamically mapped both visually and audibly for the user to experience.
As for the manner in which the impulse responses in a library such as impulse response library 412 are generated, any suitable method and/or technology may be employed. For instance, in some implementations, some or all of the impulse responses may be defined by recording the impulse responses using one or more microphones (e.g., an ambisonic microphone such as described above that is configured to capture an A-format ambisonic impulse response) placed at respective locations corresponding to the different subspaces of the extended reality world (e.g., placed in the center of each subspace 302 of world 200). For example, the microphones may record, from each particular listener location (e.g., locations at the center of each particular subspace 302), the sound heard at the listener location when an impulse sound representing a wide range of frequencies (e.g., a starter pistol, a sine sweep, a balloon pop, a chirp from 0-20 kHz, etc.) is made at each particular sound source location (e.g., the same locations at the center of each particular subspace 302).
In the same or other implementations, some or all of the impulse responses may be defined by synthesizing the impulse responses based on respective acoustic characteristics of the respective locations corresponding to the different subspaces of the extended reality world (e.g., based on how sound is expected to propagate to or from a center of each subspace 302 of world 200). For example, system 100 or another impulse response generation system separate from system 100 may be configured to perform a soundwave raytracing technique to determine how soundwaves originating at one point (e.g., a sound source location) will echo, reverberate, and otherwise propagate through an environment to ultimately arrive at another point in the world (e.g., a listener location).
In operation, system 100 may access a single impulse response from impulse response library 412 that corresponds to a current location of the listener (e.g., avatar 202) and the sound source (e.g., avatar 206, who, as described above, will be assumed to be speaking to avatar 202 in this example). To illustrate this example,
While this impulse response may well serve the presentation of sound to user 202 while both avatar 202 and avatar 206 are positioned in world 200 as shown in
Accordingly, system 100 may modify, based on the second impulse response (ImpulseResponse_10_07), the audio stream being generated such that, when the audio stream is rendered by the media player device, the audio stream presents sound to user 202 in accordance with simulated acoustics customized to location 702-1 in subspace 302-10, rather than to the original identified location in subspace 302-14. In some examples, this modification may take place gradually such that a smooth transition from effects associated with ImpulseResponse_14_07 to effects associated with ImpulseResponse_10_07 are applied to sound presented to the user. For example, system 100 may crossfade or otherwise gradually transition from one impulse response (or combination of impulse responses) to another impulse response (or other combination of impulse responses) in a manner that sounds natural, continuous, and realistic to the user.
In the examples described above, it may be relatively straightforward for system 100 to determine the most appropriate impulse response because both the listener location (i.e., the location of avatar 202) and the source location (i.e., the location of avatar 206) are squarely contained within designated subspaces 302 at the center of their respective subspaces. Other examples in which avatars 202 and/or 206 are not so squarely positioned at the center of their respective subspaces, and/or in which multiple sound sources are present, however, may lead to more complex impulse response selection scenarios. In such scenarios, system 100 may be configured to select and apply more than one impulse response at a time to create an effect that mixes and makes use of elements of multiple selected impulse responses.
For instance, a scenario will be considered in which user 202 directs avatar 202 to move from the location shown in subspace 302-14 to a location 702-2 (which, as shown, is not centered in any subspace 302, but rather is proximate to a boundary between subspaces 302-14 and 302-15). In this example, the selecting of an impulse response by system 100 may include not only selecting the first impulse response (i.e., ImpulseResponse_14_07), but further selecting an additional impulse response that corresponds to subspace 302-15 (i.e., ImpulseResponse_15_07). Accordingly, the generating of the audio stream performed by system 100 may be performed based not only on the first impulse response (i.e., ImpulseResponse_14_07), but also further based on the additional impulse response (i.e., ImpulseResponse_15_07). In a similar scenario (or at a later time in the scenario described above), user 202 may direct avatar 202 to move to a location 702-3, which, as shown, is proximate to two boundaries (i.e., a corner) where subspaces 302-10, 302-11, 302-14, and 302-15 all meet. In this scenario, as in the example described above in relation to location 702-2, system 100 may be configured to select four impulse responses corresponding to the source location and to each of the four subspaces proximate to or containing location 702-3. Specifically, system 100 may select ImpulseResponse_10_07, ImpulseResponse_11_07, ImpulseResponse_14_07, and ImpulseResponse_15_07.
As another example, a scenario will be considered in which avatar 202 is still located at the location shown at the center of subspace 302-14, but where avatar 206 (i.e., the sound source in this example) moves from the location shown at the center of subspace 302-7 to a location 702-4 (which, as shown, is not centered in any subspace 302, but rather is proximate a boundary between subspaces 302-7 and 302-6). In this example, the selecting of an impulse response by system 100 may include not only selecting the first impulse response corresponding to the listener location subspace 302-14 and the original source location subspace 302-7 (i.e., ImpulseResponse_14_07), but further selecting an additional impulse response that corresponds to the listener location subspace 302-14 (assuming that avatar 202 has not also moved) and to source location subspace 302-6 to which location 702-4 is proximate. Accordingly, the generating of the audio stream performed by system 100 may be performed based not only on the first impulse response (i.e., ImpulseResponse_14_07), but also further based on the additional impulse response (i.e., ImpulseResponse_14_06). While not explicitly described herein, it will be understood that, in additional examples, appropriate combinations of impulse responses may be selected when either or both of the listener and the sound source move to other locations in world 200 (e.g., four impulse responses if avatar 206 moves near a corner connecting four subspaces 302, up to eight impulse responses if both avatars 202 and 206 are proximate corners connecting four subspaces 302, etc.).
As yet another example, a scenario will be considered in which avatar 202 is still located at the location shown at the center of subspace 302-14, but where, instead of avatar 206 serving as the sound source, a first and a second sound source located, respectively, at a location 702-5 and a location 702-6 originate virtual sound that propagates through world 200 to avatar 202 (who is still the listener in this example). In this example, the selecting of an impulse response by system 100 may include selecting a first impulse response that corresponds to subspace 302-14 associated with the identified location of avatar 202 and to subspace 302-2, which is associated with location 702-5 of the first sound source. For example, this first impulse response may be ImpulseResponse_14_02. Moreover, the selecting of the impulse response by system 100 may further include selecting an additional impulse response that corresponds to subspace 302-14 associated with the identified location of avatar 202 and to subspace 302-12, which is associated with location 702-6 of the second sound source. For example, this additional impulse response may be ImpulseResponse_14_12. In this scenario, the generating of the audio stream by system 100 may be performed based on both the first impulse response (i.e., ImpulseResponse_14_02) as well as the additional impulse response (i.e., ImpulseResponse_14_12).
Returning to
World propagation data, as used herein, may refer to data that dynamically describes propagation effects of a variety of virtual sound sources from which virtual sounds heard by avatar 202 may originate. For example, world propagation data may include real-time information about poses, sizes, shapes, materials, and environmental considerations of one or more virtual sound sources included in world 206. Thus, for example, if avatar 206 turns to face avatar 202 directly or moves closer to avatar 202, world propagation data may include data describing this change in pose that may be used to make the audio more prominent (e.g., louder, more pronounced, etc.) in audio stream 414. In contrast, world propagation data may similarly include data describing a pose change of the virtual sound source when turning to face away from avatar 202 and/or moving farther from avatar 202, and this data may be used to make the audio less prominent (e.g., quieter, fainter, etc.) in audio stream 414. Effects that are applied to sounds presented to user 202 based on world propagation may augment or serve as an alternative to effects on the sound achieved by applying one or more of the impulse responses from impulse response library 412.
Head pose data may describe real-time pose changes of avatar 202 itself. For example, head pose data may describe movements (e.g., head turn movements, point-to-point walking movements, etc.) or control actions performed by user 202 that cause avatar 202 to change pose within world 200. When user 202 turns his or her head, for example, interaural time differences, interaural level differences, and other cues that may assist user 202 in localizing sounds may need to be recalculated and adjusted in a binaural audio stream being provided to media player device 204 (e.g., audio stream 414) in order to properly model how virtual sound arrives at the virtual ears of avatar 202. Head pose data thus tracks these types of variables and provides them to system 100 so that head turns and other movements of user 202 may be accounted for in real time as impulse responses are selected and applied, and as audio stream 414 is generated and provided to media player device 204 for presentation to user 202. For instance, based on head pose data, system 100 may use digital signal processing techniques to model virtual body parts of avatar 202 (e.g., the head, ears, pinnae, shoulders, etc.) and perform binaural rendering of audio data that accounts for how those virtual body parts affect the virtual propagation of sound to avatar 202. To this end, system 100 may determine a head related transfer function (“HRTF”) for avatar 202 and may employ the HRTF as the digital signal processing is performed to generate the binaural rendering of audio stream 414 so as to mimic the sound avatar 202 would hear if the virtual sound propagation and virtual body parts of avatar 202 were real.
Because of the low-latency nature of MEC server 408, system 100 may receive real-time acoustic propagation data from media player device 204 regardless of whether system 100 is implemented as part of media player device 204 itself or is integrated with MEC server 408. Moreover, system 100 may be configured to return audio stream 414 to media player device 204 with a small enough delay that user 202 perceives the presented audio as being instantaneously responsive to his or her actions (e.g., head turns, etc.). For example, real-time acoustic propagation data accessed by system 100 may include head pose data representative of a real-time pose (e.g., including a position and an orientation) of avatar 202 at a first time while user 202 is experiencing world 200, and the transmitting of audio stream 414 by system 100 may be performed at a second time that is within a predetermined latency threshold after the first time. For instance, the predetermined latency threshold may be about 10 ms, 20 ms, 50 ms, 100 ms, or any other suitable threshold amount of time that is determined, in a psychoacoustic analysis of users such as user 202, to result in sufficiently low-latency responsiveness to immerse the users in world 200 without perceiving that sound being presented has any delay.
In order to illustrate how system 100 may generate audio stream 414 to simulate spatially-varying acoustics of world 200,
Dry audio stream 802 may be received by system 100 from any suitable audio source. For instance, audio stream 802 may be included as one of several streams or signals represented by audio data 410 illustrated in
Impulse response 804 may represent any impulse response or combination of impulse responses selected from impulse response library 412 in the ways described herein. As shown, impulse response 804 is a spherical impulse response that, like audio stream 802, includes components associated with each of x, y, z, and w components of coordinate system 504. System 100 may apply spherical impulse response 804 to spherical audio stream 802 to imbue audio stream 802 with reverberation effects and other environmental acoustics associated with the one or more impulse responses that have been selected from the impulse response library. As described above, one impulse response 804 may smoothly transition or crossfade to another impulse response 804 as user 202 moves within world 200 from one subspace 302 to another.
Impulse response 804 may be generated or synthesized in any of the ways described herein, including by combining elements from a plurality of selected impulse responses in scenarios such as those described above in which the listener or sound source location is near a subspace boundary, or multiple sound sources exist. Impulse responses may be combined to form impulse response 804 in any suitable way. For instance, multiple spherical impulse responses may be synthesized together to form a single spherical impulse response used as the impulse response 804 that is applied to audio stream 802. In other examples, averaging (e.g., weighted averaging) techniques may be employed in which respective portions from each of several impulse responses for a given component of the coordinate system are averaged. In still other examples, each of multiple spherical impulse responses may be individually applied to dry audio stream 802 (e.g., by way of separate convolution operations 806) to form a plurality of different wet audio streams 808 that may be mixed, averaged, or otherwise combined after the fact.
Convolution operation 806 may represent any mathematical operation by way of which impulse response 804 is applied to dry audio stream 802 to form wet audio stream 808. For example, convolution operation 806 may use convolution reverb techniques to apply a given impulse response 804 and/or to crossfade from one impulse response 804 to another in a continuous and natural-sounding manner. As shown, when convolution operation 806 is used to apply a spherical impulse response to a spherical audio stream (e.g., impulse response 804 to audio stream 802), a spherical audio stream (e.g., wet audio stream 808) results that also includes different components for each of the x, y, z, and w coordinate system components. In some examples, it will be understood that non-spherical impulse responses may be applied to non-spherical audio streams using a convolution operation similar to convolution operation 806. For example, the input and output of convolution operation 806 could be monaural, stereo, or another suitable format. Such non-spherical signals, together with additional spherical signals and/or any other signals being processed in parallel with audio stream 808 within system 100 may be represented in
As shown, mixer 812 is configured to combine the wet audio stream 808 with the dry audio stream 802, as well as any other audio signals 810 that may be available in a given example. Mixer 812 may be configurable to deliver any amount of wet or dry signal in the final mixed signal as may be desired by a given user or for a given use scenario. For instance, if mixer 812 relies heavily on wet audio stream 808, the reverberation and other acoustic effects of impulse response 804 will be very pronounced and easy to hear in the final mix. Conversely, if mixer 812 relies heavily on dry audio stream 802, the reverberation and other acoustic effects of impulse response 804 will be less pronounced and more subtle in the final mix. Mixer 812 may also be configured to convert incoming signals (e.g., wet and dry audio streams 808 and 802, other audio signals 810, etc.) to different formats as may serve a particular application. For example, mixer 812 may convert non-spherical signals to spherical formats (e.g., ambisonic formats such as the B-format) or may convert spherical signals to non-spherical formats (e.g., stereo formats, surround sound formats, etc.) as may serve a particular implementation.
Binaural renderer 814 may receive an audio stream (e.g., a mix of the wet and dry audio streams 808 and 802 described above) together with, in certain examples, one or more other audio signals 810 that may be spherical or any other suitable format. Additionally, binaural renderer 814 may receive (e.g., from media player device 204) acoustic propagation data 816 indicative of an orientation of a head of avatar 202. Binaural renderer 814 generates audio stream 414 as a binaural audio stream using the input audio streams from mixer 812 and other audio signals 810 and based on acoustic propagation data 816. More specifically, for example, binaural renderer 814 may convert the audio streams received from mixer 812 and/or other audio signals 810 into a binaural audio stream that includes proper sound for each ear of user 202 based on the direction that the head of avatar 202 is facing within world 200. As with mixer 802, signal processing performed by binaural renderer 814 may include converting to and from different formats (e.g., converting a non-spherical signal to a spherical format, converting a spherical signal to a non-spherical format, etc.). The binaural audio stream generated by binaural renderer 814 may be provided to media player device 204 as audio stream 414, and may be configured to be presented to user 202 by media player device 204 (e.g., by audio rendering system 204-2 of media player device 204). In this way, sound presented by media player device 204 to user 202 may be presented in accordance with the simulated acoustics customized to the identified location of avatar 202 in world 200, as has been described.
In operation 902, an acoustics simulation system may identify a location within an extended reality world. For example, the location identified by the acoustics simulation system may be a location of an avatar of a user who is using a media player device to experience, via the avatar, the extended reality world from the identified location. Operation 902 may be performed in any of the ways described herein.
In operation 904, the acoustics simulation system may select an impulse response from an impulse response library. For example, the impulse response library may include a plurality of different impulse responses each corresponding to a different subspace of the extended reality world, and the selected impulse response may correspond to a particular subspace of the different subspaces of the extended reality world. More particularly, the particular subspace to which the selected impulse response corresponds may be associated with the identified location. Operation 904 may be performed in any of the ways described herein.
In operation 906, the acoustics simulation system may generate an audio stream based on the impulse response selected at operation 904. For example, the generated audio stream may be configured, when rendered by the media player device, to present sound to the user in accordance with simulated acoustics customized to the identified location of the avatar within the extended reality world. Operation 906 may be performed in any of the ways described herein.
In operation 1002, an acoustics simulation system implemented by a MEC server may identify a location within an extended reality world. For instance, the location identified by the acoustics simulation system may be a location of an avatar of a user as the user uses a media player device to experience, via the avatar, the extended reality world from the identified location. Operation 1002 may be performed in any of the ways described herein.
In operation 1004, the acoustics simulation system may select an impulse response from an impulse response library. The impulse response library may include a plurality of different impulse responses each corresponding to a different subspace of the extended reality world, and the selected impulse response may correspond to a particular subspace of the different subspaces of the extended reality world that is associated with the identified location. Operation 1004 may be performed in any of the ways described herein.
In operation 1006, the acoustics simulation system may receive acoustic propagation data. For instance, the acoustic propagation data may be received from the media player device. In some examples, the received acoustic propagation data may be indicative of an orientation of a head of the avatar. Operation 1006 may be performed in any of the ways described herein.
In operation 1008, the acoustics simulation system may generate an audio stream based on the impulse response selected at operation 1004 and the acoustic propagation data received at operation 1006. The audio stream may be configured, when rendered by the media player device, to present sound to the user in accordance with simulated acoustics customized to the identified location of the avatar within the extended reality world. Operation 1008 may be performed in any of the ways described herein.
In operation 1010, the acoustics simulation system may provide the audio stream generated at operation 1008 to the media player device for rendering by the media player device. Operation 1010 may be performed in any of the ways described herein.
In some examples, a non-transitory computer-readable medium storing computer-readable instructions may be provided in accordance with the principles described herein. The instructions, when executed by a processor of a computing device, may direct the processor and/or computing device to perform one or more operations, including one or more of the operations described herein. Such instructions may be stored and/or transmitted using any of a variety of known computer-readable media.
A non-transitory computer-readable medium as referred to herein may include any non-transitory storage medium that participates in providing data (e.g., instructions) that may be read and/or executed by a computing device (e.g., by a processor of a computing device). For example, a non-transitory computer-readable medium may include, but is not limited to, any combination of non-volatile storage media and/or volatile storage media. Exemplary non-volatile storage media include, but are not limited to, read-only memory, flash memory, a solid-state drive, a magnetic storage device (e.g. a hard disk, a floppy disk, magnetic tape, etc.), ferroelectric random-access memory (“RAM”), and an optical disc (e.g., a compact disc, a digital video disc, a Blu-ray disc, etc.). Exemplary volatile storage media include, but are not limited to, RAM (e.g., dynamic RAM).
As shown in
Communication interface 1102 may be configured to communicate with one or more computing devices. Examples of communication interface 1102 include, without limitation, a wired network interface (such as a network interface card), a wireless network interface (such as a wireless network interface card), a modem, an audio/video connection, and any other suitable interface.
Processor 1104 generally represents any type or form of processing unit capable of processing data and/or interpreting, executing, and/or directing execution of one or more of the instructions, processes, and/or operations described herein. Processor 1104 may perform operations by executing computer-executable instructions 1112 (e.g., an application, software, code, and/or other executable data instance) stored in storage device 1106.
Storage device 1106 may include one or more data storage media, devices, or configurations and may employ any type, form, and combination of data storage media and/or device. For example, storage device 1106 may include, but is not limited to, any combination of the non-volatile media and/or volatile media described herein. Electronic data, including data described herein, may be temporarily and/or permanently stored in storage device 1106. For example, data representative of computer-executable instructions 1112 configured to direct processor 1104 to perform any of the operations described herein may be stored within storage device 1106. In some examples, data may be arranged in one or more databases residing within storage device 1106.
I/O module 1108 may include one or more I/O modules configured to receive user input and provide user output. I/O module 1108 may include any hardware, firmware, software, or combination thereof supportive of input and output capabilities. For example, I/O module 1108 may include hardware and/or software for capturing user input, including, but not limited to, a keyboard or keypad, a touchscreen component (e.g., touchscreen display), a receiver (e.g., an RF or infrared receiver), motion sensors, and/or one or more input buttons.
I/O module 1108 may include one or more devices for presenting output to a user, including, but not limited to, a graphics engine, a display (e.g., a display screen), one or more output drivers (e.g., display drivers), one or more audio speakers, and one or more audio drivers. In certain embodiments, I/O module 1108 is configured to provide graphical data to a display for presentation to a user. The graphical data may be representative of one or more graphical user interfaces and/or any other graphical content as may serve a particular implementation.
In some examples, any of the facilities described herein may be implemented by or within one or more components of computing device 1100. For example, one or more applications 1112 residing within storage device 1106 may be configured to direct processor 1104 to perform one or more processes or functions associated with processing facility 104 of system 100. Likewise, storage facility 102 of system 100 may be implemented by or within storage device 1106.
To the extent the aforementioned embodiments collect, store, and/or employ personal information provided by individuals, it should be understood that such information shall be used in accordance with all applicable laws concerning protection of personal information. Additionally, the collection, storage, and use of such information may be subject to consent of the individual to such activity, for example, through well known “opt-in” or “opt-out” processes as may be appropriate for the situation and type of information. Storage and use of personal information may be in an appropriately secure manner reflective of the type of information, for example, through various encryption and anonymization techniques for particularly sensitive information.
In the preceding description, various exemplary embodiments have been described with reference to the accompanying drawings. It will, however, be evident that various modifications and changes may be made thereto, and additional embodiments may be implemented, without departing from the scope of the invention as set forth in the claims that follow. For example, certain features of one embodiment described herein may be combined with or substituted for features of another embodiment described herein. The description and drawings are accordingly to be regarded in an illustrative rather than a restrictive sense.
This application is a continuation application of U.S. patent application Ser. No. 16/599,958, filed Oct. 11, 2019, and entitled “Methods and Systems for Simulating Spatially-Varying Acoustics of an Extended Reality World,” which is hereby incorporated by reference in its entirety.
Number | Name | Date | Kind |
---|---|---|---|
5526429 | Inanaga | Jun 1996 | A |
5761314 | Inanaga | Jun 1998 | A |
6111962 | Akio | Aug 2000 | A |
9197977 | Mahabub | Nov 2015 | B2 |
9522330 | Pile | Dec 2016 | B2 |
10062208 | Ziman | Aug 2018 | B2 |
10206055 | Mindlin et al. | Feb 2019 | B1 |
10297981 | Bovington et al. | May 2019 | B2 |
10484811 | Mindlin et al. | Nov 2019 | B1 |
10516959 | Mindlin et al. | Dec 2019 | B1 |
10705790 | Dantrey | Jul 2020 | B2 |
10757528 | Mindlin | Aug 2020 | B1 |
10820135 | Boerum | Oct 2020 | B2 |
20090066690 | Harrison | Mar 2009 | A1 |
20100119075 | Xiang | May 2010 | A1 |
20140368543 | Hamilton et al. | Dec 2014 | A1 |
20150331666 | Bucsa et al. | Nov 2015 | A1 |
20160313790 | Clement et al. | Oct 2016 | A1 |
20170045941 | Tokubo et al. | Feb 2017 | A1 |
20180181367 | Goi | Jun 2018 | A1 |
20190099678 | Khan et al. | Apr 2019 | A1 |
20190385613 | Mindlin et al. | Dec 2019 | A1 |
Number | Date | Country | |
---|---|---|---|
20210112361 A1 | Apr 2021 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 16599958 | Oct 2019 | US |
Child | 16934651 | US |