1. Field
This disclosure relates to audio signal processing.
2. Background
Active noise cancellation (ANC, also called active noise reduction) is a technology that actively reduces acoustic noise in the air by generating a waveform that is an inverse form of the noise wave (e.g., having the same level and an inverted phase), also called an “antiphase” or “anti-noise” waveform. An ANC system generally uses one or more microphones to pick up an external noise reference signal, generates an anti-noise waveform from the noise reference signal, and reproduces the anti-noise waveform through one or more loudspeakers. This anti-noise waveform interferes destructively with the original noise wave to reduce the level of the noise that reaches the ear of the user.
A method of audio signal processing according to a general configuration includes producing an anti-noise signal based on information from a first audio signal, separating a target component of a second audio signal from a noise component of the second audio signal to produce at least one among (A) a separated target component and (B) a separated noise component, and producing an audio output signal based on the anti-noise signal. In this method, the audio output signal is based on at least one among (A) the separated target component and (B) the separated noise component. Apparatus and other means for performing such a method, and computer-readable media having executable instructions for such a method, are also disclosed herein.
Also disclosed herein are variations of such a method, in which: the first audio signal is an error feedback signal; the second audio signal includes the first audio signal; the audio output signal is based on the separated target component; the second audio signal is a multichannel audio signal; the first audio signal is the separated noise component; and/or the audio output signal is mixed with a far-end communications signal. Apparatus and other means for performing such methods, and computer-readable media having executable instructions for such methods, are also disclosed herein.
The principles described herein may be applied, for example, to a headset or other communications or sound reproduction device that is configured to perform an ANC operation.
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). 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) “based on at least” (e.g., “A is based on at least B”) and, if appropriate in the particular context, (ii) “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 indicate the location of the center of an acoustically sensitive face of the microphone, unless otherwise indicated by the context. 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.
Active noise cancellation techniques may be applied to personal communications devices (e.g., cellular telephones, wireless headsets) and/or sound reproduction devices (e.g., earphones, headphones) to reduce acoustic noise from the surrounding environment. In such applications, the use of an ANC technique may reduce the level of background noise that reaches the ear (e.g., by up to twenty decibels or more) while delivering one or more desired sound signals, such as music, speech from a far-end speaker, etc.
A headset or headphone for communications applications typically includes at least one microphone and at least one loudspeaker, such that at least one microphone is used to capture the user's voice for transmission and at least one loudspeaker is used to reproduce the received far-end signal. In such a device, each microphone may be mounted on a boom or on an earcup, and each loudspeaker may be mounted in an earcup or earplug.
As an ANC system is typically designed to cancel any incoming acoustic signals, it tends to cancel the user's own voice as well the background noise. Such an effect may be undesirable, especially in a communications application. An ANC system may also tend to cancel other useful signals, such as a siren, car horn, or other sound that is intended to warn and/or to capture one's attention. Additionally, an ANC system may include good acoustic shielding (e.g., a padded circumaural earcup or a tight-fitting earplug) that passively blocks ambient sound from reaching the user's ear. Such shielding, which is typically especially in systems intended for use in industrial or aviation environments, may reduce signal power at high frequencies (e.g., frequencies greater than one kilohertz) by more than twenty decibels and therefore may also contribute to inhibiting the user from hearing her own voice. Such cancellation of the user's own voice is not natural and may cause an unusual or even unpleasant perception while using an ANC system in a communication scenario. For example, such cancellation may cause the user to perceive that the communications device is not working.
It may be desirable, in a communications application, to mix the sound of a user's own voice into the received signal that is played at the user's ear. The technique of mixing a microphone input signal into a loudspeaker output in a voice communications device, such as a headset or telephone, is called “sidetone.” By permitting the user to hear her own voice, sidetone typically enhances user comfort and increases efficiency of the communication.
As an ANC system may inhibit the user's voice from reaching her own ear, one can implement such a sidetone feature in an ANC communications device. For example, a basic ANC system as shown in
However, using sidetone features without sophisticated processing tends to weaken the effectiveness of the ANC operation. Since a conventional sidetone feature is designed to add any acoustic signal captured by the microphone to the loudspeaker, it will tend to add environmental noise as well as the user's own voice to the signal driving the loudspeaker, which reduces the effectiveness of the ANC operation. While the user of such a system may hear her own voice or other useful signals better, the user also tends to hear more noise than in an ANC system without a sidetone feature. Unfortunately, current ANC products do not address this problem.
Configurations disclosed herein include systems, methods, and apparatus having a source separation module or operation that separates a target component (e.g., the user's voice and/or another useful signal) from the environmental noise. Such a source separation module or operation may be used to support an enhanced sidetone (EST) approach which can deliver the sound of the user's own voice to the user's ear while retaining the effectiveness of the ANC operation. An EST approach may include separating the user's voice from a microphone signal and adding it into the signal played at the loudspeaker. Such a method allows the user to hear her own voice while the ANC operation continues to block ambient noise.
An enhanced sidetone approach may be performed by mixing a separated voice component into an ANC loudspeaker output. Separation of the voice component from a noise component may be achieved using a general noise suppression method or a specialized multi-microphone noise separation method. The effectiveness of the voice-noise separation operation may vary depending on the complexity of the separation technique.
An enhanced sidetone approach may be used to enable the ANC user to hear her own voice without sacrificing the effectiveness of the ANC operation. Such a result may help to enhance the naturalness of the ANC system and create a more comfortable user experience.
Several different approaches may be used to implement an enhanced sidetone feature.
Apparatus A100 includes an ANC filter AN10 that is configured to receive the environmental sound signal and to perform an ANC operation (e.g., according to any desired digital and/or analog ANC technique) to produce a corresponding anti-noise signal. Such an ANC filter is typically configured to invert the phase of the environmental noise signal and may also be configured to equalize the frequency response and/or to match or minimize the delay. Examples of ANC operations that may be performed by ANC filter AN10 to produce the anti-noise signal include a phase-inverting filtering operation, a least mean squares (LMS) filtering operation, a variant or derivative of LMS (e.g., filtered-x LMS, as described in U.S. Pat. Appl. Publ. No. 2006/0069566 (Nadjar et al.) and elsewhere), and a digital virtual earth algorithm (e.g., as described in U.S. Pat. No. 5,105,377 (Ziegler)). ANC filter AN10 may be configured to perform the ANC operation in the time domain and/or in a transform domain (e.g., a Fourier transform or other frequency domain).
Apparatus A100 also includes a source separation module SS10 that is configured to separate a desired sound component (a “target component”) from a noise component of the environmental noise signal (possibly by removing or otherwise suppressing the noise component) and to produce a separated target component S10. The target component may be the user's voice and/or another useful signal. In general, source separation module SS10 may be implemented using any available noise reduction technology, including single-microphone noise reduction technology, dual- or multiple-microphone noise reduction technology, directional-microphone noise reduction technology, and/or signal separation or beamforming technology. Implementations of source separation module SS10 that perform one or more voice detection and/or spatially selective processing operations are expressly contemplated, and examples of such implementations are described herein.
Many useful signals, such as a siren, car horn, alarm, or other sound that is intended to warn, alert, and/or to capture one's attention, are typically tonal components that have narrow bandwidths in comparison to other sound signals such as noise components. It may be desirable to configure source separation module SS10 to separate a target component that appears only within a particular frequency range (e.g., from about 500 or 1000 Hertz to about two or three kilohertz), has a narrow bandwidth (e.g., not greater than about fifty, one hundred, or two hundred Hertz), and/or has a sharp attack profile (e.g., has an increase in energy not less than about fifty, seventy-five, or one hundred percent from one frame to the next). Source separation module SS10 may be configured to operate in the time domain and/or in a transform domain (e.g., a Fourier or other frequency domain).
Apparatus A100 also includes an audio output stage AO10 that is configured to produce an audio output signal to drive loudspeaker SP10 that is based on the anti-noise signal. For example, audio output stage AO10 may be configured to produce the audio output signal by converting a digital anti-noise signal to analog; by amplifying, applying a gain to, and/or controlling a gain of the anti-noise signal; by mixing the anti-noise signal with one or more other signals (e.g., a music signal or other reproduced audio signal, a far-end communications signal, and/or a separated target component); by filtering the anti-noise and/or output signals; by providing impedance matching to loudspeaker SP10; and/or by performing any other desired audio processing operation. In this example, audio output stage AO10 is also configured to apply target component S10 as a sidetone signal by mixing it with (e.g., adding it to) the anti-noise signal. Audio output stage AO10 may be implemented to perform such mixing in the digital domain or in the analog domain.
It may be desirable to configure an enhanced sidetone ANC apparatus such that the anti-noise signal is based on an environmental noise signal that has been processed to attenuate the target component. Removing the separated voice component from the environmental noise signal upstream of ANC filter AN10, for example, may cause ANC filter AN10 to produce an anti-noise signal that has less of a cancellation effect on the sound of the user's voice.
The examples shown in
As shown in the schematic of
In a feedback ANC system, it may be desirable for the error feedback microphone to be disposed within the acoustic field generated by the loudspeaker. For example, it may be desirable for the error feedback microphone to be disposed with the loudspeaker within the earcup of a headphone. It may also be desirable for the error feedback microphone to be acoustically insulated from the environmental noise.
The approaches shown in the schematics of
An earpiece or other headset having one or more microphones is one kind of portable communications device that may include an implementation of an ANC system as described herein. Such a headset may be wired or wireless. For example, a wireless headset may be configured to support half- or full-duplex telephony via communication with a telephone device such as a cellular telephone handset (e.g., using a version of the Bluetooth™ protocol as promulgated by the Bluetooth Special Interest Group, Inc., Bellevue, Wash.).
Typically each microphone of array R100 is mounted within the device behind one or more small holes in the housing that serve as an acoustic port.
A headset may also include a securing device, such as ear hook Z30, which is typically detachable from the headset. An external ear hook may be reversible, for example, to allow the user to configure the headset for use on either ear. Alternatively, the earphone of a headset may be designed as an internal securing device (e.g., an earplug) which may include a removable earpiece to allow different users to use an earpiece of different size (e.g., diameter) for better fit to the outer portion of the particular user's ear canal. For a feedback ANC system, the earphone of a headset may also include a microphone arranged to pick up an acoustic error signal (e.g., microphone EM10).
In the example of
Devices such as D100, D200, H100, and H110 may be implemented as instances of a communications device D10 as shown in
It may be desirable to configure source separation module SS10 to calculate a noise estimate based on frames (e.g., 5-, 10-, or 20-millisecond blocks, which may be overlapping or nonoverlapping) of the environmental noise signal that do not contain voice activity. For example, such an implementation of source separation module SS10 may be configured to calculate the noise estimate by time-averaging inactive frames of the environmental noise signal. Such an implementation of source separation module SS10 may include a voice activity detector (VAD) that is configured to classify a frame of the environmental noise signal as active (e.g., speech) or inactive (e.g., noise) based on one or more factors such as frame energy, signal-to-noise ratio, periodicity, autocorrelation of speech and/or residual (e.g., linear prediction coding residual), zero crossing rate, and/or first reflection coefficient. Such classification may include comparing a value or magnitude of such a factor to a threshold value and/or comparing the magnitude of a change in such a factor to a threshold value.
The VAD may be configured to produce an update control signal whose state indicates whether speech activity is currently detected on the environmental noise signal. Such an implementation of source separation module SS10 may be configured to suspend updates of the noise estimate when the VAD V10 indicates that the current frame of the environmental noise signal is active, and possibly to obtain voice signal V10 by subtracting the noise estimate from the environmental noise signal (e.g., by performing a spectral subtraction operation).
The VAD may be configured to classify a frame of the environmental noise signal as active or inactive (e.g., to control a binary state of the update control signal) based on one or more factors such as frame energy, signal-to-noise ratio (SNR), periodicity, zero-crossing rate, autocorrelation of speech and/or residual, and first reflection coefficient. Such classification may include comparing a value or magnitude of such a factor to a threshold value and/or comparing the magnitude of a change in such a factor to a threshold value. Alternatively or additionally, such classification may include comparing a value or magnitude of such a factor, such as energy, or the magnitude of a change in such a factor, in one frequency band to a like value in another frequency band. It may be desirable to implement the VAD to perform voice activity detection based on multiple criteria (e.g., energy, zero-crossing rate, etc.) and/or a memory of recent VAD decisions. One example of a voice activity detection operation that may be performed by the VAD includes comparing highband and lowband energies of reproduced audio signal S40 to respective thresholds as described, for example, in section 4.7 (pp. 4-49 to 4-57) of the 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,” January 2007 (available online at www-dot-3gpp-dot-org). Such a VAD is typically configured to produce an update control signal that is a binary-valued voice detection indication signal, but configurations that produce a continuous and/or multi-valued signal are also possible.
Alternatively, it may be desirable to configure source separation module SS20 to perform a spatially selective processing operation on a multichannel environmental noise signal (i.e., from microphones VM10 and VM20) to produce target component S10 and/or noise component S20. For example, source separation module SS20 may be configured to separate a directional desired component of the multichannel environmental noise signal (e.g., the user's voice) from one or more other components of the signal, such as a directional interfering component and/or a diffuse noise component. In such case, source separation module SS20 may be configured to concentrate energy of the directional desired component so that target component S10 includes more of the energy of the directional desired component than each channel of the multichannel environmental noise signal does (that is to say, so that target component S10 includes more of the energy of the directional desired component than any individual channel of the multichannel environmental noise signal does).
Source separation module SS20 may be implemented to include a fixed filter FF10 that is characterized by one or more matrices of filter coefficient values. These filter coefficient values may be obtained using a beamforming, blind source separation (BSS), or combined BSS/beamforming method, as described in more detail below. Source separation module SS20 may also be implemented to include more than one stage.
It may be desirable to use fixed filter stage FF10 to generate initial conditions (e.g., an initial filter state) for adaptive filter stage AF10. It may also be desirable to perform adaptive scaling of the inputs to source separation module SS20 (e.g., to ensure stability of an IIR fixed or adaptive filter bank). The filter coefficient values that characterize source separation module SS20 may be obtained according to an operation to train an adaptive structure of source separation module SS20, which may include feedforward and/or feedback coefficients and may be a finite-impulse-response (FIR) or infinite-impulse-response (IIR) design. Further details of such structures, adaptive scaling, training operations, and initial-conditions generation operations are described, for example, in U.S. patent application Ser. No. 12/197,924, filed Aug. 25, 2008, entitled “SYSTEMS, METHODS, AND APPARATUS FOR SIGNAL SEPARATION.”
Source separation module SS20 may be implemented according to a source separation algorithm. The term “source separation algorithm” includes blind source separation (BSS) algorithms, which are methods of separating individual source signals (which may include signals from one or more information sources and one or more interference sources) based only on mixtures of the source signals. Blind source separation algorithms may be used to separate mixed signals that come from multiple independent sources. Because these techniques do not require information on the source of each signal, they are known as “blind source separation” methods. The term “blind” refers to the fact that the reference signal or signal of interest is not available, and such methods commonly include assumptions regarding the statistics of one or more of the information and/or interference signals. In speech applications, for example, the speech signal of interest is commonly assumed to have a supergaussian distribution (e.g., a high kurtosis). The class of BSS algorithms also includes multivariate blind deconvolution algorithms.
A BSS method may include an implementation of independent component analysis. Independent component analysis (ICA) is a technique for separating mixed source signals (components) which are presumably independent from each other. In its simplified form, independent component analysis applies an “un-mixing” matrix of weights to the mixed signals (for example, by multiplying the matrix with the mixed signals) to produce separated signals. The weights may be assigned initial values that are then adjusted to maximize joint entropy of the signals in order to minimize information redundancy. This weight-adjusting and entropy-increasing process is repeated until the information redundancy of the signals is reduced to a minimum. Methods such as ICA provide relatively accurate and flexible means for the separation of speech signals from noise sources. Independent vector analysis (IVA) is a related BSS technique in which the source signal is a vector source signal instead of a single variable source signal.
The class of source separation algorithms also includes variants of BSS algorithms, such as constrained ICA and constrained IVA, which are constrained according to other a priori information, such as a known direction of each of one or more of the source signals with respect to, for example, an axis of the microphone array. Such algorithms may be distinguished from beamformers that apply fixed, non-adaptive solutions based only on directional information and not on observed signals. Examples of such beamformers that may be used to configure other implementations of source separation module SS20 include generalized sidelobe canceller (GSC) techniques, minimum variance distortionless response (MVDR) beamforming techniques, and linearly constrained minimum variance (LCMV) beamforming techniques.
Alternatively or additionally, source separation module SS20 may be configured to distinguish target and noise components according to a measure of directional coherence of a signal component across a range of frequencies. Such a measure may be based on phase differences between corresponding frequency components of different channels of the multichannel audio signal (e.g., as described in U.S. Prov'l Pat. Appl. No. 61/108,447, entitled “Motivation for multi mic phase correlation based masking scheme,” filed Oct. 24, 2008 and U.S. Prov'l Pat. Appl. No. 61/185,518, entitled “SYSTEMS, METHODS, APPARATUS, AND COMPUTER-READABLE MEDIA FOR COHERENCE DETECTION,” filed Jun. 9, 2009). Such an implementation of source separation module SS20 may be configured to distinguish components that are highly directionally coherent (perhaps within a particular range of directions relative to the microphone array) from other components of the multichannel audio signal, such that the separated target component S10 includes only coherent components.
Alternatively or additionally, source separation module SS20 may be configured to distinguish target and noise components according to a measure of the distance of the source of the component from the microphone array. Such a measure may be based on differences between the energies of different channels of the multichannel audio signal at different times (e.g., as described in U.S. Prov'l Pat. Appl. No. 61/227,037, entitled “SYSTEMS, METHODS, APPARATUS, AND COMPUTER-READABLE MEDIA FOR PHASE-BASED PROCESSING OF MULTICHANNEL SIGNAL,” filed Jul. 20, 2009). Such an implementation of source separation module SS20 may be configured to distinguish components whose sources are within a particular distance of the microphone array (i.e., components from near-field sources) from other components of the multichannel audio signal, such that the separated target component S10 includes only near-field components.
It may be desirable to implement source separation module SS20 to include a noise reduction stage that is configured to apply noise component S20 to further reduce noise in target component S10. Such a noise reduction stage may be implemented as a Wiener filter whose filter coefficient values are based on signal and noise power information from target component S10 and noise component S20. In such case, the noise reduction stage may be configured to estimate the noise spectrum based on information from noise component S20. Alternatively, the noise reduction stage may be implemented to perform a spectral subtraction operation on target component S10, based on a spectrum from noise component S20. Alternatively, the noise reduction stage may be implemented as a Kalman filter, with noise covariance being based on information from noise component S20.
The foregoing 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, state 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 voice communications at higher sampling rates (e.g., for wideband communications).
The various elements of an implementation of an apparatus as disclosed herein (e.g., the various elements of apparatus A100, A110, A120, A200, A210, A220, A300, A310, A320, A400, A420, A500, A510, A520, A530, G100, G200, G300, and G400) may be embodied in any combination of hardware, software, and/or firmware that is deemed suitable for the intended application. For example, such elements 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., as enumerated above) 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 (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.
Those of skill will appreciate that the various illustrative modules, logical blocks, circuits, and 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 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, a CD-ROM, or 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 M100, M200, M300, M400, and M500, as well as other methods disclosed by virtue of the descriptions of the operation of the various implementations of apparatus as disclosed herein) may be performed by a 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 one or more computer-readable media as listed herein) as one or more sets of instructions readable and/or 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 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, a fiber optic medium, a radio frequency (RF) link, or any other medium which can be used to store the desired information and which 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 operations disclosed herein may be performed by a portable communications device such as a handset, headset, or portable digital assistant (PDA), and that the various apparatus described herein may be included with 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 storage media and communication media, including any medium that facilitates transfer of a computer program from one place to another. A storage media may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable 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, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to carry or store desired program code in the form of instructions or data structures and that can be accessed by a computer. 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/117,445, entitled “SYSTEMS, METHODS, APPARATUS, AND COMPUTER PROGRAM PRODUCTS FOR ENHANCED ACTIVE NOISE CANCELLATION,” filed Nov. 24, 2008, and assigned to the assignee hereof.
Number | Date | Country | |
---|---|---|---|
61117445 | Nov 2008 | US |