This application relates generally to audio processing and more particularly to content-based audio stream separation.
There is considerable market interest in technology that can analyze captured audio signals (e.g., from a microphone array) and enhance (or separate) one or more of the source signals. Existing systems typically approach this problem in one of two ways. Some systems assume there is a single “target” signal in the presence of background noise (a scenario referred to as target-in-noise paradigm). For example, this approach has been used for speech enhancement, noise suppression and beamforming systems. Alternatively, some systems attempt to perform blind source separation (BSS), whereby all sound sources in the environment are separated from one another such that multiple output signals, one for each sound source, are produced.
The target-in-noise paradigm is useful in some applications, but not as useful in other areas such as virtual reality (VR), augmented reality (AR), video chat and other connected devices. In such applications, if all sources could be effectively separated after being captured by a microphone array, it would be possible to adjust the level, quality and spatial position of each source, similar to the way that sound engineers mix independently recorded tracks in audio production. However, existing BSS approaches are impractical because they make unrealistic assumptions, such as knowledge of the number of sound sources, sound-source directions, and/or that the sources and device do not move too quickly. Unrealistic assumptions cause inaccuracy in separation of signals of the sound sources and prevent deployment of BSS technology in real-world applications.
For a more complete understanding of the disclosure, reference should be made to the following detailed description and accompanying drawings wherein:
Skilled artisans will appreciate that elements in the figures are illustrated for simplicity and clarity. It will further be appreciated that certain actions and/or steps may be described or depicted in a particular order of occurrence while those skilled in the art will understand that such specificity with respect to sequence is not actually required. It will also be understood that the terms and expressions used herein have the ordinary meaning as is accorded to such terms and expressions with respect to their corresponding respective areas of inquiry and study except where specific meanings have otherwise been set forth herein.
According to certain general aspects, the present embodiments are directed to an audio separation technology that is capable of separating an audio signal captured by one or more acoustic sensors into one or more sound signals of specific sound categories. In some embodiments, the disclosed audio separation technology utilizes deep learning to separate the sound signals (also referred to as audio signals or audio streams if continuously fed) based on specific sound content categories (also referred to as content classes) such as speech, music or ambient sound.
In some particularly useful embodiments, the disclosed audio separation technology may be used to separate out speech from an individual talker or persons in a conversation from other sounds present in an audio signal that contains the conversation. As such, the present embodiments can be used to improve speech quality in various speech-centric applications such as hearing aids, cellular phone or other communication systems and voice interface systems (e.g. voice controlled remote controls), or enable talker separation in voice conference systems. In some other embodiments, the disclosed audio separation technology may be used to separate non-speech sounds, separate different sound content, and even recognize underlying content classes.
To illustrate certain aspects of some embodiments, consider a scenario where a captured audio signal contains a conversation of two people talking near a jazz trio at an outdoor cafe. BSS attempts to separate all sources, including both talkers, each instrument of the jazz trio and any prominent ambient sound sources nearby. But BSS makes impractical assumptions and fails in such complex acoustic scenes. By contrast, the disclosed technology is capable of separating the speech content (e.g., from both talkers) from the music content (e.g., from the entire jazz trio) and from other ambient sounds. The disclosed technology enables capabilities analogous to film production, where sound engineers can combine dialogue, music and ambient tracks to achieve a final audio mix for a film. Further, because the disclosed technology utilizes deep learning rather than beamforming or BSS, the disclosed technology is capable of preserving spatial information captured by a microphone array (or other acoustic sensor(s) capturing the sound signals). The spatial information can be used to, e.g., reproduce the captured sound environment for VR or AR applications.
To further illustrate certain aspects of the present embodiments,
The present applicant recognizes that the problem of separating out sounds for various categories such as those described above is especially challenging because there can be substantial temporal and spectral overlap between the sounds. Prior art approaches such as BSS cannot effectively distinguish between sounds under these conditions. In view of these and other challenges, according to some embodiments of the present disclosure to be described in more detail below, the disclosed audio separation technology utilizes deep learning to separate sound signals based on content categories. Deep learning refers to a learning architecture that uses one or more deep neural networks (NNs), each of which contains more than one hidden layer. The deep neural networks may be, e.g., feed-forward neural networks, recurrent neural networks, convolutional neural networks, etc. In some embodiments, data driven models or supervised machine learning models other than neural networks may be used for audio separation as well. For example, a Gaussian mixture model, hidden Markov model, or support vector machine may be used in some embodiments.
In particular, in some embodiments, the disclosed audio separation technology uses deep neural networks to estimate filters (i.e. time-frequency masks) for filtering the sound signal(s). A time-frequency mask is a real-valued or complex-valued function (also referred to as masking function) of frequency for each time frame, where each frequency bin has a value between 0 and 1. The masking function is multiplied by a complex, frequency-domain representation of an audio signal to attenuate a portion of the audio signal at those time-frequency points where the value of the masking function is less than 1. For example, a value of zero of the masking function mutes a portion of the audio signal at a corresponding time-frequency point. In other words, sound in any time-frequency point where the masking function is equal to 0 is inaudible in a reconstructed output signal filtered by the masking function.
In some embodiments, the disclosed audio separation technology transforms at least one time-domain audio signal captured from one or more acoustic sensors (e.g., microphones) into a frequency domain or a time-frequency domain (using, e.g., fast Fourier transform (FFT), short-time Fourier transform (STFT), an auditory filterbank and/or other types of suitable transforms). The disclosed audio separation technology performs feature extraction on the frequency domain representation of the audio signal. The extracted signal features are used as inputs to at least one deep neural network. The neural network may run in a real time as the audio signal is captured and received. The neural network receives a new set of features for each new time frame and generates one or more filters (i.e. time-frequency masks) for that time frame. Each filter corresponds to a pre-defined sound content category. The frequency-domain audio signal(s) are multiplied by the masking functions of the filters and resynthesized into the time domain to produce multiple output signals. Each output signal is an audio signal of a corresponding audio content category.
Although embodiments of the disclosed audio separation technology may find useful application in performing speech separation, the disclosed technology can be applied to sound sources including or excluding human speech, because of its inherent ability to recognize different content categories. At least one type of output of a disclosed audio separation system can be multiple channels of audio streams for different content categories, as well as metadata (e.g., spatial information of sound sources) for each channel.
In embodiments, an offline training stage is used to train the deep neural network to recognize the differences between different sound classes in the feature space defined by the features that are extracted from the audio signals. The training process may involve feeding a training data set including audio signals with known sound content categories. The known sound content categories may include, e.g., one or more of the categories illustrated in
At step 210, the system trains the neural network by feeding the training audio signal into the neural network and optimizing parameters of the neural network. The goal of the training of the neural network is that a trained version of the neural network can be used to separate the training audio signal (in this simplified example) into an instance of the first audio signal and an instance of the second audio signal. Those instances are the same as, or close to, the original first and second audio signals. Once the neural network is trained, the audio separation system can perform audio separation. It should be noted that, although shown here along with other processing for ease of illustration, step 210 can actually be performed in an off-line process that is separate from the remaining “on-line” processing performed as described below.
Having the trained neural network, at step 215, one or more microphones (e.g., a microphone array) capture sounds of an environment into an audio signal. The audio signal includes a combination of content-based audio signals. In some embodiments, the one or more microphones are part of the audio separation system. In some other embodiments, the one or more microphones are external components or devices separate from the audio separation system.
At step 220, a feature extraction module of the audio separation system generates a plurality of features from the audio signal. Examples of features that can be extracted from the audio signal, as well as examples of how feature extraction can be done, are described in more detail below.
At step 225, the neural network of the audio separation system generates a plurality of time-varying filters in a frequency domain using the signal features as inputs to the neural network. Each of the time-varying filters corresponds to one of a plurality of sound content categories. In some embodiments, each of the time-varying filters is a time-varying real-valued or complex-valued function of frequency. A value of the real-valued or complex-valued function for a corresponding frequency represents a level of attenuation for the corresponding frequency.
At step 230, the audio separation system separates the audio signal into a plurality of content-based (i.e., category specific) audio signals by applying the time-varying filters to the audio signal. Each of the content-based (i.e., category specific) audio signals contains content of a corresponding sound content category among the plurality of sound content categories for which the system has been trained. In some embodiments, the content-based audio signals are produced by multiplying the audio signal by the time-varying real-valued or complex-valued functions.
At step 235, the audio separation system outputs the content-based audio signals, possibly along with spatial information of sound sources that emit sounds of the sound content categories, as will be described in more detail below. In some embodiments, a sound of particular interest contained in the audio signal (for example, speech) may be enhanced by attenuating sound levels of some of the content-based audio signals corresponding to other sound content categories of the plurality of sound content categories.
In step 310, a model coefficient update process is performed to update parameters of the deep neural network until the deep neural network is optimized to make predictions consistent with the known content categories. As shown in this example, the update process can be performed iteratively from random coefficient initialization and in step 315 the updated deep neural network is used to produce separated audio signals. For example, and as will be described in more detail below, the training data containing signals with the known sound categories can be fed to a feature extraction module to generate features in the frequency domain. The deep neural network that is being trained receives the signal features and generates a set of frequency masks that filter the audio signals to generate separated audio signals corresponding to the known sound content categories, which may include the known target signal and the known interference signal.
In step 320 the filters (i.e. frequency masks) that are generated by the deep neural network to separate content streams are compared to the optimal filters, or “labels”. Optimal filters are available in training because audio mixtures are created from mixing the clean content signals, making it possible to compute the filter that perfectly reconstructs the magnitude spectrum of the desired signal for a given content category in a process called label extraction. As shown, the model coefficient update process in step 310 can be repeated iteratively, for example using a gradient descent approach, until the filters produced by the deep neural network are very close to the optimal filters, at which point the deep neural network is optimized. In some embodiments, rather than, or in addition to, comparing the generated filters to optimal filters, the magnitude spectra or complex spectra of the separated content signals can be estimated directly by the deep neural networks. In this case, the spectra produced by the deep neural network can be compared to the clean signal spectra during optimization.
It should be noted that the training process performed as illustrated in the example method described in connection with
For example,
The combination of the target signal 412 and the interference signal 414 is used to perform a label extraction 420 to obtain the optimal filter for each of the sound content categories of the signals. More particularly, because the “clean” version of the target signal 412 is known, it is very straightforward to compute the optimal filter that can be applied to the combination of the target signal 412 and the interference signal 414 so as to obtain the target signal 412. During the offline training, a model coefficient update process 425 is performed using features extracted from the combination of the target signal 412 and interference signal 414 to update parameters of the deep neural network 450 until the deep neural network 450 is optimized to make predictions consistent with the known content categories. In other words, the optimized deep neural network 450 can be used to produce separated audio signals that are the same as, or close to, the target signal 412 and the one or more interference signals 414 of known sound content categories.
Once the deep neural network 450 is trained, the deep neural network 450 may be downloaded to operate in an online filtering stage 416. As will be described in more detail below, an audio input 418 containing audio signals of various sound categories can be fed to a feature extraction module 460 to generate signal features in the frequency domain (the same signal features that are extracted during off-line training). The deep neural network 450 (trained during the offline process described above) receives the signal features and generates a set of time-varying filters 470 (i.e. frequency masks). The time-varying filters 470 filter the audio signals to generate separated audio signals 480 of various sound content categories, which may include the target signal (e.g., an audio signal of a target sound content category such as speech).
As further shown in
These captured time segments of live audio data can then be uploaded back to the offline model training 410 process and added to the content used during offline model training 410. Model coefficients could then be updated in stage 425 of offline training process 410 and then the updated deep neural network 450 can be downloaded back to the online filtering stage 416 to update the coefficients being used by the network 450 of the online system 416. In other embodiments, the deep neural network 450 can be incrementally updated online on the device itself using the captured time segments of live audio data.
Returning to
At step 505, one or more microphones (e.g., a microphone array) capture sounds of an environment into an audio signal. The audio signal includes a combination of content-based audio signals. In some embodiments, the one or more microphones are part of the audio separation system. In some other embodiments, the one or more microphones are external components or devices separate from the audio separation system.
At step 510, the system receives the audio signal. At step 515, the system converts the audio signal from a time domain to a frequency domain. At step 520, a feature extraction module of the audio separation system generates a plurality of signal features from the audio signal. The particular set of signal features that are extracted in this step 520 should be the same set of signal features that are/were used during training of the neural network. The signal features can be extracted from the audio signal in various ways known to those skilled in the art, depending upon the type of signal feature that is extracted. For example, where the audio signal comprises sounds captured by several different microphones, the signal features can include phase differences between sound signals captured by the different microphones, magnitude differences between sound signals captured by the different microphones, respective microphone energies, etc. For individual sound signals from a given microphone, the signal features may include magnitude across a particular spectrum, modulations across a spectrum, frames of magnitude spectra, etc. In these and other embodiments, the signal features may include information representing relationships or correlations between the audio signals of various sound content categories and/or between audio signals from different microphones such as inter-microphone coherence. In some embodiments, the signal features may be represented by, e.g., vectors. In additional or alternative embodiments, some or all of signal features can also be extracted captured from the time-domain signals (i.e. some portions of step 520 can be performed before step 510).
At step 525, the neural network of the audio separation system generates a plurality of time-varying filters in a frequency domain using the signal features as inputs of the neural network. Each of the time-varying filters corresponds to one of a plurality of sound content categories. In some embodiments, each of the time-varying filters is a time-varying real-valued function of frequency. A value of the real-valued function for a corresponding frequency represents a level of attenuation for the corresponding frequency or range of frequencies. For example, a value of 0.5 for a given frequency or frequency range would cause the signal amplitude for that frequency or frequency range to be reduced by half.
At step 530, the audio separation system separates the audio signal into a plurality of category specific audio signals by applying the time-varying filters to the audio signal. Each of the category specific audio signals contains content of a corresponding sound content category among the plurality of sound content categories. In some embodiments, the category specific audio signals are produced by multiplying the audio signal by the time-varying real-valued functions.
At step 535, the system converts the category specific audio signals from the frequency domain into the time domain. At step 540, the audio separation system outputs the category specific audio signals, possibly along with spatial information of sound sources that emit sounds of the sound content categories as will be described in more detail below.
The processor 610 may include hardware and software that implement the processing of audio data and various other operations depending on a type of the system 600. For example, at least some components of the system 600 may be a part of a communication device (e.g., a mobile phone) or a computing device (e.g., a computer). Memory 620 (for example, non-transitory computer readable storage medium) stores, at least in part, instructions and data for execution by processor 610 and/or the audio processing system 640.
The audio processing system 640 may be configured to receive acoustic signals representing at least one sound captured by the one or more acoustic sensors 630 and process the acoustic signal components such as performing audio separation based on content categories. The acoustic sensors 630 may be, e.g., microphones. Although various examples are described in regard to the acoustic sensor(s) 630 being one or more microphones 630, other suitable acoustic sensors may be used. In some embodiments, an array of two or more acoustic sensors (e.g., microphones) 630 are spaced at a spatial pattern such that the acoustic waves impinging on the device from certain directions and at different phases exhibit different energy levels at the array of two or more acoustic sensors. After reception by the acoustic sensors (e.g., a microphone array) 630, the acoustic signals can be converted into electric signals. These electric signals can, in turn, be converted by an analog-to-digital converter into digital signals for processing in accordance with some embodiments described herein. In some embodiments, the electric signals from the acoustic sensors 630 are digital signals. In still further embodiments, the microphones may be placed in different locations pointing to different directions in an environment.
The output device 660 is a device that provides audio output (e.g. one or more separated sound signals) to an external device. For example, the output device 660 may include a network interface or other data communications interface. In some embodiments, the audio output may be stored in memory 620 before being provided to an external device.
Notably, in embodiments, neural network 730 is a deep neural network that has been trained for specific sound categories, for example using the methodologies described above in connection with
In some embodiments, the domain converter 710 receives at least one input audio signal 705 presented in the time domain. The input audio signal 705 includes a combination of sound signals of different content categories. For example, the input audio signal 705 may include a combination of speech, music, and/or ambient sound. In some other embodiments, the input may include multiple audio signals. For example, the input may include multiple audio signals captured by the microphones of the array.
In some embodiments, the input audio signal 705 is comprised of, or is converted into, frames containing audio for a certain amount of time. In these and other embodiments, for each time frame, the domain converter 710 converts the input audio signal 705 from the time domain to a frequency domain. In some embodiments, the conversion may be performed using, e.g., an auditory filterbank, FFT, or STFT. Each time frame of the converted audio signal 715 presented in the frequency domain is fed to the feature extraction module 720. The domain converter 710 may continuously process the input audio signal 705 for each time frame and continuously feeds the converted signal 715 for each time frame to the feature extraction module 720.
In the illustrated embodiment, the feature extraction module 720 extracts signal features 725 in the frequency domain representation of signal 715. The feature extraction module 720 further feeds the signal features 725 to the neural network 730. The signal features 725 may include information such as that described above in connection with
In some embodiments, for each time frame, the neural network 730 receives a new set of signal features 725 as input and may run in real time as the audio processing system 700 continuously receives the input audio signal 705. In real time, using the set of signal features 725 as input, the neural network 730 generates a set of filters 740A, 740B, 740C, and 740D for the specific time frame. Each time-varying filter 740A, 740B, 740C, 740D corresponds to a pre-defined sound content category. As should be apparent, the filters of the sound content categories can be different from each other, and so each sound content category at a specific time frame has its own unique filter. The term “time-varying filter” refers to the fact that a filter for a given one of the sound categories for a first time frame may be different than the filter for the given sound category in a second time frame based on changing signal features 725 over time.
The domain converter 710 sends the converted audio signal 715 in the frequency domain for a specific time frame to the filters 740A-740D generated for the same specific time frame. Each of the filters 740A-740D filters the converted audio signal 715 into a separated audio signal 745A, 745B, 745C, or 740D. Each of the separated audio signals 745A, 745B, 745C, or 740D includes an audio signal of a corresponding sound content category.
More particularly, in some embodiments, each of the filters 740A-740D is a real-valued (or alternatively, complex-valued) function (also referred to as masking function) of frequency for a specific time frame, where each frequency bin (e.g., a frequency range) has a value from 0 to 1. Thus, each of the filters 740A-740D filters the converted audio signal 715 in the frequency domain by multiplying the converted audio signal 715 by the masking function. A portion of the audio signal is attenuated at frequency points where the value of the masking function is less than 1. For example, a value of zero of the masking function mutes a portion of the audio signal at a corresponding frequency point. In other words, sound in frequency points where the masking function is equal to 0 is inaudible in a reconstructed output signal filtered by the masking function.
In some other embodiments, for example, the input audio signal 705 may include multiple audio signals. For example, the input may include multiple audio signals captured by the microphones of the array. In some embodiments, the input audio signal 705 comprising the multiple separate audio signals are combined together for use in generating the filters 740A-740D. After the filters are generated for a given time frame, they are used to filter each of the multiple input audio signals in the input audio signal 705 individually, which results in multiple separated audio signals 745A, 745B, 745C and 745D, one for each audio input for each time frame. This may help preserve the spatial information of the source sources, which can be derived from information about the respective positions of the microphones of the array as described in more detail below, for example.
In some embodiments, the output module 750 receives the separated audio signals 745A, 745B, 745C, and 745D for the corresponding sound content categories and may convert the separated audio signals 745A, 745B, 745C, and 745D from the frequency domain back to the time domain In some embodiments, the output module 750 may output the separated audio signals 745A, 745B, 745C, and 745D to other systems or modules for further processing depending on the applications. In some embodiments, prior to signal outputting, the output module 750 may combine the separated audio signals 745A, 745B, 745C, and 745D into one or more combined audio signals. For example, each combined audio signal may include one or more channels, each channel corresponding to a different sound content category. In some embodiments, the number of separated audio signals (and the number of masks) may vary according to various embodiments.
The audio signals separated based on sound content categories (either as separate audio signal streams or channels of an audio signal stream) may be used for various applications such as reproducing a sound environment in virtual reality (VR) or augmented reality (AR) applications. For example, as shown in
In these and other embodiments, the output module 750 may output the separated audio signals 745A, 745B, 745C, and 745D along with metadata 760. In such embodiments, metadata 760 includes spatial information of sound sources that is generated by spatial information module 755. For example, the input audio signal 705 may include multiple audio signals captured by multiple microphones of an array. Spatial information module 760 has access to information about the relative physical locations of these microphones and uses this information and the relative strength of the separated audio signal from each of the input audio signals to estimate a spatial location of a sound source for the corresponding sound category.
The VR audio rendering system 765 receives the separated audio signals 745A, 745B, 745C, and 745D and the metadata 760 (e.g., spatial information of sound sources) and performs further audio processing for VR rendering. For example, the VR audio rendering system 765 may mix and/or playback one or more of the separated audio signals 745A, 745B, 745C, and 745D based on the spatial information of sound sources, such that the VR audio rendering system 765 recreates a sound environment (also referred to as sound stage) that is the same as, or similar to, the actual sound environment including the original sound sources. For example, the VR audio rendering system 765 may be included in an overall virtual reality system that displays both video and audio. In an example where one of the audio signals 745 is associated with human speech, the overall system may display an avatar or animated person in a virtual environment or virtual world, and the audio signal 745 may be rendered so as to originate from the mouth of the avatar or animated person, with the display including the mouth moving in accordance with the rendered audio. If another of the audio signals 745 is associated with music, for example, the video and audio display may further include a band, with the sound originating from the band. Using the spatial information of the sound source of 745 (e.g. a person speaking), AR audio rendering system 765 may further dynamically adjust the mixing and playback of the audio signals, for example depending on a position and an orientation of a head of the user wearing a VR headset.
It should be noted that the term “rendering” of the separated audio signals 745 should be construed broadly to include many different types of applications that may or may not include VR or AR applications, such as selectively filtering out unwanted noises. For example, one of the audio signals 745 can be associated with a speech content category and another of the audio signals 745 can be associated with a background noise content category, and the rendering system 765 can allow a user to dynamically select whether or not to mute the audio signal 745 associated with the background noise content category.
As used herein, the singular terms “a,” “an,” and “the” may include plural references unless the context clearly dictates otherwise. Additionally, amounts, ratios, and other numerical values are sometimes presented herein in a range format. It is to be understood that such range format is used for convenience and brevity and should be understood flexibly to include numerical values explicitly specified as limits of a range, but also to include all individual numerical values or sub-ranges encompassed within that range as if each numerical value and sub-range is explicitly specified.
While the present disclosure has been described and illustrated with reference to specific embodiments thereof, these descriptions and illustrations do not limit the present disclosure. It should be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the true spirit and scope of the present disclosure as defined by the appended claims. The illustrations may not be necessarily drawn to scale. There may be distinctions between the artistic renditions in the present disclosure and the actual apparatus due to manufacturing processes and tolerances. There may be other embodiments of the present disclosure which are not specifically illustrated. The specification and drawings are to be regarded as illustrative rather than restrictive. Modifications may be made to adapt a particular situation, material, composition of matter, method, or process to the objective, spirit and scope of the present disclosure. All such modifications are intended to be within the scope of the claims appended hereto. While the methods disclosed herein have been described with reference to particular operations performed in a particular order, it will be understood that these operations may be combined, sub-divided, or re-ordered to form an equivalent method without departing from the teachings of the present disclosure. Accordingly, unless specifically indicated herein, the order and grouping of the operations are not limitations of the present disclosure.
The present application claims priority to U.S. Provisional Patent Application No. 62/611,218 filed Dec. 28, 2017, the contents of which are incorporated by reference herein in their entirety.
Number | Date | Country | |
---|---|---|---|
62611218 | Dec 2017 | US |