Aspects of the present application relate to electronic gaming. More specifically, to methods and systems for surround sound processing in a headset.
Limitations and disadvantages of conventional approaches to audio processing for gaming will become apparent to one of skill in the art, through comparison of such approaches with some aspects of the present method and system set forth in the remainder of this disclosure with reference to the drawings.
Methods and systems are provided for surround sound processing in a headset, substantially as illustrated by and/or described in connection with at least one of the figures, as set forth more completely in the claims.
The game console 176 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to present a game to, and also enable game play interaction between, one or more local players and/or one or more remote players. The game console 176 which may be, for example, a Windows computing device, a Unix computing device, a Linux computing device, an Apple OSX computing device, an Apple iOS computing device, an Android computing device, a Microsoft Xbox, a Sony Playstation, a Nintendo Wii, or the like. The example game console 176 comprises a radio 126, network interface 130, video interface 132, audio interface 134, controller hub 150, main system on chip (SoC) 148, memory 162, optical drive 172, and storage device 174. The SoC 148 comprises central processing unit (CPU) 154, graphics processing unit (GPU) 156, audio processing unit (APU) 158, cache memory 164, and memory management unit (MMU) 166. The various components of the game console 176 are communicatively coupled through various buses/links 136, 138, 142, 144, 146, 152, 160, 168, and 170.
The controller hub 150 comprises circuitry that supports one or more data bus protocols such as High-Definition Multimedia Interface (HDMI), Universal Serial Bus (USB), Serial Advanced Technology Attachment II, III or variants thereof (SATA II, SATA III), embedded multimedia card interface (e.MMC), Peripheral Component Interconnect Express (PCIe), or the like. The controller hub 150 may also be referred to as an input/output (I/O) controller hub. Exemplary controller hubs may comprise Southbridge, Haswell, Fusion and Sandybridge. The controller hub 150 may be operable to receive audio and/or video from an external source via link 112 (e.g., HDMI), from the optical drive (e.g., Blu-Ray) 172 via link 168 (e.g., SATA II, SATA III), and/or from storage 174 (e.g., hard drive, FLASH memory, or the like) via link 170 (e.g., SATA II, III and/or e.MMC). Digital audio and/or video is output to the SoC 148 via link 136 (e.g., CEA-861-E compliant video and IEC 61937 compliant audio). The controller hub 150 exchanges data with the radio 126 via link 138 (e.g., USB), with external devices via link 140 (e.g., USB), with the storage 174 via the link 170, and with the SoC 148 via the link 152 (e.g., PCIe).
The radio 126 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to communicate in accordance with one or more wireless standards such as the IEEE 802.11 family of standards, the Bluetooth family of standards, near field communication (NFC), and/or the like.
The network interface 130 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to communicate in accordance with one or more wired standards and to convert between wired standards. For example, the network interface 130 may communicate with the SoC 148 via link 142 using a first standard (e.g., PCIe) and may communicate with the network 106 using a second standard (e.g., gigabit Ethernet).
The video interface 132 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to communicate video in accordance with one or more wired or wireless video transmission standards. For example, the video interface 132 may receive CEA-861-E compliant video data via link 144 and encapsulate/format, etc., the video data in accordance with an HDMI standard for output to the monitor 108 via an HDMI link 120.
The audio interface 134 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to communicate audio in accordance with one or more wired or wireless audio transmission standards. For example, the audio interface 134 may receive CEA-861-E compliant audio data via the link 146 and encapsulate/format, etc., the video data in accordance with an HDMI standard for output to the audio subsystem 110 via an link 122.
The central processing unit (CPU) 154 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to execute instructions for controlling/coordinating the overall operation of the game console 176. Such instructions may be part of an operating system of the console and/or part of one or more software applications running on the console.
The graphics processing unit (CPU) 156 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to perform graphics processing functions such as compression, decompression, encoding, decoding, 3D rendering, and/or the like.
The audio processing unit (APU) 158 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to perform audio processing functions such as volume/gain control, compression, decompression, encoding, decoding, surroundsound processing, and/or the like to generate one or more output audio signals (e.g., left channel and right channel signals for stereo; or front left channel, center channel, front right channel, left side channel, right side channel, left rear channel, right rear channel, and subwoofer channel signals for 7.1 surround). The APU 158 comprises memory (e.g., volatile and/or non-volatile memory) 159 which stores parameter settings to affect processing of audio by the APU 158. For example, the parameter settings may include a first audio gain/volume setting that determines, at least in part, a volume of game audio output by the console 176 and a second audio gain/volume setting that determines, at least in part, a volume of chat audio output by the console 176. The parameter settings may be modified via a graphical user interface (GUI) of the console and/or via an application programming interface (API) provided by the console 176.
The cache memory 164 may comprise suitable logic, circuitry, interfaces and/or code that may provide high-speed memory functions for use by the CPU 154, GPU 156, and/or APU 158. The cache memory 164 may typically comprise DRAM or variants thereof. The memory 162 may comprise additional memory for use by the CPU 154, GPU 156, and/or APU 158. The memory 162, typically DRAM, may operate at a slower speed than the cache memory 164 but may also be less expensive than cache memory as well as operate at a higher speed than the memory of the storage device 174. The MMU 166 controls accesses by the CPU 154, GPU 156, and/or APU 158 to the memory 162, the cache 164, and/or the storage device 174.
In
Each of the user interface devices 102 and 104 may comprise, for example, a game controller, a keyboard, a motion sensor/position tracker, or the like. The user interface device 102 communicates with the game console 176 wirelessly via link 114 (e.g., Wi-Fi Direct, Bluetooth, NFC and/or the like). The user interface device 102 may be operable to communicate with the game console 176 via the wired link 140 (e.g., USB or the like).
The network 106 comprises a local area network and/or a wide area network. The game console 176 communicates with the network 106 via wired link 118 (e.g., Gigabit Ethernet).
The monitor 108 may be, for example, a LCD, OLED, or PLASMA screen. The game console 176 sends video to the monitor 108 via link 120 (e.g., HDMI).
The audio subsystem 110 may be, for example, a headset, a combination of headset and audio basestation, or a set of speakers and accompanying audio processing circuitry. The game console 176 sends audio to the audio subsystem 110 via link(s) 122 (e.g., S/PDIF for digital audio or "line out" for analog audio). Additional details of an example audio subsystem 110 are described below.
The monitor 108 and the user interface device 102 are as described above. The headset 200 is as described below with reference to
The multi-purpose device 192 may comprise, for example, a tablet computer, a smartphone, a laptop computer, or the like and that runs an operating system such as Android, Linux, Windows, iOS, OSX, or the like. An example multi-purpose device is described below with reference to
The peripheral devices 102, 108, 192, 200, 300 are in communication with one another via a plurality of wired and/or wireless links (represented visually by the placement of the devices in the cloud of GPN 190). Each of the peripheral devices in the gaming peripheral network (GPN) 190 may communicate with one or more others of the peripheral devices in the GPN 190 in a single-hop or multi-hop fashion. For example, the headset 200 may communicate with the basestation 301 in a single hop (e.g., over a proprietary RF link) and with the device 192 in a single hop (e.g., over a Bluetooth or Wi-Fi direct link), while the tablet may communicate with the basestation 301 in two hops via the headset 200. As another example, the user interface device 102 may communicate with the headset 200 in a single hop (e.g., over a Bluetooth or Wi-Fi direct link) and with the device 192 in a single hop (e.g., over a Bluetooth or Wi-Fi direct link), while the device 192 may communicate with the headset 200 in two hops via the user interface device 102. These example interconnections among the peripheral devices of the GPN 190 are merely examples, any number and/or types of links and/or hops among the devices of the GPN 190 is possible.
The GPN 190 may communicate with the console 176 via any one or more of the connections 114, 140, 122, and 120 described above. The GPN 190 may communicate with a network 106 via one or more links 194 each of which may be, for example, Wi-Fi, wired Ethernet, and/or the like.
A database 182 which stores gaming audio data is accessible via the network 106. The gaming audio data may comprise, for example, signatures of particular audio clips (e.g., individual sounds or collections or sequences of sounds) that are part of the game audio of particular games, of particular levels/scenarios of particular games, particular characters of particular games, etc. In an example implementation, the database 182 may comprise a plurality of records 183, where each record 183 comprises an audio clip (or signature of the clip) 184, a description of the clip 184 (e.g., the game it is from, when it occurs in the game, etc.), one or more gaming commands 186 associated with the clip, one or more parameter settings 187 associated with the clip, and/or other data associated with the audio clip. Records 183 of the database 182 may be downloadable to, or accessed in real-time by, one of more devices of the GPN 190.
The connector 210 may be, for example, a 3.5 mm headphone socket for receiving analog audio signals (e.g., receiving chat audio via an Xbox "talkback" cable).
The microphone 204 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to convert acoustic waves (e.g., the voice of the person wearing the headset) to electric signals for processing by circuitry of the headset and/or for output to a device (e.g., console 176, basestation 301, a smartphone, and/or the like) that is in communication with the headset.
The speakers 216a and 216b may comprise circuitry that may be operable to convert electrical signals to sound waves.
The user controls 212 may comprise dedicated and/or programmable buttons, switches, sliders, wheels, etc. for performing various functions. Example functions which the controls 212 may be configured to perform include: power the headset 200 on/off, mute/unmute the microphone 204, control gain/volume of, and/or effects applied to, chat audio by the audio processing circuitry of the headset 200, control gain/volume of, and/or effects applied to, game audio by the audio processing circuitry of the headset 200, enable/disable/initiate pairing (e.g., via Bluetooth, Wi-Fi direct, NFC, or the like) with another computing device, and/or the like. Some of the user controls 212 may adaptively and/or dynamically change during gameplay based on a particular game that is being played. Some of the user controls 212 may also adaptively and/or dynamically change during gameplay based on a particular player that is engage in the game play. The connector 214 may be, for example, a USB, thunderbolt, Firewire or other type of port or interface. The connector 214 may be used for downloading data to the headset 200 from another computing device and/or uploading data from the headset 200 to another computing device. Such data may include, for example, parameter settings (described below). Additionally, or alternatively, the connector 214 may be used for communicating with another computing device such as a smartphone, tablet computer, laptop computer, or the like.
The radio 220 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to communicate in accordance with one or more standardized (such as, for example, the IEEE 802.11 family of standards, NFC, the Bluetooth family of standards, and/or the like) and/or proprietary wireless protocol(s) (e.g., a proprietary protocol for receiving audio from an audio basestation such as the basestation 301).
The CPU 222 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to execute instructions for controlling/coordinating the overall operation of the headset 200. Such instructions may be part of an operating system or state machine of the headset 200 and/or part of one or more software applications running on the headset 200. In some implementations, the CPU 222 may be, for example, a programmable interrupt controller, a state machine, or the like.
The CPU 222 may also be operable to handle surround sound processing of a received plurality of audio signals of a corresponding plurality of surround sound channels. In this regard, the CPU 222 may be operable to control operation of the audio processing circuit 230 in order to control and/or manage analysis of the context and the content of the audio signals received by the headset 200.
The storage device 224 may comprise suitable logic, circuitry, interfaces and/or code that may comprise, for example, FLASH or other nonvolatile memory, which may be operable to store data comprising operating data, configuration data, settings, and so on, which may be used by the CPU 222 and/or the audio processing circuit 230. Such data may include, for example, parameter settings that affect processing of audio signals in the headset 200 and parameter settings that affect functions performed by the user controls 212. For example, one or more parameter settings may determine, at least in part, a gain of one or more gain elements of the audio processing circuit 230. As another example, one or more parameter settings may determine, at least in part, a frequency response of one or more filters that operate on audio signals in the audio processing circuit 230. As another example, one or more parameter settings may determine, at least in part, whether and which sound effects are added to audio signals in the audio processing circuit 230 (e.g., which effects to add to microphone audio to morph the user's voice). Example parameter settings which affect audio processing are described in the co-pending U.S. Pat. Application 13/040,144 titled "Gaming Headset with Programmable Audio" and published as US2012/0014553, the entirety of which is hereby incorporated herein by reference. Particular parameter settings may be selected autonomously by the headset 200 in accordance with one or more algorithms, based on user input (e.g., via controls 212), and/or based on input received via one or more of the connectors 210 and 214.
The storage device 224 may also be operable to store information and/or data that may be utilized to analyze the context and content of received audio signals. For example, the storage device 224 may be operable to store audio information corresponding to a plurality of audio processing modes, the listener default preferences, and/or listener preferences for specific games, songs, albums, and/or movies.
In another embodiment of the disclosure, the CPU 222 may be operable to configure the audio processing circuit 230 to perform signal analysis on the audio signals received via the connector 210 and/or the radio 220. The signal analysis may be utilized to determine the content and context of the audio signals so that the audio processing circuit 230 may process the audio signals to generate output audio signals that provide a customized listening experience for the listener.
In some embodiments of the disclosure, the CPU 222 may be operable to control the operation of the audio processing circuit 230 in order to store the results of the audio analysis along with an identifier of the game in the storage device 224. For non-gaming applications where the content does not vary, for example, music and movies, the CPU 222 may be operable to store results of the audio analysis in the storage device 224 so that it may be utilized during subsequent playback. The audio analysis may be executed the first time that the game is played using the headset 200. In some embodiments of the disclosure, information related to corresponding video may also be utilized as part of the analysis of the content and context and may be stored in the storage device 224.
The memory 226 may comprise suitable logic, circuitry, interfaces and/or code that may comprise volatile memory used by the CPU 222 and/or audio processing circuit 230 as program memory, for storing runtime data, etc. In this regard, the memory 226 may comprise information and/or data that may be utilized to control operation of the audio processing circuit 230 to perform signal analysis on the plurality of received audio signals.
The audio processing circuit 230 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to perform audio processing functions such as volume/gain control, compression, decompression, encoding, decoding, introduction of audio effects (e.g., echo, phasing, virtual surround effect, etc.), and/or the like. For example, the audio processing circuit 230 may be operable to receive five or more signals corresponding to five or more surround channels and process (e.g., adjust amplitudes, phases, and/or other characteristics) the signals to generate a pair of virtual surround stereo signals. As described above, the processing performed by the audio processing circuit 230 may be determined, at least in part, by which parameter settings have been selected. The processing performed by the audio processing circuit 230 may also be determined based on default settings, player preference, and/or by adaptive and/or dynamic changes to the game play environment. The processing may be performed on game, chat, and/or microphone audio that is subsequently output to speaker 216a and 216b. Additionally, or alternatively, the processing may be performed on chat audio that is subsequently output to the connector 210 and/or radio 220.
The audio processing circuit 230 may be operable to provide signal analysis on the received audio signals. In this regard, the audio processing circuit 230 may be operable to analyze the context and content of the received audio signals and process the corresponding audio signals so as to control simulated acoustic environment of a listener wearing the headset 200. The simulated acoustic environment may be characterized by, for example, perceived distances to sources of sounds in the audio signals, perceived distances to, and types of, surfaces in the simulated acoustic environment, and/or the like. For example, selection between a simulated "wooden concert hall" acoustic environment, a simulated "concrete concert hall" acoustic environment, a simulated "movie theater" acoustic environment, a simulated "playing in the band" acoustic environment, and a simulated "watching band from audience" acoustic environment may be performed based on the context and content of the audio signals. Such processing to adjust the simulated acoustic environment may comprise, for example, adjusting amplitudes, phases, delay and/or other characteristics of three or more received surround sound signals when combining the three or more signals to generate the virtual surround stereo signals. The virtual surround stereo signals may be such that, although there are only two signals and two speakers, the listener perceives three or more virtual audio channels (e.g., virtual center, virtual left front, virtual right front, virtual back left, and virtual back right).
In accordance with an embodiment of the disclosure, the audio processing circuit 230 may be operable to, for example, sample the content of the plurality of audio signals in order to determine the type of audio that is being carried by the plurality of audio signals. In an exemplary embodiment of the disclosure, the types of audio recognized by the audio processing circuitry may comprise game audio, movie audio, and music audio. In instances where the audio type comprises game audio, the audio processing circuit 230 may be operable to process the received audio signals so the virtual center channel may be perceived as being relatively close to the listener wearing the headset (e.g., right in front of the listener, who may be engaged in game play). For example, if the listener's character in the game is driving a car, the audio processing circuitry may be operable to process the received audio signals so that the engine of the car is perceived by the listener as being just in front of or behind the listener as would be the case in a real car, rather than being perceived as farther away than a car's engine could realistically be from the car's driver.
In instances where the audio type comprises movie audio, the audio processing circuit 230 may be operable to process at least a portion of the received audio signals to generate virtual surround stereo signals so that the listener perceives being surrounded by, and being in the center of, the corresponding sounds from the audio signals. For example, the audio processing circuit 230 may be operable to process the received signals to generate a virtual left side, virtual right side (RS), virtual left rear (LR), and virtual right rear (RR) audio channels that surround the listener.
In instances where the audio type comprises music audio, the audio processing circuit 230 may be operable to process the received audio signals to generate virtual surround stereo signals such that the listener perceives being part of an audience with the music originating from a stage in front of him/her, rather than perceiving the sound as if he/she is on the stage surrounded by the band. This may comprise, for example, attenuating, possibly to zero (i.e., muting), ones of the received signals corresponding to left rear and right rear audio channels for 5.1 surround, or attenuating, possibly to zero (i.e., muting), ones of the received signals corresponding to left side, left rear, right side, and right reach channels for 7.1 surround. For example, the audio processing circuit 230 may be operable to process the received audio signals to generate virtual left front, virtual center, and virtual right front that cause the listener to perceive audio as if the listener were in the audience watching a band on stage.
In accordance with an embodiment of the disclosure, the listener may have the capability to select the type of audio and/or the desired simulated acoustic environment. In some embodiments of the disclosure, the type of audio may be automatically detected and/or the best-suited simulated acoustic environment may be automatically selected by the audio processing circuit 230 and the CPU 222 based on, for example, listener preferences stored in memory, the state of the in-game environment, and so on. The state of the in-game environment may include, for example, the current scenario taking place in the game (e.g., what level the player is on; whether the player's character is walking, driving, fighting, talking, driving, etc.; and/or what the player's character is carrying, using, etc.), a current character being used by the player (e.g., man or woman character, tall or short character, etc.), the current viewpoint the player is using (e.g., first-person, third-person, or bird's-eye), and/or the like. In some embodiments of the disclosure, changes in the type of audio may be detected in or near real-time. In some embodiments of the disclosure, the selected simulated acoustic environment may adapt/change, in or near real-time, by the audio processing circuit 230 and the CPU 222 based on, for example, listener preferences stored in memory, the state of an environment in which the sound is generated, and so on in order to provide optimal user experience. Adaptive changes may occur in response to changes such as scenarios that take place or game features that may be unlocked or achieved during the game play.
In accordance with an embodiment of the disclosure, the audio processing circuit 230 and the CPU 222 may be operable to analyze the content carried by the plurality of audio signals in order to determine the best-suited simulated acoustic environment. For example, at a first time instant, t1, it may be determined that a first sound occurring in the received audio signals should be perceived as being closer to the listener while a second sound occurring in the received audio signals is perceived as being further away from the listener. In a subsequent time instant, t2, it may be determined that the second sound should be perceived as being close to the listener while the first sound is perceived as being further away from the listener. Accordingly, perceived distance of the listener to the source of the first sound and the second sound may be dynamically and/or adaptively moved in real-time. The audio processing circuit 230 may be operable to process and dynamically and/or adaptively adjust at least a portion of the plurality of audio signals channels to provide the desired or optimal simulated acoustic environment. In various embodiments of the disclosure, the audio processing circuit 230 may be operable to adjust the amplitude, phase, and/or other characteristics of selective ones of the received audio signals (e.g., received via connector 210 and/or radio 220) to provide the desired or optimal listener perception. For example, characteristics of the signals may be adjusted such that the virtual center channel may be moved close to the listener when a particular sound is present and moved further away from the listen when the particular sound is not present.
In accordance with an embodiment of the disclosure, the audio processing circuit 230 and the CPU 222 may be operable to sample the content carried by the plurality of audio signals in order to determine the state of the in-game environment. Once the state of the in-game environment is determined, the audio processing circuit 230 may be operable to selectively adjust levels, phase, and/or other characteristics one or more of the plurality of audio signals to provide the desired or optimal simulated location of the listener relative to various sounds present in the audio.
The audio processing circuit 230 and the CPU 222 may be operable to determine when, for example, the listener/player is utilizing a particular view. Whenever the particular view is detected, the audio processing circuit 230 and the CPU 222 may be operable to dynamically and/or adaptively adjust one or more virtual surround channels to provide the desired or optimal listener perception. For example, in instances when the listener/player is in a first-person view, the audio processing circuit 230 and the CPU 222 may be operable to detect the first person view and adjust the virtual center channel so that the listener perceives the sounds on the virtual center channel as being relatively close to him/her. In instances when the listener/player, is in a bird's eye view, the audio processing circuit 230 and the CPU 222 may be operable to detect the bird's eye view and adjust the virtual center channel so that the listener perceives the sounds on the virtual center channel as being relatively far from him/her.
In accordance with some embodiments of the disclosure, the context, may be determined based on metadata that may be extracted from the one or more of the plurality of audio signals. The context may include, for example, type of audio, state of the in-game environment, and/or the content of the audio. In this regard, the audio processing circuit 230 and the CPU 222 may be operable to inspect or examine the content carried by the one or more of the plurality of audio signals in order to determine the corresponding metadata.
In accordance with some embodiments of the disclosure, audio information or data corresponding to the context including the type of audio, and/or the state of the in-game environment, and the content of the audio, may be acquired from a database or information that may be stored in the storage device 224 or memory 226. The audio information or data corresponding to the context and/or content of the audio, may be loaded when for example, game play is initiated, a movie is started or a song or album is played. The CPU 222 may be operable to acquire the stored audio information for a particular game, movie, song or album from the storage device 224. In this regard, the CPU 222 may be operable to detect or determine the identity of the game, movie, song or album and acquire or load the corresponding stored audio information from the storage device 224 and/or the memory 226.
The audio connectors 314 and 316 may comprise digital audio in and digital audio out (e.g., S/PDIF) connectors, respectively. The audio connectors 318 and 320 may comprise a left "line in" and a right "line in" connector, respectively. The controls 310 may comprise, for example, a power button, a button for enabling/disabling virtual surround sound, a button for adjusting the perceived angles/locations of the speakers when the virtual surround sound is enabled, and a dial for controlling a volume/gain of the audio received via the "line in" connectors 318 and 320. The status indicators 302 may indicate, for example, whether the audio basestation 301 is powered on, whether audio data is being received by the basestation 301 via connectors 314, and/or what class of audio data (e.g., Dolby Digital) is being received by the basestation 301.
The radio 320 comprises suitable logic, circuitry, interfaces and/or code that may be operable to communicate in accordance with one or more standardized (such as the IEEE 802.11 family of standards, the Bluetooth family of standards, NFC, and/or the like) and/or proprietary (e.g., proprietary protocol for receiving audio protocols for receiving audio from a console such as the console 176) wireless protocols.
The radio 332 comprises suitable logic, circuitry, interfaces and/or code that may be operable to communicate in accordance with one or more standardized (such as, for example, the IEEE 802.11 family of standards, the Bluetooth family of standards, and/or the like) and/or proprietary wireless protocol(s) (e.g., a proprietary protocol for transmitting audio to the headphones 200).
The CPU 322 comprises suitable logic, circuitry, interfaces and/or code that may be operable to execute instructions for controlling/coordinating the overall operation of the audio basestation 301. Such instructions may be part of an operating system or state machine of the audio basestation 301 and/or part of one or more software applications running on the audio basestation 301. In some implementations, the CPU 322 may be, for example, a programmable interrupt controller, a state machine, or the like.
The storage 324 may comprise, for example, FLASH or other nonvolatile memory for storing data which may be used by the CPU 322 and/or the audio processing circuit 330. Such data may include, for example, parameter settings that affect processing of audio signals in the basestation 301. For example, one or more parameter settings may determine, at least in part, a gain of one or more gain elements of the audio processing circuit 330. As another example, one or more parameter settings may determine, at least in part, a frequency response of one or more filters that operate on audio signals in the audio processing circuit 330. As another example, one or more parameter settings may determine, at least in part, whether and which sound effects are added to audio signals in the audio processing circuit 330 (e.g., which effects to add to microphone audio to morph the user's voice). Example parameter settings which affect audio processing are described in the co-pending U.S. Pat. Application 13/040,144 titled "Gaming Headset with Programmable Audio" and published as US2012/0014553, the entirety of which is hereby incorporated herein by reference. Particular parameter settings may be selected autonomously by the basestation 301 in accordance with one or more algorithms, based on user input (e.g., via controls 310), and/or based on input received via one or more of the connectors 314, 316, 318, and 320.
The memory 326 may comprise volatile memory used by the CPU 322 and/or audio processing circuit 330 as program memory, for storing runtime data, etc.
The audio processing circuit 330 may comprise suitable logic, circuitry, interfaces and/or code that may be operable to perform audio processing functions such as volume/gain control, compression, decompression, encoding, decoding, introduction of audio effects (e.g., echo, phasing, virtual surround effect, etc.), and/or the like. As described above, the processing performed by the audio processing circuit 330 may be determined, at least in part, by which parameter settings have been selected. The processing may be performed on game and/or chat audio signals that are subsequently output to a device (e.g., headset 200) in communication with the basestation 301. Additionally, or alternatively, the processing may be performed on a microphone audio signal that is subsequently output to a device (e.g., console 176) in communication with the basestation 301.
The application processor 402 comprises suitable logic, circuitry, interfaces and/or code that may be operable to execute instructions for controlling/coordinating the overall operation of the multi-purpose device 192 as well as graphics processing functions of the multi-purpose device 192. Such instructions may be part of an operating system of the console and/or part of one or more software applications running on the console.
The memory subsystem 404 comprises volatile memory for storing runtime data, nonvolatile memory for mass storage and long-term storage, and/or a memory controller which controls reads/writes to memory.
The cellular/GPS networking subsystem 406 comprises suitable logic, circuitry, interfaces and/or code that may be operable to perform baseband processing and analog/RF processing for transmission and reception of cellular and GPS signals.
The sensors 408 comprise, for example, a camera, a gyroscope, an accelerometer, a biometric sensor, and/or the like.
The power management subsystem 410 comprises suitable logic, circuitry, interfaces and/or code that may be operable to manage distribution of power among the various components of the multi-purpose device 192.
The LAN subsystem 412 comprises suitable logic, circuitry, interfaces and/or code that may be operable to perform baseband processing and analog/RF processing for transmission and reception of cellular and GPS signals.
The bus adaptor 414 comprises suitable logic, circuitry, interfaces and/or code that may be operable for interfacing one or more internal data busses of the multi-purpose device with an external bus (e.g., a Universal Serial Bus) for transferring data to/from the multi-purpose device via a wired connection.
The user interface subsystem 416 comprises suitable logic, circuitry, interfaces and/or code that may be operable to control and relay signals to/from a touchscreen, hard buttons, and/or other input devices of the multi-purpose device 192.
The audio processor 418 comprises suitable logic, circuitry, interfaces and/or code that may be operable to process (e.g., digital-to-analog conversion, analog-todigital conversion, compression, decompression, encryption, decryption, resampling, etc.) audio signals. The audio processor 418 may be operable to receive and/or output signals via a connector such as a 3.5 mm stereo and microphone connector.
In accordance with an exemplary embodiment of the disclosure, an audio headset 200 may receive a plurality of audio signals corresponding to plurality of surround sound channels (e.g., right-front, left-front, center, left-side, right-side, left-rear, and right-rear). The headset may determine, via audio processing circuitry (e.g., 330), context and content of the audio signals. The audio processing circuitry may process the audio signals to generate a pair of stereo signals carrying one or more virtual surround channels, wherein the processing comprises automatically controlling, based on the context and the content of the audio signals, a simulated acoustic environment of the virtual surround channels. The determining the context of the audio signals may comprise determining whether a type of audio carried by the audio signals is game audio, music audio, or movie audio. When the audio carried by the audio signals is game audio the audio processing circuitry may automatically (e.g., without requiring user intervention) select a first simulated acoustic environment. When the audio carried by the audio signals is music audio the audio processing circuitry may automatically select a second simulated acoustic environment. When the audio carried by the audio signals is movie audio the audio processing circuitry may automatically select a third simulated acoustic environment. When the type of the audio is music audio, the audio processing circuitry may attenuate side audio and rear audio channels of the plurality of surround sound channels. The determining of the context of the audio signals may comprise the audio processing circuitry determining a scenario taking place in the game that is generating the game audio. The determining the context of the audio signals may comprise the audio processing circuitry determining a viewpoint being used in the game that is generating the game audio. The controlling the simulated acoustic environment may comprises the audio processing circuitry selecting between a first simulated acoustic environment and a second simulated acoustic environment where, for the first simulated acoustic environment, the processing may be such that a listener would perceive a source of one of the virtual surround channels (e.g., the center channel) as being relatively close, and, for the second simulated acoustic environment, the processing may be such that a listener would perceive a source of one of the virtual surround channels as being relatively far. The determining the content may comprise: detecting a particular sound within the audio signals, and searching a data structure (e.g., database 182) for a record corresponding to the particular sound.
As utilized herein the terms "circuits" and "circuitry" refer to physical electronic components (i.e. hardware) and any software and/or firmware ("code") which may configure the hardware, be executed by the hardware, and or otherwise be associated with the hardware. As used herein, for example, a particular processor and memory may comprise a first "circuit" when executing a first one or more lines of code and may comprise a second "circuit" when executing a second one or more lines of code. As utilized herein, "and/or" means any one or more of the items in the list joined by "and/or". As an example, "x and/or y" means any element of the three-element set {(x), (y), (x, y)}. As another example, "x, y, and/or z" means any element of the sevenelement set {(x), (y), (z), (x, y), (x, z), (y, z), (x, y, z)}. As utilized herein, the terms "e.g.," and "for example" set off lists of one or more non-limiting examples, instances, or illustrations. As utilized herein, circuitry is "operable" to perform a function whenever the circuitry comprises the necessary hardware and code (if any is necessary) to perform the function, regardless of whether performance of the function is disabled, or not enabled, by some user-configurable setting.
Throughout this disclosure, the use of the terms dynamically and/or adaptively with respect to an operation means that, for example, parameters for, configurations for and/or execution of the operation may be configured or reconfigured during run-time (e.g., in, or near, real-time) based on newly received or updated information or data. For example, an operation within a transmitter and/or a receiver may be configured or reconfigured based on, for example, current, recently received and/or updated signals, information and/or data.
The present method and/or system may be realized in hardware, software, or a combination of hardware and software. The present methods and/or systems may be realized in a centralized fashion in at least one computing system, or in a distributed fashion where different elements are spread across several interconnected computing systems. Any kind of computing system or other apparatus adapted for carrying out the methods described herein is suited. A typical combination of hardware and software may be a general-purpose computing system with a program or other code that, when being loaded and executed, controls the computing system such that it carries out the methods described herein. Another typical implementation may comprise an application specific integrated circuit or chip. Some implementations may comprise a non-transitory machine-readable (e.g., computer readable) medium (e.g., FLASH drive, optical disk, magnetic storage disk, or the like) having stored thereon one or more lines of code executable by a machine, thereby causing the machine to perform processes as described herein.
While the present method and/or system has been described with reference to certain implementations, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the scope of the present method and/or system. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the present disclosure without departing from its scope. Therefore, it is intended that the present method and/or system not be limited to the particular implementations disclosed, but that the present method and/or system will include all implementations falling within the scope of the appended claims.
This application is a continuation of U.S. Application No. 16/871,463 filed on May 11, 2020, now Pat. No. 10,880,665, which is a continuation of U.S. Application No. 16/353,565 filed on Mar. 14, 2019, now Pat. No. 10,652,682, which is a continuation of U.S. Pat. Application No. 15/659,161 filed on Jul. 25, 2017, now Patent No. 10,237,672, which is a continuation of U.S. Pat. Application No. 14/449,236 filed on Aug. 1, 2014, now Pat. No. 9,716,958, which claims the benefit of priority to U.S. Provisional Pat. Application 61/888,586 titled "Method and System for Surround Sound Processing in a Headset" and filed on Oct. 9, 2013, each of which is hereby incorporated herein by reference in its entirety.
Number | Date | Country | |
---|---|---|---|
61888586 | Oct 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 17123755 | Dec 2020 | US |
Child | 17957441 | US | |
Parent | 16871463 | May 2020 | US |
Child | 17123755 | US | |
Parent | 16353565 | Mar 2019 | US |
Child | 16871463 | US | |
Parent | 15659161 | Jul 2017 | US |
Child | 16353565 | US | |
Parent | 14449236 | Aug 2014 | US |
Child | 15659161 | US |