Limitations and disadvantages of conventional approaches to noise cancellation will become apparent to one of skill in the art, through comparison of such systems with some aspects of the present invention as set forth in the remainder of the present application with reference to the drawings.
Systems and methods are provided for a headset with configurable noise cancellation substantially as shown in and/or described in connection with at least one of the figures, as set forth more completely in the claims.
These and other advantages, aspects and novel features of the present invention, as well as details of an illustrated embodiment thereof, will be more fully understood from the following description and drawings.
Referring to
The user microphone 104 is 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 100 and/or for output to a device (e.g., console 176, basestation 300, a smartphone, and/or the like) that is in communication with the headset.
In an example implementation, the user microphone 104 may also operate as an ANC microphone when the user of the headset 100 is not speaking into the user microphone 104. In this regard, the headset 100 may be connected to a device (e.g., 150) with voice telephony and music capabilities. During a voice call, the headset 100, the device, or combination of the two may automatically detect that a call is in progress (e.g., in response to the user pressing an off-hook button on the headset or on the device itself) and/or that the wearer of the headset is talking (e.g., when level of captured vocal band audio in the direction of the user's mouth is above a threshold). In response to detecting that a call is in progress and/or that the wearer of the headset 100 is talking, the directionality, sensitivity, frequency response, and/or other characteristics of the microphone 104 and/or driver 240 (
Each of the ANC microphones 152a, 152b, 154a, and 154b is operable to convert acoustic waves incident on it from external sources to electric signals to be processed by circuitry of the headset for performing ANC.
The speakers 116a and 116b are operable to convert electrical signals to acoustic waves.
The user controls 112 may comprise dedicated and/or programmable buttons, switches, sliders, wheels, etc., for performing various functions. Example functions which the controls 112 may be configured to perform include configuring ANC settings such as are described below with reference to
The connectors 114a and 114b may be, for example, a USB port and/or charging port. The connectors 114a and 114b may be used for downloading data to the headset 100 from another computing device, uploading data from the headset 100 to another computing device, and/or charging batteries, if any, in the headset 100.
In addition to the user controls 112, connectors 114a/114b, and speaker 116a already discussed, shown are a user microphone driver 204a, ANC microphone(s) driver 240a, radio 220a, a CPU 222a, a storage device 224a, a memory 226a, and an audio processing circuit 230a.
The radio 220a comprises circuitry 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 receiving audio from an audio basestation of the same manufacturer as the headset 100).
The CPU 222a comprises circuitry operable to execute instructions for controlling/coordinating the overall operation of the headset 100. Such instructions may be part of an operating system or state machine of the headset 100 and/or part of one or more software applications running on the headset 100. In some implementations, the CPU 222a may be, for example, a programmable interrupt controller, a state machine, or the like.
The storage device 224a comprises, for example, FLASH or other nonvolatile memory for storing data which may be used by the CPU 222a and/or the audio processing circuitry 230a. Such data may include, for example, ANC configuration settings that affect ANC operations performed by the audio processing circuitry 230a.
The memory 226a comprises volatile memory used by the CPU 222a and/or audio processing circuit 230a as program memory, for storing runtime data, etc.
The audio processing circuit 230a comprises circuitry operable to perform audio processing functions such as volume/gain control, automatic noise cancellation, compression, decompression, encoding, decoding, introduction of audio effects (e.g., echo, phasing, virtual surround effect, etc.), and/or the like. The automatic noise cancellation may be configured via one or more user-configurable settings, such as those described below with reference to
The ANC microphone(s) driver 240a may comprise, for example, one or more audio-band amplifiers and/or filters. In an implementation in which automatic noise cancellation is performed digitally, the ANC microphone(s) driver 240 may comprise one or more analog-to-digital converters.
In the example implementation depicted, a first GUI element 302 enables configuring a sounds whitelist, that is, a list of sounds that the user does not want cancelled by ANC. Additionally, or alternatively, the GUI element 302 may enable configuring a sounds blacklist, that is, a list of sounds that the user does want cancelled by ANC. For each sound in the whitelist and/or blacklist, the headset 100 may store characteristics/signatures of such sounds that enable it to detect such sounds in the audio from the ANC microphones. As an example, a user may desire to whitelist the voice of a person that is talking to the user so that the user does not have to take off the headset and/or manually turn down the music volume in order to hear the speaker. As other examples, a user may (e.g., for safety reasons) desire to whitelist the sound of an approaching vehicle or the sound of approaching steps. An example process for how the whitelist/blacklist may be used is described below with reference to
The characteristics/signatures may, for example, be provided by the producer(s) of the headset 110, the device 150, and/or software/firmware for the device 150 or headset 110. The producer(s) may record and analyze common sounds and upload characteristics/signatures of such sounds to a database which may then be transferred to the headset 100 and/or device 150 in the factory, during installation of ANC-related software/firmware, and/or made available for download via the Internet (e.g., on demand as requested by a user). Additionally, or alternatively, the characteristics/signatures may be captured by the user of the headset 100 and device 150. For example, when scrolling through the possible sounds to be included in the user's whitelist or blacklist, the user may not find a signature/characteristic that works well for a particular sound he or she wants to whitelist or blacklist. Accordingly, the GUI may provide an interface for triggering capture and analysis of a new sound to identify configuration of the ACN circuitry that works best for that user and that sound. The user may, for example, get close to the source of the sound (e.g., a buzzing appliance), trigger recording of the sound, and then the GUI may enable him to manually configure various ANC settings to try and find one that best cancels the sound and/or may simply cycle through a variety of settings asking the user to indicate whether each setting is better or worse than a previous setting until arriving at a setting that the user feels provides the best cancelling of the particular sound. The captured sound may then be named and stored to the device 150 and/or headset 100 for future selection as a whitelisted or blacklisted sound. The characteristics/signature and user's selected settings for cancelling it may also be uploaded to the Internet for download by other users.
In an example implementation, which sounds are whitelisted and/or blacklisted may automatically change based on a variety of factors such as, location of the device 150 and/or other devices in communication with the device 150 (via Bluetooth, Wi-Fi, or any suitable communication link). For example, a first set of whitelisted and/or blacklisted sounds (e.g., previously programmed by the user) may be automatically selected when the device 150 is connected to a car entertainment and navigation system via Bluetooth, and a second set of whitelisted and/or blacklisted sounds may be automatically selected when the device 150 is connected to the user's office Wi-Fi network. As another example, where headset 100 and computing device 150 make up a virtual reality headset, a first set of whitelisted and/or blacklisted sounds (e.g., previously programmed by the user) may be automatically selected when the display is showing live video of the wearer's surroundings and a second set of whitelisted and/or blacklisted sounds may be automatically selected when the display is showing virtual reality video.
In the example implementation depicted in
Automatic control of volume based on location may comprise, for example, automatically reducing volume when it is determined the wearer is in a place where he needs to hear his surroundings, such as on a busy street. Automatic control of volume based on sensor output may comprise, for example, automatically increasing volume when it is determined that the wearer is exercising. Automatic control based on detection of particular sounds may comprise, for example, automatically decreasing volume when the sound of an approaching car is detected, speech directed at the wearer of the headset 100 is detected, etc.
In the example implementation depicted in
The element 306 may further enable the user to set whether the amount of ANC should be automatically adjusted and to configure settings for such automatic adjustments. For example, element 306 may be configured to enable the user to configure whether the amount of ANC is automatically adjusted based on the location of the headset 100, based on the activity of the wearer of the headset 100, and/or based on particular sounds being detected. The location may correspond to, for example, whether the wearer of the headset 100 is indoors, outdoors, on a busy street, in an elevator, in a plane, at home, at work, and/or the like. The location may be determined based on, for example, GPS coordinates (e.g., determined by radio 220a and/or a GPS receiver in device 150), which networks (e.g., Wi-Fi, cellular, etc.) are in range (e.g., determined by radio 220a and/or a radio in the device 150), inertial positioning using sensors 242 (and/or similar sensors in the device 150), manual selection by the user via the GUI, applications running on the device 150, and/or the like. The activity of the wearer may correspond to, for example, whether the wearer is running, biking, sleeping, working, and/or the like. The activity may be determined based on, for example, the determined location, outputs of the sensors 242 and/or similar sensors in the device 150, based on applications running on the device 150, and/or the like.
In an example implementation, the element 306 may be set to desired levels with user-programmable preset buttons. For example, a user may program a “jogging” button which, when pressed, moves the element 306 to a preset position toward the right end of the slider and a “plane” preset which, when pressed, moves the element 306 all the way to the left. As another example, where headset 100 and computing device 150 make up a virtual reality headset, the element 306 may automatically move to a first position when the display is showing live video of the wearer's surroundings, and move to a second position when the display is showing virtual reality video.
Automatic control of ANC based on location may comprise, for example, automatically reducing ANC when it is determined the wearer is in a place where he needs to hear his surroundings, such as on a busy street. Automatic control of ANC based on sensor output may comprise, for example, automatically increasing ANC when it is determined that the wearer is sleeping. Automatic control based on detection of particular sounds may comprise, for example, automatically decreasing ANC when the sound of an approaching car is detected, speech directed at the wearer of the headset 100 is detected, etc.
Although
In block 408, the user adjusts the amount of ANC to an intermediate amount (e.g., the user slides the slider of element 306 to somewhere near the middle). In block 410, in response to the user configuration of the amount of ANC, the audio processing circuitry 230a and/or ANC microphone driver 240a is configured (e.g., gains are set, filter coefficients are set, and/or the like) to provide an intermediate amount of noise cancellation. This results in the user/wearer being able to hear more external noise than he/she was able to hear in block 406.
In block 412, the user adjusts the amount of ANC to disable ANC (e.g., slides the slider of element 306 all the way to the right). In block 414, in response to the user configuration of the amount of ANC, the audio processing circuitry 230a and/or ANC microphone driver 240a is configured (e.g., gains are set; filter coefficients are set; circuitry is disabled, switched out or powered down; particular software or firmware is retrieved from storage 224a and/or memory 226a and loaded into audio processing circuitry 230a , particular parameter values are retrieved from storage 224a and/or memory 226a and loaded into registers of the audio processing circuitry 230a , particular parameter values are into memory 226, and/or the like) to disable cancellation of the noise based on the audio picked up by the ANC microphones. This results in the user/wearer being able to hear more external noise than he/she was able to hear in block 410.
For example, if the voice of someone talking to the user is selected as a whitelisted sound, the analysis in block 508 may determine the directionality of voice (whether it is directed at the user of the headset 100) and the volume (e.g., whether the volume of the sound is increasing, as would typically happen when the person starts talking louder upon seeing that the user cannot hear because of the headset).
As another example, if the sound of an approaching vehicle is a whitelisted sound, the analysis in block 508 may determine whether the frequency content is consistent with the sound of vehicles, whether the frequency is increasing (due to Doppler), and whether the volume is increasing (as it would as the vehicle gets closer).
As another example, if the sound of approaching footsteps is a whitelisted sound, the analysis in block 508 may determine whether the frequency content are consistent with the sound of footsteps, and whether interval of the sounds is consistent with footsteps, and whether the volume is increasing (as it would as the footsteps get closer).
In parallel with blocks 508-510 are blocks 514 and 516. In block 514, the possible blacklisted sound is analyzed to determine whether it matches the criteria of one of the user-configured blacklisted sounds. If so, then in block 516 the headset 100 attempts to cancel the sound and/or drown out the sound by turning up the music volume (if the user has enabled automatic volume control).
In accordance with various example implementations of this disclosure, a system may comprise automatic noise cancellation circuitry (e.g., 230a) and interface circuitry (e.g., 212a, 204a, 222a, 112, and/or 154) operable provide an interface via which a user can configure which sounds said automatic noise cancelling circuitry attempts to cancel and which sounds said automatic noise cancelling circuitry does not attempt to cancel. The interface circuitry may be operable to provide an interface via which a user can select a sound to whitelist or blacklist. The interface circuitry may be operable to provide an interface via which a user can increase or decrease an amount of noise cancellation that is desired. The interface circuitry may be operable to provide an interface via which a user can select from among three or more levels of noise cancellation. The automatic noise cancellation circuitry may reside in a headset (e.g., 100) and the interface circuitry may reside in a computing device (e.g., 150) communicatively coupled to the headset via a wireless link. The automatic noise cancellation circuitry may comprise a microphone (e.g., 240a), and the interface circuitry may be operable to provide an interface via which a user can select whether to enable or disable automatic control of music volume based on audio captured by the microphone. The system may comprise audio processing circuitry (e.g., 220a, 230a, 204a, 222a, and/or 226a). The interface circuitry may be operable to provide an interface via which a user can trigger the audio processing circuitry to record a sound (e.g., to storage 224a), and switch among a plurality of settings of the automatic noise cancellation circuitry to determine a best one of the settings for automatic noise cancellation of the recorded sound. The system may comprise networking circuitry (e.g., 220a) operable to upload the recorded sound and the determined best one of the settings to a network. The system may comprise control circuitry (e.g., 230a and/or 222a) operable to automatically control an amount of automatic noise cancellation applied by the automatic noise cancellation circuitry based on detection of a particular sound (e.g., that was previously recorded or downloaded and selected by the user as a sound to be monitored for), by the automatic noise cancellation circuitry. The system may comprise control circuitry (e.g., 230a, 220a, 242, and/or 222a) operable to determine location of the user, and automatically control an amount of automatic noise cancellation applied by the automatic noise cancellation circuitry based on the determined location. The system may comprise control circuitry (e.g., 230a 242, and/or 222a) operable to determine an ongoing activity of the user, and automatically control an amount of automatic noise cancellation applied by the automatic noise cancellation circuitry based on the determined activity. The system may comprise audio processing circuitry (e.g., 230a) operable to automatically control a volume at which audio is presented to the user based on detection of particular sounds by the automatic noise cancellation circuitry. The system may comprise control circuitry (e.g., 222a, 242, and 220a) operable to determine location of the user, and audio processing circuitry (e.g., 230a) operable to automatically control a volume at which audio is presented to the user based on the determined location. The system may comprise control circuitry (e.g., 222a, 242, and 220a) operable to determine ongoing activity of the user, and audio processing circuitry (e.g., 230a) operable to automatically control an amount of automatic noise cancellation applied by the automatic noise cancellation circuitry based on the determined activity. The system may comprise a microphone (e.g., 240a) and a radio (e.g., 220a) operable to communicate audio over a wired or wireless connection, wherein audio captured by the microphone is provided to both the automatic noise cancellation circuitry and to the radio.
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)}. That is, “x and/or y” means one or both of x and y. As another example, “x, y, and/or z” means any element of the seven-element set {(x), (y), (z), (x, y), (x, z), (y, z), (x, y, z)}. That is, “x, y and/or z” means one or more of x, y, and z. As utilized herein, the term “exemplary” means serving as a non-limiting example, instance, or illustration. 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 (e.g., by a user-configurable setting, factory trim, etc.).
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 claims priority to U.S. provisional patent application 62/075,322 titled “Headset with User Configurable Noise Cancellation vs. Ambient Noise Pickup” filed on Nov. 5, 2014, the entirety of which is hereby incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
8542817 | Short | Sep 2013 | B1 |
20100172510 | Juvonen | Jul 2010 | A1 |
20130293723 | Benson | Nov 2013 | A1 |
20140079235 | Lyons | Mar 2014 | A1 |
20140105412 | Alves | Apr 2014 | A1 |
20140301557 | Milligan | Oct 2014 | A1 |
20150195641 | Di Censo | Jul 2015 | A1 |
20150294662 | Ibrahim | Oct 2015 | A1 |
Number | Date | Country | |
---|---|---|---|
20160125869 A1 | May 2016 | US |
Number | Date | Country | |
---|---|---|---|
62075322 | Nov 2014 | US |