1. Field
This disclosure relates to signal processing.
2. Background
Many activities that were previously performed in quiet office or home environments are being performed today in acoustically variable situations like a car, a street, or a café. For example, a person may desire to communicate with another person using a voice communication channel. The channel may be provided, for example, by a mobile wireless handset or headset, a walkie-talkie, a two-way radio, a car-kit, or another communications device. Consequently, a substantial amount of voice communication is taking place using portable audio sensing devices (e.g., smartphones, handsets, and/or headsets) in environments where users are surrounded by other people, with the kind of noise content that is typically encountered where people tend to gather. Such noise tends to distract or annoy a user at the far end of a telephone conversation. Moreover, many standard automated business transactions (e.g., account balance or stock quote checks) employ voice recognition based data inquiry, and the accuracy of these systems may be significantly impeded by interfering noise.
For applications in which communication occurs in noisy environments, it may be desirable to separate a desired speech signal from background noise. Noise may be defined as the combination of all signals interfering with or otherwise degrading the desired signal. Background noise may include numerous noise signals generated within the acoustic environment, such as background conversations of other people, as well as reflections and reverberation generated from the desired signal and/or any of the other signals. Unless the desired speech signal is separated from the background noise, it may be difficult to make reliable and efficient use of it. In one particular example, a speech signal is generated in a noisy environment, and speech processing methods are used to separate the speech signal from the environmental noise.
Noise encountered in a mobile environment may include a variety of different components, such as competing talkers, music, babble, street noise, and/or airport noise. As the signature of such noise is typically nonstationary and close to the user's own frequency signature, the noise may be hard to model using traditional single microphone or fixed beamforming type methods. Single-microphone noise reduction techniques typically require significant parameter tuning to achieve optimal performance. For example, a suitable noise reference may not be directly available in such cases, and it may be necessary to derive a noise reference indirectly. Therefore multiple-microphone based advanced signal processing may be desirable to support the use of mobile devices for voice communications in noisy environments.
A method of audio signal processing according to a general configuration includes calculating a first indication of a direction of arrival, relative to a first pair of microphones, of a first sound component received by the first pair of microphones and calculating a second indication of a direction of arrival, relative to a second pair of microphones that is separate from the first pair, of a second sound component received by the second pair of microphones. This method also includes controlling a gain of an audio signal to produce an output signal, based on the first and second direction indications. In this method, the microphones of the first pair are located at a first side of a midsagittal plane of a head of a user, and the microphones of the second pair are located at a second side of the midsagittal plane that is opposite to the first side. This method may be implemented such that the first pair is separated from the second pair by at least ten centimeters. Computer-readable storage media (e.g., non-transitory media) having tangible features that cause a machine reading the features to perform such a method are also disclosed.
An apparatus for audio signal processing according to a general configuration includes means for calculating a first indication of a direction of arrival, relative to a second pair of microphones that is separate from the first pair, of a first sound component received by the first pair of microphones and means for calculating a second indication of a direction of arrival, relative to a second pair of microphones, of a second sound component received by the second pair of microphones. This apparatus also includes means for controlling a gain of an audio signal, based on the first and second direction indications. In this apparatus, the microphones of the first pair are located at a first side of a midsagittal plane of a head of a user, and the microphones of the second pair are located at a second side of the midsagittal plane that is opposite to the first side. This apparatus may be implemented such that the first pair is separated from the second pair by at least ten centimeters.
An apparatus for audio signal processing according to a general configuration includes a first pair of microphones configured to be located during a use of the apparatus at a first side of a midsagittal plane of a head of a user, and a second pair of microphones that is separate from the first pair and configured to be located during the use of the apparatus at a second side of the midsagittal plane that is opposite to the first side. This apparatus also includes a first direction indication calculator configured to calculate a first indication of a direction of arrival, relative to the first pair of microphones, of a first sound component received by the first pair of microphones and a second direction indication calculator configured to calculate a second indication of a direction of arrival, relative to the second pair of microphones, of a second sound component received by the second pair of microphones. This apparatus also includes a gain control module configured to control a gain of an audio signal, based on the first and second direction indications. This apparatus may be implemented such that the first pair is configured to be separated from the second pair during the use of the apparatus by at least ten centimeters.
An acoustic signal sensed by a portable sensing device may contain components that are received from different sources (e.g., a desired sound source, such as a user's mouth, and one or more interfering sources). It may be desirable to separate these components in the received signal in time and/or in frequency. For example, it may be desirable to distinguish the user's voice from diffuse background noise and from other directional sounds.
Unfortunately, the dimensions of a portable audio sensing device are typically too small to allow microphone spacings that are large enough to support effective acoustic ranging. Moreover, methods of obtaining range information from a microphone array typically depend on measuring gain differences between the microphones, and acquiring reliable gain difference measurements typically requires performing and maintaining calibration of the gain responses of the microphones relative to one another.
A four-microphone headset-based range-selective acoustic imaging system is described. The proposed system includes two broadside-mounted microphone arrays (e.g., pairs) and uses directional information from each array to define a region around the user's mouth that is limited by direction of arrival (DOA) and by range. When phase differences are used to indicate direction of arrival, such a system may be configured to separate signal components according to range without requiring calibration of the microphone gains relative to one another. Examples of applications for such a system include extracting the user's voice from the background noise and/or imaging different spatial regions in front of, behind, and/or to either side of the user.
Unless expressly limited by its context, the term “signal” is used herein to indicate any of its ordinary meanings, including a state of a memory location (or set of memory locations) as expressed on a wire, bus, or other transmission medium. Unless expressly limited by its context, the term “generating” is used herein to indicate any of its ordinary meanings, such as computing or otherwise producing. Unless expressly limited by its context, the term “calculating” is used herein to indicate any of its ordinary meanings, such as computing, evaluating, smoothing, and/or selecting from a plurality of values. Unless expressly limited by its context, the term “obtaining” is used to indicate any of its ordinary meanings, such as calculating, deriving, receiving (e.g., from an external device), and/or retrieving (e.g., from an array of storage elements). Unless expressly limited by its context, the term “selecting” is used to indicate any of its ordinary meanings, such as identifying, indicating, applying, and/or using at least one, and fewer than all, of a set of two or more. Where the term “comprising” is used in the present description and claims, it does not exclude other elements or operations. The term “based on” (as in “A is based on B”) is used to indicate any of its ordinary meanings, including the cases (i) “derived from” (e.g., “B is a precursor of A”), (ii) “based on at least” (e.g., “A is based on at least B”) and, if appropriate in the particular context, (iii) “equal to” (e.g., “A is equal to B”). Similarly, the term “in response to” is used to indicate any of its ordinary meanings, including “in response to at least.”
References to a “location” of a microphone of a multi-microphone audio sensing device indicate the location of the center of an acoustically sensitive face of the microphone, unless otherwise indicated by the context. The term “channel” is used at times to indicate a signal path and at other times to indicate a signal carried by such a path, according to the particular context. Unless otherwise indicated, the term “series” is used to indicate a sequence of two or more items. The term “logarithm” is used to indicate the base-ten logarithm, although extensions of such an operation to other bases are within the scope of this disclosure. The term “frequency component” is used to indicate one among a set of frequencies or frequency bands of a signal, such as a sample of a frequency domain representation of the signal (e.g., as produced by a fast Fourier transform) or a subband of the signal (e.g., a Bark scale or mel scale subband).
Unless indicated otherwise, any disclosure of an operation of an apparatus having a particular feature is also expressly intended to disclose a method having an analogous feature (and vice versa), and any disclosure of an operation of an apparatus according to a particular configuration is also expressly intended to disclose a method according to an analogous configuration (and vice versa). The term “configuration” may be used in reference to a method, apparatus, and/or system as indicated by its particular context. The terms “method,” “process,” “procedure,” and “technique” are used generically and interchangeably unless otherwise indicated by the particular context. The terms “apparatus” and “device” are also used generically and interchangeably unless otherwise indicated by the particular context. The terms “element” and “module” are typically used to indicate a portion of a greater configuration. Unless expressly limited by its context, the term “system” is used herein to indicate any of its ordinary meanings, including “a group of elements that interact to serve a common purpose.” Any incorporation by reference of a portion of a document shall also be understood to incorporate definitions of terms or variables that are referenced within the portion, where such definitions appear elsewhere in the document, as well as any figures referenced in the incorporated portion.
The terms “coder,” “codec,” and “coding system” are used interchangeably to denote a system that includes at least one encoder configured to receive and encode frames of an audio signal (possibly after one or more pre-processing operations, such as a perceptual weighting and/or other filtering operation) and a corresponding decoder configured to produce decoded representations of the frames. Such an encoder and decoder are typically deployed at opposite terminals of a communications link. In order to support a full-duplex communication, instances of both of the encoder and the decoder are typically deployed at each end of such a link.
In this description, the term “sensed audio signal” denotes a signal that is received via one or more microphones, and the term “reproduced audio signal” denotes a signal that is reproduced from information that is retrieved from storage and/or received via a wired or wireless connection to another device. An audio reproduction device, such as a communications or playback device, may be configured to output the reproduced audio signal to one or more loudspeakers of the device. Alternatively, such a device may be configured to output the reproduced audio signal to an earpiece, other headset, or external loudspeaker that is coupled to the device via a wire or wirelessly. With reference to transceiver applications for voice communications, such as telephony, the sensed audio signal is the near-end signal to be transmitted by the transceiver, and the reproduced audio signal is the far-end signal received by the transceiver (e.g., via a wireless communications link). With reference to mobile audio reproduction applications, such as playback of recorded music, video, or speech (e.g., MP3-encoded music files, movies, video clips, audiobooks, podcasts) or streaming of such content, the reproduced audio signal is the audio signal being played back or streamed.
System S100 may be implemented such that apparatus A100 is coupled to each of microphones ML10, ML20, MR10, and MR20 via wires or other conductive paths. Alternatively, system S100 may be implemented such that apparatus A100 is coupled conductively to one of the microphone pairs (e.g., located within the same earcup as this microphone pair) and wirelessly to the other microphone pair. Alternatively, system S100 may be implemented such that apparatus A100 is wirelessly coupled to microphones ML10, ML20, MR10, and MR20 (e.g., such that apparatus A100 is implemented within a portable audio sensing device, such as a handset, smartphone, or laptop or tablet computer).
Each of the microphones ML10, ML20, MR10, and MR20 may have a response that is omnidirectional, bidirectional, or unidirectional (e.g., cardioid). The various types of microphones that may be used for each of the microphones ML10, ML20, MR10, and MR20 include (without limitation) piezoelectric microphones, dynamic microphones, and electret microphones.
It may be desirable for the spacing between the microphones of each microphone array (e.g., between ML10 and ML20, and between MR10 and MR20) to be in the range of from about two to about four centimeters (or even up to five or six centimeters). It may be desirable for the separation between the left and right microphone arrays during a use of the device to be greater than or equal to eight, nine, ten, eleven, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, or 22 centimeters. For example, it may be desirable for the distance between the inner microphones of each array (i.e., between microphones ML10 and MR10) during a use of the device to be at least equal to the interaural distance (i.e., the distance along a straight line in space between the openings of the user's ear canals). Such microphone placements may provide a satisfactory level of noise reduction performance across a desired range of directions of arrival.
System S100 may be implemented to include a pair of headphones, such as a pair of earcups that are joined by a band to be worn over the user's head.
System S100 may be implemented to include an instance of such an earcup for each of the user's ears. For example,
It may be desirable for the axis of the microphone pair ML10, ML20 (i.e., the line that passes through the centers of the sensitive surfaces of each microphone of the pair) to be generally orthogonal to the midsagittal plane of the user's head during use of the system. Similarly, it may be desirable for the axis of the microphone pair MR10, MR20 to be generally orthogonal to the midsagittal plane of the user's head during use of the system. It may be desirable to configure system S100, for example, such that each of the axis of microphone pair ML10, ML20 and the axis of microphone pair MR10, MR20 is not more than fifteen, twenty, twenty-five, thirty, or forty-five degrees from orthogonal to the midsagittal plane of the user's head during use of the system.
It is noted that the plus and minus bounds of such a range of allowable angles need not be the same. For example, system S100 may be implemented such that each of the axis of microphone pair ML10, ML20 and the axis of microphone pair MR10, MR20 is not more than plus fifteen degrees and not more than minus thirty degrees, in a coronal plane of the user's head, from orthogonal to the midsagittal plane of the user's head during use of the system. Alternatively or additionally, system S100 may be implemented such that each of the axis of microphone pair ML10, ML20 and the axis of microphone pair MR10, MR20 is not more than plus thirty degrees and not more than minus fifteen degrees, in a transverse plane of the user's head, from orthogonal to the midsagittal plane of the user's head during use of the system.
Other implementations of system S100 in which microphones ML10, ML20, MR10, and MR20 may be mounted according to any of the spacing and orthogonality constraints noted above include a circular arrangement, such as on a helmet. For example, inner microphones ML10, MR10 may be mounted on a visor of such a helmet.
During the operation of a multi-microphone audio sensing device as described herein, each instance of microphone array R100 produces a multichannel signal in which each channel is based on the response of a corresponding one of the microphones to the acoustic environment. One microphone may receive a particular sound more directly than another microphone, such that the corresponding channels differ from one another to provide collectively a more complete representation of the acoustic environment than can be captured using a single microphone.
It may be desirable for the array to perform one or more processing operations on the signals produced by the microphones to produce the corresponding multichannel signal. For example,
It may be desirable for each of arrays R100L and R100R to produce the corresponding multichannel signal as a digital signal, that is to say, as a sequence of samples. Array R210R, for example, includes analog-to-digital converters (ADCs) C10a and C10b that are each arranged to sample the corresponding analog channel. Typical sampling rates for acoustic applications include 8 kHz, 12 kHz, 16 kHz, and other frequencies in the range of from about 8 to about 16 kHz, although sampling rates as high as about 44.1, 48, or 192 kHz may also be used. In this particular example, array R210R also includes digital preprocessing stages P20a and P20b that are each configured to perform one or more preprocessing operations (e.g., echo cancellation, noise reduction, and/or spectral shaping) on the corresponding digitized channel to produce corresponding channels SR10, SR20 of multichannel signal MCS10R. Array R100L may be similarly implemented.
Each of the direction indications DI10L and DI10R indicates a direction of arrival (DOA) of a sound component of the corresponding multichannel signal relative to the corresponding array. Depending on the particular implementation of calculators DC10L and DC10R, the direction indicator may indicate the DOA relative to the location of the inner microphone, relative to the location of the outer microphone, or relative to another reference point on the corresponding array axis that is between those locations (e.g., a midpoint between the microphone locations). Examples of direction indications include a gain difference or ratio, a time difference of arrival, a phase difference, and a ratio between phase difference and frequency. Apparatus A110 also includes a gain control module GC10 that is configured to control a gain of input audio signal SI10 according to the values of the direction indications DI10L and DI10R.
Each of direction indication calculators DC10L and DC10R may be configured to process the corresponding multichannel signal as a series of segments. For example, each of direction indication calculators DC10L and DC10R may be configured to calculate a direction indicator for each of a series of segments of the corresponding multichannel signal. Typical segment lengths range from about five or ten milliseconds to about forty or fifty milliseconds, and the segments may be overlapping (e.g., with adjacent segments overlapping by 25% or 50%) or nonoverlapping. In one particular example, the multichannel signal is divided into a series of nonoverlapping segments or “frames”, each having a length of ten milliseconds. In another particular example, each frame has a length of twenty milliseconds. A segment as processed by a DOA estimation operation may also be a segment (i.e., a “subframe”) of a larger segment as processed by a different audio processing operation, or vice versa.
Calculators DC10L and DC10R may be configured to perform any one or more of several different DOA estimation techniques to produce the direction indications. Techniques for DOA estimation that may be expected to produce estimates of source DOA with similar spatial resolution include gain-difference-based methods and phase-difference-based methods. Cross-correlation-based methods (e.g., calculating a lag between channels of the multichannel signal, and using the lag as a time-difference-of-arrival to determine DOA) may also be useful in some cases.
As described herein, direction calculators DC10L and DC10R may be implemented to perform DOA estimation on the corresponding multichannel signal in the time domain or in a frequency domain (e.g., a transform domain, such as an FFT, DCT, or MDCT domain).
A gain-difference-based method estimates the DOA based on a difference between the gains of signals that are based on channels of the multichannel signal. For example, such implementations of calculators DC10L and DC10R may be configured to estimate the DOA based on a difference between the gains of different channels of the multichannel signal (e.g., a difference in magnitude or energy). Measures of the gain of a segment of the multichannel signal may be calculated in the time domain or in a frequency domain (e.g., a transform domain, such as an FFT, DCT, or MDCT domain). Examples of such gain measures include, without limitation, the following: total magnitude (e.g., sum of absolute values of sample values), average magnitude (e.g., per sample), RMS amplitude, median magnitude, peak magnitude, peak energy, total energy (e.g., sum of squares of sample values), and average energy (e.g., per sample). In order to obtain accurate results with a gain-difference technique, it may be desirable for the responses of the two microphone channels to be calibrated relative to each other. It may be desirable to apply a lowpass filter to the multichannel signal such that calculation of the gain measure is limited to an audio-frequency component of the multichannel signal.
Direction calculators DC10L and DC10R may be implemented to calculate a difference between gains as a difference between corresponding gain measure values for each channel in a logarithmic domain (e.g., values in decibels) or, equivalently, as a ratio between the gain measure values in a linear domain. For a calibrated microphone pair, a gain difference of zero may be taken to indicate that the source is equidistant from each microphone (i.e., located in a broadside direction of the pair), a gain difference with a large positive value may be taken to indicate that the source is closer to one microphone (i.e., located in one endfire direction of the pair), and a gain difference with a large negative value may be taken to indicate that the source is closer to the other microphone (i.e., located in the other endfire direction of the pair).
In another example, direction calculators DC10L and DC10R are implemented to estimate the DOA of a source using a gain-difference-based method which is based on a difference in gain among beams that are generated from the multichannel signal (e.g., from an audio-frequency component of the multichannel signal). Such implementations of calculators DC10L and DC10R may be configured to use a set of fixed filters to generate a corresponding set of beams that span a desired range of directions (e.g., 180 degrees in 10-degree increments, 30-degree increments, or 45-degree increments). In one example, such an approach applies each of the fixed filters to the multichannel signal and estimates the DOA (e.g., for each segment) as the look direction of the beam that exhibits the highest output energy.
In a further example, direction calculators DC10L and DC10R are implemented to estimate the DOA of a source using a gain-difference-based method which is based on a difference in gain between channels of beams that are generated from the multichannel signal (e.g., using a beamforming or BSS method as described above) to produce a multichannel output. For example, a fixed filter may be configured to generate such a beam by concentrating energy arriving from a particular direction or source (e.g., a look direction) into one output channel and/or concentrating energy arriving from another direction or source into a different output channel. In such case, the gain-difference-based method may be implemented to estimate the DOA as the look direction of the beam that has the greatest difference in energy between its output channels.
Direction indication calculators DC10L and DC10R may also be implemented to obtain a DOA estimate by directly using a BSS unmixing matrix W and the microphone spacing. Such a technique may include estimating the source DOA (e.g., for each source-microphone pair) by using back-projection of separated source signals, using an inverse (e.g., the Moore-Penrose pseudo-inverse) of the unmixing matrix W, followed by single-source DOA estimation on the back-projected data. Such a DOA estimation method is typically robust to errors in microphone gain response calibration. The BSS unmixing matrix W is applied to the m microphone signals X1 to XM, and the source signal to be back-projected Yj is selected from among the outputs of matrix W. A DOA for each source-microphone pair may be computed from the back-projected signals using a technique such as GCC-PHAT or SRP-PHAT. A maximum likelihood and/or multiple signal classification (MUSIC) algorithm may also be applied to the back-projected signals for source localization. The back-projection methods described above are illustrated in
Alternatively, direction calculators DC10L and DC10R may be implemented to estimate the DOA of a source using a phase-difference-based method that is based on a difference between phases of different channels of the multichannel signal. Such methods include techniques that are based on a cross-power-spectrum phase (CPSP) of the multichannel signal (e.g., of an audio-frequency component of the multichannel signal), which may be calculated by normalizing each element of the cross-power-spectral-density vector by its magnitude. Examples of such techniques include generalized cross-correlation with phase transform (GCC-PHAT) and steered response power-phase transform (SRP-PHAT), which typically produce the estimated DOA in the form of a time difference of arrival. One potential advantage of phase-difference-based implementations of direction indication calculators DC10L and DC10R is that they are typically robust to mismatches between the gain responses of the microphones.
Other phase-difference-based methods include estimating the phase in each channel for each of a plurality of frequency components to be examined. In one example, direction indication calculators DC12L and DC12R are configured to estimate the phase of a frequency component as the inverse tangent (also called the arctangent) of the ratio of the imaginary term of the FFT coefficient of the frequency component to the real term of the FFT coefficient of the frequency component. It may be desirable to configure such a calculator to calculate the phase difference Δφ for each frequency component to be examined by subtracting the estimated phase for that frequency component in a primary channel from the estimated phase for that frequency component in another (e.g., secondary) channel. In such case, the primary channel may be the channel expected to have the highest signal-to-noise ratio, such as the channel corresponding to a microphone that is expected to receive the user's voice most directly during a typical use of the device.
It may be unnecessary for a DOA estimation method to consider phase differences across the entire bandwidth of the signal. For many bands in a wideband range (e.g., 0-8000 Hz), for example, phase estimation may be impractical or unnecessary. The practical valuation of phase relationships of a received waveform at very low frequencies typically requires correspondingly large spacings between the transducers. Consequently, the maximum available spacing between microphones may establish a low frequency bound. On the other end, the distance between microphones should not exceed half of the minimum wavelength in order to avoid spatial aliasing. An eight-kilohertz sampling rate, for example, gives a bandwidth from zero to four kilohertz. The wavelength of a four-kHz signal is about 8.5 centimeters, so in this case, the spacing between adjacent microphones should not exceed about four centimeters. The microphone channels may be lowpass filtered in order to remove frequencies that might give rise to spatial aliasing.
It may be desirable to perform DOA estimation over a limited audio-frequency range of the multichannel signal, such as the expected frequency range of a speech signal. In one such example, direction indication calculators DC12L and DC12R are configured to calculate phase differences for the frequency range of 700 Hz to 2000 Hz, which may be expected to include most of the energy of the user's voice. For a 128-point FFT of a four-kilohertz-bandwidth signal, the range of 700 to 2000 Hz corresponds roughly to the twenty-three frequency samples from the tenth sample through the thirty-second sample. In further examples, such a calculator is configured to calculate phase differences over a frequency range that extends from a lower bound of about fifty, 100, 200, 300, or 500 Hz to an upper bound of about 700, 1000, 1200, 1500, or 2000 Hz (each of the twenty-five combinations of these lower and upper bounds is expressly contemplated and disclosed).
The energy spectrum of voiced speech (e.g., vowel sounds) tends to have local peaks at harmonics of the pitch frequency. The energy spectrum of background noise, on the other hand, tends to be relatively unstructured. Consequently, components of the input channels at harmonics of the pitch frequency may be expected to have a higher signal-to-noise ratio (SNR) than other components. It may be desirable to configure direction indication calculators DC12L and DC12R to favor phase differences which correspond to multiples of an estimated pitch frequency. For example, it may be desirable for at least twenty-five, fifty, or seventy-five percent (possibly all) of the calculated phase differences to correspond to multiples of an estimated pitch frequency, or to weight direction indicators that correspond to such components more heavily than others. Typical pitch frequencies range from about 70 to 100 Hz for a male speaker to about 150 to 200 Hz for a female speaker, and a current estimate of the pitch frequency (e.g., in the form of an estimate of the pitch period or “pitch lag”) will typically already be available in applications that include speech encoding and/or decoding (e.g., voice communications using codecs that include pitch estimation, such as code-excited linear prediction (CELP) and prototype waveform interpolation (PWI)). The same principle may be applied to other desired harmonic signals as well. Conversely, it may be desirable to configure direction indication calculators DC12L and DC12R to ignore frequency components which correspond to known interferers, such as tonal signals (e.g., alarms, telephone rings, and other electronic alerts).
Direction indication calculators DC12L and DC12R may be implemented to calculate, for each of a plurality of the calculated phase differences, a corresponding indication of the DOA. In one example, an indication of the DOA 0, of each frequency component is calculated as a ratio ri between estimated phase difference Δφi and frequency fi (e.g., ri=φi/fi). Alternatively, an indication of the DOA θi may be calculated as the inverse cosine (also called the arccosine) of the quantity
where c denotes the speed of sound (approximately 340 m/sec), d denotes the distance between the microphones, Δφi denotes the difference in radians between the corresponding phase estimates for the two microphones, and fi is the frequency component to which the phase estimates correspond (e.g., the frequency of the corresponding FFT samples, or a center or edge frequency of the corresponding subbands). Alternatively, an indication of the direction of arrival θi may be calculated the inverse cosine of the quantity
where λi denotes the wavelength of frequency component fi.
In another example, direction indication calculators DC12L and DC12R are implemented to calculate an indication of the DOA, for each of a plurality of the calculated phase differences, as the time delay of arrival τi (e.g., in seconds) of the corresponding frequency component fi of the multichannel signal. For example, such a method may be configured to estimate the time delay of arrival τi at a secondary microphone with reference to a primary microphone, using an expression such as
In these examples, a value of τi=0 indicates a signal arriving from a broadside direction, a large positive value of τi indicates a signal arriving from the reference endfire direction, and a large negative value of τi indicates a signal arriving from the other endfire direction. In calculating the values τi, it may be desirable to use a unit of time that is deemed appropriate for the particular application, such as sampling periods (e.g., units of 125 microseconds for a sampling rate of 8 kHz) or fractions of a second (e.g., 10−3, 10−4, 10−5, or 10−6 sec). It is noted that a time delay of arrival τi may also be calculated by cross-correlating the frequency components fi of each channel in the time domain.
Direction indication calculators DC12L and DC12R may be implemented to perform a phase-difference-based method by indicating the DOA of a frame (or subband) as an average (e.g., the mean, median, or mode) of the DOA indicators of the corresponding frequency components. Alternatively, such calculators may be implemented to indicate the DOA of a frame (or subband) by dividing the desired range of DOA coverage into a plurality of bins (e.g., a fixed scheme of 3, 4, 5, 6, 7, 8, 9, 10, 11, or 12 bins for a range of 0-180 degrees) and determining the number of DOA indicators of the corresponding frequency components whose values fall within each bin (i.e., the bin population). For a case in which the bins have unequal bandwidths, it may be desirable for such a calculator to calculate the bin population values by normalizing each bin population by the corresponding bandwidth. The DOA of the desired source may be indicated as the direction corresponding to the bin having the highest population value, or as the direction corresponding to the bin whose current population value has the greatest contrast (e.g., that differs by the greatest relative magnitude from a long-term time average of the population value for that bin).
Similar implementations of calculators DC12L and DC12R use a set of directional masking functions to divide the desired range of DOA coverage into a plurality of spatial sectors (e.g., 3, 4, 5, 6, 7, 8, 9, 10, 11, or 12 sectors for a range of 0-180 degrees). The directional masking functions for adjacent sectors may overlap or not, and the profile of a directional masking function may be linear or nonlinear. A directional masking function may be implemented such that the sharpness of the transition or transitions between stopband and passband are selectable and/or variable during operation according to the values of one or more factors (e.g., signal-to-noise ratio (SNR), noise floor, etc.). For example, it may be desirable for the calculator to use a more narrow passband when the SNR is low.
The sectors may have the same angular width (e.g., in degrees or radians) as one another, or two or more (possibly all) of the sectors may have different widths from one another.
It may be expected that a microphone array will receive different amounts of ambient noise from different directions.
The “directional coherence” of a multichannel signal is defined as the degree to which the various frequency components of the signal arrive from the same direction. For an ideally directionally coherent channel pair, the value of
is equal to a constant k for all frequencies, where the value of k is related to the direction of arrival θ and the time delay of arrival τ. Implementations of direction calculator DC12L and DC12R may be configured to quantify the directional coherence of a multichannel signal, for example, by rating the estimated direction of arrival for each frequency component according to how well it agrees with a particular direction (e.g., using a directional masking function), and then combining the rating results for the various frequency components to obtain a coherency measure for the signal. Consequently, the masking function output for a spatial sector, as calculated by a corresponding implementation of direction calculator DC12L or DC12R, is also a measure of the directional coherence of the multichannel signal within that sector. Calculation and application of a measure of directional coherence is also described in, e.g., Int'l Pat. Publ's WO2010/048620 A1 and WO2010/144577 A1 (Visser et al.).
It may be desirable to implement direction calculators DC12L and DC12R to produce a coherency measure for each sector as a temporally smoothed value. In one such example, the direction calculator is configured to produce the coherency measure as a mean value over the most recent m frames, where possible values of m include four, five, eight, ten, sixteen, and twenty. In another such example, the direction calculator is configured to calculate a smoothed coherency measure z(n) for frame n according to an expression such as z(n)=βz(n−1)+(1−β)c(n) (also known as a first-order IIR or recursive filter), where z(n−1) denotes the smoothed coherency measure for the previous frame, c(n) denotes the current unsmoothed value of the coherency measure, and β is a smoothing factor whose value may be selected from the range of from zero (no smoothing) to one (no updating). Typical values for smoothing factor β include 0.1, 0.2, 0.25, 0.3, 0.4, and 0.5. It is typical, but not necessary, for such implementations of direction calculators DC12L and DC12R to use the same value of β to smooth coherency measures that correspond to different sectors.
The contrast of a coherency measure may be expressed as the value of a relation (e.g., the difference or the ratio) between the current value of the coherency measure and an average value of the coherency measure over time (e.g., the mean, mode, or median over the most recent ten, twenty, fifty, or one hundred frames). Implementations of direction calculators DC12L and DC12R may be configured to calculate the average value of a coherency measure for each sector using a temporal smoothing function, such as a leaky integrator or according to an expression such as ν(n)=αν(n−1)+(1−α)c(n), where v(n) denotes the average value for the current frame, v(n−1) denotes the average value for the previous frame, c(n) denotes the current value of the coherency measure, and α is a smoothing factor whose value may be selected from the range of from zero (no smoothing) to one (no updating). Typical values for smoothing factor α include 0.01, 0.02, 0.05, and 0.1.
Implementations of direction calculators DC12L and DC12R may be configured to use a sector-based DOA estimation method to estimate the DOA of the signal as the DOA associated with the sector whose coherency measure is greatest. Alternatively, such a direction calculator may be configured to estimate the DOA of the signal as the DOA associated with the sector whose coherency measure currently has the greatest contrast (e.g., has a current value that differs by the greatest relative magnitude from a long-term time average of the coherency measure for that sector). Additional description of phase-difference-based DOA estimation may be found, for example, in U.S. Publ. Pat. Appl. 2011/0038489 (publ. Feb. 17, 2011) and U.S. patent application Ser. No. 13/029,582 (filed Feb. 17, 2011).
For both gain-difference-based approaches and phase-difference-based approaches, it may be desirable to implement direction calculators DC10L and DC10R to perform DOA indication over a limited audio-frequency range of the multichannel signal. For example, it may be desirable for such a direction calculator to perform DOA estimation over a mid-frequency range (e.g., from 100, 200, 300, or 500 to 800, 100, 1200, 1500, or 2000 Hz) to avoid problems due to reverberation in low frequencies and/or attenuation of the desired signal in high frequencies.
An indicator of DOA with respect to a microphone pair is typically ambiguous in sign. For example, the time delay of arrival or phase difference will be the same for a source that is located in front of the microphone pair as for a source that is located behind the microphone pair.
Each of direction indication calculators DC10L and DC10R may also be configured to produce a direction indication as described herein for each of a plurality of frequency components (e.g., subbands or frequency bins) of each of a series of frames of the multichannel signal. In one example, apparatus A100 is configured to calculate a gain difference for each of several frequency components (e.g., subbands or FFT bins) of the frame. Such implementations of apparatus A100 may be configured to operate in a transform domain or to include subband filter banks to generate subbands of the input channels in the time domain.
It may be desirable to configure apparatus A100 to operate in a noise reduction mode. In this mode, input signal SI10 is based on at least one of the microphone channels SL10, SL20, SR10, and SR20 and/or on a signal produced by another microphone that is disposed to receive the user's voice. Such operation may be applied to discriminate against far-field noise and focus on a near-field signal from the user's mouth.
For operation in noise reduction mode, input signal SI10 may include a signal produced by another microphone MC10 that is positioned closer to the user's mouth and/or to receive more directly the user's voice (e.g., a boom-mounted or cord-mounted microphone). Microphone MC10 is arranged within apparatus A100 such that during a use of apparatus A100, the SNR of the user's voice in the signal from microphone signal MC30 is greater than the SNR of the user's voice in any of the microphone channels SL10, SL20, SR10, and SR20. Alternatively or additionally, voice microphone MC10 may be arranged during use to be oriented more directly toward the central exit point of the user's voice, to be closer to the central exit point, and/or to lie in a coronal plane that is closer to the central exit point, than either of noise reference microphones ML10 and MR10 is.
Several different examples of positions for voice microphone MC10 during a use of apparatus A100 are shown by labeled circles in
The side view of
For operation in a noise reduction mode, it may be desirable to configure the pickup cones such that apparatus A100 may distinguish the user's voice from sound from a source that is located at least a threshold distance (e.g., at least 25, 30, 50, 75, or 100 centimeters) from the central exit point of the user's voice. For example, it may be desirable to select the pickup cones such that their intersection extends no farther along the midsagittal plane than the threshold distance from the central exit point of the user's voice.
As discussed above, each of direction indication calculators DC10L and DC10R may be implemented to identify a spatial sector that includes the direction of arrival (e.g., as described herein with reference to
Alternatively, as discussed above, each of direction indication calculators DC10L and DC10R may be implemented to calculate a value (e.g., an angle relative to the microphone axis, a time difference of arrival, or a ratio of phase difference and frequency) that indicates an estimated direction of arrival. In such cases, each of calculators DC10L and DC10R may be implemented to produce the corresponding direction indication by applying, to the calculated DOA value, a respective mapping to a value of the corresponding direction indication DI10L or DI10R (e.g., a value of zero or one) that indicates whether the corresponding DOA is within the corresponding pickup cone. Such a mapping may be implemented, for example, as one or more threshold values (e.g., mapping values that indicate DOAs less than a threshold value to a direction indication of one, and values that indicate DOAs greater than the threshold value to a direction indication of zero, or vice versa).
It may be desirable to implement a hangover or other temporal smoothing operation on the gain factor calculated by gain control element GC10 (e.g., to avoid jitter in output signal SO10 for a source that is close to the intersection boundary). For example, gain control element GC10 may be configured to refrain from changing the state of the gain factor until the new state has been indicated for a threshold number (e.g., five, ten, or twenty) of consecutive frames.
Gain control module GC10 may be implemented to perform binary control (i.e., gating) of input signal SI10, according to whether the direction indications indicate that the source is within an intersection defined by the pickup cones, to produce output signal SO10. In such case, the gain factor may be considered as a voice activity detection signal that causes gain control element GC10 to pass or attenuate input signal SI10 accordingly. Alternatively, gain control module GC10 may implemented to produce output signal SO10 by applying a gain factor to input signal SI10 that has more than two possible values. For example, calculators DC10L and DC10R may be configured to produce the direction indications DI10L and DI10R according to a mapping of sector number to pickup cone that indicates a first value (e.g., one) if the sector is within the pickup cone, a second value (e.g., zero) if the sector is outside of the pickup cone, and a third, intermediate value (e.g., one-half) if the sector is partially within the pickup cone (e.g., sector 4 in
As noted above, each of the direction indication calculators DC10L and DC10R may be implemented to produce a corresponding direction indication for each subband of a frame. In such cases, gain control module GC10 may be implemented to combine the subband-level direction indications from each direction indication calculator to obtain a corresponding frame-level direction indication (e.g., as a sum, average, or weighted average of the subband direction indications from that direction calculator). Alternatively, gain control module GC10 may be implemented to perform multiple instances of a combination as described herein to produce a corresponding gain factor for each subband. In such case, gain control element GC10 may be similarly implemented to combine (e.g., to add or multiply) the subband-level source location decisions to obtain a corresponding frame-level gain factor value, or to map each subband-level source location decision to a corresponding subband-level gain factor value. Gain control element GC10 may be configured to apply gain factors to corresponding subbands of input signal SI10 in the time domain (e.g., using a subband filter bank) or in the frequency domain.
It may be desirable to encode audio-frequency information from output signal SO10 (for example, for transmission via a wireless communications link).
It may be desirable to implement apparatus A100 to include post-processing of output signal SO10 (e.g., for noise reduction).
In addition to, or in the alternative to, a noise reduction mode as described above, apparatus A100 may be implemented to operate in a hearing-aid mode. In a hearing-aid mode, system S100 may be used to perform feedback control and far-field beamforming by suppressing the near-field region, which may include the signal from the user's mouth and interfering sound signals, while simultaneously focusing on far-field directions. A hearing-aid mode may be implemented using unidirectional and/or omnidirectional microphones.
For operation in a hearing-aid mode, system S100 may be implemented to include one or more loudspeakers LS10 configured to reproduce output signal SO10 at one or both of the user's ears. System S100 may be implemented such that apparatus A100 is coupled to one or more such loudspeakers LS10 via wires or other conductive paths. Alternatively or additionally, system S100 may be implemented such that apparatus A100 is coupled wirelessly to one or more such loudspeakers LS10.
In one example, gain control element GC10 is configured to pass acoustic information received from a direction within either of pickup cones LF10 and RF10 as output signal OS10 (e.g., an “OR” case). In another example, gain control element GC10 is configured to pass acoustic information received by at least one of the microphones as output signal OS10 only if direction indicator DI10L indicates a direction of arrival within pickup cone LF10 and direction indicator DI10R indicates a direction of arrival within pickup cone RF10 (e.g., an “AND” case).
For a hearing-aid mode, apparatus A100 may be configured for independent operation on each microphone array. For example, operation of apparatus A100 in a hearing-aid mode may be configured such that selection of signals from an outward endfire direction is independent on each side. Alternatively, operation of apparatus A100 in a hearing-aid mode may be configured to attenuate distributed noise (for example, by blocking sound components that are found in both multichannel signals and/or passing directional sound components that are present within a selected directional range of only one of the multichannel signals).
It may be desirable to implement system S100 to combine a hearing-aid mode implementation of apparatus A100 with playback of a reproduced audio signal, such as a far-end communications signal or other compressed audio or audiovisual information, such as a file or stream encoded according to a standard compression format (e.g., Moving Pictures Experts Group (MPEG)-1 Audio Layer 3 (MP3), MPEG-4 Part 14 (MP4), a version of Windows Media Audio/Video (WMA/WMV) (Microsoft Corp., Redmond, Wash.), Advanced Audio Coding (AAC), International Telecommunication Union (ITU)-T H.264, or the like).
It may be desirable to implement system S100 to support operation of apparatus A100 in either or both of a noise-reduction mode and a hearing-aid mode as described herein.
Such a device may be configured to transmit and receive voice communications data wirelessly via one or more encoding and decoding schemes (also called “codecs”). Examples of such codecs include the Enhanced Variable Rate Codec, as described in the Third Generation Partnership Project 2 (3GPP2) document C.S0014-C, v1.0, entitled “Enhanced Variable Rate Codec, Speech Service Options 3, 68, and 70 for Wideband Spread Spectrum Digital Systems,” February 2007 (available online at www-dot-3gpp-dot-org); the Selectable Mode Vocoder speech codec, as described in the 3GPP2 document C.S0030-0, v3.0, entitled “Selectable Mode Vocoder (SMV) Service Option for Wideband Spread Spectrum Communication Systems,” January 2004 (available online at www-dot-3gpp-dot-org); the Adaptive Multi Rate (AMR) speech codec, as described in the document ETSI TS 126 092 V6.0.0 (European Telecommunications Standards Institute (ETSI), Sophia Antipolis Cedex, FR, December 2004); and the AMR Wideband speech codec, as described in the document ETSI TS 126 192 V6.0.0 (ETSI, December 2004). For example, chip or chipset CS10 may be configured to produce the encoded audio signal to be compliant with one or more such codecs.
Device D10 is configured to receive and transmit the RF communications signals via an antenna C30. Device D10 may also include a diplexer and one or more power amplifiers in the path to antenna C30. Chip/chipset CS10 is also configured to receive user input via keypad C10 and to display information via display C20. In this example, device D10 also includes one or more antennas C40 to support Global Positioning System (GPS) location services and/or short-range communications with an external device such as a wireless (e.g., Bluetooth™) headset. In another example, such a communications device is itself a Bluetooth headset and lacks keypad C10, display C20, and antenna C30.
The methods and apparatus disclosed herein may be applied generally in any transceiving and/or audio sensing application, especially mobile or otherwise portable instances of such applications. For example, the range of configurations disclosed herein includes communications devices that reside in a wireless telephony communication system configured to employ a code-division multiple-access (CDMA) over-the-air interface. Nevertheless, it would be understood by those skilled in the art that a method and apparatus having features as described herein may reside in any of the various communication systems employing a wide range of technologies known to those of skill in the art, such as systems employing Voice over IP (VoIP) over wired and/or wireless (e.g., CDMA, TDMA, FDMA, and/or TD-SCDMA) transmission channels.
It is expressly contemplated and hereby disclosed that communications devices disclosed herein may be adapted for use in networks that are packet-switched (for example, wired and/or wireless networks arranged to carry audio transmissions according to protocols such as VoIP) and/or circuit-switched. It is also expressly contemplated and hereby disclosed that communications devices disclosed herein may be adapted for use in narrowband coding systems (e.g., systems that encode an audio frequency range of about four or five kilohertz) and/or for use in wideband coding systems (e.g., systems that encode audio frequencies greater than five kilohertz), including whole-band wideband coding systems and split-band wideband coding systems.
The presentation of the described configurations is provided to enable any person skilled in the art to make or use the methods and other structures disclosed herein. The flowcharts, block diagrams, and other structures shown and described herein are examples only, and other variants of these structures are also within the scope of the disclosure. Various modifications to these configurations are possible, and the generic principles presented herein may be applied to other configurations as well. Thus, the present disclosure is not intended to be limited to the configurations shown above but rather is to be accorded the widest scope consistent with the principles and novel features disclosed in any fashion herein, including in the attached claims as filed, which form a part of the original disclosure.
Those of skill in the art will understand that information and signals may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits, and symbols that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
Important design requirements for implementation of a configuration as disclosed herein may include minimizing processing delay and/or computational complexity (typically measured in millions of instructions per second or MIPS), especially for computation-intensive applications, such as playback of compressed audio or audiovisual information (e.g., a file or stream encoded according to a compression format, such as one of the examples identified herein) or applications for wideband communications (e.g., voice communications at sampling rates higher than eight kilohertz, such as 12, 16, 44.1, 48, or 192 kHz).
Goals of a multi-microphone processing system may include achieving ten to twelve dB in overall noise reduction, preserving voice level and color during movement of a desired speaker, obtaining a perception that the noise has been moved into the background instead of an aggressive noise removal, dereverberation of speech, and/or enabling the option of post-processing for more aggressive noise reduction.
An apparatus as disclosed herein (e.g., apparatus A100, A110, A120, A130, A140, A210, A220, A300, and MF100) may be implemented in any combination of hardware with software, and/or with firmware, that is deemed suitable for the intended application. For example, the elements of such an apparatus may be fabricated as electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or logic gates, and any of these elements may be implemented as one or more such arrays. Any two or more, or even all, of these elements may be implemented within the same array or arrays. Such an array or arrays may be implemented within one or more chips (for example, within a chipset including two or more chips).
One or more elements of the various implementations of the apparatus disclosed herein (e.g., apparatus A100, A110, A120, A130, A140, A210, A220, A300, and MF100) may be implemented in whole or in part as one or more sets of instructions arranged to execute on one or more fixed or programmable arrays of logic elements, such as microprocessors, embedded processors, IP cores, digital signal processors, FPGAs (field-programmable gate arrays), ASSPs (application-specific standard products), and ASICs (application-specific integrated circuits). Any of the various elements of an implementation of an apparatus as disclosed herein may also be embodied as one or more computers (e.g., machines including one or more arrays programmed to execute one or more sets or sequences of instructions, also called “processors”), and any two or more, or even all, of these elements may be implemented within the same such computer or computers.
A processor or other means for processing as disclosed herein may be fabricated as one or more electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or logic gates, and any of these elements may be implemented as one or more such arrays. Such an array or arrays may be implemented within one or more chips (for example, within a chipset including two or more chips). Examples of such arrays include fixed or programmable arrays of logic elements, such as microprocessors, embedded processors, IP cores, DSPs, FPGAs, ASSPs, and ASICs. A processor or other means for processing as disclosed herein may also be embodied as one or more computers (e.g., machines including one or more arrays programmed to execute one or more sets or sequences of instructions) or other processors. It is possible for a processor as described herein to be used to perform tasks or execute other sets of instructions that are not directly related to a procedure of an implementation of method M100, such as a task relating to another operation of a device or system in which the processor is embedded (e.g., an audio sensing device). It is also possible for part of a method as disclosed herein to be performed by a processor of the audio sensing device and for another part of the method to be performed under the control of one or more other processors.
Those of skill will appreciate that the various illustrative modules, logical blocks, circuits, and tests and other operations described in connection with the configurations disclosed herein may be implemented as electronic hardware, computer software, or combinations of both. Such modules, logical blocks, circuits, and operations may be implemented or performed with a general purpose processor, a digital signal processor (DSP), an ASIC or ASSP, an FPGA or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to produce the configuration as disclosed herein. For example, such a configuration may be implemented at least in part as a hard-wired circuit, as a circuit configuration fabricated into an application-specific integrated circuit, or as a firmware program loaded into non-volatile storage or a software program loaded from or into a data storage medium as machine-readable code, such code being instructions executable by an array of logic elements such as a general purpose processor or other digital signal processing unit. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller, or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration. A software module may reside in a non-transitory storage medium such as RAM (random-access memory), ROM (read-only memory), nonvolatile RAM (NVRAM) such as flash RAM, erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), registers, hard disk, a removable disk, or a CD-ROM; or in any other form of storage medium known in the art. An illustrative storage medium is coupled to the processor such the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an ASIC. The ASIC may reside in a user terminal. In the alternative, the processor and the storage medium may reside as discrete components in a user terminal.
It is noted that the various methods disclosed herein (e.g., methods N100, N200, N300, and M100, and other methods disclosed with reference to the operation of the various apparatus described herein) may be performed by an array of logic elements such as a processor, and that the various elements of an apparatus as described herein may be implemented as modules designed to execute on such an array. As used herein, the term “module” or “sub-module” can refer to any method, apparatus, device, unit or computer-readable data storage medium that includes computer instructions (e.g., logical expressions) in software, hardware or firmware form. It is to be understood that multiple modules or systems can be combined into one module or system and one module or system can be separated into multiple modules or systems to perform the same functions. When implemented in software or other computer-executable instructions, the elements of a process are essentially the code segments to perform the related tasks, such as with routines, programs, objects, components, data structures, and the like. The term “software” should be understood to include source code, assembly language code, machine code, binary code, firmware, macrocode, microcode, any one or more sets or sequences of instructions executable by an array of logic elements, and any combination of such examples. The program or code segments can be stored in a processor readable medium or transmitted by a computer data signal embodied in a carrier wave over a transmission medium or communication link.
The implementations of methods, schemes, and techniques disclosed herein may also be tangibly embodied (for example, in tangible, computer-readable features of one or more computer-readable storage media as listed herein) as one or more sets of instructions executable by a machine including an array of logic elements (e.g., a processor, microprocessor, microcontroller, or other finite state machine). The term “computer-readable medium” may include any medium that can store or transfer information, including volatile, nonvolatile, removable, and non-removable storage media. Examples of a computer-readable medium include an electronic circuit, a semiconductor memory device, a ROM, a flash memory, an erasable ROM (EROM), a floppy diskette or other magnetic storage, a CD-ROM/DVD or other optical storage, a hard disk or any other medium which can be used to store the desired information, a fiber optic medium, a radio frequency (RF) link, or any other medium which can be used to carry the desired information and can be accessed. The computer data signal may include any signal that can propagate over a transmission medium such as electronic network channels, optical fibers, air, electromagnetic, RF links, etc. The code segments may be downloaded via computer networks such as the Internet or an intranet. In any case, the scope of the present disclosure should not be construed as limited by such embodiments.
Each of the tasks of the methods described herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. In a typical application of an implementation of a method as disclosed herein, an array of logic elements (e.g., logic gates) is configured to perform one, more than one, or even all of the various tasks of the method. One or more (possibly all) of the tasks may also be implemented as code (e.g., one or more sets of instructions), embodied in a computer program product (e.g., one or more data storage media such as disks, flash or other nonvolatile memory cards, semiconductor memory chips, etc.), that is readable and/or executable by a machine (e.g., a computer) including an array of logic elements (e.g., a processor, microprocessor, microcontroller, or other finite state machine). The tasks of an implementation of a method as disclosed herein may also be performed by more than one such array or machine. In these or other implementations, the tasks may be performed within a device for wireless communications such as a cellular telephone or other device having such communications capability. Such a device may be configured to communicate with circuit-switched and/or packet-switched networks (e.g., using one or more protocols such as VoIP). For example, such a device may include RF circuitry configured to receive and/or transmit encoded frames.
It is expressly disclosed that the various methods disclosed herein may be performed by a portable communications device such as a handset, headset, smartphone, or tablet computer, and that the various apparatus described herein may be included within such a device. A typical real-time (e.g., online) application is a telephone conversation conducted using such a mobile device.
In one or more exemplary embodiments, the operations described herein may be implemented in hardware, software, firmware, or any combination thereof. If implemented in software, such operations may be stored on or transmitted over a computer-readable medium as one or more instructions or code. The term “computer-readable media” includes both computer-readable storage media and communication (e.g., transmission) media. By way of example, and not limitation, computer-readable storage media can comprise an array of storage elements, such as semiconductor memory (which may include without limitation dynamic or static RAM, ROM, EEPROM, and/or flash RAM), or ferroelectric, magnetoresistive, ovonic, polymeric, or phase-change memory; CD-ROM or other optical disk storage; and/or magnetic disk storage or other magnetic storage devices. Such storage media may store information in the form of instructions or data structures that can be accessed by a computer. Communication media can comprise any medium that can be used to carry desired program code in the form of instructions or data structures and that can be accessed by a computer, including any medium that facilitates transfer of a computer program from one place to another. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technology such as infrared, radio, and/or microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technology such as infrared, radio, and/or microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray Disc™ (Blu-Ray Disc Association, Universal City, Calif.), where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
An acoustic signal processing apparatus as described herein may be incorporated into an electronic device that accepts speech input in order to control certain operations, or may otherwise benefit from separation of desired noises from background noises, such as communications devices. Many applications may benefit from enhancing or separating clear desired sound from background sounds originating from multiple directions. Such applications may include human-machine interfaces in electronic or computing devices which incorporate capabilities such as voice recognition and detection, speech enhancement and separation, voice-activated control, and the like. It may be desirable to implement such an acoustic signal processing apparatus to be suitable in devices that only provide limited processing capabilities.
The elements of the various implementations of the modules, elements, and devices described herein may be fabricated as electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or gates. One or more elements of the various implementations of the apparatus described herein may also be implemented in whole or in part as one or more sets of instructions arranged to execute on one or more fixed or programmable arrays of logic elements such as microprocessors, embedded processors, IP cores, digital signal processors, FPGAs, ASSPs, and ASICs.
It is possible for one or more elements of an implementation of an apparatus as described herein to be used to perform tasks or execute other sets of instructions that are not directly related to an operation of the apparatus, such as a task relating to another operation of a device or system in which the apparatus is embedded. It is also possible for one or more elements of an implementation of such an apparatus to have structure in common (e.g., a processor used to execute portions of code corresponding to different elements at different times, a set of instructions executed to perform tasks corresponding to different elements at different times, or an arrangement of electronic and/or optical devices performing operations for different elements at different times).
The present application for patent claims priority to Provisional Application No. 61/367,730, entitled “SYSTEMS, METHODS, APPARATUS, AND COMPUTER-READABLE MEDIA FOR MULTI-MICROPHONE RANGE-SELECTIVE PROCESSING,” filed Jul. 26, 2010.
Number | Name | Date | Kind |
---|---|---|---|
5764778 | Zurek | Jun 1998 | A |
7039198 | Birchfield et al. | May 2006 | B2 |
20040175008 | Roeck et al. | Sep 2004 | A1 |
20060204019 | Suzuki et al. | Sep 2006 | A1 |
20090268931 | Andrea et al. | Oct 2009 | A1 |
20090310444 | Hiroe | Dec 2009 | A1 |
20100008515 | Fulton et al. | Jan 2010 | A1 |
Number | Date | Country |
---|---|---|
0671721 | Sep 1995 | EP |
H0823383 | Jan 1996 | JP |
H0851686 | Feb 1996 | JP |
2001204092 | Jul 2001 | JP |
2005049876 | Feb 2005 | JP |
2008507926 | Mar 2008 | JP |
2009135594 | Jun 2009 | JP |
WO-2006028587 | Mar 2006 | WO |
WO2007082579 | Jul 2007 | WO |
WO2007137364 | Dec 2007 | WO |
WO2010048620 | Apr 2010 | WO |
Entry |
---|
Togami, M. et al., “Stepwise phase difference restoration method for sound source localization using multiple microphone pairs”, Proc. ICASSP 2007, IEEE, Apr. 15-20, 2007, pp. I-117 to I-120. |
Goetze et al., “Direction of arrival estimation based on the dual delay line approach for binaural hearing aid microphone arrays”, International Symposium on Intelligent Signal Processing and Communication Systems (ISPACS), Nov. 1, 2007, pp. 84-87, IEEE, XP031211473, ISBN: 978-1-4244-1446-8. |
International Search Report and Written Opinion—PCT/US2011/045411—ISA/EPO—Mar. 6, 2012. |
Merks et al., “Design of a broadside array for a binaural hearing aid”, IEEE ASSP Workshop on Applications of Signal Processing to Audio and Acoustics, Oct. 19, 1997, p. 4PP, IEEE, XP010248190, ISBN: 978-0-7803-3908-8. |
Number | Date | Country | |
---|---|---|---|
20120020485 A1 | Jan 2012 | US |
Number | Date | Country | |
---|---|---|---|
61367730 | Jul 2010 | US |