Many audio systems both detect sound and produce sound in a space, such as automotive audio systems, conference room systems, telephone systems, and others. These systems may include playback transducers, e.g., loudspeakers, and may also include one or more microphones. In various examples, acoustic energy in the space may include audio played by the system, desired signals such as user speech, and audio from other sources, which may include noise. Playback audio from the audio system may be, for example, entertainment audio, audio from a far end participant, or other audio. One or more microphones may pick up any or all of these acoustic signals, and for various applications there may be a benefit to estimating a power spectral density (PSD) of any of the playback audio, noise, or other signal components in the microphone signal.
In one aspect, a method for estimating a power spectral density of a selected signal component is provided, the method including receiving, at one or more processing devices, an input signal representing audio captured using a microphone. The input signal includes at least a first portion that represents acoustic output from a first audio source in an environment (e.g., a first loudspeaker) and a second portion that represents other acoustic energy in the environment (such as a noise component). The method also includes iteratively modifying, by the one or more processing devices, a frequency domain representation of the input signal. The modified frequency domain representation represents a portion of the input signal in which effects due to all but a selected one of the first or second portions is substantially reduced. The method may further include determining, from the modified frequency domain representation, an estimate of a power spectral density of the selected portion.
In another aspect, a system that includes a signal analysis engine having one or more processing devices is provided. The signal analysis engine is configured to receive an input signal representing audio captured using a microphone. The input signal includes at least a first portion that represents acoustic output from a first audio source in an environment (e.g., a first loudspeaker) and a second portion that represents other acoustic energy in the environment (such as a noise component). The signal analysis engine is also configured to iteratively modify a frequency domain representation of the input signal. The modified frequency domain representation represents a portion of the input signal in which effects due to all but a selected one of the first or second portions is substantially reduced. The signal analysis engine is further configured to determine, from the modified frequency domain representation, an estimate of a power spectral density of the selected portion.
In another aspect, this document features one or more machine-readable storage devices having encoded thereon computer readable instructions for causing one or more processing devices to perform various operations to perform the above method or implement the above system.
Implementations of the above aspects can include one or more of the following features.
In various examples, the input signal may include additional portions, each of which represents an additional audio source in the environment (e.g., additional loudspeakers). The selected portion may be any of the additional portion(s).
The selected portion may be the second portion and the estimated power spectral density may be representative of the other acoustic energy in the environment, such as noise. Such a noise estimated power spectral density may be used by a noise reduction system to reduce noise from a microphone signal and/or may be used to replace noise in a quiescent communication system. The selected portion may be the first portion and the estimated power spectral density may be representative of an echo, which may be applied to a residual echo suppression system. The frequency domain representation can include, for each frequency bin, one or more of: (i) values that each represent a level of coherence between acoustic outputs of the one or more audio sources, (ii) values that each represent a level of coherence between an acoustic output of a particular one of the audio source(s) and the input signal, and (iii) values that each represent the power of the acoustic output for the particular frequency bin, of an individual one of the audio source(s). The frequency domain representation can include a cross-spectral density matrix computed based on output(s) of the one or more audio sources. Iteratively modifying the frequency domain representation can include executing a matrix diagonalization process on the cross-spectral density matrix.
In some implementations, the technology described herein may provide one or more of the following advantages.
By deriving the power spectral density of a selected portion of an input signal, frequency-specific information (which is directly usable in various applications) about the selected portion can be directly computed without wasting computing resources in determining a time waveform of the selected portion. The technology, which can be implemented based on input signals captured using a single microphone, is scalable with the number of (input) audio sources. Input audio sources that are highly correlated can be handled simply by omitting one or more row reduction steps in the matrix operations described herein. In some cases, this can provide significant improvements over adaptive filtration techniques that often malfunction in the presence of correlated sources.
Two or more of the features described in this disclosure, including those described in this summary section, may be combined to form implementations not specifically described herein.
The details of one or more implementations are set forth in the accompanying drawings and the description below. Other features, objects, and advantages will be apparent from the description and drawings, and from the claims.
The technology described in this document is directed to separating a noise signal from a microphone signal that represents captured audio from both an audio system and the noise sources. This can be used, for example, in an automotive audio system that continuously and automatically adjusts the audio reproduction in response to changing noise conditions in a vehicle cabin, to provide a uniform/consistent perceptual audio experience. This can also be used to reduce the noise content of the microphone signal, e.g., for hands-free communication applications, such as by spectral subtraction or postfiltering, and/or for estimating a “comfort noise” to be added to a telephony line when a far end is quiescent (absence of a transmitted signal).
Such audio systems may include a microphone that is typically placed in the vehicle cabin to measure the noise. Such systems may depend on separating the contribution of the system audio from the noise in the microphone signal. This document describes technology directed to removing, from the microphone signal, the contributions from multiple acoustic transducers, or multiple input channels of the audio system, based on estimating coherence between pairs of acoustic transducers and coherence between each acoustic transducer and the microphone signal. The estimations and removals are done iteratively using matrix operations in the frequency domain, which directly generates an estimate of the power spectral density of the time-varying noise. Computing such frequency-specific information directly without first estimating a corresponding time domain estimate of the noise results in savings of computational resources, particular for audio systems where gain adjustments are made separately for different frequency bands. The technology described herein can be implemented using signals captured by a single microphone, and is scalable for increasing number of channels/acoustic transducers in the underlying audio system.
The microphone signal 104 can include contributions from both the acoustic transducers of the underlying audio system and the noise sources. The technology described herein is directed to separating, from the microphone signal 104, the contributions from the system audio, such that the residual (after removal of the contributions from the system audio) can be taken as an estimate of the noise that may be used in further processing steps.
In
where * represents the linear convolution operation. In the frequency domain, equation (1) is represented as:
where the capitalized form of each variable indicates the frequency domain counterpart.
This document describes, computation of an instantaneous measure—e.g., energy level, power spectral density—of the noise signal w(n), given the source signals xi(n) and the microphone signal y(n). The transfer functions hiy(n) are assumed to be varying and unknown. In some implementations, the determination of the instantaneous measure of the noise signal can be made using a microphone signal captured using a single microphone 206, and using the concept of coherence. Multiple coherence calculations can be executed, for example, between each of the multiple input sources and the microphone in determining the instantaneous measure of the noise signal.
For the case of two acoustic transducers only, equation (2) becomes:
Y=H1yX1+H2yX2+W (3)
Estimates of the auto-spectra and cross-spectra of the inputs and output signals may be computed and assembled in a cross-spectrum matrix as:
In some implementations, the instantaneous measure of the noise signal can be determined as the auto-spectrum of the cabin noise Gww, which is the residual auto-spectrum of the microphone signal Gyy after content correlated with the inputs x1 and x2 has been removed. This can be represented as Gyy·1,2, the auto-spectrum of the microphone signal Gyy conditioned on the inputs x1 and x2. The general formula for removing the content correlated with one signal a from the cross-spectrum of two signals b and c is given by:
For an auto-spectrum Gbb, the substitution b=c in equation (4) yields:
where γab2 is the coherence between a and b, so that Gbb·a is the fraction of the auto-spectrum of b that is not coherent with a. Removing the content correlated with one signal from all the remaining signals is equivalent to performing one step of Gaussian elimination on the cross-spectrum matrix. If the first row of the cross-spectrum matrix above is multiplied by
and the product is subtracted from the second row, the first step of diagonalization yields:
Equation (6) represents the formula for conditioned cross-spectra being used in in re-writing the elements (2,2) and (2,3) of the matrix. Continuing with the iterative diagonalization process, multiplication of the first row of the cross-spectrum matrix on the right-hand side of equation (6) by
and subtracting the product from the third row yields:
The right-hand side of equation (7) represents a point in the iterative matrix diagonalization process, where content coherent with the first audio input are removed from the auto and cross-spectra of the other signals, and the 2×2 cross-spectrum matrix in the lower right corner represents the residual auto and cross-spectra conditioned on the first signal. Terms involving the second audio input stand modified to account for the case in which the two audio inputs are not entirely independent but have some correlation (e.g., as is the case for left and right stereo channels). To further reduce the effect of the second audio input from the microphone signal, the matrix diagonalization (e.g., by Gaussian elimination) can be continued on the 2×2 matrix in the lower right corner. This can include multiplying the second row by
and subtracting the products from the third row:
The last element in the diagonal, Gyy·1,2 is the auto-spectrum of the microphone signal conditioned on the two audio inputs, which is essentially an estimate of the noise auto-spectrum Gww. Iterative modification of the frequency domain representation of the input signal, as described above, therefore yields an estimate of power spectral density of the noise signal via removal of contributions due to the various acoustic sources.
For systems with more audio input sources such as the acoustic transducers 202, the iterative process described above can be scaled as needed to reduce the effect of content of each audio input one by one from the remaining signals. In some implementations, a subset of the audio inputs may be linearly dependent (e.g., when a stereo pair is up-mixed to more channels, for example, for a 5.1 or 7.1 configuration). In such cases, a diagonal term used in the denominator of a row reduction coefficient (e.g., G22·1 above) can have a low value (possibly zero in some cases), which in turn can lead to numerical problems. In such circumstances, row reductions using that particular row may be omitted. For example, if
that implies that 99% of the power in the original auto-spectrum of the output of the second acoustic transducer has already been accounted for by the operations involving the auto and cross-spectra of the output of the first acoustic transducer. Accordingly, a separate row reduction using the output of the second acoustic transducer may be avoided without significantly affecting the noise estimate.
The scalability aspect of the technology is illustrated with reference to
In some implementations, the noise analysis engine 115 is configured to capture/use time segments of the N system audio sources xi(n), i=1, 2, . . . , N, as well as that of y(n) from the microphone 206. In some implementations, the noise analysis engine is configured to apply appropriate windowing to the time segments. The noise analysis engine 115 is also configured to compute a frequency domain representation from the time segments of each input. For example, the noise analysis engine 115 may compute Fourier transforms of the windowed time segments to get spectra Xi(f) and Y(f). These spectra essentially represent one time-slice of the short-time Fourier transforms (STFT) of the signals. The noise analysis engine 115 is further configured to compute the cross-spectral density matrix, for example, by forming products and averaging over several time slices to generate a representation of the following matrix:
where Gij=E{X*iXj}, Giy=E{X*iY}, and Gyy=E{Y*Y}. In some implementations, the operation E{⋅} can be approximated by applying a single-order low pass filter.
For the iterative process, the noise analysis engine 115 is configured to use a matrix diagonalization process (e.g., Gaussian elimination) on rows of the matrix to make the matrix upper triangular as follows:
where Gii.j! is the auto-spectrum of the signal xi(n) conditioned on all the previous sources xk(n), k=1, 2, . . . , j. As discussed above, a row reduction step may be omitted for numerical stability if a particular diagonal term used is small (e.g., less than a threshold).
The last element on the diagonal in the upper triangular matrix Gyy·x is the power spectral density of the microphone signal y(n) conditioned on all the system audio source signals xi(n), i=1, 2, . . . , N, and can be considered to be equivalent to the power spectral density estimate Gww of the cabin noise not due to the known system audio content. The power spectral density is in the form of a frequency vector, and therefore provides frequency specific information about the noise.
The above steps derive the noise estimate corresponding to one particular time segment. The procedure can be repeated for subsequent time segments to provide a running instantaneous measure of the noise. Such instantaneous measures of the noise can be used for further processing, such as in adjusting the gain of an audio system in accordance with the instantaneous noise. In some implementations, such gain adjustments may be performed separately for different frequency bands such as ranges corresponding to bass, mid-range, and treble.
Overall, the technology described herein can be used to mitigate effects of variable noise on the listening experience by adjusting, automatically and dynamically, the music or speech signals played by an audio system in a moving vehicle. In some implementations, the technology can be used to promote a consistent listening experience without typically requiring significant manual intervention. For example, the audio system can include one or more controllers in communication with one or more noise detectors. An example of a noise detector includes a microphone placed in a cabin of the vehicle. The microphone is typically placed at a location near a user's ears, e.g., along a headliner of the passenger cabin. Other examples of noise detectors can include speedometers and/or electronic transducers capable of measuring engine revolutions per minute, which in turn can provide information that is indicative of the level of noise perceived in the passenger cabin. An example of a controller includes, but is not limited to, a processor, e.g., a microprocessor. The audio system can include one or more of the source analysis engine 110, loudness analysis engine 120, noise analysis engine 115, and gain adjustment circuit 125. In some implementations, one or more controllers of the audio system can be used to implement one or more of the above described engines.
Operations of the process 400 can also include iteratively modifying a frequency domain representation of the input signal, such that the modified frequency domain representation represents a portion of the input signal in which effects due to the first portion are substantially reduced (420). The frequency domain representation can be based on a time segment of the input signal. In some implementations, the frequency domain representation includes, for each frequency bin, values that each represent a level of coherence between acoustic outputs from a pair of two or more audio sources, values that each represent a level of coherence between an acoustic output of a particular audio source of the one or more audio sources and the audio captured using the microphone, and values that each represent the power of the acoustic output for the particular frequency bin, of an individual audio source of the one or more audio sources. In some implementations, the values that each represent a level of coherence between acoustic outputs from a pair of two or more audio sources include one value for every permutation of pairs of two or more audio sources. In some implementations, the values that each represent a level of coherence between an acoustic output of a particular audio source of the one or more audio sources and the audio captured using the microphone include two values for each of the one or more audio sources. In some implementations, the values that each represent the power of the acoustic output for the particular frequency bin, of an individual audio source of the one or more audio sources include one value for each of the one or more audio sources.
In some implementations, the frequency domain representation can include a cross-spectral density matrix computed based on outputs of the one or more audio sources. Iteratively modifying the frequency domain representation can include executing a matrix diagonalization process on the cross-spectral density matrix.
Operations of the process 400 also includes determining, from the modified frequency domain representation, an estimate of a power spectral density of the noise (430), and generating a control signal configured to adjust one or more gains of an acoustic transducer corresponding one or more frequency ranges (440). The control signal being generated can be based on the estimate of the power spectral density of the noise. For example, the one or more gains of the acoustic transducer are adjusted to increase with an increase in the estimate of the power spectral density of the noise, and decrease with a decrease in the estimate of the power spectral density.
In various examples, the method illustrated by blocks 410, 420, and 430 of
In various examples, Gaussian elimination as described may be performed on a cross power spectral density matrix, e.g., as described with reference to
For example, the input signals may be deemed reference signals, and in various examples, the total power spectral density of an output signal is comprised of the sum of all the cross power spectral densities of the components contributed by the input signals plus the power spectral density of any components not contributed by any of the input signals. Components of an output signal that are not contributed by any of the input signals are, in various examples, “noise” signals.
For example,
In some examples, the output signal, e.g., y(n), may be a superposition of a desired signal and noise. For example, if a microphone is used to pick up audio content in a vehicle cabin or in a room, the desired signal may be the content that is played back by an audio system. The signals that are being played are input signals known to the system and will therefore serve as the reference signals. To reduce the noise level from the microphone signal, the multi-coherence method can be used to estimate the power spectral density of the noise. In some examples, the estimated noise spectrum is spectrally subtracted from the microphone signal spectrum, such that the modified microphone signal will have lower noise.
In some examples, the multi-coherence method may be used for residual echo reduction/suppression. For example, in an echo cancelling system, the multi-coherence method may be used to estimate the residual echo signal spectrum, and then subtracted from the echo canceller output to further reduce the level of residual echo. Such a subtraction may be a spectral subtraction. In such examples, an input (near-end) speech signal (e.g., from a microphone) may be a reference signal and the multi-coherence method may estimate power spectral density of a residual echo (e.g., from the far-end speech signal) through the Gaussian elimination operation process. The residual echo may be reduced in the output of the echo cancelling system by subtracting the echo spectrum from the signal to be transmitted. Various examples may use this method for reducing echo component(s) caused by any audio playback, e.g., far end speech signals and entertainment, navigation, etc., played by the audio system during, e.g., a phone conversation.
Some examples may use a multi-coherence method to estimate an appropriate comfort noise in, e.g., a telephony system. A comfort noise signal is sometimes added to the line to assure a user that the line is still connected even when the system has gone quiescent in the absence of a (desired) signal transmitted from the far end (e.g., the other conversation participant is not speaking). The multi-coherence method can be used to estimate the power spectral density and overall level of the original noise to create a corresponding comfort noise, thus allowing a seamless and transparent transition between the two. In some examples, a known test or training signal may be used as an input signal at the transmitter to provide a reference signal at the receiver.
Embodiments of the subject matter and the functional operations described in this specification can be implemented in digital electronic circuitry, in tangibly-embodied computer software or firmware, in computer hardware, including the structures disclosed in this specification and their structural equivalents, or in combinations of one or more of them. Embodiments of the subject matter described in this specification can be implemented as one or more computer programs, i.e., one or more modules of computer program instructions encoded on a tangible non-transitory storage medium for execution by, or to control the operation of, data processing apparatus. The computer storage medium can be a machine-readable storage device, a machine-readable storage substrate, a random or serial access memory device, or a combination of one or more of them.
The term “data processing apparatus” refers to data processing hardware and encompasses all kinds of apparatus, devices, and machines for processing data, including by way of example a programmable digital processor, a digital computer, or multiple digital processors or computers. The apparatus can also be or further include special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit). The apparatus can optionally include, in addition to hardware, code that creates an execution environment for computer programs, e.g., code that constitutes processor firmware, a protocol stack, a database management system, an operating system, or a combination of one or more of them.
A computer program, which may also be referred to or described as a program, software, a software application, a module, a software module, a script, or code, can be written in any form of programming language, including compiled or interpreted languages, or declarative or procedural languages, and it can be deployed in any form, including as a standalone program or as a module, component, subroutine, or other unit suitable for use in a computing environment. A computer program may, but need not, correspond to a file in a file system. A program can be stored in a portion of a file that holds other programs or data, e.g., one or more scripts stored in a markup language document, in a single file dedicated to the program in question, or in multiple coordinated files, e.g., files that store one or more modules, sub programs, or portions of code. A computer program can be deployed to be executed on one computer or on multiple computers that are located at one site or distributed across multiple sites and interconnected by a data communication network.
The processes and logic flows described in this specification can be performed by one or more programmable computers executing one or more computer programs to perform functions by operating on input data and generating output. The processes and logic flows can also be performed by, and apparatus can also be implemented as, special purpose logic circuitry, e.g., an FPGA (field programmable gate array) or an ASIC (application specific integrated circuit). For a system of one or more computers to be “configured to” perform particular operations or actions means that the system has installed on it software, firmware, hardware, or a combination of them that in operation cause the system to perform the operations or actions. For one or more computer programs to be configured to perform particular operations or actions means that the one or more programs include instructions that, when executed by data processing apparatus, cause the apparatus to perform the operations or actions.
Computers suitable for the execution of a computer program include, by way of example, can be based on general or special purpose microprocessors or both, or any other kind of central processing unit. Generally, a central processing unit will receive instructions and data from a read only memory or a random access memory or both. The essential elements of a computer are a central processing unit for performing or executing instructions and one or more memory devices for storing instructions and data. Generally, a computer will also include, or be operatively coupled to receive data from or transfer data to, or both, one or more mass storage devices for storing data, e.g., magnetic, magneto optical disks, or optical disks. However, a computer need not have such devices. Moreover, a computer can be embedded in another device, e.g., a mobile telephone, a personal digital assistant (PDA), a mobile audio or video player, a game console, a Global Positioning System (GPS) receiver, or a portable storage device, e.g., a universal serial bus (USB) flash drive, to name just a few.
Computer readable media suitable for storing computer program instructions and data include all forms of nonvolatile memory, media and memory devices, including by way of example semiconductor memory devices, e.g., EPROM, EEPROM, and flash memory devices; magnetic disks, e.g., internal hard disks or removable disks; magneto optical disks; and CD ROM and DVD-ROM disks. The processor and the memory can be supplemented by, or incorporated in, special purpose logic circuitry.
Control of the various systems described in this specification, or portions of them, can be implemented in a computer program product that includes instructions that are stored on one or more non-transitory machine-readable storage media, and that are executable on one or more processing devices. The systems described in this specification, or portions of them, can be implemented as an apparatus, method, or electronic system that may include one or more processing devices and memory to store executable instructions to perform the operations described in this specification.
While this specification contains many specific implementation details, these should not be construed as limitations on the scope of any claims or on the scope of what may be claimed, but rather as descriptions of features that may be specific to particular embodiments of particular inventions. Certain features that are described in this specification in the context of separate embodiments can also be implemented in combination in a single embodiment. Conversely, various features that are described in the context of a single embodiment can also be implemented in multiple embodiments separately or in any suitable subcombination. Moreover, although features may be described above as acting in certain combinations and even initially claimed as such, one or more features from a claimed combination can in some cases be excised from the combination, and the claimed combination may be directed to a subcombination or variation of a subcombination.
Similarly, while operations are depicted in the drawings in a particular order, this should not be understood as requiring that such operations be performed in the particular order shown or in sequential order, or that all illustrated operations be performed, to achieve desirable results. In certain circumstances, multitasking and parallel processing may be advantageous. Moreover, the separation of various system modules and components in the embodiments described above should not be understood as requiring such separation in all embodiments, and it should be understood that the described program components and systems can generally be integrated together in a single software product or packaged into multiple software products.
Particular embodiments of the subject matter have been described. Other embodiments are within the scope of the following claims. For example, the actions recited in the claims can be performed in a different order and still achieve desirable results. As one example, the processes depicted in the accompanying figures do not necessarily require the particular order shown, or sequential order, to achieve desirable results. In some cases, multitasking and parallel processing may be advantageous.
This application claims priority to U.S. Application 62/841,608, filed on May 1, 2019, titled SIGNAL COMPONENT ESTIMATION USING COHERENCE, the entire contents of which are incorporated herein by reference.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2020/030742 | 4/30/2020 | WO |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2020/223495 | 11/5/2020 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
5209237 | Rosenthal | May 1993 | A |
9832569 | Ayrapetian | Nov 2017 | B1 |
10937418 | Chatlani | Mar 2021 | B1 |
20050251389 | Zangi | Nov 2005 | A1 |
20170251301 | Nesta | Aug 2017 | A1 |
20190131950 | Cheung | May 2019 | A1 |
20200219493 | Li | Jul 2020 | A1 |
Number | Date | Country | |
---|---|---|---|
20220199105 A1 | Jun 2022 | US |
Number | Date | Country | |
---|---|---|---|
62841608 | May 2019 | US |