Hearing devices (e.g., hearing aids, cochlear implants, etc.) are used to improve the hearing and/or communication capabilities of hearing device users (also referred to herein as “listeners”). To this end, hearing devices may be configured to receive and process an audio input signal (e.g., ambient sound picked up by a microphone, prerecorded sound such as music provided over a line input, etc.), and to present the processed audio input signal to the user (e.g., by way of acoustic stimulation from a speaker in the case of a hearing aid, by way of electrical stimulation from an implanted electrode lead in the case of a cochlear implant, etc.).
While many hearing devices include one or more built-in microphones housed in the hearing device (e.g., so as to be positioned near the ear canal as the hearing device is worn at the user's ear), it may be advantageous, in certain circumstances, for external microphone assemblies to capture and provide an audio input signal. For example, a hearing device user may place an external microphone assembly (e.g., a “table microphone,” etc.) on a conference room table during a meeting, on a dinner table during a meal, or the like. Such microphones assemblies may be configured to clearly capture voices and ambient sounds in the room that may be captured suboptimally by built-in hearing device microphones alone. Accordingly, in certain situations, the user may be presented with improved sound quality when an audio input signal is received from an external microphone assembly instead of or in addition to audio input signals captured by one or more built-in microphones of the hearing device.
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.
Stereo rendering systems and methods for a microphone assembly with dynamic tracking are described herein. Stereo rendering, as used herein, refers to presentations of sound that differentiate signals presented to each ear of a user (as opposed to monaural rendering, where both ears would be presented with identical signals). Stereo rendering of an audio input signal may be desirable for many reasons. For instance, stereo rendering may allow a listener to identify interaural cues (e.g., interaural level differences (“ILDs”), interaural time differences (“ITDs”), etc.) that facilitate the listener in localizing the source of a sound in the room (e.g., which direction the sound is coming from, etc.). As another example, stereo rendering may help a listener focus in on one sound over another (e.g., a sound coming from straight ahead instead of a sound coming from one side or noise coming from multiple directions) to thereby improve how well the listener can understand speech when multiple people are talking at once or there is a lot of ambient noise, as well as improve how well the listener can identify who is speaking and/or distinguish between different speakers.
Microphone assemblies with dynamic tracking, as used herein, refer to systems or devices that include one or more microphone elements and that are configured to detect and continuously track where a primary sound within a particular environment (e.g., a main presenter speaking in a conference room, etc.) originates from, even when other secondary sounds or noise (e.g., people speaking in low voices during the conference room presentation, a fan in the corner of the conference room, etc.) are also present. Based on the direction of the primary sound, microphone assemblies with a dynamic tracking feature may dynamically perform beamforming operations to attempt to automatically focus in on primary sounds while at least somewhat filtering out undesirable secondary sounds. Accordingly, an audio signal provided by a microphone assembly with a dynamic tracking feature may tend to emphasize (e.g., amplify) speech spoken by a primary presenter in a conference room scenario while deemphasizing (e.g., attenuating) noise in the room. Additionally, as different people may speak up (e.g., asking questions to a presenter, discussing a topic in a back and forth manner, etc.), such microphone assemblies may capture the discussion and continuously attempt to focus in on whatever sound is the primary sound from moment to moment.
Systems and methods described herein include both stereo rendering and dynamic tracking features to allow listeners to enjoy a stereo rendering of ambient sound in which primary sounds are emphasized while noise is deemphasized. While stereo rendering and dynamic tracking features both clearly provide advantages on their own, stereo rendering systems and methods described herein for use with microphone assemblies having dynamic tracking features provide significant benefits and advantages that conventional systems fail to provide. For example, rather than merely attempting to reproduce an acoustic scene with perfect stereo fidelity, as a conventional stereo sound pick-up technique might do, stereo rendering systems described herein are configured to isolate primary sounds by adaptive beamforming, and then enhance those sounds (e.g., by processing the sounds to improve a signal-to-noise ratio, applying advanced noise cancellation, etc.) before they are presented to the listener within a configurable stereo rendering. These benefits and various others made apparent herein may allow hearing device users to confidently engage in various challenging hearing scenarios and localize, distinguish, and understand speech in these scenarios in a comfortable and accurate manner.
Various specific implementations will now be described in detail with reference to the figures. It will be understood that the specific implementations described below are provided as non-limiting examples of how various novel and inventive principles may be applied in various situations. Additionally, it will be understood that other examples not explicitly described herein may also be captured by the scope of the claims set forth below. Stereo rendering systems and methods described herein for microphone assemblies with dynamic tracking may provide any of the benefits mentioned above, as well as various additional and/or alternative benefits that will be described and/or made apparent below.
As illustrated in
Memory 102 may store and/or otherwise maintain executable data used by processor 104 to perform any of the functionality described herein. For example, memory 102 may store instructions 106 that may be executed by processor 104. Memory 102 may be implemented by one or more memory or storage devices, including any memory or storage devices described herein, that are configured to store data in a transitory or non-transitory manner. Instructions 106 may be executed by processor 104 to cause system 100 to perform any of the functionality described herein. Instructions 106 may be implemented by any suitable application, software, firmware, script, code, and/or other executable data instance. Additionally, memory 102 may also maintain any other data accessed, managed, used, and/or transmitted by processor 104 in a particular implementation.
Processor 104 may be implemented by one or more computer processing devices, including general purpose processors (e.g., central processing units (“CPUs”), microprocessors, etc.), special purpose processors (e.g., application-specific integrated circuits (“ASICs”), field-programmable gate arrays (“FPGAs”), etc.), or the like. Using processor 104 (e.g., when processor 104 is directed to perform operations represented by instructions 106 stored in memory 102), system 100 may perform functions associated with stereo rendering for a microphone assembly with dynamic tracking as described herein and/or as may serve a particular implementation.
As one example of functionality that processor 104 may perform,
In some examples, the operations of
Each of operations 202-208 of method 200 will now be described in more detail as the operations may be performed by system 100, an implementation thereof, or another suitable stereo rendering system.
At operation 202, system 100 may obtain a contradirectional audio input signal generated by a microphone assembly having a plurality of microphone elements. The contradirectional audio input signal may implement a contradirectional polar pattern oriented with respect to a listener.
As used herein, a “contradirectional” signal or polar pattern refers to a directional signal or polar pattern that has two lobes facing in substantially opposite directions. For example, a figure-of-eight (also known as a figure-eight) signal or polar pattern may serve as one example of a contradirectional signal or polar pattern. Other examples may be similar to a figure-of-eight signal or polar pattern but may have lobes that are turned at least somewhat inward so as not to be completely opposite of one another. In these examples, as long as the lobes are directed in substantially opposite directions (e.g., making an angle near 180°, an angle between 90° and 270°, etc.) the signal or polar pattern will be considered to be contradirectional as that term is used herein. Accordingly, in certain examples, the contradirectional audio input signal obtained at operation 202 may be a figure-of-eight audio input signal captured by microphone elements that have a figure-of-eight polar pattern or generated by a beamforming operation to create a figure-of-eight polar pattern.
As used herein, a contradirectional audio input signal is “oriented with respect to a listener” when the polar pattern of the signal is aligned such that the contradirectional lobes are substantially oriented in the same way as the ears of the listener. For example, if a listener is facing forward (at an angle of 0°), a contradirectional audio input signal oriented with respect to the listener would have two lobes that are directed substantially to the left (e.g., at an angle of approximately 90°) and to the right (e.g., at an angle of approximately −90° or 270°). It will be understood that a contradirectional audio input signal may be considered to be oriented with respect to a listener based on how a hardware device is oriented with respect to the listener's position (e.g., how a contradirectional microphone is situated based on a seat of the listener at the table), and not necessarily on how the listener turns his or her head (i.e., such that a static orientation of a contradirectional polar pattern remains oriented with respect to the listener when the listener turns his or her head but stays seated in the same seat).
At operation 204, system 100 may obtain an array of multidirectional audio input signals generated by the microphone assembly (e.g., using the same or different microphone elements as those that captured the sound used to generate the contradirectional audio input signal of operation 202). The array of multidirectional audio input signals may implement different unidirectional polar patterns that are collectively omnidirectional in a horizontal plane (e.g., a plane of a table on which a table microphone system is placed). For instance, in one example, the array may include six multidirectional audio input signals that each have a cardioid polar pattern that is directed in a way that uniformly covers a full 360° angle (e.g., a first signal directed at 0°, a second signal directed at 60°, a third signal directed at 120°, a fourth signal directed at 180°, a fifth signal directed at 240°, and a sixth signal directed at 300°). Along with covering the full 360° of the horizontal plane (e.g., a plane of a tabletop), the array of multidirectional audio input signals may also include input signals configured to cover angles outside of the horizontal plane (e.g., three-dimensional signals pointing up or down out of the table, etc.).
As used herein, a collection of signals or polar patterns that collectively cover (e.g., capture sound from) various angles around a 360° angle will be referred to as being “collectively omnidirectional” with regard to that angle (e.g., with regard to the plane along which the angle is set), even though each signal or polar pattern by itself may be a unidirectional or contradirectional signal or polar pattern that would not properly be referred to as omnidirectional. Examples of unidirectional signals that are collectively omnidirectional will be described and illustrated in more detail below.
At operation 206, system 100 may generate a weighted audio input signal by mixing the array of multidirectional audio input signals. For example, the mixing of the multidirectional audio input signals may be performed in accordance with respective weight values assigned to each multidirectional audio input signal in the array based on a respective real-time signal-to-noise ratio of each multidirectional audio input signal in the array. In this way, the weighted audio input signal may emphasize signals that are oriented in the direction of primary sounds in the environment (e.g., a main presenter in a conference room, a person telling a story to everyone at the table during a meal, etc.) while deemphasizing signals that are oriented in the direction of noise or secondary sounds in the environment (e.g., quiet side conversation around the conference room, people at other tables in a crowded restaurant during the meal, etc.). The weighting of each signal based on the respective real-time signal-to-noise ratios may be performed continuously and dynamically as the source of the primary sound changes (e.g., as different people take turns speaking in a dialogue or group discussion). The assigning of weight values will be described and illustrated in more detail below.
At operation 208, system 100 may generate a stereo audio output signal for presentation to the listener. Specifically, system 100 may generate the stereo audio output signal based on the contradirectional audio input signal obtained at operation 202 and the weighted audio input signal generated at operation 206. In this way, the stereo audio output signal may have the tracking and emphasizing benefits of the weighted audio input signal together with the stereo benefits of the contradirectional audio input signal. System 100 may provide this stereo audio output signal to a hearing device used by the listener (e.g., by way of wireless transmission, etc.) such that the stereo audio output signal can be presented to the listener and the listener can easily understand the primary sounds without being distracted by secondary noise (e.g., due to the tracking benefits of the weighted audio input signal) and can also easily localize and differentiate sound sources (e.g., due to the stereo benefits of the contradirectional audio input signal that is oriented to the listener).
To illustrate how system 100 and method 200 may function in operation,
As further shown in
Microphone assembly system 300 may be implemented as any suitable type of external microphone assembly system (e.g., a system that is separate from a hearing device worn by a listener). For example, in certain implementations, microphone assembly system 300 may be a portable, battery-powered table microphone device that listener 312 carries with him or her (e.g., in a pocket, purse, or briefcase) and that is configured to be powered on and situated in front of listener 312 when seated at a table with others (e.g., during a meeting, meal, conversation, or the like). In other implementations, microphone assembly system 300 may be permanently or semi-permanently built into a table such as a conference room table and may receive power from an outlet. In this example, listener 312 may not need to bother with carrying and setting up the microphone assembly system, since it would already be set up on the table. In still other implementations, microphone assembly system 300 may be integrated (e.g., built into) other devices and/or systems so as to share a common housing, processing circuitry, and/or microphone elements with the other devices or systems. For instance, an implementation of microphone assembly system 300 may be integrated with a conference phone that resides semi-permanently on a conference table in a conference room.
Housing 302 may take any form factor (e.g., size, shape, etc.) as may serve any of the various types of implementations described herein. For example, housing 302 may have a small, portable form (e.g., of a pocket-sized device); a larger, less portable form (e.g., of a conference phone); a form that is permanently integrated into a conference table; or the like. In any of these implementations, housing 302 may be configured to enclose processor and memory resources implementing system 100, circuitry implementing wireless communication interface 304, and various microphone elements of microphone assembly 306 in a manner that serves the particular implementation.
Wireless communication interface 304 may be any suitable type of communication interface configured to wirelessly transmit data (e.g., a stereo audio output signal) from housing 302 of microphone assembly system 300 to hearing device 310 (which, as mentioned above, may be separate from microphone assembly system 300 and worn by listener 312). Various types of wireless and/or networking technologies may be employed or implemented by wireless communication interface 304 to this end. For instance, Bluetooth and WiFi are common wireless protocols that may be used for these purposes. In other examples, other similar protocols, including proprietary and/or customized protocols, may be employed.
Microphone assembly 306 may include any suitable microphone elements 308 as may serve a particular implementation. For example, as shown in
As further shown within microphone assembly 306, one or more microphone elements 308-2 may also be included within the plurality of microphone elements 308. Microphone elements 308-2 may be distinct and separate from the plurality of microphone elements 308-1, and may be configured to capture one or more audio signals from which the contradirectional audio input signal is derived. For example, a single microphone element having a contradirectional polar pattern may implement microphone element 308-2 in certain examples, while back-to-back unidirectional microphone elements or other such configurations may be used in other implementations.
The configuration illustrated in
System 100 may be configured to perform the operations of method 200 in any of the ways described above, as well as to perform other suitable operations as may serve a particular implementation. To this end, system 100 may include or be implemented by a processor housed within housing 302 and communicatively coupled to the plurality of microphone elements 308 and wireless communication interface 304. In this configuration, the processor may be configured to generate a contradirectional audio input signal, generate an array of multidirectional audio input signals, generate a weighted audio input signal by mixing the array of multidirectional audio input signals, generate a stereo audio output signal based on the contradirectional audio input signal and the weighted audio input signal, and wirelessly transmit (e.g., by way of wireless communication interface 304 to hearing device 310) the stereo audio output signal for presentation to listener 312 by hearing device 310.
Hearing device 310 may be implemented by any device configured to provide or enhance hearing to listener 312. For example, a hearing device may be implemented by a binaural hearing aid system configured to amplify audio content to listener 312, a binaural cochlear implant system configured to apply electrical stimulation representative of audio content to listener 312, a sound processor included in an electroacoustic stimulation system configured to apply electrical and acoustic stimulation to listener 312, or any other suitable hearing prosthesis or combination of hearing prostheses. In some examples, a hearing device may be implemented by a behind-the-ear (“BTE”) component configured to be worn behind an ear of listener 312. In some examples, a hearing device may be implemented by an in-the-ear (“ITE”) component configured to at least partially be inserted within an ear canal of listener 312. In some examples, a hearing device may include a combination of an ITE component, a BTE component, and/or any other suitable component.
The operation of this implementation of system 100 will now be described in relation to the role of each of units 402 through 414. In particular, the function to be performed by each unit will be described with reference to input and output signals of each unit (i.e., signals 416 through 432), as well as with reference to
Multidirectional beamformer unit 402 may receive a plurality of audio input signals 416 as input, and may perform beamforming operations using audio input signals 416 to generate an array of multidirectional audio input signals 418 that are output to weight assignment unit 406, multidirectional mixing unit 408, and/or contradirectional beamformer unit 404. In this way, system 100 may obtain the array of multidirectional audio input signals 418, as described above in relation to operation 204 of method 200.
In one illustrative implementation, microphone assembly 306 may have at least three omnidirectional microphone elements 308-1 in the plurality of microphone elements 308. In this implementation, the obtaining of the array of multidirectional audio input signals may include a beamforming operation that uses audio input signals 416 captured by the at least three omnidirectional microphone elements 308-1 to generate at least six multidirectional audio input signals 418 for the array of multidirectional audio input signals 418. For example, the at least six multidirectional audio input signals 418 may be distributed to point along every 60° angle of a full 360° angle in the horizontal plane.
To illustrate this example of how multidirectional beamformer unit 402 may function,
The function of multidirectional beamformer unit 402 is represented in
Returning to
To illustrate an example of the beamforming that system 100 may perform to derive a contradirectional audio input signal,
In certain implementations, the obtaining of a contradirectional audio input signal 420 includes deriving the contradirectional audio input signal by way of a beamforming operation using a static subset of the array of multidirectional audio input signals 418. For instance, this type of implementation is shown in
In the example of
In this example, contradirectional beamformer unit 404 may generate a left component 604-L of contradirectional audio input signal 420-1 based on a combination of multidirectional audio input signals 418-5 and 418-6, and may generate a right component 604-R of contradirectional audio input signal 420-1 based on a combination of multidirectional audio input signals 418-2 and 418-3, as shown. The output of contradirectional beamformer unit 404 is shown at the bottom of
Signal420-1=½((Signal418-2+Signal418-3)−(Signal418-5+Signal418-6))
In some situations or for certain microphone assembly system implementations, it may not be that case that listener 312 is able to manually align microphone assembly system 300 such that the fixed subset of multidirectional audio input signals 418 can be used to generate a contradirectional audio input signal 420 aligned to the listener. For instance, if an implementation of microphone assembly system 300 is part of a conference phone or a permanent fixture on a conference table, it may not be convenient or desirable to have to physically realign the microphone assembly system before every meeting depending on where listener 312 happens to be sitting in the conference room. Additionally, even if microphone assembly system 300 is implemented as a portable device that is easily realignable by listener 312, it may be advantageous for microphone assembly system 300 to have at least some ability to automatically realign itself, especially if beamforming is being used to generate the contradirectional audio input signal 420 (rather than the signal being an output of a physical contradirectional microphone element).
Accordingly, in such situations and implementations, system 100 may be configured to determine a position of listener 312 with respect to an orientation of the microphone assembly and, based on that orientation, to identify a dynamic subset of the array of multidirectional audio input signals 418 that collectively capture audio signals implementing a contradirectional polar pattern that is oriented with respect to listener 312. The obtaining of the contradirectional audio input signal 420 may then include deriving the contradirectional audio input signal 420 by way of a beamforming operation using the dynamic subset of the array of multidirectional audio input signals 418.
To illustrate a few examples,
Signal420-2=½((Signal418-5)−(Signal418-2))
Contradirectional beamformer unit 404 may use the following equation to generate contradirectional audio input signal 420-3:
Signal420-3=½((Signal418-1)−(Signal418-4))
Contradirectional beamformer unit 404 may use the following equation to generate contradirectional audio input signal 420-4:
Signal420-4=½((Signal418-1+Signal418-6)−(Signal418-3+Signal418-4))
In like manner, contradirectional beamformer unit 404 may use similar equations to generate various other contradirectional audio input signals 420 to align an orientation of the contradirectional polar pattern 606 with listener 312 regardless of where listener 312 is positioned with respect to microphone assembly system 300 (i.e., with respect to orientation reference icon 602).
In examples like those illustrated in
To illustrate how this approach may work with respect to a specific example, contradirectional audio input signal 420-4 of
In other examples, the position of listener 312 may be determined in any other suitable way. For instance, rather than or in addition to voice recognition, a manual selection method may be used to indicate the listener's position (e.g., pressing a button on microphone assembly system 300, using a remote control, etc.), a spoken instruction or keyword may be used, visual examination may be used, or the like.
It will be understood that a contradirectional audio input signal generated in the ways described above with respect to
Returning to
Weight assignment unit 406 may assign respective weight values 422 to each of multidirectional audio input signals 418 in any suitable manner. For instance, in certain implementations, weight assignment unit 406 may be configured to 1) identify a particular multidirectional audio input signal 418 in the array that has a real-time signal-to-noise ratio higher, at a particular time, than real-time signal-to-noise ratios of other multidirectional audio input signals 418 in the array; 2) assign, based on the identifying and for the particular time, a unity weight value to the particular multidirectional audio input signal; and 3) assign, based on the identifying and for the particular time, respective weight values less than the unity weight value and greater than a null value to the other multidirectional audio input signals in the array.
To identify the multidirectional audio input signal 418 with the highest signal-to-noise ratio for a particular time (e.g., a particular moment in time, a particular duration of time, etc.) weight assignment unit 406 may estimate respective signal-to-noise ratios of each multidirectional audio input signal 418 in any suitable way. For example, weight assignment unit 406 may process (e.g., clean, filter, etc.) each signal using sound processing or sound cleaning techniques such as anti-shock, noise cancellation, or the like. Weight assignment unit 406 may then measure the signal-to-noise ratio of each multidirectional audio input signal 418 by combining two averagers with different time constants, one tracking the onsets of speech and the other one tracking the background noise. Based on the signal-to-noise ratio determine for each multidirectional audio input signal 418, weight assignment unit 406 may then determine which of the multidirectional audio input signals 418 has the highest signal-to-noise ratio (or, in certain examples, which plurality of multidirectional audio input signals 418 tie or substantially tie for having the highest signal-to-noise ratios).
A specific example is considered in which listener 312 is oriented with respect to multidirectional audio input signals 418 as was shown in
In certain examples, a multidirectional audio input signal 418 with the highest signal-to-noise ratio may be assigned the unity weight value (e.g., 0 dB) while the other multidirectional audio input signals 418 may be assigned a minimum weight values (e.g., a non-null value such as −20 dB or another suitable value). In other examples, however, it may be undesirable for the emphasized multidirectional audio input signal 418 to change as abruptly as this type of implementation would cause it to change. For example, in a back and forth dialogue between two speakers, it may be disorienting or distracting for the emphasis to abruptly change back and forth nearly instantaneously. Accordingly, in certain implementations, weight assignment unit 406 may be configured to immediately (e.g., with a relatively fast attack time of a few milliseconds) assign a new signal the unity weight value when it comes to have the highest signal-to-noise ratio, but, rather than immediately dropping the weight values of signals that previously had the highest signal-to-noise ratio (i.e., for previous times), weight assignment unit 406 may be configured to gradually (e.g., with a relatively slow release time of a full second or several seconds) drop the weight values of the other multidirectional audio input signals 418 until a minimum weight value (e.g., a null minimum weight value such as −∞ dB, a non-null minimum weight value such as −20 dB, etc.) is reached. The other multidirectional audio input signals 418 may then remain at the minimum weight value until they are identified as again having the highest signal-to-noise ratio, at which point they may again be immediately reset to the unity value.
To illustrate,
Next to hearing scenario 700, a timeline 706 is presented alongside respective weight values 422 (e.g., weight values 422-1 through 422-6) for each of multidirectional audio input signals 418. Each weight value 422 is illustrated as a solid bold line that is drawn on a graph with time as the x-axis and a weight value (e.g., between a null weight value of −∞ dB and a unity weight value of 0 dB) as the y-axis. Along timeline 706, different moments in time are labeled as Time0, Time1, Time2, and Time3. Timeline 706 illustrates that, at these labeled moments in time, a speaker 704 who is speaking (or speaking the loudest so as to produce a multidirectional audio input signal 418 with the highest signal-to-noise ratio) changes. Specifically, as shown, speaker 704-1 is shown to be the primary speaker starting at Time0, speaker 704-3 becomes the primary speaker starting at Time1, speaker 704-4 becomes the primary speaker starting at Time2, and speaker 704-2 becomes the primary speaker starting at Time3.
As described above, the weight value 422 most closely associated with the speaker 704 who is the primary speaker at a given moment in time may be immediately set to the unity value and may stay there until a new primary speaker is identified, at which point the weight value 422 may gradually drop off until reaching a non-null minimum weight value (e.g., −20 dB in this example). Specifically, for example, weight value 422-1, which is associated with multidirectional audio input signal 418-1 (i.e., the multidirectional audio input signal most closely directed toward speaker 704-1), is shown to quickly ramp up from the minimum weight value (−20 dB) to the unity weight value (0 dB) at Time 0 when speaker 704-1 begins speaking as the primary speaker. Weight value 422-1 remains at the unity value until Time1 when speaker 704-1 is no longer the primary speaker. At Time1, weight value 422-1 is shown to begin gradually decreasing from the unity weight value back toward the minimum weight value as weight value 422-4 (the weight value most closely associated with speaker 704-3) immediately ramps up from the minimum weight value to the unity weight value.
As labeled specifically with respect to weight value 422-1 (and as similarly shown, though not labeled, by the other weight values 422), an attack time 708 during which weight value 422-1 ramps up may be significantly faster (e.g., more than twice as fast, an order of magnitude faster, a plurality of orders of magnitude faster, etc.) than a release time 710 during which weight value 422-1 drops off. For example, while attack time 708 may be instantaneous or just a few milliseconds (e.g., 10 ms, 100 ms, etc.), release time 708 may be on the order of seconds or more (e.g., 1 s, 5 s, etc.). It will be understood that timing relationships depicted in
Returning to
Stereo mixing unit 410 may receive weighted audio input signal 424 and contradirectional audio input signal 420 as input, and may generate an intermediate stereo signal 428 as output that includes a left component (intermediate stereo signal 428-L) and a right component (intermediate stereo signal 428-R). Stereo mixing unit 410 may mix weighted audio input signal 424 and contradirectional audio input signal 420 to generate intermediate stereo signal 428 in any suitable manner. For example, stereo mixing unit 410 may utilize a mid-side mixing technique in which weighted audio input signal 424 is used as the mid signal (e.g., in place of a cardioid or omnidirectional signal as may be conventionally used in a mid-side mixing technique) while contradirectional audio input signal 420 may be used as the side signal that adds a stereo component to the mid signal. More specifically, for example, the following equations may be used in which Signal428-L and Signal428-R respectively represent intermediate stereo signals 428 output by stereo mixing unit 410, Signal424 represents weighted audio input signal 424, and Signal420 represents contradirectional audio input signal 420:
Signal428-L=(Signal424−Signal420)
Signal428-R=(Signal424+Signal420)
In certain examples, an alpha value (“Alpha Value” in
Accordingly, it will be understood that in certain examples, the generating of the stereo audio output signal by system 100 may be performed in accordance with an alpha value configured to define a relative strength of contradirectional audio input signal 420 with respect to weighted audio input signal 424 as contradirectional audio input signal 420 and weighted audio input signal 424 are combined to generate the stereo audio output signal that will ultimately be derived from intermediate stereo signal 428. In certain implementations, the alpha value may be fixed at a predetermined value such as 0.5 that has been determined to be suitable under a wide variety of circumstances. In other implementations, however, system 100 may automatically and dynamically change the alpha value based on run time conditions. For example, the alpha value may be dynamically modified during runtime based on a preference of the listener (e.g., how much stereo the listener indicates that he or she wishes to hear), and/or based on a runtime condition associated with sound being captured by the microphone assembly (e.g., based on how noisy the room is detected to be, what type of sound is being captured, a detected noise floor, etc.). For example, it may be more appropriate in a quiet room for the listener to be provided a signal that has a heavy stereo component (e.g., a relatively high alpha value), whereas so much stereo may make it difficult to understand speech in a noise room (e.g., thereby calling for a relatively low alpha value).
The generating of the stereo audio output signal by system 100 may, in certain examples, include: 1) determining, based on at least one of a predefined preference of the listener or a runtime condition associated with sound being captured by the microphone assembly, a gain to be applied to the stereo audio output signal for presentation to the listener; 2) combining contradirectional audio input signal 420 and weighted audio input signal 424 to generate intermediate stereo signal 428 (as described above); and 3) applying the gain to intermediate stereo signal 428 to generate the stereo audio output signal for presentation to the listener.
To illustrate,
Gain application unit 414 may receive intermediate stereo signal 428 and gain parameters 430 as input, and may generate a stereo output signal 432 that includes a left component (stereo output signal 432-L) and a right component (stereo output signal 432-R). Gain application unit 414 may apply gain parameters 430 to intermediate stereo signal 428 (e.g., in the frequency domain, as described above) and/or perform any other suitable processing to generate stereo output signal 432. Stereo output signal 432 may then be provided for wireless transmission to a hearing device (e.g., to hearing device 310 by way of wireless communication interface 304, as described above in relation to
To illustrate this final output that is generated,
In both polar pattern diagrams 800 (i.e., polar pattern diagrams 800-A and 800-B), a unidirectional polar pattern 802 represents the directionality of weighted audio output signal 424 and a contradirectional polar pattern 804 represents the directionality of contradirectional audio input signal 420. Additional unidirectional polar patterns 806-L and 806-R then represent the directionality of left and right components of stereo audio output signal 432.
As shown in
As shown in
In certain implementations, one or more of the processes described herein may be implemented at least in part as instructions embodied in a non-transitory computer-readable medium and executable by one or more computing devices. In general, a processor (e.g., a microprocessor) receives instructions, from a non-transitory computer-readable medium, (e.g., a memory, etc.), and executes those instructions, thereby performing one or more processes, including one or more of the processes described herein. Such instructions may be stored and/or transmitted using a variety of known computer-readable media.
A computer-readable medium (also referred to as a processor-readable medium) includes any non-transitory medium that participates in providing data (e.g., instructions) that may be read by a computer (e.g., by a processor of a computer). Such a medium may take many forms, including, but not limited to, non-volatile media, and/or volatile media. Non-volatile media may include, for example, optical or magnetic disks and other persistent memory. Volatile media may include, for example, dynamic random access memory (DRAM), which typically constitutes a main memory. Common forms of computer-readable media include, for example, a disk, hard disk, magnetic tape, any other magnetic medium, a compact disc read-only memory (CD-ROM), a digital video disc (DVD), any other optical medium, random access memory (RAM), programmable read-only memory (PROM), electrically erasable programmable read-only memory (EPROM), FLASH-EEPROM, any other memory chip or cartridge, or any other tangible medium from which a computer can read.
As shown in
Communication interface 902 may be configured to communicate with one or more computing devices. Examples of communication interface 902 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 904 generally represents any type or form of processing unit capable of processing data or interpreting, executing, and/or directing execution of one or more of the instructions, processes, and/or operations described herein. Processor 904 may direct execution of operations in accordance with one or more applications 912 or other computer-executable instructions such as may be stored in storage device 906 or another computer-readable medium.
Storage device 906 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 906 may include, but is not limited to, a hard drive, network drive, flash drive, magnetic disc, optical disc, RAM, dynamic RAM, other non-volatile and/or volatile data storage units, or a combination or sub-combination thereof. Electronic data, including data described herein, may be temporarily and/or permanently stored in storage device 906. For example, data representative of one or more executable applications 912 configured to direct processor 904 to perform any of the operations described herein may be stored within storage device 906. In some examples, data may be arranged in one or more databases residing within storage device 906.
I/O module 908 may include one or more I/O modules configured to receive user input and provide user output. One or more I/O modules may be used to receive input for a single virtual experience. I/O module 908 may include any hardware, firmware, software, or combination thereof supportive of input and output capabilities. For example, I/O module 908 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 908 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 implementations, I/O module 908 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 system 900. For example, one or more applications 912 residing within storage device 906 may be configured to direct processor 904 to perform one or more processes or functions associated with processor 104 of system 100. Likewise, memory 102 of system 100 may be implemented by or within storage device 906.
In the preceding description, various illustrative 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.