This invention was made with government support under Grant Nos. 1910839, 1453101, and 1850069 awarded by the National Science Foundation (NFS), and under a contract awarded by the Knowledge-directed Artificial Intelligence Reasoning Over Schemas (KAIROS) program run by the Defense Advanced Research Projects Agency (DARPA). The government has certain rights in the invention.
Audio recordings of human speech are often contaminated with noise from various sources. Some noise in recordings may be stationary, while other noise may fluctuate in frequency and amplitude throughout the recording. This latter noise, called nonstationary noise, is difficult to remove from audio recordings.
The components in the figures are not necessarily to scale, emphasis instead being placed upon illustrating the principals of the invention. Like reference numerals designate corresponding parts throughout the different views. Embodiments are illustrated by way of example and not limitation in the figures of the accompanying drawings, in which:
Disclosed are systems, methods, and other implementations (including hardware, software, and hybrid hardware/software implementations) directed at a speech denoising framework that leverages the abundance of silent intervals in speech to learn a model for automatic speech denoising given only mono-channel audio. The implementations described herein are based on a deep neural network for speech denoising approach that tightly integrates silent intervals, and thereby overcomes many of the limitations of classical approaches. The goal is not just to identify a single silent interval, but to find as many as possible silent intervals over time. Indeed, silent intervals in speech appear in abundance: psycholinguistic studies have shown that there is almost always a pause after each sentence and even after each word in speech. Each pause, however short, provides a silent interval revealing noise characteristics local in time. Altogether, these silent intervals assemble a time-varying picture of background noise, allowing a neural network to better denoise speech signals, even in presence of nonstationary noise.
The technology described herein uses a neural network architecture based on long short-term memory (LSTM) structures to reliably denoise vocal recordings (other learning machine architectures/structures may also be used). To do this, the LSTM is trained on noise obtained from intermittent gaps in speech called silent intervals, which it automatically identifies in the recording. The silent intervals contain a combination of stationary and nonstationary noise, and thus the spectral distributions of noise during these silent intervals can be used in denoising. LSTM is capable of removing the stationary and nonstationary spectra in the vocal intervals to provide a robustly denoised, high quality speech recording. This technology is also applicable to audio recording, filmmaking, and speech-to-text applications.
To interleave neural networks with established denoising pipelines, a network structure is proposed that includes three major components (illustrated in
More particularly, the silent interval detection component is configured to detect silent intervals in the input signal. The input to this component is the spectrogram of the input (noisy) signal x. The spectrogram Sx is first encoded by a 2D convolutional encoder into a 2D feature map, which, in turn, is processed by a bidirectional LSTM followed by two fully-connected (FC) layers. The bidirectional LSTM is suitable for processing time-series features resulting from the spectrogram, and the FC layers are applied to the features of each time sample to accommodate variable length input. The output from this network component is a vector D(Sx). Each element of D(Sx) is a scalar in [0,1] (after applying the sigmoid function), indicating a confidence score of a small-time segment being silent. In some examples, each time segment has a duration of 1/30 second, which is small enough to capture short speech pauses and large enough to allow robust prediction. The output vector D(Sx) is then expanded to a longer mask, denoted m(x). Each element of this mask indicates the confidence of classifying each sample of the input signal x as pure noise. With this mask,
the noise profile {tilde over (x)}
exposed by silent intervals are estimated by an element-wise product, namely
{tilde over (x)}=x⊙m(x).
In the noise estimation component/module,
the signal {tilde over (x)}
resulting from silent interval detection is noise profile exposed only through a series of time windows, but not a complete picture of the noise. However, since the input signal is a superposition of clean speech signal and noise, having a complete noise profile would ease the denoising process, especially in presence of nonstationary noise. Therefore, the entire noise profile over time is estimated, which is achieved, in some implementations, using a neural network. Inputs to this component include both the noisy audio signal representation x and
the incomplete noise profile {tilde over (x)}.
Both are converted by STFT into spectrograms, denoted as
sx and s{tilde over (x)},
respectively. The spectrograms can be thought of as 2D images. Because the neighboring time-frequency pixels in a spectrogram are often correlated, the goal here is conceptually akin to the image inpainting task in computer vision. To this end,
sx and s{tilde over (x)}
are encoded by two separate 2D convolutional encoders into two feature maps. The feature maps are then concatenated in a channel-wise manner and further decoded by a convolutional decoder to estimate the full noise spectrogram, denoted
N(sx, s{tilde over (x)}).
Lastly, the noise from the input signal x is cleaned up using the noise removal component/module. A neural network R receives as input both the input audio spectrogram Sx and the estimated full noise spectrogram
N(sx, s{tilde over (x)}).
The two input spectrograms are processed individually by their own 2D convolutional encoders. The two encoded feature maps are then concatenated together before passing to a bidirectional LSTM, followed by three fully connected layers. The output of this component is a vector with two channels which form the real and imaginary parts of a complex ratio mask
c:=R(sx,N(sx, s{tilde over (x)}))
in frequency-time domain. In other words, the mask c has the same (temporal and frequency) dimensions as Sx. In a final step, the denoised spectrogram
Sx*
is computed through element-wise multiplication of the input audio spectrogram Sx and the mask
c(i.e., sx*=sx⊙c).
Finally, the cleaned-up audio signal representation is obtained by applying the inverse STFT (ISTFT) to
sx*
Since a subgradient exists at every step, in some embodiments, the network can be trained in an end-to-end fashion with a stochastic gradient descent approach. The following loss function is optimized:
L
0
=E
x˜(x)
[∥N(sx,s{tilde over (x)})−sn*∥2+β∥ss⊙R(sx,N(sx,s{tilde over (x)}))−sx*∥2],
where the notations
s
x
, s
{tilde over (x)}
,N(·,·), and R(·,·)
are as defined above,
sx* and sn*
denote the spectrograms of the ground-truth foreground signal and background noise, respectively. The first term penalizes the discrepancy between estimated noise and the ground-truth noise, while the second term accounts for the estimation of foreground signal. These two terms are balanced by the scalar β(β=1.0 in some examples).
While producing plausible denoising results, the end-to-end training process has no supervision on silent interval detection: the loss function only accounts for the recoveries of noise and clean speech signal. However, somewhat surprisingly, the ability of detecting silent intervals automatically emerges as the output of the first network component. In other words, the network automatically learns to detect silent intervals for speech denoising without this supervision.
As the model is learning to detect silent intervals on its own, silent detection can be directly supervised to further improve the denoising quality. To that end, a term can be added to the above loss function that penalizes the discrepancy between detected silent intervals and their ground truth. Experiments showed that this way is not effective, so instead the model is trained in two sequential steps. First, the silent interval detection component is computed through the following loss function:
L
1
=E
x,p(x)[BCE(m(x),mx*)],
where IBCE is the binary cross-entropy loss, m(x) is the mask resulted from silent interval detection component, and
mx*
is the ground-truth label of each signal sample being silent or not.
Next, the noise estimation and removal components are trained through the loss function L0. This training step starts by neglecting the silent detection component. In the loss function L0, instead of using
the noise spectrogram exposed by the estimated silent intervals, the spectrogram of the noise exposed by the ground-truth silent intervals
(i.e., the STFT of x⊙m{tilde over (x)}*)
is used. After training using such a loss function, the network components are fine-tuned by incorporating the already trained silent interval detection component. With the silent interval detection component fixed, this fine-tuning step optimizes the original loss function L0 and thereby updates the weights of the noise estimation and removal components.
Thus, in some embodiments, a system is provided that includes a receiver unit (e.g., a microphone, a communication module to receive electronic signal representations of audio/sound, etc.) to receive an audio signal representation, and a controller (e.g., a programmable device), implementing one or more learning engines, in communication with the receiver unit and a memory device to store programmable instructions, to detect in the received audio signal representation, using a first learning model, one or more silent intervals with reduced foreground sound levels, determine based on the detected one or more silent intervals an estimated full noise profile corresponding to the audio signal representation, and generate with a second learning model, based on the received audio signal representation and on the determined estimated full noise profile, a resultant audio signal representation with a reduced noise level. In some implementations, a non-transitory computer readable media is provided, that stores a set of instructions, executable on at least one programmable device, to receive an audio signal representation, detect in the received audio signal representation, using a first learning model, one or more silent intervals with reduced foreground sound levels, determine based on the detected one or more silent intervals an estimated full noise profile corresponding to the audio signal representation, and generate with a second learning model, based on the received audio signal representation and on the determined estimated full noise profile, a resultant audio signal representation with a reduced noise level.
In some implementations, a method is provided that includes receiving an audio signal representation, detecting in the received audio signal representation, using a first learning model, one or more silent intervals with reduced foreground sound levels, determining based on the detected one or more silent intervals an estimated full noise profile corresponding to the audio signal representation, and generating with a second learning model, based on the received audio signal representation and on the determined estimated full noise profile, a resultant audio signal representation with a reduced noise level.
In some examples, detecting using the first learning model the one or more silent intervals may include segmenting the audio signal representation into multiple segments, each segment being shorter than an interval length of the received audio signal representation, transforming the multiple segments into a time-frequency representation, and processing the time-frequency representation of the multiple segments using a first learning machine, implementing the first learning model, to produce a noise vector that includes, for each of the multiple segments, a confidence value representative of a likelihood that the respective one of the multiple segments is a silent interval. In such examples, processing the time-frequency representation may include encoding the time-frequency representation of the multiple segment with a 2D convolutional encoder to a generate a 2D feature map, applying a learning network structure, comprising at least a bidirectional long short-term memory (LSTM) structure, to the 2D feature map to produce the silence vector, determining a noise mask from the silence vector, and generating based on the audio signal representation and the noise mask a partial noise profile for the audio signal representation.
In some embodiments, determining the estimated full noise profile may include generating a partial noise profile representative of time-frequency characteristics of the detected one or more silent intervals, transforming the audio signal representation and the partial noise profile into respective time-frequency representations, applying convolutional encoding to the time-frequency representations of the audio signal representation and the partial noise profile to produce an encoded audio signal representation and encoded partial noise profile, and combining the encoded audio signal representation and the encoded partial noise profile to produce the estimated full noise profile. In some examples, generating the resultant audio signal representation with the reduced noise level may include generating time-frequency representations for the audio signal representation and the estimated full noise profile, and applying the second learning model to the time-frequency representations for the audio signal representation and the estimated full noise profile to generate the resultant audio signal representation. The second learning model may be implemented with a bidirectional long short- term memory (LSTM) structure.
As noted, implementation of the denoising processing described herein may be realized using one or more learning machines (such as neural networks). Neural networks are in general composed of multiple layers of linear transformations (multiplications by a “weight” matrix), each followed by a nonlinear function (e.g., a rectified linear activation function, or ReLU, etc.) The linear transformations are learned during training by making small changes to the weight matrices that progressively make the transformations more helpful to the final classification task (or some other type of desired output). The layered network may include convolutional processes which are followed by pooling processes along with intermediate connections between the layers to enhance the sharing of information between the layers. Several examples of learning engine approaches/architectures that may be used include generating an auto-encoder and using a dense layer of the network to correlate with probability for a future event through a support vector machine, or constructing a regression or classification neural network model that predicts a specific output from input data (based on training reflective of correlation between similar input and the output that is to predicted).
Examples of neural networks include convolutional neural network (CNN), feed-forward neural networks, recurrent neural networks (RNN, e.g., implemented, for example, using long short-term memory (LSTM) structures), etc. Feed-forward networks include one or more layers of learning nodes/elements with connections to one or more portions of the input data. In a feedforward network, the connectivity of the inputs and layers of learning elements is such that input data and intermediate data propagate in a forward direction towards the network's output. There are typically no feedback loops or cycles in the configuration/structure of the feed-forward network. Convolutional layers allow a network to efficiently learn features by applying the same learned transformation to subsections of the data. In some embodiments, the various learning processes implemented through use of the learning machines may be realized using keras (an open-source neural network library) building blocks and/or NumPy (an open-source programming library useful for realizing modules to process arrays) building blocks.
In some embodiments, the various learning engine implementations may include a trained learning engine (e.g., a neural network) and a corresponding coupled learning engine controller/adapter configured to determine and/or adapt the parameters (e.g., neural network weights) of the learning engine that would produce desired output. In such implementations, training data includes sets of input records along with corresponding data defining the ground truth for the input training records. After initial training of the various learning engines comprising the systems described herein, subsequent training may be intermittently performed (at regular or irregular periods). Upon completion of a training cycles by the adapter/controller coupled to a particular learning engine, the adapter provides data representative of updates/changes (e.g., in the form of parameter values/weights to be assigned to links of a neural-network-based learning engine) to the particular learning engine to cause the learning engine to be updated in accordance with the training cycle(s) completed.
Performing the various techniques and operations described herein may be facilitated by a controller device (e.g., a processor-based computing device) that may be realized as part of a verbal communication device (such as a hearing aid device). Such a controller device may include a processor-based device such as a computing device, and so forth, that typically includes a central processor unit or a processing core. The device may also include one or more dedicated learning machines (e.g., neural networks) that may be part of the CPU or processing core. In addition to the CPU, the system includes main memory, cache memory and bus interface circuits. The controller device may include a mass storage element, such as a hard drive (solid state hard drive, or other types of hard drive), or flash drive associated with the computer system. The controller device may further include a keyboard, or keypad, or some other user input interface, and a monitor, e.g., an LCD (liquid crystal display) monitor, that may be placed where a user can access them.
The controller device is configured to facilitate, for example, the implementation of de-noising processing. The storage device may thus include a computer program product that when executed on the controller device (which, as noted, may be a programmable or processor-based device) causes the processor-based device to perform operations to facilitate the implementation of procedures and operations described herein. The controller device may further include peripheral devices to enable input/output functionality. Such peripheral devices may include, for example, flash drive (e.g., a removable flash drive), or a network connection (e.g., implemented using a USB port and/or a wireless transceiver), for downloading related content to the connected system. Such peripheral devices may also be used for downloading software containing computer instructions to enable general operation of the respective system/device. Alternatively and/or additionally, in some embodiments, special purpose logic circuitry, e.g., an FPGA (field programmable gate array), an ASIC (application-specific integrated circuit), a DSP processor, a graphics processing unit (GPU), accelerated processing unit (APU), application processing unit, etc., may be used in the implementations of the controller device. Other modules that may be included with the controller device may include a user interface to provide or receive input and output data. Additionally, in some embodiments, sensor devices such as a microphone, a light-capture device (e.g., a CMOS-based or CCD-based camera device), other types of optical or electromagnetic sensors, sensors for measuring environmental conditions, etc., may be coupled to the controller device, and may be configured to observe or measure the signals or data to be processed. The controller device may include an operating system.
Computer programs (also known as programs, software, software applications or code) include machine instructions for a programmable processor, and may be implemented in a high-level procedural and/or object-oriented programming language, and/or in assembly/machine language. As used herein, the term “machine-readable medium” refers to any non-transitory computer program product, apparatus and/or device (e.g., magnetic discs, optical disks, memory, Programmable Logic Devices (PLDs)) used to provide machine instructions and/or data to a programmable processor, including a non-transitory machine-readable medium that receives machine instructions as a machine-readable signal.
In some embodiments, any suitable computer readable media can be used for storing instructions for performing the processes/operations/procedures described herein. For example, in some embodiments computer readable media can be transitory or non-transitory. For example, non-transitory computer readable media can include media such as magnetic media (such as hard disks, floppy disks, etc.), optical media (such as compact discs, digital video discs, Blu-ray discs, etc.), semiconductor media (such as flash memory, electrically programmable read only memory (EPROM), electrically erasable programmable read only Memory (EEPROM), etc.), any suitable media that is not fleeting or not devoid of any semblance of permanence during transmission, and/or any suitable tangible media. As another example, transitory computer readable media can include signals on networks, in wires, conductors, optical fibers, circuits, any suitable media that is fleeting and devoid of any semblance of permanence during transmission, and/or any suitable intangible media.
The presently disclosed subject matter is further described in the materials appended hereto. Although particular embodiments have been disclosed herein in detail, this has been done by way of example for purposes of illustration only, and is not intended to be limiting with respect to the scope of the appended claims, which follow. Features of the disclosed embodiments can be combined, rearranged, etc., within the scope of the invention to produce more embodiments. Some other aspects, advantages, and modifications are considered to be within the scope of the claims provided below. The claims presented are representative of at least some of the embodiments and features disclosed herein. Other unclaimed embodiments and features are also contemplated.
In this embodiment, we introduce a deep learning model for speech denoising, a long-standing challenge in audio analysis arising in numerous applications. Our approach is based on a key observation about human speech: there is often a short pause between each sentence or word. In a recorded speech signal, those pauses introduce a series of time periods during which only noise is present. We leverage these incidental Silent intervals to learn a model for automatic speech denoising given only mono-channel audio. Detected silent intervals over time expose not just pure noise but its time-varying features, allowing the model to learn noise dynamics and suppress it from the speech signal. Experiments on multiple datasets confirm the pivotal role of silent interval detection for speech denoising, and our method outperforms several state-of-the-art denoising methods, including those that accept only audio input (like ours) and those that denoise based on audiovisual input (and hence require more information). We also show that our method enjoys excellent generalization properties, such as denoising spoken languages not seen during training.
Noise is everywhere. When we listen to someone speak, the audio signals we receive are never pure and clean, always contaminated by all kinds of noises-cars passing by, spinning fans in an air conditioner, barking dogs, music from a loudspeaker, and so forth. To a large extent, people in a conversation can effortlessly filter out these noises (Ref. 40). In the same vein, numerous applications, ranging from cellular communications to human-robot interaction, rely on speech denoising algorithms as a fundamental building block.
Despite its vital importance, algorithmic speech denoising remains a grand challenge. Provided an input audio signal, speech denoising aims to separate the foreground (speech) signal from its additive background noise. This separation problem is inherently ill-posed. Classic approaches such as spectral subtraction (Ref. 7, 91, 6, 66, 73) and Wiener filtering (Ref. 74, 38) conduct audio denoising in the spectral domain, and they are typically restricted to stationary or quasi-stationary noise. In recent years, the advance of deep neural networks has also inspired their use in audio denoising. While outperforming the classic denoising approaches, existing neural-network-based approaches use network structures developed for general audio processing tasks (Ref. 51, 83, 93) or borrowed from other areas such as computer vision (Ref. 29, 24, 3, 34, 30) and generative adversarial networks (Ref. 64, 65). Nevertheless, beyond reusing well-developed network models as a black box, a fundamental question remains: What natural Structures of Speech can we leverage to mold network architectures for better performance on Speech denoising.
Motivated by this question, we revisit one of the most widely used audio denoising methods in practice, namely the spectral subtraction method (Ref. 7, 91, 6, 66, 73). Implemented in many commercial software such as Adobe Audition (Ref. 37), this classical method requires the user to specify a time interval during which the foreground signal is absent. We call such an interval a Silent interval. A silent interval is a time window that exposes pure noise. The algorithm then learns from the silent interval the noise characteristics, which are in turn used to suppress the additive noise of the entire input signal (through subtraction in the spectral domain).
Submitted to 34th Conference on Neural Information Processing Systems (NeurIPS 2020). Do not distribute. Yet, the spectral subtraction method suffers from two major shortcomings: i) it requires user specification of a silent interval, that is, not fully automatic; and ii) the single silent interval, although undemanding for the user, is insufficient in presence of nonstationary noise—for example, a back-ground music. Ubiquitous in daily life, nonstationary noise has time-varying spectral features. The single silent interval reveals the noise spectral features only in that particular time span, thus inade-quate for denoising the entire input signal. The success of spectral subtraction pivots on the concept of silent interval; so do its shortcomings.
In this embodiment, we introduce a deep network for speech denoising that tightly integrates silent intervals, and thereby overcomes many of the limitations of classical approaches. Our goal is not just to identify a single silent interval, but to find as many as possible silent intervals over time. Indeed, silent intervals in speech appear in abundance: psycholinguistic studies have shown that there is almost always a pause after each sentence and even each word in speech (Ref. 72, 21). Each pause, however short, provides a silent interval revealing noise characteristics local in time. All together, these silent intervals assemble a time-varying picture of background noise, allowing the neural network to better denoise speech signals, even in presence of nonstationary noise (see
In short, to interleave neural networks with established denoising pipelines, we propose a network structure consisting of three major components (see
Summary of results. Our neural-network-based denoising model accepts a single channel of audio signal and outputs the cleaned-up signal. Unlike some of the recent denoising methods that take as input audiovisual signals (i.e., both audio and video footage), our method can be applied in a wider range of scenarios (e.g., in cellular communication). We conducted extensive experiments, including ablation studies to show the efficacy of our network components and comparisons to several state-of-the-art denoising methods. We also evaluate our method under various signal-to-noise ratios-even under strong noise levels that are not tested against in previous methods. We show that, under a variety of denoising metrics, our method consistently outperforms those methods, including those that accept only audio input (like ours) and those that denoise based on audiovisual input.
The pivotal role of silent intervals for speech denoising is further confirmed by a few key results. Even without supervising on silent interval detection, the ability to detect silent intervals naturally emerges in our network. Moreover, while our model is trained on English speech only, with no additional training it can be readily used to denoise speech in other languages (such as Chinese, Japanese, and Korean). Please refer to the supplementary materials for listening to our denoising results.
Speech denoising. Speech denoising (Ref. 48) is a fundamental problem studied over several decades. Spectral subtraction (Ref. 7, 91, 6, 66, 73) estimates the clean signal spectrum by subtracting an estimate of the noise spectrum from the noisy speech spectrum. This classic method was followed by spectrogram factorization methods (Ref. 78). Wiener filtering (Ref. 74, 38) derives the enhanced signal by optimizing the mean-square error. Other methods exploit pauses in speech, forming segments of low acoustic energy where noise statistics can be more accurately measured (Ref. 13, 52, 79, 15, 69, 10, 11). Statistical model-based methods (Ref. 14, 32) and subspace algorithms (Ref. 12, 16) are also studied.
Applying neural networks to audio denoising dates back to the 80s (Ref. 81, 63). With increased computing power, deep neural networks are often used (Ref. 97, 99, 98, 42). Long short-term memory networks (LSTMs) (Ref. 33) are able to preserve temporal context information of the audio signal (Ref. 47), leading to strong results (Ref. 51, 83, 93). Leveraging generative adversarial networks (GANs) (Ref. 31), methods such as (Ref. 64, 65) have adopted GANs into the audio field and have also achieved strong performance.
Audio signal processing methods operate on either the raw waveform or the spectrogram by Short-time Fourier Transform (STFT). Some work directly on waveform (Ref. 22, 62, 54, 50), and others use Wavenet (Ref. 84) for speech denoising (Ref. 68, 70, 28). Many other methods such as (Ref. 49, 87, 56, 92, 41, 100, 9) work on audio signal's spectrogram, which contains both magnitude and phase information. There are works discussing how to use the spectrogram to its best potential (Ref. 86, 61), while one of the disadvantages is that the inverse STFT needs to be applied. Meanwhile, there also exist works (Ref. 46, 27, 26, 88, 19, 94, 55) investigating how to overcome artifacts from time aliasing.
Speech denoising has also been studied in conjunction with computer vision due to the relations between speech and facial features (Ref. 8). Methods such as (Ref. 29, 24, 3, 34, 30) utilize different network structures to enhance the audio signal to the best of their ability. Adeel et al. (Ref. 1) even utilize lip-reading to filter out the background noise of a speech.
Deep learning for other audio processing tasks. Deep learning is widely used for lip reading, speech recognition, speech separation, and many audio processing or audio-related tasks, with the help of computer vision (Ref. 58, 60, 5, 4). Methods such as (Ref. 45, 17, 59) are able to reconstruct speech from pure facial features. Methods such as (Ref. 2, 57) take advantage of facial features to improve speech recognition accuracy. Speech separation is one of the areas where computer vision is best leveraged. Methods such as (Ref. 23, 58, 18, 102) have achieved impressive results, making the previously impossible speech separation from a single audio signal possible. Recently, Zhang et al. (Ref. 101) proposed a new operation called Harmonic Convolution to help networks distill audio priors, which is shown to even further improve the quality of speech separation.
We present a neural network that harnesses the time distribution of silent intervals for speech denoising. The input to our model is a spectrogram of noisy speech (Ref. 96, 20, 77), which can be viewed as a 2D image of size T×F with two channels, where T represents the time length of the signal and F is the number of frequency bins. The two channels store the real and imaginary parts of STFT, respectively. After learning, the model will produce another spectrogram of the same size as the noise suppressed.
We first train our proposed network structure in an end-to-end fashion, with only denoising super-vision (Sec. 3.2); and it already outperforms the state-of-the-art methods that we compare against. Furthermore, we incorporate the supervision on silent interval detection (Sec. 3.3) and obtain even better denoising results (see Sec. 4).
Classic denoising algorithms work in three general stages: silent interval specification, noise feature estimation, and noise removal. We propose to interweave learning throughout this process: we rethink each stage with the help of a neural network, forming a new speech denoising model. Since we can chain these networks together and estimate gradients, we can efficiently train the model with large-scale audio data.
Silent interval detection. The first component is dedicated to detecting silent intervals in the input signal. The input to this component is the spectrogram of the input (noisy) signal x. The spectrogram Sx is first encoded by a 2D convolutional encoder into a 2D feature map, which is in turn processed by a bidirectional LSTM (Ref. 33, 75) followed by two fully-connected (FC) layers (see network details in the following A). The bidirectional LSTM is suitable for processing time-series features resulting from the spectrogram (Ref. 53, 39, 67, 18), and the FC layers are applied to the features of each time sample to accommodate variable length input. The output from this network component is a vector D(Sx). Each element of D(Sx) is a scalar in [0,1] (after applying the sigmoid function), indicating a confidence score of a small time segment being silent. We choose each time segment to have 1/30 second, small enough to capture short speech pauses and large enough to allow robust prediction (see Sec. 3.3).
The output vector D(Sx) is then expanded to a longer mask, which we denote as m(x). Each element of this mask indicates the confidence of classifying each sample of the input signal x as pure noise (see
the noise profile {tilde over (x)}
exposed by silent intervals are estimated by an element-wise product, namely
{tilde over (x)}=x⊙m(x).
Noise estimation.
The signal {tilde over (x)}
resulted from silent interval detection is noise profile exposed only through a series of time windows (see
Inputs to this component include both the noisy audio signal at and
the incomplete noise profile {tilde over (x)}.
Both are converted by STFT into spectrograms, denoted as
sx and s{tilde over (x)},
respectively. We view the spectrograms as 2D images. And because the neighboring time-frequency pixels in a spectrogram are often correlated, our goal here is conceptually akin to the image inpainting task in computer vision (Ref. 36). To this end, we encode
sx and s{tilde over (x)},
by two separate 2D convolutional encoders into two feature maps. The feature maps are then concatenated in a channel-wise manner and further decoded by a convolutional decoder to estimate the full noise spectrogram, denoted as
N(sx,s{tilde over (x)}).
A result of this step is illustrated in
Noise removal. Lastly, we clean up the noise from the input signal x. We use a neural network R that takes as input both the input audio spectrogram Sx and the estimated full noise spectrogram
N(sx,s{tilde over (x)}).
The two input spectrograms are processed individually by their own 2D convolutional encoders. The two encoded feature maps are then concatenated together before passing to a bidirectional LSTM followed by three fully connected layers. (see details in the following A). Like other audio enhancement models (Ref. 18, 85, 89), the output of this component is a vector with two channels which form the real and imaginary parts of a complex ratio mask
c:=R(sx,N(sx,s{tilde over (x)}))
in frequency-time domain. In other words, the mask c has the same (temporal and frequency) dimensions as Sx.
In a final step, the denoised spectrogram
sx*
through element-wise multiplication of the input audio spectrogram Sx and the mask
c(i.e., sx*=sx⊙c).
Finally, the cleaned-up audio signal representation is obtained by applying the inverse STFT to
sx* (see FIG. 3-g).
Since a subgradient exists at every step, we are able to train our network in an end-to-end fashion with stochastic gradient descent. We optimize the following loss function:
0=x˜p(x)[∥N(sx,s{tilde over (x)})−sn*∥2+β∥sx⊙R(sx,N(sx,s{tilde over (x)}))−sx*∥2]. (1)
where the notations
s
x
,s
{tilde over (x)}
,N(·,·), and R(·,·)
are defined in Sec. 3.1;
s
x* and sn*
denote the spectrograms of the ground-truth foreground signal and background noise, respectively. The first term penalizes the discrepancy between estimated noise and the ground-truth noise, while the second term accounts for the estimation of foreground signal. These two terms are balanced by the scalarβ (β=1.0 in some examples).
Natural emergence of silent intervals. While producing plausible denoising results (see Sec. 4.4), the end-to-end training process has no supervision on silent interval detection: the loss function (1) only accounts for the recoveries of noise and clean speech signal. But somewhat surprisingly, the ability of detecting silent intervals automatically emerges as the output of the first network component
(see
In other words, the network automatically learns to detect silent intervals for speech denoising without this supervision.
As the model is learning to detect silent intervals on its own, we are able to directly supervise silent interval detection to further improve the denoising quality. Our first attempt was to add a term in (1) that penalizes the discrepancy between detected silent intervals and their ground truth. But our experiments show that this way is not effective (see Sec. 4.4). Instead, we train our network in two sequential steps.
First, we train the silent interval detection component through the following loss function:
1=x˜p(x)[BCE(m(x), mx*)],
where
lBCE(·,·)
is the binary cross entropy loss, m(x) is the mask resulted from silent interval detection component, and
mx*
is the ground-truth label of each signal sample being silent or not-the way of constructing
mx*
and the training dataset will be described in Sec. 4.1.
Next, we train the noise estimation and removal components through the loss function (1). This training step starts by neglecting the silent detection component. In the loss function (1), instead of using
mx*
the noise spectrogram exposed by the estimated silent intervals, we use the spectrogram of the noise exposed by the ground-truth silent intervals
(i.e., the STFT of x⊙m{tilde over (x)}*)
After training using such a loss function, we fine-tune the network components by incorporating the already trained silent interval detection component. With the silent interval detection component fixed, this fine-tuning step optimizes the original loss function (1) and thereby updates the weights of the noise estimation and removal components.
This section presents the major evaluations of our method, comparisons to several baselines and prior works, and ablation studies. We also refer the reader to the supplementary materials (including a supplemental document and audio effects organized on an off-line webpage) for the full description of our network structure, implementation details, additional evaluations, as well as audio examples.
Dataset construction. To construct training and testing data, we leverage publicly available audio datasets. We obtain clean speech signals using AVSPEECH (Ref. 18), from which we randomly choose 2448 videos (4.5 hours of total length) and extract their speech audio channels. Among them, we use 2214 videos for training and 234 videos for testing, so the training and testing speeches are fully separate. All these speech videos are in English, selected on purpose: as we show in supplementary materials, our model trained on this dataset can readily denoise speeches in other languages
We use two datasets, DEMAND (Ref. 82) and Google's AudioSet (Ref. 25), as background noise. Both consist of environmental noise, transportation noise, music, and many other types of noises. DEMAND has been used in previous denoising works (e.g., (Ref. 64, 28, 83)). Yet AudioSet is much larger and more diverse than DEMAND, thus more challenging when used as noise.
Due to the linearity of acoustic wave propagation, we can superimpose clean speech signals with noise to synthesize noisy input signals (similar to previous works (Ref. 64, 28, 83)). When synthesizing a noisy input signal, we randomly choose a signal-to-noise ratio (SNR) from seven discrete values: −10 dB, −7 dB, −3 dB, 0 dB, 3 dB, 7 dB, and 10 dB; and by mixing the foreground speech with properly scaled noise, we produce a noisy signal with the chosen SNR. For example, a −10 dB SNR means that the power of noise is ten times the speech (see
To supervise our silent interval detection (recall Sec. 3.3), we need ground-truth labels of silent intervals. To this end, we divide each clean speech signal into time segments, each of which lasts 1/30 seconds. We label a time segment as silent when the total acoustic energy in that segment is below a threshold. Since the speech is clean, this automatic labeling process is robust.
Method comparison. We compare our method with several existing methods that are also designed for speech denoising, including both the classic approaches and recently proposed learning-based methods. We refer to these methods as follows: i) Ours, our model trained with silent interval supervision (recall Sec. 3.3); ii) Baseline-thres, a baseline method that uses acoustic energy threshold to label silent intervals (the same as our automatic labeling approach in Sec. 4.1 but applied on noisy input signals), and then uses our trained noise estimation and removal networks for speech denoising. iii) Ours-GTSI, another reference method that uses our trained noise estimation and removal networks, but hypothetically uses the ground-truth silent intervals; iv) Spectral Gating, the classic speech denoising algorithm based on spectral subtraction (Ref. 73); v) Adobe Audition (Ref. 37), one of the most widely used professional audio processing software, and we use its machine-learning-based noise reduction feature, provided in the latest Adobe Audition CC 2020, with default parameters to batch process all our test data; vi) SEGAN (Ref. 64), one of the state-of-the-art audio-only speech enhancement methods based on generative adversarial networks. vii) DFL (Ref. 28), a recently proposed speech denoising method based on a loss function over deep network features; 1 viii) VSE (Ref. 24), a learning-based method that takes both video and audio as input, and leverages both audio signal and mouth motions (from video footage) for speech denoising. We could not compare with another audiovisual method (Ref. 18) because no source code or executable is made publicly available.
For fair comparisons, we train all the methods (except Spectral Gating which is not learning-based and Adobe Audition which is commercially shipped as a black box) using the same datasets. For SEGAN, DFL, and VSE, we use their source codes published by the authors. The audiovisual denoising method VSE also requires video footage, which is available in AVSPEECH.
Metrics. Due to the perceptual nature of audio processing tasks, there is no widely accepted single metric for quantitative evaluation and comparisons. We therefore evaluate our method under six different metrics, all of which have been frequently used for evaluating audio processing quality. Namely, these metrics are: i) Perceptual Evaluation of Speech Quality (PESQ) (Ref. 71), ii) Segmental Signal-to-Noise Ratio (SSNR) (Ref. 76), iii) Short-Time Objective Intelligibility (STOI) (Ref. 80), iv) Mean opinion score (MOS) predictor of signal distortion (CSIG) (Ref. 35), v) MOS predictor of background-noise intrusiveness (CBAK) (Ref. 35), and vi) MOS predictor of overall signal quality (COVL) (Ref. 35).
Results. We train two separate models using DEMAND and AudioSet noise datasets respectively, and compare them with other models trained with the same datasets. We evaluate the average metric values and report them in
We breakdown the performance of each method with respect to SNR levels from −10 dB to 10 dB on both noise datasets. The results are reported in
From
Due to the importance of silent intervals for speech denoising, we also evaluate the quality of our silent interval detection, in comparison to two alternatives, the baseline Baseline-thres and a Voice Activity Detector (VAD) (Ref. 95). The former is described above, while the latter classifies each time window of an audio signal as having human voice or not (Ref. 43, 44). We use an off-the-shelf VAD, which is developed by Google's WebRTC project and reported as one of the best available.
We evaluate these methods using four standard statistic metrics: the precision, recall, F1 score, and accuracy. We follow the standard definitions of these metrics, which are summarized in C.1. These metrics are based on the definition of positive/negative conditions. Here, the positive condition indicates a time segment being labeled as a silent segment, and the negative condition indicates a non-silent label. Thus, the higher the metric values are, the better the detection approach.
Table 1 shows that, under all metrics, our method is consistently better than the alternatives. Between VAD and Baseline-thres, VAD has higher precision and lower recall, meaning that VAD is overly conservative and Baseline-thres is overly aggressive when detecting silent intervals (see
In addition, we perform a series of ablation studies to understand the efficacy of individual network components and loss terms (see the following D.1 for more details). In Table 2, “Ours W/O SID loss refers to the training method presented in Sec. 3.2 (i.e., without silent interval supervision). “Ours Joint 1oss” refers to the end-to-end training approach that optimizes the loss function (1) with the additional term (2). And “Ours w/o NE loss” uses our two-step training (in Sec. 3.3) but without the loss term on noise estimation-that is, without the first term in (1). In comparison to these alternative training approaches, our two-step training with silent interval supervision (referred to as
“Ours”) performs the best. We also note that “Ours W/O SID 1oss”—i.e., without supervision on already outperforms the methods we compared to in
We also experimented with two variants of our network structure. The first one, referred to as “Ours w/o SID comp”, turns off silent interval detection: the silent interval detection component always outputs a vector with all zeros. The second, referred as “Ours w/o NR comp”, uses a simple spectral subtraction to replace our noise removal component. Table 2 shows that, under all the tested metrics, both variants perform worse than our method, suggesting our proposed network structure is effective.
Furthermore, we studied to what extent the accuracy of silent interval detection affects the speech denoising quality. We show that as the silent interval detection becomes less accurate, the denoising quality degrades. Presented in details in the following D.2, these experiments reinforce our intuition that silent intervals are instructive for speech denoising tasks.
Speech denoising has been a long-standing challenge. We present a new network structure that leverages the abundance of silent intervals in speech. Even without silent interval supervision, our network is able to denoise speech signals plausibly, and meanwhile, the ability to detect silent intervals automatically emerges. We reinforce this ability. Our explicit supervision on silent intervals enables the network to detect them more accurately, thereby further improving the performance of speech denoising. As a result, under a variety of denoising metrics, our method consistently outperforms several state-of-the-art audio denoising models.
High-quality speech denoising is desired in a myriad of applications: human-robot interaction, cellular communications, hearing aids, teleconferencing, music recording, filmmaking, news reporting, and surveillance systems to name a few. Therefore, we expect our proposed denoising method-be it a system used in practice or a foundation for future technology-to find impact in these applications.
In our experiments, we train our model using English speech only, to demonstrate its generalization property-the ability of denoising spoken languages beyond English. Our demonstration of denoising Japanese, Chinese, and Korean speeches is intentional: they are linguistically and phonologically distant from English (in contrast to other English “siblings” such as German and Dutch). Still, our model may bias in favour of spoken languages and cultures that are closer to English or that have frequent pauses to reveal silent intervals. Deeper understanding of this potential bias requires future studies in tandem with linguistic and sociocultural insights.
Lastly, it is natural to extend our model for denoising audio signals in general or even signals beyond audio (such as Gravitational wave denoising (Ref. 90)). If successful, our model can bring in even broader impacts. Pursuing this extension, however, requires a judicious definition of “silent intervals”. After all, the notion of “noise” in a general context of signal processing depends on specific applications: noise in one application may be another's signals. To train a neural network that exploits a general notion of silent intervals, prudence must be taken to avoid biasing toward certain types of noise.
We now present the details of our network structure and training configurations.
The silent interval detection component of our model is composed of 2D convolutional layers, a bidirectional LSTM, and two FC layers. The parameters of the convolutional layers are shown in Table 3. Each convolutional layer is followed by a batch normalization layer with a ReLU activation function. The hidden size of bidirectional LSTM is 100. The two FC layers, interleaved with a ReLU activation function, have hidden size of 100 and 1, respectively.
The noise estimation component of our model is fully convolutional, consisting of two encoders and one decoder. The two encoders process the noisy signal and the incomplete noise profile, respectively; they have the same architecture (shown in Table 4) but different weights. The two feature maps resulted from the two encoders are concatenated in a channel-wise manner before feeding into the decoder. In Table 4, every layer, except the last one, is followed by a batch normalization layer together with a ReLU activation function. In addition, there is skip connections between the 2nd and 14-th layer and between the 4-th and 12-th layer.
The noise removal component of our model is composed of two 2D convolutional encoders, a bidirectional LSTM, and three FC layers. The two convolutional encoders take as input the input audio spectrogram Sx and the estimated full noise spectrogram
N(sx, s{tilde over (x)}),
respectively. The first encoder has the network architecture listed in Table 5, and the second has the same architecture but with half of the number of filters at each convolutional layer. Moreover, the bidirectional LSTM has the hidden size of 200, and the three FC layers have the hidden size of 600, 600, and 2F, respectively, where F is the number of frequency bins in the spectrogram. In terms of the activation function, ReLU is used after each layer except the last layer, which uses sigmoid.
Training details. We use PyTorch platform to implement our speech denoising model, which is then trained with the Adam optimizer. In our end-to-end training without silent interval supervision (referred to as “Ours W/O SID loss” in Sec. 4; also recall Sec. 3.2), we run the Adam optimizer for 50 epochs with a batch size of 20 and a learning rate of 0.001. When the silent interval supervision is incorporated (recall Sec. 3.3), we first train the silent interval detection component with the following setup: run the Adam optimizer for 100 epochs with a batch size of 15 and a learning rate of 0.001. Afterwards, we train the noise estimation and removal components using the same setup as the end-to-end training of “Ours w/o SID 1oss”.
Our model is designed to take as input a mono-channel audio clip of an arbitrary length. However, when constructing the training dataset, we set each audio clip in the training dataset to have the same 2-second length, to enable batching at training time. To this end, we split each original audio clip from AVSPEECH, DEMAND, and AudioSet into 2-second long clips. All audio clips are then downsampled at 16 kHz before converting into spectrograms using STFT. To perform STFT, the Fast Fourier Transform (FFT) size is set to 510, the Hann window size is set to 28 ms, and the hop length is set to 11 ms. As a result, each 2-second clip yields a (complex-valued) spectrogram with a resolution 256×178, where 256 is the number of frequency bins, and 178 is the temporal resolution. At inference time, our model can still accept audio clips with arbitrary length.
Both our clean speech dataset and noise datasets are first split into training and test sets, so that no audio clips in training and testing are from the same original audio source-they are fully separate.
To supervise our silent interval detection, we label the clean audio signals in the following way. We first normalize each audio clip so that its magnitude is in the range [−1,1], that is, ensuring the largest waveform magnitude at −1 or 1. Then, the clean audio clip is divided into segments of length 1/30 seconds. We label a time segment as a “silent” segment (i.e., label 0) if its average waveform energy in that segment is below 0.08. Otherwise, it is labeled as a “non-silent” segment (i.e., label 1).
We now provide the details of the metrics used for evaluating our silent interval detection (i.e., results in Table 1). Detecting silent intervals is a binary classification task, one that classifies every time segment as being silent (i.e., a positive condition) or not (i.e., a negative condition). Recall that the confusion matrix in a binary classification task is as follows:
In our case, we have the following conditions:
The four metrics used in Table 1 follow the standard definitions in statistics, which we review here:
where NTP, NTN, NFP, and NFN indicate the numbers of true positive, true negative, false positive, and false negative predictions among all tests. Intuitively, recall indicates the ability of correctly finding all true silent intervals, precision measures how much proportion of the labeled silent intervals are truly silent. F1 score takes both precision and recall into account, and produces their harmonic mean. And accuracy is the ratio of correct predictions among all predictions.
In
In Sec. 4.4 and Table 2, the ablation studies are set up in the following way. “Ours” refers to our proposed network structure and training method that incorporates silent interval supervision (recall Sec. 3.3). Details are described in A.
“Ours w/o SID loss” refers to our proposed network structure but optimized by the training method in Sec. 3.2 (i.e. an end-to-end training without silent interval supervision). This ablation study is to confirm that silent interval supervision indeed helps to improve the denoising quality. “Ours Joint 1oss” refers to our proposed network structure optimized by the end-to-end training approach that optimizes the loss function (1) with the additional term (2). In this end-to-end training, silent interval detection is also supervised through the loss function. This ablation study is to confirm that our two-step training (Sec. 3.3) is more effective. “Ours w/o NE 1oss” uses our two-step training (in Sec. 3.3) but without the loss term on noise estimation-that is, without the first term in (1). This ablation study is to examine the necessity of the loss term on noise estimation for better denoising quality. “Ours w/o SID comp” turns off silent interval detection: the silent interval detection component always outputs a vector with all zeros. As a result, the input noise profile to the noise estimation component N is made precisely the same as the original noisy signal. This ablation study is to examine the effect of silent intervals for speech denoising. “Ours w/o NR comp” uses a simple spectral subtraction to replace our noise removal component; the other components remain unchanged. This ablation study is to examine the efficacy of our noise removal component.
A key insight of our neural-network-based denoising model is the leverage of silent interval distribution over time. The experiments above have confirmed the efficacy of our silent interval detection for better speech denoising. We now report additional experiments, aiming to gain some empirical understanding of how the quality of silent interval prediction would affect speech denoising quality.
First, starting with ground-truth silent intervals, we shift them on the time axis by 1/30, 1/10, ⅙, and ½ seconds. As the shifted time amount increases, more time segments become incorrectly labeled: both the numbers of false positive labels (i.e., non-silent time segments labeled silent) and false negative labels (i.e., silent time segments are labeled non-silent) increase. After each shift, we feed the silent interval labels to our noise estimation and removal components and measure the denoising quality under the PESQ score.
In the second experiment, we again start with ground-truth silent intervals; but instead of shifting them, we shrink each silent interval toward its center by 20%, 40%, 60%, and 80%. As the silent intervals become more shrunken, fewer time segments are labeled as silent. In other words, only the number of false negative predictions increases. Similar to the previous experiment, after each shrink, we use the silent interval labels in our speech denoising pipeline, and meausure the PESQ score.
The results of both experiments are reported in Table S5. As we shrink the silent intervals, the denoising quality drops gently. In contrast, even a small amount of shift causes a clear drop of denoising quality. These results suggest that in comparison to false negative predictions, false positive predictions affect the denoising quality more negatively. On the one hand, reasonably conservative predictions may leave certain silent time segments undetected (i.e., introducing some false negative labels), but the detected silent intervals indeed reveal the noise profile. On the other hand, even a small amount of false positive predictions causes certain non-silent time segments to be treated as silent segments, and thus the observed noise profile through the detected silent intervals would be tainted by foreground signals.
The Contents of the Following Patent Application(S) Are Incorporated Herein by Reference: NO. 63/116,400 FILED IN US ON Nov. 20, 2020, NO. PCT/JP2021/027243 FILED IN WO ON JUL. 20, 2021
Number | Date | Country | |
---|---|---|---|
63116400 | Nov 2020 | US |
Number | Date | Country | |
---|---|---|---|
Parent | PCT/JP2021/027243 | Jul 2021 | US |
Child | 18320206 | US |